## RM0083 Reference manual 32-bit MCU family built on the Power Architecture® embedded category for automotive chassis and safety electronics applications ## Introduction The SPC56xP60x/SPC56xP54x microcontroller is built on the Power Architecture<sup>®</sup> platform and targets the chassis market segment, specifically the airbag application space. The Power Architecture based 32-bit microcontrollers represent the latest achievement in integrated automotive application controllers. SPC56xP60x/SPC56xP54x devices are built around a dual-core platform for optimized performance-power consumption trade-off but is available also as single-core version. July 2016 DocID018714 Rev 5 1/1102 Contents RM0083 ## **Contents** | Preface. | | | | 51 | |----------|--------|------------|-----------------------------------------------|------| | | Overvi | ew | | 51 | | | Audier | nce | | 51 | | | Chapte | er organi: | zation and device-specific information | 51 | | | - | • | | | | | | | | | | 1 | Introd | luction | | 52 | | | 1.1 | The SP | C56xP60x/54x microcontroller family | 52 | | | 1.2 | Applicat | ion examples | 52 | | | 1.3 | SPC56x | P60x/54x Device Summary | 53 | | | 1.4 | Device I | olock diagram | 56 | | | 1.5 | Critical | performance parameters | 59 | | | 1.6 | Feature | summary | 60 | | | 1.7 | Feature | s details | 61 | | | | 1.7.1 | High performance e200z0h core processor | . 61 | | | | 1.7.2 | Crossbar switch (XBAR) | . 61 | | | | 1.7.3 | Enhanced direct memory access (eDMA) | . 62 | | | | 1.7.4 | On-chip flash memory with ECC | . 62 | | | | 1.7.5 | On-chip SRAM with ECC | . 63 | | | | 1.7.6 | Interrupt controller (INTC) | . 63 | | | | 1.7.7 | System clocks and clock generation | . 64 | | | | 1.7.8 | Frequency modulated phase-locked loop (FMPLL) | . 64 | | | | 1.7.9 | Main oscillator | . 65 | | | | 1.7.10 | Internal RC oscillator | . 65 | | | | 1.7.11 | Periodic interrupt timer (PIT) | . 65 | | | | 1.7.12 | System timer module (STM) | . 65 | | | | 1.7.13 | Software watchdog timer (SWT) | . 66 | | | | 1.7.14 | Fault collection and control unit (FCCU) | . 66 | | | | 1.7.15 | System integration unit (SIUL) | . 66 | | | | 1.7.16 | Boot and censorship | . 66 | | | | 1.7.17 | Error correction status module (ECSM) | . 67 | | | | 1.7.18 | FlexCAN | . 67 | | | | 1.7.19 | Safety port (FlexCAN) | . 68 | | | | 1.7.20 FlexRay | 68 | |---|------|--------------------------------------------------------|-----| | | | 1.7.21 Serial communication interface module (LINFlex) | 69 | | | | 1.7.22 Deserial serial peripheral interface (DSPI) | 69 | | | | 1.7.23 eTimer | 70 | | | | 1.7.24 Analog-to-digital converter (ADC) | 70 | | | | 1.7.25 Cross triggering unit (CTU) | 71 | | | | 1.7.26 Cyclic redundancy check (CRC) | 72 | | | | 1.7.27 Nexus development interface (NDI) | 72 | | | | 1.7.28 IEEE 1149.1 (JTAG) controller | 73 | | | | 1.7.29 On-chip voltage regulator (VREG) | 73 | | | 1.8 | Developer environment | 74 | | 2 | Mem | mory Map | 75 | | 3 | Sign | nal Description | 78 | | | 3.1 | 176-pin LQFP pinout | 78 | | | 3.2 | 144-pin LQFP pinout | 79 | | | 3.3 | 100-pin LQFP pinout | 79 | | | 3.4 | Pin descriptions | 80 | | | | 3.4.1 Power supply and reference voltage pins | | | | | 3.4.2 System pins | | | | | 3.4.3 Pin muxing | | | | 3.5 | CTU / ADCs / eTimers / DSPI / FlexRay connections | | | 4 | Cloc | ck Description | 100 | | | 4.1 | Clock architecture | | | | 4.2 | Available clock domains | | | | | 4.2.1 FMPLL input reference clock | | | | | 4.2.2 Clock selectors | | | | | 4.2.3 Auxiliary Clock Selector 0 | | | | | 4.2.4 Auxiliary Clock Selector 1 | 104 | | | | 4.2.5 Auxiliary Clock Selector 2 | | | | | 4.2.6 Auxiliary clock dividers | | | | | 4.2.7 External clock divider | 105 | | | 4.3 | Alternate module clock domains | 106 | | | | 4.3.1 FlexCAN clock domains | | | | | | | | | | 4.3.2 | FlexRay clock domains | 106 | |---|------|----------|----------------------------------------------|-----| | | | 4.3.3 | SWT clock domains | 106 | | | | 4.3.4 | Nexus Message Clock (MCKO) | 106 | | | | 4.3.5 | Cross Triggering Unit (CTU) clock domains | 106 | | | | 4.3.6 | Peripherals | 107 | | | 4.4 | Clock I | behavior in STOP and HALT mode | 107 | | | 4.5 | Softwa | are controlled power management/clock gating | 108 | | | 4.6 | Systen | n clock functional safety | 108 | | | 4.7 | IRC 16 | 6 MHz internal RC oscillator (RC_CTL) | 109 | | | 4.8 | XOSC | external crystal oscillator | 109 | | | | 4.8.1 | Functional description | 109 | | | | 4.8.2 | Register description | 110 | | | 4.9 | Freque | ency Modulated Phase Locked Loop (FMPLL) | 111 | | | | 4.9.1 | Introduction | 111 | | | | 4.9.2 | Overview | 112 | | | | 4.9.3 | Features | 112 | | | | 4.9.4 | Memory map | 112 | | | | 4.9.5 | Register description | 113 | | | | 4.9.6 | Functional description | 116 | | | | 4.9.7 | Recommendations | 119 | | | 4.10 | Clock I | Monitor Unit (CMU) | 120 | | | | 4.10.1 | Overview | 120 | | | | 4.10.2 | Main features | 121 | | | | 4.10.3 | Functional description | 121 | | | | 4.10.4 | Memory map and register description | 123 | | 5 | Cloc | k Gene | ration Module (MC_CGM) | 131 | | | 5.1 | Introdu | uction | 131 | | | | 5.1.1 | Overview | 131 | | | | 5.1.2 | Features | 133 | | | 5.2 | Extern | al Signal Description | 133 | | | 5.3 | Memoi | ry Map and Register Definition | 133 | | | | 5.3.1 | Register Descriptions | | | | 5.4 | Function | onal Description | | | | | 5.4.1 | System Clock Generation | | | | | 5.4.2 | Auxiliary Clock Generation | | | | | | | | | | | 5.4.3 | Dividers Functional Description | . 148 | |---|------|---------|--------------------------------------------|-------| | | | 5.4.4 | Output Clock Multiplexing | . 149 | | | | 5.4.5 | Output Clock Division Selection | . 149 | | 6 | Mod | e Entry | Module (MC_ME) | 150 | | | 6.1 | Introdu | uction | 150 | | | | 6.1.1 | Overview | . 150 | | | | 6.1.2 | Features | . 152 | | | | 6.1.3 | Modes of Operation | . 152 | | | 6.2 | Extern | nal Signal Description | 153 | | | 6.3 | Memo | ry Map and Register Definition | 153 | | | | 6.3.1 | Memory Map | . 153 | | | | 6.3.2 | Register Description | . 161 | | | 6.4 | Functi | onal Description | 181 | | | | 6.4.1 | Mode Transition Request | . 181 | | | | 6.4.2 | Modes Details | . 183 | | | | 6.4.3 | Mode Transition Process | . 186 | | | | 6.4.4 | Protection of Mode Configuration Registers | . 193 | | | | 6.4.5 | Mode Transition Interrupts | . 193 | | | | 6.4.6 | Peripheral Clock Gating | . 195 | | | | 6.4.7 | Application Example | . 195 | | 7 | Pow | er Cont | rol Unit (MC_PCU) | 197 | | | 7.1 | Introdu | uction | 197 | | | | 7.1.1 | Overview | . 197 | | | | 7.1.2 | Features | . 198 | | | 7.2 | Extern | nal Signal Description | 198 | | | 7.3 | Memo | ry Map and Register Definition | 198 | | | | 7.3.1 | Memory Map | | | | | 7.3.2 | Register Descriptions | | | 8 | Rese | et Gene | ration Module (MC_RGM) | 202 | | | 8.1 | Introdu | uction | 202 | | | | 8.1.1 | Overview | | | | | 8.1.2 | Features | | | | | 8.1.3 | Reset Sources | | | | | | | | | | 8.2 | Extern | al Signal Description | 205 | |---|-------|-----------|---------------------------------------------------------------|-------| | | 8.3 | Memoi | ry Map and Register Definition | 205 | | | | 8.3.1 | Register Descriptions | 207 | | | 8.4 | Functi | ional Description | 217 | | | | 8.4.1 | Reset State Machine | 217 | | | | 8.4.2 | Destructive Resets | 219 | | | | 8.4.3 | External Reset | 220 | | | | 8.4.4 | Functional Resets | 220 | | | | 8.4.5 | Alternate Event Generation | 221 | | | | 8.4.6 | Boot Mode Capturing | 221 | | 9 | Inter | rupt Co | ontroller (INTC) | . 223 | | | 9.1 | Introdu | uction | 223 | | | 9.2 | Featur | es | 223 | | | 9.3 | Block | diagram | 224 | | | 9.4 | Modes | of operation | 225 | | | | 9.4.1 | Normal mode | 225 | | | 9.5 | Memoi | ry map and registers description | 226 | | | | 9.5.1 | Module memory map | 226 | | | | 9.5.2 | Registers description | 227 | | | 9.6 | Function | onal description | 235 | | | | 9.6.1 | Interrupt request sources | 244 | | | | 9.6.2 | Priority management | 245 | | | | 9.6.3 | Handshaking with processor | 246 | | | 9.7 | Initializ | ration/application information | 248 | | | | 9.7.1 | Initialization flow | 248 | | | | 9.7.2 | Interrupt exception handler | 249 | | | | 9.7.3 | ISR, RTOS, and task hierarchy | 251 | | | | 9.7.4 | Order of execution | 251 | | | | 9.7.5 | Priority ceiling protocol | 252 | | | | 9.7.6 | Selecting priorities according to request rates and deadlines | 253 | | | | 9.7.7 | Software configurable interrupt requests | 254 | | | | 9.7.8 | Lowering priority within an ISR | 255 | | | | 9.7.9 | Negating an interrupt request outside of its ISR | 255 | | | | 9.7.10 | Examining LIFO contents | 255 | | 10 | Syste | em Status and Configuration Module (SSCM) | 257 | | | |----|-------|-----------------------------------------------------|-------|--|--| | | 10.1 | Introduction | 257 | | | | | | 10.1.1 Overview | . 257 | | | | | | 10.1.2 Features | . 257 | | | | | | 10.1.3 Modes of operation | . 258 | | | | | 10.2 | Memory map and register description | 258 | | | | | | 10.2.1 Memory map | . 258 | | | | | | 10.2.2 Register description | . 258 | | | | | 10.3 | Functional description | 267 | | | | | 10.4 | Initialization/application information | 267 | | | | | | 10.4.1 Reset | . 267 | | | | 11 | Syste | em Integration Unit Lite (SIUL) | 268 | | | | | 11.1 | Introduction | | | | | | 11.2 | Overview | | | | | | 11.3 | Features | 269 | | | | | | 11.3.1 Register protection | . 270 | | | | | 11.4 | External signal description | 270 | | | | | | 11.4.1 Detailed signal descriptions | . 270 | | | | | 11.5 | Memory map and register description | 271 | | | | | | 11.5.1 SIUL memory map | . 271 | | | | | | 11.5.2 Register description | . 272 | | | | | 11.6 | Functional description | 286 | | | | | | 11.6.1 General | . 286 | | | | | | 11.6.2 Pad control | . 286 | | | | | | 11.6.3 General purpose input and output pads (GPIO) | . 286 | | | | | | 11.6.4 External interrupts | . 287 | | | | | 11.7 | Pin muxing | 288 | | | | 12 | e200 | z0 and e200z0h Core | 289 | | | | | 12.1 | Overview | 289 | | | | | 12.2 | Features | 290 | | | | | | 12.2.1 Microarchitecture summary | . 290 | | | | | 12.3 | Core registers and programmer's model | 295 | | | | | 12.4 | Instruction summary | 297 | | | | | | | | | | | 13 | Perip | heral B | ridge (PBRIDGE) | |----|-------|------------|--------------------------------| | | 13.1 | Introdu | ction | | | 13.2 | Block ir | nterface | | | 13.3 | Feature | es | | | 13.4 | Memor | y map and register description | | | | 13.4.1 | Register access | | | | 13.4.2 | Memory map | | | | 13.4.3 | Register descriptions | | | 13.5 | Functio | nal description | | | | 13.5.1 | Access support | | | | 13.5.2 | General operation | | 14 | Cros | sbar Sw | vitch (XBAR) | | | 14.1 | Informa | ation specific to this device | | | | 14.1.1 | Register availability | | | | 14.1.2 | MPR reset value | | | | 14.1.3 | max_halt_request signal value | | | | 14.1.4 | Logical master IDs | | | | 14.1.5 | Master port allocation | | | | 14.1.6 | Slave port allocation | | | 14.2 | Introdu | ction 306 | | | | 14.2.1 | Overview | | | | 14.2.2 | Features | | | | 14.2.3 | Limitations | | | | 14.2.4 | General Operation | | | 14.3 | XBAR r | registers | | | | 14.3.1 | Register summary | | | | 14.3.2 | XBAR register descriptions | | | | 14.3.3 | Coherency | | | 14.4 | Functio | on 317 | | | | 14.4.1 | Arbitration | | | | 14.4.2 | Priority Assignment | | | | 14.4.3 | Master Port Functionality | | | | 14.4.4 | Slave Port Functionality | | | 14.5 | Initializa | ation/Application Information | | | 14.6 | Interfac | e 327 | | | | | | | | | 14.6.1<br>14.6.2<br>14.6.3 | Overview | . 327 | |----|--------|----------------------------|--------------------------------------|-------| | 15 | Error | Correct | ion Status Module (ECSM) | 330 | | | 15.1 | Introduc | tion | 330 | | | 15.2 | Overvie | w | 330 | | | 15.3 | Feature | s | 330 | | | 15.4 | Memory | map and registers description | 330 | | | | 15.4.1 | Memory map | . 330 | | | | 15.4.2 | Registers description | . 332 | | 16 | Intern | al Statio | RAM (SRAM) | 351 | | | 16.1 | Introduc | tion | 351 | | | 16.2 | SRAM o | perating mode | 351 | | | 16.3 | Module | memory map | 351 | | | 16.4 | Registe | descriptions | 351 | | | 16.5 | SRAM E | ECC mechanism | 351 | | | | 16.5.1 | Access timing | . 352 | | | | 16.5.2 | Reset effects on SRAM accesses | . 353 | | | 16.6 | Function | nal description | 353 | | | 16.7 | Initializa | tion and application information | 353 | | 17 | Flash | Memor | y | 354 | | | 17.1 | Introduc | tion | 354 | | | 17.2 | Platform | Flash controller | 355 | | | | 17.2.1 | Introduction | . 355 | | | | 17.2.2 | Modes of operation | . 357 | | | | 17.2.3 | External signal descriptions | . 357 | | | | 17.2.4 | Memory map and registers description | . 357 | | | | 17.2.5 | Functional description | . 359 | | | | 17.2.6 | Basic interface protocol | | | | | 17.2.7 | Access protections | | | | | 17.2.8 | Read cycles — buffer miss | | | | | 17.2.9 | Read cycles — buffer hit | | | | | 17.2.10 | Write cycles | . 361 | | | | 17.2.11 | Error termination | 361 | |----|------|------------|-----------------------------------------------------------|------| | | | 17.2.12 | Access pipelining | 362 | | | | 17.2.13 | Flash error response operation | 362 | | | | 17.2.14 | Bank0 page read buffers and prefetch operation | 362 | | | | 17.2.15 | Bank1 temporary holding register | 365 | | | | 17.2.16 | Read-While-Write functionality | 365 | | | | 17.2.17 | Wait state emulation | 367 | | | | 17.2.18 | Timing diagrams | 368 | | | 17.3 | Flash m | nemory | 374 | | | | 17.3.1 | Introduction | 374 | | | | 17.3.2 | Main features | 374 | | | | 17.3.3 | Block diagram | 374 | | | | 17.3.4 | Functional description | 376 | | | | 17.3.5 | Operating modes | 380 | | | | 17.3.6 | Registers description | 383 | | | | 17.3.7 | Register map | 383 | | | | 17.3.8 | Code Flash programming considerations | 422 | | 40 | Mana | D | to ation I limit (MADII) | 40.4 | | 18 | | - | tection Unit (MPU) | | | | 18.1 | | ction | | | | 18.2 | Block d | iagram | 434 | | | 18.3 | Feature | es | 436 | | | 18.4 | Modes | of operation | 436 | | | 18.5 | Externa | al signal description | 437 | | | 18.6 | Memory | y map and register definition | 437 | | | | 18.6.1 | MPU Control/Error Status Register (MPU_CESR) | 438 | | | | 18.6.2 | MPU Error Address Register, Slave Port n (MPU_EARn) | 439 | | | | 18.6.3 | MPU Error Detail Register, Slave Port n (MPU_EDRn) | 440 | | | | 18.6.4 | MPU Region Descriptor n (MPU_RGDn) | 441 | | | | 18.6.5 | MPU Region Descriptor Alternate Access Control n (MPU_RGE | • | | | | | | | | | 18.7 | | nal description | | | | | 18.7.1 | Access evaluation macro | | | | | 18.7.2 | Putting it all together and AHB error terminations | | | | 18.8 | Initializa | ation information | 451 | | | 18.9 | Applica | tion information | 451 | | 19 | Enha | nced Direct Memo | ry Access (eDMA) | 454 | | | | |----|------|--------------------------|--------------------------|---------|--|--|--| | | 19.1 | Introduction | | | | | | | | 19.2 | Overview | | | | | | | | 19.3 | Features | | 455 | | | | | | 19.4 | Modes of operation | | 455 | | | | | | | • | e | | | | | | | | | · | | | | | | | 19.5 | _ | egister definition | | | | | | | | | o<br>o | | | | | | | | | scriptions | | | | | | | 19.6 | _ | on | | | | | | | | 19.6.1 eDMA micro | architecture | 478 | | | | | | | 19.6.2 eDMA basic | data flow | 479 | | | | | | | 19.6.3 eDMA perfor | rmance | 482 | | | | | | 19.7 | Initialization / applica | ation information | 485 | | | | | | | 19.7.1 eDMA initiali | zation | 485 | | | | | | | 19.7.2 DMA program | mming errors | 487 | | | | | | | 19.7.3 DMA reques | t assignments | 488 | | | | | | | 19.7.4 DMA arbitrat | tion mode considerations | 488 | | | | | | | 19.7.5 DMA transfe | r | 488 | | | | | | | 19.7.6 TCD status . | | 492 | | | | | | | 19.7.7 Channel link | ing | 493 | | | | | | | 19.7.8 Dynamic pro | ogramming | 494 | | | | | 20 | DMA | Channel Mux (DM | A_MUX) | 495 | | | | | | 20.1 | Introduction | | 495 | | | | | | | 20.1.1 Overview | | 495 | | | | | | | 20.1.2 Features | | 495 | | | | | | | 20.1.3 Modes of op | eration | 496 | | | | | | 20.2 | External signal desc | ription | 496 | | | | | | | 20.2.1 Overview | | 496 | | | | | | 20.3 | Memory map and re | gister definition | 496 | | | | | | | 20.3.1 Memory map | o | 496 | | | | | | | 20.3.2 Register des | scriptions | 497 | | | | | | 20.4 | 20.4 DMA request mapping | | | | | | | | 20.5 | Functional description | on | 499 | | | | | | | | DocID018714 Rev 5 | 11/1102 | | | | | | | | POOIDO 101 14 1/E/ 9 | 11/1102 | | | | | | | 20.5.1 | DMA channels with periodic triggering capability500 | |----|-------|------------|------------------------------------------------------| | | | 20.5.2 | DMA channels with no triggering capability 502 | | | 20.6 | Initializa | ation/application information 502 | | | | 20.6.1 | Reset 502 | | | | 20.6.2 | Enabling and configuring sources502 | | 21 | FlexF | Ray Con | nmunication Controller (FlexRay) 507 | | | 21.1 | Introdu | ction 507 | | | | 21.1.1 | Color coding | | | | 21.1.2 | Overview | | | | 21.1.3 | Features | | | | 21.1.4 | Modes of operation | | | 21.2 | Externa | al signal description | | | | 21.2.1 | Detailed signal descriptions | | | 21.3 | Control | ler host interface clocking | | | 21.4 | Protoco | ol engine clocking 512 | | | | 21.4.1 | PLL Clocking | | | | 21.4.2 | Oscillator Clocking | | | 21.5 | Memor | y map and register description | | | | 21.5.1 | Memory map | | | | 21.5.2 | Register descriptions | | | 21.6 | Functio | onal description | | | | 21.6.1 | Message buffer concept587 | | | | 21.6.2 | Physical message buffer587 | | | | 21.6.3 | Message buffer types | | | | 21.6.4 | FlexRay memory layout | | | | 21.6.5 | Physical message buffer description | | | | 21.6.6 | Individual message buffer functional description 605 | | | | 21.6.7 | Individual message buffer search | | | | 21.6.8 | Individual message buffer reconfiguration 633 | | | | 21.6.9 | Receive FIFO | | | | 21.6.10 | Channel device modes | | | | 21.6.11 | External clock synchronization | | | | 21.6.12 | • | | | | 21.6.13 | MTS generation | | | | 21.6.14 | Key slot transmission | | | | 21.6.15 | Sync frame filtering | 647 | |----|------|-----------|--------------------------------------------------------------|-------| | | | 21.6.16 | Strobe signal support | 647 | | | | 21.6.17 | Timer support | 649 | | | | 21.6.18 | Slot status monitoring | 650 | | | | 21.6.19 | System bus access | 654 | | | | 21.6.20 | Interrupt support | 655 | | | | 21.6.21 | Lower bit rate support | 658 | | | 21.7 | Applica | tion information | . 659 | | | | 21.7.1 | Initialization sequence | 659 | | | | 21.7.2 | Shut down sequence | 660 | | | | 21.7.3 | Number of usable message buffers | 660 | | | | 21.7.4 | Protocol control command execution | 661 | | | | 21.7.5 | Protocol reset command | 662 | | | | 21.7.6 | Message buffer search on simple message buffer configuration | 663 | | 22 | Dese | rial Seri | ial Peripheral Interface (DSPI) | . 666 | | | 22.1 | Introduc | ction | . 666 | | | 22.2 | Block d | iagram | . 666 | | | 22.3 | Overvie | ew | . 667 | | | 22.4 | Feature | es | . 668 | | | 22.5 | Modes | of operation | . 668 | | | | 22.5.1 | Master mode | 669 | | | | 22.5.2 | Slave mode | 669 | | | | 22.5.3 | Module disable mode | 669 | | | | 22.5.4 | Debug mode | 669 | | | 22.6 | Externa | al signal description | . 669 | | | | 22.6.1 | Signal overview | 669 | | | | 22.6.2 | Signal names and descriptions | 670 | | | 22.7 | Memory | y map and registers description | . 671 | | | | 22.7.1 | Memory map | 671 | | | | 22.7.2 | Registers description | 672 | | | 22.8 | Functio | nal description | . 690 | | | | 22.8.1 | Modes of operation | | | | | 22.8.2 | Start and stop of DSPI transfers | | | | | 22.8.3 | Serial Peripheral Interface (SPI) configuration | | | | | 22.8.4 | DSPI baud rate and clock delay generation | | | | | | • • | | | | | 22.8.5 | Transfer formats | 699 | |----|-------|-----------|----------------------------------------|-----| | | | 22.8.6 | Continuous Serial communications clock | | | | | 22.8.7 | Interrupts/DMA requests | 708 | | | | 22.8.8 | Power saving features | 709 | | | 22.9 | Initializ | ation and application information | 710 | | | | 22.9.1 | Managing queues | 710 | | | | 22.9.2 | Baud rate settings | 710 | | | | 22.9.3 | Delay settings | | | | | 22.9.4 | Calculation of FIFO pointer addresses | 712 | | 23 | LIN C | Controll | er (LINFlex) | 715 | | | 23.1 | Introdu | ction | 715 | | | 23.2 | Main fe | eatures | 715 | | | | 23.2.1 | LIN mode features | 715 | | | | 23.2.2 | UART mode features | 715 | | | | 23.2.3 | Features common to LIN and UART | 716 | | | 23.3 | Genera | al description | 716 | | | 23.4 | Fractio | nal baud rate generation | 717 | | | 23.5 | Operat | ing modes | 719 | | | | 23.5.1 | Initialization mode | 719 | | | | 23.5.2 | Normal mode | 719 | | | | 23.5.3 | Low power mode (Sleep) | 719 | | | 23.6 | Test mo | odes | 720 | | | | 23.6.1 | Loop Back mode | 720 | | | | 23.6.2 | Self Test mode | 720 | | | 23.7 | Memor | y map and registers description | 721 | | | | 23.7.1 | Memory map | 721 | | | 23.8 | Function | onal description | 746 | | | | 23.8.1 | UART mode | 746 | | | | 23.8.2 | LIN mode | 748 | | | | 23.8.3 | 8-bit timeout counter | 756 | | | | 23.8.4 | Interrupts | 757 | | 24 | Flex | CAN | | 759 | | | 24.1 | Introdu | ction | 759 | | | | 24.1.1 | Overview | 759 | | | | | | | | | | 24.1.2 | FlexCAN module features | . 761 | |----|-------|--------------------|-----------------------------------------------|-------| | | | 24.1.3 | Modes of operation | . 761 | | | 24.2 | Externa | I signal description | 762 | | | | 24.2.1 | Overview | . 762 | | | | 24.2.2 | Signal Descriptions | . 762 | | | 24.3 | Memory | map and registers description | 763 | | | | 24.3.1 | FlexCAN memory mapping | . 763 | | | | 24.3.2 | Message buffer structure | . 765 | | | | 24.3.3 | Rx FIFO structure | . 768 | | | | 24.3.4 | Registers description | . 770 | | | 24.4 | Function | nal description | 789 | | | | 24.4.1 | Overview | . 789 | | | | 24.4.2 | Transmit process | . 789 | | | | 24.4.3 | Arbitration process | . 790 | | | | 24.4.4 | Receive process | . 790 | | | | 24.4.5 | Matching process | . 792 | | | | 24.4.6 | Data coherence | . 793 | | | | 24.4.7 | Rx FIFO | . 795 | | | | 24.4.8 | CAN protocol related features | . 796 | | | | 24.4.9 | Modes of operation details | . 800 | | | | 24.4.10 | Interrupts | . 801 | | | | 24.4.11 | Bus interface | . 802 | | | 24.5 | Initializa | ation/application information | 802 | | | | 24.5.1 | FlexCAN initialization sequence | . 803 | | 25 | Analo | a-to-Di | gital Converter (ADC) | 804 | | | 25.1 | | w | | | | | 25.1.1 | Device-specific features | | | | | 25.1.2 | Device-specific pin configuration features | | | | | 25.1.3 | Device-specific implementation | | | | 25.2 | | tion | | | | 25.3 | | nal description | | | | 20.0 | 25.3.1 | Analog channel conversion | | | | | 25.3.1 | Analog clock generator and conversion timings | | | | | 25.3.2 | ADC sampling and conversion timing | | | | | 25.3.4 | ADC CTU (Cross Triggering Unit) | | | | | 20.0. <del>4</del> | ADO 010 (01035 Higgering Offic) | . 012 | | | | 25.3.5 | Presampling | 813 | |----|------|-----------------------------|------------------------------------|-----| | | | 25.3.6 | Programmable analog watchdog | 814 | | | | 25.3.7 | DMA functionality | 815 | | | | 25.3.8 | Interrupts | 815 | | | | 25.3.9 | Power-down mode | 816 | | | | 25.3.10 | Auto-clock-off mode | 816 | | | 25.4 | Registe | er descriptions | 816 | | | | 25.4.1 | Introduction | 816 | | | | 25.4.2 | Control logic registers | 818 | | | | 25.4.3 | Interrupt registers | 821 | | | | 25.4.4 | DMA registers | 824 | | | | 25.4.5 | Threshold registers | 826 | | | | 25.4.6 | Presampling registers | 827 | | | | 25.4.7 | Conversion Timing Registers CTR[0] | 829 | | | | 25.4.8 | Mask registers | 829 | | | | 25.4.9 | Delay registers | 831 | | | | 25.4.10 | Data registers | 831 | | 26 | Cros | s Trigge | ering Unit (CTU) | 833 | | | 26.1 | Introduc | ction | 833 | | | 26.2 | CTU ov | verview | 833 | | | 26.3 | | nal description | | | | | 26.3.1 | Trigger events features | | | | | 26.3.2 | Trigger generator subunit (TGS) | | | | | 26.3.3 | TGS in triggered mode | | | | | 26.3.4 | TGS in sequential mode | | | | | 26.3.5 | TGS counter | | | | 26.4 | Schedu | ıler subunit (SU) | 838 | | | | 26.4.1 | ADC commands list | 840 | | | | 26.4.2 | ADC commands list format | 840 | | | | 26.4.3 | ADC results | 842 | | | 26.5 | Dalaad | mechanism | 842 | | | | Reload | | | | | 26.6 | | | 843 | | | 26.6 | | safety mode | | | | 26.6 | Powers | | 844 | | | 26.6 | Power s<br>26.6.1<br>26.6.2 | safety mode | 844 | | | | 26.7.1 | DMA support | . 844 | |----|------|----------|--------------------------------------------------------------|-------| | | | 26.7.2 | CTU faults and errors | . 844 | | | | 26.7.3 | CTU interrupt/DMA requests | . 845 | | | 26.8 | Memory | map | 847 | | | | 26.8.1 | Trigger Generator Sub-unit Input Selection Register (TGSISR) | . 851 | | | | 26.8.2 | Trigger Generator Sub-unit Control Register (TGSCR) | 853 | | | | 26.8.3 | Trigger x Compare Register (TxCR, x = 07) | . 854 | | | | 26.8.4 | TGS Counter Compare Register (TGSCCR) | . 854 | | | | 26.8.5 | TGS Counter Reload Register (TGSCRR) | . 855 | | | | 26.8.6 | Commands list control register 1 (CLCR1) | 855 | | | | 26.8.7 | Commands list control register 2 (CLCR2) | 856 | | | | 26.8.8 | Trigger handler control register 1 (THCR1) | 856 | | | | 26.8.9 | Trigger handler control register 2 (THCR2) | 858 | | | | 26.8.10 | Commands list register x (x = 1,,24) (CLRx) | . 860 | | | | 26.8.11 | FIFO DMA control register (FDCR) | . 861 | | | | 26.8.12 | FIFO control register (FCR) | . 862 | | | | 26.8.13 | FIFO threshold register (FTH) | . 864 | | | | 26.8.14 | FIFO status register (FST) | . 864 | | | | 26.8.15 | FIFO Right aligned data $x$ ( $x = 0,,3$ ) (FR $x$ ) | . 866 | | | | 26.8.16 | FIFO signed Left aligned data $x$ ( $x = 0,,3$ ) (FL $x$ ) | . 867 | | | | 26.8.17 | Cross triggering unit error flag register (CTUEFR) | . 867 | | | | 26.8.18 | Cross triggering unit interrupt flag register (CTUIFR) | . 868 | | | | 26.8.19 | Cross triggering unit interrupt/DMA register (CTUIR) | . 869 | | | | 26.8.20 | Control ON time register (COTR) | . 870 | | | | 26.8.21 | Cross triggering unit control register (CTUCR) | . 871 | | | | 26.8.22 | Cross triggering unit digital filter (CTUDF) | . 872 | | | | 26.8.23 | Cross triggering unit power control register (CTUPCR) | . 872 | | 27 | Sema | phore U | Init (SEMA4) | 873 | | | 27.1 | Introduc | tion | 873 | | | | 27.1.1 | Block diagram | . 873 | | | | 27.1.2 | Features | . 875 | | | | 27.1.3 | Modes of operation | . 875 | | | 27.2 | Signal d | escription | 875 | | | 27.3 | • | map and register description | | | | | 27.3.1 | Semaphores gate <i>n</i> register (SEMA4_GATE <i>n</i> ) | | | | | | Comaphiolog gate in regioner (CEIIII IT_O/ITEII) | . 575 | | | | 27.3.2 | Semaphores processor <i>n</i> IRQ notification enable (SEMA4_CP{0,1 | | |----|-------|------------|---------------------------------------------------------------------|-----| | | | 27.3.3 | Semaphores processor <i>n</i> IRQ notification (SEMA4_CP{0,1}NTF) | | | | | 27.3.4 | Semaphores (secure) reset gate n (SEMA4_RSTGT) | 878 | | | | 27.3.5 | Semaphores (secure) Reset IRQ notification (SEMA4_RSTNTF) | 880 | | | 27.4 | Functio | nal description | 882 | | | | 27.4.1 | Semaphore usage | 883 | | | 27.5 | Initializa | ation information | 884 | | | 27.6 | Applica | tion information | 884 | | | 27.7 | DMA re | quests | 885 | | 28 | eTime | er | | 886 | | | 28.1 | Introduc | ction | 886 | | | 28.2 | Feature | es | 887 | | | 28.3 | Module | block diagram | 888 | | | 28.4 | Channe | el block diagram | 889 | | | 28.5 | Externa | ıl signal descriptions | 889 | | | | 28.5.1 | ETC[5:0]—eTimer input/outputs | 889 | | | 28.6 | Memory | y map and registers | 889 | | | | 28.6.1 | Overview | 889 | | | | 28.6.2 | Timer channel registers | 893 | | | | 28.6.3 | Watchdog timer registers | | | | | 28.6.4 | Configuration registers | 909 | | | 28.7 | Functio | nal description | 912 | | | | 28.7.1 | General | | | | | 28.7.2 | Counting modes | | | | | 28.7.3 | Other features | | | | 28.8 | | | | | | 28.9 | • | ts | | | | 28.10 | DMA . | | 919 | | 29 | Func | tional S | afety | 920 | | | 29.1 | | ction | | | | 29.2 | Registe | r protection module | 920 | | | | 29.2.1 | Overview | | | | | 29.2.2 | Features | 921 | | | | | | | | | | 29.2.3 | Modes of operation | 921 | |----|-------|---------|----------------------------------------------------|-------| | | | 29.2.4 | External signal description | 921 | | | | 29.2.5 | Memory map and registers description | 921 | | | | 29.2.6 | Functional description | 925 | | | | 29.2.7 | Reset | 928 | | | 29.3 | Softwa | re Watchdog Timer (SWT) | 928 | | | | 29.3.1 | Overview | 928 | | | | 29.3.2 | Features | 929 | | | | 29.3.3 | Modes of operation | 929 | | | | 29.3.4 | External signal description | 929 | | | | 29.3.5 | SWT memory map and registers description | 929 | | | | 29.3.6 | Functional description | 935 | | 30 | Fault | Collect | tion and Control Unit (FCCU) | . 938 | | | 30.1 | Introdu | ction | 938 | | | | 30.1.1 | Glossary and acronyms | 938 | | | 30.2 | Main fe | eatures | 939 | | | 30.3 | Block d | liagram | 939 | | | 30.4 | Signal | description | 940 | | | 30.5 | _ | er interface | | | | 30.6 | - | y map and register description | | | | 00.0 | 30.6.1 | FCCU Control Register (FCCU_CTRL) | | | | | 30.6.2 | FCCU CTRL Key Register (FCCU_CTRLK) | | | | | 30.6.3 | FCCU Configuration Register (FCCU_CFG) | | | | | 30.6.4 | FCCU CF Configuration Register (FCCU_CF_CFG03) | | | | | 30.6.5 | FCCU NCF Configuration Register (FCCU_NCF_CFG03) | | | | | 30.6.6 | FCCU CFS Configuration Register (FCCU_CFS_CFG07) | | | | | 30.6.7 | FCCU NCFS Configuration Register (FCCU_NCFS_CFG07) | | | | | 30.6.8 | FCCU CF Status Register (FCCU_CFS03) | | | | | 30.6.9 | FCCU CF Key Register (FCCU_CFK) | | | | | 30.6.10 | | | | | | 30.6.11 | FCCU NCF Key Register (FCCU_NCFK) | | | | | 30.6.12 | | | | | | 30.6.13 | FCCU NCF Time-out Enable Register (FCCU_NCF_TOE03) | | | | | | FCCU NCF Time-out Register (FCCU_NCF_TO) | | | | | 30.6.15 | FCCU CFG Timeout Register (FCCU_CFG_TO) | 959 | | | | | | | | | | 30.6.16 | FCCU Status Register (FCCU_STAT) | 960 | | | | |----|-------|-----------------------|------------------------------------------|-----|--|--|--| | | | 30.6.17 | FCCU CF Fake Register (FCCU_CFF) | 961 | | | | | | | 30.6.18 | FCCU NCF Fake Register (FCCU_NCFF) | 962 | | | | | | | 30.6.19 | FCCU IRQ Status Register (FCCU_IRQ_STAT) | 962 | | | | | | | 30.6.20 | FCCU IRQ Enable Register (FCCU_IRQ_EN) | 963 | | | | | | | 30.6.21 | FCCU XTMR Register (FCCU_XTMR) | 964 | | | | | | | 30.6.22 | FCCU MCS Register (FCCU_MCS) | 965 | | | | | | 30.7 | Functio | nal description | 966 | | | | | | | 30.7.1 | Definitions | 966 | | | | | | | 30.7.2 | FSM description | 966 | | | | | | | 30.7.3 | Self-checking capabilities | 968 | | | | | | | 30.7.4 | Reset interface | 969 | | | | | | | 30.7.5 | Fault priority scheme and nesting | 969 | | | | | | | 30.7.6 | Fault recovery | 970 | | | | | | | 30.7.7 | NVM interface | 974 | | | | | | | 30.7.8 | FCCU_F interface | | | | | | | | 30.7.9 | Fault mapping | 978 | | | | | 31 | Wake | Wakeup Unit (WKPU)980 | | | | | | | | 31.1 | Overvie | ew | 980 | | | | | | 31.2 | Feature | es | 980 | | | | | | 31.3 | Externa | al signal description | 980 | | | | | | 31.4 | Memory | y map and registers description | 980 | | | | | | | 31.4.1 | Memory map | | | | | | | | 31.4.2 | Registers description | | | | | | | 31.5 | Functio | nal description | | | | | | | | 31.5.1 | General | | | | | | | | 31.5.2 | Non-Maskable Interrupts | | | | | | 32 | Perio | dic Inte | rrupt Timer (PIT) | 985 | | | | | | 32.1 | | ction | | | | | | | 02.1 | 32.1.1 | Overview | | | | | | | | 32.1.2 | Features | | | | | | | 32.2 | | description | | | | | | | | • | · | | | | | | | 32.3 | | y map and registers description | | | | | | | | 32.3.1 | Memory map | 986 | | | | | | | 32.3.2 Registers description | 987 | |----|-------|-------------------------------------------------|--------| | | 32.4 | Functional description | 991 | | | | 32.4.1 General | 991 | | | | 32.4.2 Interrupts | 992 | | | 32.5 | Initialization and application information | 993 | | | | 32.5.1 Example configuration | 993 | | 33 | Syste | em Timer Module (STM) | . 994 | | | 33.1 | Overview | 994 | | | 33.2 | Features | 994 | | | 33.3 | Modes of operation | 994 | | | 33.4 | External signal description | 994 | | | 33.5 | Memory map and registers description | 994 | | | | 33.5.1 Memory map | 994 | | | | 33.5.2 Registers description | 995 | | | 33.6 | Functional description | 999 | | 34 | Cycli | ic Redundancy Check (CRC) | 1000 | | | 34.1 | Introduction | . 1000 | | | | 34.1.1 Glossary | 1000 | | | 34.2 | Main features | . 1000 | | | | 34.2.1 Standard features | 1000 | | | 34.3 | Block diagram | . 1000 | | | | 34.3.1 IPS bus interface | 1001 | | | 34.4 | Functional description | . 1001 | | | 34.5 | Memory map and registers description | . 1003 | | | | 34.5.1 CRC Configuration Register (CRC_CFG) | 1004 | | | | 34.5.2 CRC Input Register (CRC_INP) | 1005 | | | | 34.5.3 CRC Current Status Register (CRC_CSTAT) | 1006 | | | | 34.5.4 CRC Output Register (CRC_OUTP) | 1007 | | | | 34.5.5 CRC Output Check Register (CRC_OUTP_CHK) | 1007 | | | 34.6 | Use cases and limitations | . 1008 | | 35 | Boot | t Assist Module (BAM) | 1012 | | | 35.1 | Overview | . 1012 | | | 35.2 | Features | . 1012 | |----|-------|-------------------------------------------------------------|--------| | | 35.3 | Boot modes | . 1012 | | | 35.4 | Memory map | . 1012 | | | 35.5 | Functional description | . 1013 | | | | 35.5.1 Entering boot modes | 1013 | | | | 35.5.2 SPC56xP60x/54x boot pins | 1014 | | | | 35.5.3 Reset Configuration Half Word (RCHW) | 1015 | | | | 35.5.4 Single chip boot mode | 1016 | | | | 35.5.5 Boot through BAM | 1017 | | | | 35.5.6 Boot from UART—autobaud disabled | 1023 | | | | 35.5.7 Bootstrap with FlexCAN—autobaud disabled | 1024 | | | 35.6 | FlexCAN boot mode download protocol | . 1025 | | | | 35.6.1 Autobaud feature | 1025 | | | | 35.6.2 Interrupt | 1037 | | | 35.7 | Censorship | . 1037 | | 36 | Volta | age Regulators and Power Supplies | . 1042 | | | 36.1 | Voltage regulator | . 1042 | | | | 36.1.1 High Power or Main Regulator (HPREG) | | | | | 36.1.2 Low Voltage Detectors (LVD) and Power On Reset (POR) | | | | | 36.1.3 VREG digital interface | 1043 | | | | 36.1.4 Registers Description | 1044 | | | 36.2 | Power supply strategy | . 1045 | | 37 | IEEE | E 1149.1 Test Access Port Controller (JTAGC) | . 1047 | | | 37.1 | Introduction | | | | 37.2 | Block diagram | | | | 37.3 | Overview | | | | | | | | | 37.4 | Features | | | | 37.5 | Modes of operation | | | | | 37.5.1 Reset | | | | | 37.5.2 IEEE 1149.1-2001 defined test modes | | | | 37.6 | External signal description | . 1049 | | | 37.7 | Memory map and registers description | . 1049 | | | | 37.7.1 Instruction register | 1050 | | | | 37.7.2 Bypass register | 1050 | | | | | | | | | 37.7.3 | Device identification register | . 1050 | |----|-------|------------|------------------------------------------------|--------| | | | 37.7.4 | Boundary scan register | . 1051 | | | 37.8 | Function | nal description | 1051 | | | | 37.8.1 | JTAGC reset configuration | . 1051 | | | | 37.8.2 | IEEE 1149.1-2001 (JTAG) Test Access Port (TAP) | . 1051 | | | | 37.8.3 | TAP controller state machine | . 1052 | | | | 37.8.4 | JTAGC instructions | . 1054 | | | | 37.8.5 | Boundary scan | . 1056 | | | 37.9 | e200z0 | OnCE controller | 1056 | | | | 37.9.1 | e200z0 OnCE controller block diagram | . 1057 | | | | 37.9.2 | e200z0 OnCE controller functional description | . 1057 | | | | 37.9.3 | e200z0 OnCE controller registers description | . 1057 | | | 37.10 | Initializa | ation/Application Information | 1059 | | 38 | Nexu | s Port C | Controller (NPC) | 1060 | | | 38.1 | Informa | tion specific to this device | 1060 | | | | 38.1.1 | Parameter values | . 1060 | | | | 38.1.2 | Unavailable features | . 1060 | | | 38.2 | Introduc | ction | 1060 | | | | 38.2.1 | Overview | . 1061 | | | | 38.2.2 | Features | . 1061 | | | | 38.2.3 | Modes of operation | . 1062 | | | 38.3 | Externa | I signal description | 1063 | | | | 38.3.1 | Overview | . 1063 | | | | 38.3.2 | Detailed signal descriptions | . 1063 | | | 38.4 | Registe | r definition | 1065 | | | | 38.4.1 | Register descriptions | . 1065 | | | 38.5 | Function | nal description | 1069 | | | | 38.5.1 | NPC reset configuration | . 1069 | | | | 38.5.2 | Auxiliary Output Port | . 1069 | | | | 38.5.3 | IEEE 1149.1-2001 (JTAG) TAP | . 1072 | | | | 38.5.4 | Nexus JTAG Port Sharing | . 1077 | | | | 38.5.5 | MCKO and ipg_sync_mcko | . 1077 | | | | 38.5.6 | EVTO Sharing | . 1077 | | | | 38.5.7 | Nexus Reset Control | . 1077 | | | | 38.5.8 | System Clock Locked Indication | . 1077 | | | | | | | | Contents | | | RM008 | |----------|-------|----------|-------------------------------------| | | 38.6 | | ation/Application Information | | | | 38.6.1 | Accessing NPC tool-mapped registers | | Appendi | x A F | Register | s Under Protection1079 | | Revision | histo | ry | | ## List of tables | Table 1. | SPC56xP60x/54x device comparison | . 53 | |-----------|-------------------------------------------------------------------------------------|------| | Table 2. | SPC56xP60x/54x device configuration difference | . 55 | | Table 3. | SPC56xP60x/54x series block summary | . 57 | | Table 4. | Memory map | . 75 | | Table 5. | Supply pins | . 80 | | Table 6. | System pins | . 82 | | Table 7. | Pin muxing | . 84 | | Table 8. | CTU / ADCs / eTimers / DSPI / FlexRay connections | . 99 | | Table 9. | Output Clock Division 256 Select Register (CLK_DIV_256) Field Descriptions | 105 | | Table 10. | Software controlled power management/clock gating support | | | Table 11. | RC_CTL field descriptions | 109 | | Table 12. | Crystal oscillator truth table | | | Table 13. | OSC_CTL memory map | | | Table 14. | OSC_CTL field descriptions | | | Table 15. | FMPLL memory map | | | Table 16. | CR field descriptions | | | Table 17. | MR field descriptions | | | Table 18. | Progressive clock switching on pll_select rising edge | | | Table 19. | CMU module summary | | | Table 20. | CMU memory map | | | Table 21. | CMU_0_CSR field descriptions | | | Table 22. | CMU_0_FDR field descriptions | | | Table 23. | CMU_0_HFREFR_0 field descriptions | | | Table 24. | CMU 0 LFREFR 0 fields descriptions | | | Table 25. | CMU_0_ISR field descriptions | | | Table 26. | CMU_0_MDR field descriptions | | | Table 27. | CMU_1_CSR field descriptions | | | Table 28. | CMU_1_HFREFR_0 field descriptions | | | Table 29. | CMU_1_LFREFR_0 field descriptions | | | Table 30. | CMU_1_ISR field descriptions | | | Table 31. | MC_CGM Register Description | | | Table 32. | MC_CGM Memory Map | | | Table 33. | Output Clock Enable Register (CGM_OC_EN) Field Descriptions | | | Table 34. | Output Clock Division Select Register (CGM_OCDS_SC) Field Descriptions | | | Table 35. | System Clock Select Status Register (CGM_SC_SS) Field Descriptions | | | Table 36. | Auxiliary Clock 0 Select Control Register (CGM_AC0_SC) Field Descriptions | | | Table 37. | Auxiliary Clock 0 Divider 0 Configuration Register (CGM_AC0_DC0) Field Descriptions | | | Table 38. | Auxiliary Clock 1 Select Control Register (CGM_AC1_SC) Field Descriptions | | | Table 39. | Auxiliary Clock 1 Divider 0 Configuration Register (CGM_AC1_DC0) Field Descriptions | | | Table 40. | Auxiliary Clock 2 Select Control Register (CGM AC2 SC) Field Descriptions | | | Table 41. | Auxiliary Clock 2 Divider 0 Configuration Register (CGM_AC2_DC0) Field Descriptions | | | Table 42. | Auxiliary Clock 3 Select Control Register (CGM_AC3_SC) Field Descriptions | | | Table 43. | Auxiliary Clock 3 Divider 0 Configuration Register (CGM AC3 DC0) Field Descriptions | | | Table 44. | MC_ME Mode Descriptions | | | Table 45. | MC_ME Register Description | | | Table 46. | MC_ME Memory Map | | | Table 47. | Global Status Register (ME_GS) Field Descriptions | | | Table 47. | Mode Control Register (ME_GG) Field Descriptions | | | TUDIC TO. | wood Control Register (WE_WOTE) Field Descriptions | 107 | List of tables RM0083 | Table 49. | Mode Enable Register (ME_ME) Field Descriptions | . 165 | |-----------|------------------------------------------------------------------------------|-------| | Table 50. | Interrupt Status Register (ME_IS) Field Descriptions | . 166 | | Table 51. | Interrupt Mask Register (ME_IM) Field Descriptions | . 167 | | Table 52. | Invalid Mode Transition Status Register (ME_IMTS) Field Descriptions | | | Table 53. | Debug Mode Transition Status Register (ME_DMTS) Field Descriptions | | | Table 54. | Mode Configuration Registers (ME_ <mode>_MC) Field Descriptions</mode> | | | Table 55. | Peripheral Status Registers (ME_PSn) Field Descriptions | . 178 | | Table 56. | Run Peripheral Configuration Registers (ME_RUN_PC07) Field Descriptions | . 179 | | Table 57. | Low-Power Peripheral Configuration Registers (ME_LP_PC07) Field Descriptions | | | Table 58. | Peripheral Control Registers (ME_PCTLn) Field Descriptions | | | Table 59. | MC_ME Resource Control Overview | | | Table 60. | MC_ME System Clock Selection Overview | . 190 | | Table 61. | MC_PCU memory map | . 198 | | Table 62. | MC_PCU registers | . 198 | | Table 63. | Power Domain Configuration Register Field Descriptions | . 200 | | Table 64. | Power Domain Status Register (PCU_PSTAT) Field Descriptions | . 201 | | Table 65. | MC_RGM Register Description | . 205 | | Table 66. | MC_RGM Memory Map | . 206 | | Table 67. | Functional Event Status Register (RGM_FES) Field Descriptions | . 208 | | Table 68. | Destructive Event Status Register (RGM_DES) Field Descriptions | | | Table 69. | Functional Event Reset Disable Register (RGM_FERD) Field Descriptions | | | Table 70. | Destructive Event Reset Disable Register (RGM_DERD) Field Descriptions | . 213 | | Table 71. | Functional Event Alternate Request Register (RGM_FEAR) Field Descriptions | | | Table 72. | Functional Event Short Sequence Register (RGM_FESS) Field Descriptions | . 215 | | Table 73. | Functional Bidirectional Reset Enable Register (RGM_FBRE) Field Descriptions | . 216 | | Table 74. | MC_RGM Reset Implications | . 217 | | Table 75. | MC_RGM Alternate Event Selection | . 221 | | Table 76. | Interrupt sources available | | | Table 77. | INTC memory map | . 227 | | Table 78. | INTC_MCR field descriptions | . 228 | | Table 79. | INTC_CPR field descriptions | | | Table 80. | INTC_IACKR field descriptions | . 230 | | Table 81. | INTC_SSCIR[0:7] field descriptions | | | Table 82. | INTC_PSR0_3-INTC_PSR260 field descriptions | | | Table 83. | INTC Priority Select Register address offsets | | | Table 84. | Interrupt vector table | | | Table 85. | Order of ISR execution example | | | Table 86. | SSCM memory map | | | Table 87. | STATUS register accesses | | | Table 88. | STATUS field descriptions | | | Table 89. | MEMCONFIG field descriptions | | | Table 90. | MEMCONFIG register accesses | | | Table 91. | ERROR field descriptions | | | Table 92. | ERROR register accesses | | | Table 93. | DEBUGPORT field descriptions | | | Table 94. | Debug Status Port modes | | | Table 95. | DEBUGPORT register accesses | | | Table 96. | PWCMPH/L field descriptions | | | Table 97. | PWCMPH/L register accesses | | | Table 98. | DPMBOOT Field Descriptions | | | Table 99. | DPMKEY Field Descriptions | | | Table 100 | UOPS Field Descriptions | 266 | | Table 101. | PSA Field Descriptions | 267 | |------------|------------------------------------------------------|-----| | Table 102. | SIUL signal properties | | | Table 103. | SIUL memory map | 271 | | Table 104. | MIDR1 field descriptions | | | Table 105. | MIDR2 field descriptions | | | Table 106. | ISR field descriptions | 274 | | Table 107. | IRER field descriptions | 274 | | Table 108. | IREER field descriptions | 275 | | Table 109. | IFEER field descriptions | 275 | | Table 110. | IFER field descriptions | 276 | | Table 111. | PCR[0:108] field descriptions | 277 | | Table 112. | PCR[n] reset value exceptions | 278 | | Table 113. | PCR bit implementation by pad type | 278 | | Table 114. | PSMI[0_3:36_39] field descriptions | 279 | | Table 115. | Pad selection | 279 | | Table 116. | GPDO[0_3:104_107] field descriptions | 282 | | Table 117. | GPDI[0_3:104_107] field descriptions | 283 | | Table 118. | PGPDO0_3 field descriptions | | | Table 119. | PGPDI[0:3] field descriptions | 284 | | Table 120. | MPGPDO[0:6] field descriptions | 285 | | Table 121. | IFMC[0:31] field descriptions | | | Table 122. | IFCPR field descriptions | 286 | | Table 123. | PBRIDGE registers | | | Table 124. | PBRIDGE memory map | | | Table 125. | MPROT <i>n</i> field reset values | | | Table 126. | MPROT <i>n</i> field structure descriptions | | | Table 127. | PACR <i>n</i> field structure descriptions | | | Table 128. | On-platform peripherals and PACR numbers | | | Table 129. | Off-platform peripherals and OPACR numbers | | | Table 130. | Logical master IDs | | | Table 131. | XBAR master port allocation | 306 | | Table 132. | XBAR slave port allocation | 306 | | Table 133. | XBAR register configuration summary | 308 | | Table 134. | XBAR register summary | 309 | | Table 135. | Register terms | 310 | | Table 136. | Master Priority Register descriptions | 311 | | Table 137. | Slave General Purpose Control Register Descriptions | 314 | | Table 138. | Master General Purpose Control Register Descriptions | 316 | | Table 139. | ECSM registers | 331 | | Table 140. | PCT field descriptions | 332 | | Table 141. | REV field descriptions | 332 | | Table 142. | PLAMC field descriptions | 333 | | Table 143. | PLASC field descriptions | 333 | | Table 144. | IMC field descriptions | 334 | | Table 145. | MRSR field descriptions | 335 | | Table 146. | MIR field descriptions | 335 | | Table 147. | MUDCR field descriptions | 336 | | Table 148. | ECR field descriptions | 337 | | Table 149. | ESR field descriptions | 339 | | Table 150. | EEGR field descriptions | 341 | | Table 151. | FEAR field descriptions | 343 | | Table 152. | FEMR field descriptions | 343 | | | | | List of tables RM0083 | Table 153. | FEAT field descriptions | | |------------|---------------------------------------------------------|-----| | Table 154. | FEDR field descriptions | | | Table 155. | REAR field descriptions | | | Table 156. | RESR field descriptions | | | Table 157. | RAM syndrome mapping for single-bit correctable errors | | | Table 158. | REMR field descriptions | | | Table 159. | REAT field descriptions | | | Table 160. | REDR field descriptions | | | Table 161. | SRAM operating modes | | | Table 162. | SRAM memory map | | | Table 163. | Number of wait states required for SRAM operations | | | Table 164. | Flash-related regions in the system memory map | | | Table 165. | Platform Flash controller 32-bit memory map | | | Table 166. | Platform Flash controller stall-while-write interrupts | | | Table 167. | Additional wait state encoding | | | Table 168. | Extended additional wait state encoding | | | Table 169. | Code Flash memory storage address map | | | Table 170. | 64 KB data Flash module sectorization | | | Table 171. | TestFlash structure | 378 | | Table 172. | Unique Serial Number | | | Table 173. | Shadow sector structure | | | Table 174. | Flash registers | | | Table 175. | Flash 1056 KB multi-module register map | | | Table 176. | Flash 64 KB bank1 register map | 385 | | Table 177. | MCR field descriptions | 387 | | Table 178. | MCR bits set/clear priority levels | 391 | | Table 179. | LML and NVLML field descriptions | 393 | | Table 180. | HBL and NVHBL field descriptions | 395 | | Table 181. | SLL and NVSLL field descriptions | 397 | | Table 182. | LMS field descriptions | 399 | | Table 183. | HBS field descriptions | 400 | | Table 184. | ADR field descriptions | 401 | | Table 185. | ADR content: priority list | 402 | | Table 186. | PFCR0 field descriptions | 403 | | Table 187. | PFCR1 field descriptions | 408 | | Table 188. | PFAPR field descriptions | 411 | | Table 189. | BIU2 and NVBIU2 field descriptions | 412 | | Table 190. | UT0 field descriptions | 412 | | Table 191. | UT1 field descriptions | 414 | | Table 192. | UT2 field descriptions | 415 | | Table 193. | UMSIR0 field descriptions | 416 | | Table 194. | UMISR1 field descriptions | 416 | | Table 195. | UMISR2 field descriptions | 417 | | Table 196. | UMISR3 field descriptions | | | Table 197. | UMISR4 field descriptions | 418 | | Table 198. | NVPWD0 field descriptions | | | Table 199. | NVPWD1 field descriptions | | | Table 200. | NVSCI0 field descriptions | | | Table 201. | NVSCI1 field descriptions | | | Table 202. | NVUSRO field descriptions | | | Table 203. | Flash modify operations | 423 | | Table 204 | Bits manipulation: double words with the same FCC value | 431 | | Table 205. | Bits manipulation: censorship management | | |------------|------------------------------------------|-----| | Table 206. | MPU port allocation | | | Table 207. | MPU memory map | | | Table 208. | MPU_CESR field descriptions | | | Table 209. | MPU_EARn field descriptions | | | Table 210. | MPU_EDRn field descriptions | | | Table 211. | MPU_RGDn.Word0 field descriptions | | | Table 212. | MPU_RGDn.Word1 field descriptions | | | Table 213. | MPU_RGDn.Word2 field descriptions | | | Table 214. | MPU_RGDn.Word3 field descriptions | | | Table 215. | MPU_RGDAACn field descriptions | | | Table 216. | Protection violation definition | | | Table 217. | Overlapping region descriptor example | | | Table 218. | eDMA memory map | | | Table 219. | EDMA_CR field descriptions | | | Table 220. | EDMA_ESR field descriptions | | | Table 221. | EDMA_ERQRL field descriptions | | | Table 222. | EDMA_EEIRL field descriptions | | | Table 223. | EDMA_SERQR field descriptions | | | Table 224. | EDMA_CERQR field descriptions | | | Table 225. | EDMA_SEEIR field descriptions | | | Table 226. | EDMA_CEEIR field descriptions | | | Table 227. | EDMA_CIRQR field descriptions | | | Table 228. | EDMA_CER field descriptions | | | Table 229. | EDMA_SSBR field descriptions | | | Table 230. | EDMA_CDSBR field descriptions | | | Table 231. | EDMA_IRQRL field descriptions | | | Table 232. | EDMA_ERL field descriptions | | | Table 233. | EDMA_HRSL field descriptions | | | Table 234. | EDMA_CPR <i>n</i> field descriptions | | | Table 235. | TCDn 32-bit memory structure | | | Table 236. | TCDn field descriptions. | | | Table 237. | eDMA peak transfer rates (MB/Sec) | | | Table 238. | eDMA peak request Rate (MReq/sec) | | | Table 239. | TCD primary control and status fields | | | Table 240. | DMA request summary for eDMA | | | Table 241. | Modulo feature example | | | Table 242. | Channel linking parameters | | | Table 243. | DMA_MUX memory map | | | Table 244. | CHCONFIG#x field descriptions | | | Table 245. | Channel and trigger enabling | | | Table 246. | DMA channel mapping | | | Table 247. | External signal properties | | | Table 248. | FlexRay memory map | | | Table 249. | Register access conventions | | | Table 250. | Additional register reset conditions | | | Table 251. | Register write access restrictions | | | Table 252. | MVR field descriptions | | | Table 253. | MCR field descriptions | | | Table 254. | FlexRay channel selection | | | Table 255. | FlexRay channel bit rate selection | | | Table 256. | SYMBADHR and SYMBADLR field descriptions | 521 | | Table 257. | STBSCR field descriptions | 522 | |------------|-------------------------------------------------|-----| | Table 258. | Strobe signal mapping | 522 | | Table 259. | MBDSR field descriptions | 525 | | Table 260. | MBSSUTR field descriptions | | | Table 261. | POCR field descriptions | | | Table 262. | GIFER field descriptions | 528 | | Table 263. | PIFR0 field description | | | Table 264. | PIFR1 field descriptions | | | Table 265. | PIER0 field descriptions | | | Table 266. | PIER1 field descriptions | | | Table 267. | CHIERFR field descriptions | | | Table 268. | MBIVEC field descriptions | | | Table 269. | CASERCR field descriptions | | | Table 270. | CBSERCR field descriptions | | | Table 271. | PSR0 field descriptions | | | Table 272. | PSR1 field descriptions | | | Table 273. | PSR2 field descriptions | | | Table 274. | PSR3 field descriptions | | | Table 275. | MTCTR field descriptions | | | Table 276. | CYCTR field descriptions | | | Table 277. | SLTCTAR field descriptions | | | Table 278. | SLTCTBR field descriptions | | | Table 279. | RTCORVR field descriptions | | | Table 280. | OFCORVR field descriptions | | | Table 281. | CIFRR field descriptions | | | Table 282. | SYMATOR field descriptions | | | Table 283. | SFCNTR field descriptions | | | Table 284. | SFTOR field description | | | Table 285. | SFTCCSR field descriptions | | | Table 286. | SFIDRFR field descriptions | | | Table 287. | SFIDAFVR field descriptions | | | Table 288. | SFIDAFMR field descriptions | | | Table 289. | NMVR[0:5] field descriptions | | | Table 290. | Mapping of NMVRn to received payload bytes NMVn | | | Table 291. | NMVLR field descriptions | | | Table 292. | TICCR field descriptions | | | Table 293. | TI1CYSR field descriptions | | | Table 294. | TI1MTOR field descriptions | | | Table 295. | TI2CR0 field descriptions | | | Table 296. | TI2CR1 field descriptions | | | Table 297. | SSSR field descriptions | | | Table 298. | Mapping between SSSRn and SSRn | | | Table 299. | SSCCR field descriptions | | | Table 300. | Mapping between internal SSCCRn and SSCRn | | | Table 301. | SSR0–SSR7 field descriptions | | | Table 302. | SSCR0–SSCR3 field descriptions | | | Table 303. | MTSACFR field descriptions | | | Table 304. | MTSBCFR field descriptions | | | Table 305. | RSBIR field descriptions | | | Table 306. | SEL controlled receiver FIFO registers | | | Table 307. | RFSR field descriptions | | | Table 308. | RFSIR field descriptions | 567 | | Table 309. | RFDSR field descriptions | | |--------------------------|----------------------------------------------------------------------------|--| | Table 310. | RFARIR field descriptions | | | Table 311. | RFBRIR field descriptions | | | Table 312. | RFMIDAFVR field descriptions | | | Table 313. | RFMIAFMR field descriptions | | | Table 314. | RFFIDRFVR field descriptions | | | Table 315. | RFFIDRFMR field descriptions | | | Table 316. | RFRFCFR field descriptions | | | Table 317. | RFRFCTR field descriptions | | | Table 318. | LDTXSLAR field descriptions | | | Table 319. | LDTXSLBR field descriptions | | | Table 320. | Protocol configuration register fields | | | Table 321. | Wakeup channel selection | | | Table 322. | MBCCSRn field descriptions | | | Table 323. | MBCCFRn field descriptions | | | Table 324. | Channel assignment description | | | Table 325. | MBFIDRn field descriptions | | | Table 326. | MBIDXR <i>n</i> field descriptions | | | Table 327. | Frame header write access constraints (Transmit message buffer) | | | Table 328. | Frame header field descriptions (Receive message buffer and receive FFO) | | | Table 329. | Frame header field descriptions (Transmit message buffer) | | | Table 330. | Receive message buffer slot status content | | | Table 331. | Receive message buffer slot status field descriptions | | | Table 332. | Transmit message buffer slot status content | | | Table 333. | Transmit message buffer slot status structure field descriptions | | | Table 334. | Message buffer data field minimum length | | | Table 335. | Frame data write access constraints | | | Table 336. | Frame data field descriptions | | | Table 337. | Individual message buffer types | | | Table 338. | Single transmit message buffer access regions description | | | Table 339. | Single transmit message buffer state description | | | Table 340. | Single transmit message buffer application transitions | | | Table 341. | Single transmit message buffer module transitions | | | Table 342. | Single transmit message buffer transition priorities | | | Table 343.<br>Table 344. | Receive message buffer access region description | | | Table 344. | Receive message buffer application transitions | | | Table 346. | Receive message buffer module transitions | | | Table 340. | Receive message buffer transition priorities | | | Table 347. | Receive message buffer update | | | Table 349. | Double transmit message buffer access regions description | | | Table 349. | Double transmit message buffer state description (commit side) | | | Table 350. | Double transmit message buffer state description (transmit side) | | | Table 351. | Double Transmit Message Buffer Host Transitions | | | Table 352. | Double Transmit Message Buffer Module Transitions | | | Table 353. | Double transmit message buffer transition priorities | | | Table 354. | Message buffer search priority (static segment) | | | Table 356. | Message buffer search priority (dynamic segment) | | | Table 350. | Sync frame table generation modes | | | Table 357. | Key slot frame type | | | Table 359. | Slot status content | | | Table 360. | FlexRay Channel Bit Rate Control | | | . 45.5 555. | 1 lowing Chamillot bit hate control 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | | | Table 361. | Minimum f <sub>chi</sub> [MHz] examples (32 message buffers) | . 661 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Table 362. | Protocol control command priorities | . 662 | | Table 363. | Transmit buffer configuration | | | Table 364. | Receive buffer configuration | . 664 | | Table 365. | Signal properties | . 670 | | Table 366. | DSPI memory map | . 671 | | Table 367. | DSPIx_MCR field descriptions | . 673 | | Table 368. | DSPIx_TCR field descriptions | . 676 | | Table 369. | DSPIx_CTARn field descriptions | . 677 | | Table 370. | DSPI SCK duty cycle | . 680 | | Table 371. | DSPI transfer frame size | . 680 | | Table 372. | DSPI PCS to SCK delay scaler | . 681 | | Table 373. | DSPI after SCK delay scaler | . 681 | | Table 374. | DSPI delay after transfer scaler | . 681 | | Table 375. | DSPI baud rate scaler | . 682 | | Table 376. | DSPIx SR field descriptions | . 683 | | Table 377. | DSPIx RSER field descriptions | . 685 | | Table 378. | DSPIx_PUSHR field descriptions | . 687 | | Table 379. | DSPIx_POPR field descriptions | | | Table 380. | DSPIx TXFRn field descriptions | | | Table 381. | DSPIx RXFRn field description | | | Table 382. | State transitions for start and stop of DSPI transfers | | | Table 383. | Baud rate computation example | | | Table 384. | CS to SCK delay computation example | | | Table 385. | After SCK delay computation example | | | Table 386. | Delay after transfer computation example | | | | | | | Table 387. | Peripheral Chip Select strobe assert computation example | . 698 | | Table 387. Table 388. | Peripheral Chip Select strobe assert computation example | | | Table 388. | Peripheral Chip Select strobe negate computation example | . 698 | | Table 388.<br>Table 389. | Peripheral Chip Select strobe negate computation example | . 698<br>. 702 | | Table 388.<br>Table 389.<br>Table 390. | Peripheral Chip Select strobe negate computation example | . 698<br>. 702<br>. 708 | | Table 388.<br>Table 389.<br>Table 390.<br>Table 391. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values | . 698<br>. 702<br>. 708<br>. 711 | | Table 388.<br>Table 389.<br>Table 390.<br>Table 391.<br>Table 392. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values | . 698<br>. 702<br>. 708<br>. 711<br>. 712 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 723 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values. Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 723<br>. 724<br>. 724 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 723<br>. 724<br>. 724<br>. 725<br>. 725 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions LINESR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 721<br>. 724<br>. 724<br>. 725<br>. 725<br>. 730 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 728 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values. Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTSR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 730<br>. 732<br>. 733 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINTCSR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 730<br>. 730<br>. 733<br>. 735 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCSR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 724<br>. 725<br>. 725<br>. 725<br>. 730<br>. 732<br>. 733<br>. 735<br>. 736 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. Table 406. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection UNIER field descriptions LINSR field descriptions LINESR field descriptions UARTCR field descriptions UARTSR field descriptions LINTCSR field descriptions LINCR field descriptions LINCR field descriptions LINCR field descriptions LINCR field descriptions LINCR field descriptions LINCR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 724<br>. 725<br>. 725<br>. 725<br>. 730<br>. 730<br>. 731<br>. 735<br>. 736<br>. 736 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. Table 406. Table 407. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINCR field descriptions LINTCSR field descriptions LINCR field descriptions LINCR field descriptions LINCR field descriptions LINTCR field descriptions LINTCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 724<br>. 725<br>. 725<br>. 730<br>. 733<br>. 735<br>. 736<br>. 736<br>. 737 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. Table 406. Table 407. Table 408. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration. LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCR field descriptions LINTCR field descriptions LINTCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTBRR field descriptions LINTBRR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 730<br>. 735<br>. 736<br>. 736<br>. 737<br>. 737 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. Table 406. Table 407. Table 408. Table 409. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration. LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCR field descriptions LINTCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTORR field descriptions LINTBRR field descriptions LINTBRR field descriptions LINTBRR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 730<br>. 735<br>. 736<br>. 736<br>. 737<br>. 738<br>. 738 | | Table 388. Table 389. Table 390. Table 391. Table 392. Table 393. Table 394. Table 395. Table 396. Table 397. Table 398. Table 399. Table 400. Table 401. Table 402. Table 403. Table 404. Table 405. Table 406. Table 407. Table 408. | Peripheral Chip Select strobe negate computation example Delayed master sample point Interrupt and DMA request conditions Baud rate values Delay values Error calculation for programmed baud rates LINFlex memory map LINCR1 field descriptions Checksum bits configuration. LIN master break length selection Operating mode selection LINIER field descriptions LINSR field descriptions LINSR field descriptions UARTCR field descriptions UARTCR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCSR field descriptions LINTCR field descriptions LINTCR field descriptions LINTCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTOCR field descriptions LINTBRR field descriptions LINTBRR field descriptions | . 698<br>. 702<br>. 708<br>. 711<br>. 712<br>. 718<br>. 721<br>. 723<br>. 724<br>. 725<br>. 725<br>. 730<br>. 730<br>. 737<br>. 736<br>. 737<br>. 738<br>. 738<br>. 738 | | Table 413. | BDRL field descriptions | | |------------|---------------------------------------------------------------------------------------|-----| | Table 414. | BDRM field descriptions | | | Table 415. | IFER field descriptions | | | Table 416. | IFMI field descriptions | | | Table 417. | IFMR field descriptions | | | Table 418. | IFMR[IFM] configuration | | | Table 419. | IFCR2 <i>n</i> field descriptions | | | Table 420. | IFCR2 <i>n</i> + 1 field descriptions | | | Table 421. | Message buffer | | | Table 422. | Filter to interrupt vector correlation | | | Table 423. | LINFlex interrupt control | | | Table 424. | FlexCAN signals | | | Table 425. | FlexCAN module memory map | | | Table 426. | FlexCAN register reset status | | | Table 427. | Message Buffer MB0 memory mapping | | | Table 428. | Message Buffer structure field description | | | Table 429. | Message buffer code for Rx buffers | | | Table 430. | Message Buffer code for Tx buffers | | | Table 431. | MB0–MB31 addresses | | | Table 432. | Rx FIFO Structure field description | | | Table 433. | MCR field descriptions | | | Table 434. | IDAM coding | | | Table 435. | CTRL field descriptions | | | Table 436. | TIMER field descriptions | | | Table 437. | RXGMASK field description | | | Table 438. | RX14MASK field description | | | Table 439. | RX15MASK field description | | | Table 440. | Error and Status Register (ESR) field description. | | | Table 441. | Fault confinement state | | | Table 442. | IMASK1 field descriptions | | | Table 443. | IFLAG1 field descriptions | | | Table 444. | RXIMR0–RXIMR31 field descriptions | | | Table 445. | RXIMR0-RXIMR31 addresses | | | Table 446. | Time segment syntax | | | Table 447. | CAN standard compliant bit time segment settings | | | Table 448. | Minimum ratio between peripheral clock frequency and CAN bit rate | | | Table 449. | Configurations for starting normal conversion | | | Table 450. | ADC sampling and conversion timing at 5 V / 3.3 V for ADC0 | | | Table 451. | Max/Min ADC_clk frequency and related configuration settings at 5 V / 3.3 V for ADC0. | | | Table 452. | Presampling voltage selection based on PREVALx fields | | | Table 453. | Values of WDGxH and WDGxL fields | | | Table 454. | Example for Analog watchdog operation | | | Table 455. | ADC digital registers | | | Table 456. | MCR field descriptions | | | Table 457. | MSR field descriptions | | | Table 458. | ISR field descriptions | | | Table 459. | IMR field descriptions | | | Table 460. | WTISR field descriptions | | | Table 461. | WTIMR field descriptions | | | Table 462. | DMAE field descriptions | | | Table 463. | DMARx field descriptions | | | Table 464. | TRCx field descriptions | 826 | | Table 465. | THRHLRx field descriptions | 827 | |---------------|----------------------------------------|-----| | Table 466. | PSCR field descriptions | | | Table 467. | PSR field descriptions | | | Table 468. | CTR field descriptions | | | Table 469. | NCMR field descriptions | | | Table 470. | JCMR field descriptions | | | Table 471. | PDEDR field descriptions | | | Table 472. | CDR field descriptions | | | Table 473. | ADC commands translation | | | Table 474. | CTU interrupts | | | Table 475. | CTU memory map | | | Table 476. | TGS registers | | | Table 477. | SU registers | | | Table 478. | CTU registers | | | Table 479. | FIFO registers | | | Table 480. | TGSISR field descriptions. | | | Table 481. | TGSCR field descriptions | | | Table 482. | TxCR field descriptions | | | Table 483. | TGSCCR field format | | | Table 484. | TGSCRR field descriptions | | | Table 485. | CLCR1 field descriptions | | | Table 486. | CLCR2 field descriptions | | | Table 487. | THCR1 field descriptions | | | Table 488. | THCR2 field descriptions | | | Table 489. | CLRx (CMS = 0) field descriptions | | | Table 490. | CLRx (CMS = 1) field descriptions | | | Table 491. | FDCR field descriptions | | | Table 491. | FCR field descriptions | | | Table 493. | FTH field descriptions | | | Table 494. | FST field descriptions | | | Table 495. | FRx field descriptions | | | Table 496. | FLx field descriptions | | | Table 497. | CTUEFR field descriptions | | | Table 498. | CTUIFR field descriptions | | | Table 499. | CTUIR field descriptions | | | Table 500. | COTR field descriptions | | | Table 500. | CTUCR field descriptions | | | Table 501. | CTUDF field descriptions | | | Table 502. | CTUPCR field descriptions | | | Table 503. | SEMA4 memory map | | | Table 504. | SEMA4 GATE <i>n</i> field descriptions | | | Table 505. | SEMA4 CP{0,1}NTF field descriptions | | | Table 500. | SEMA4 CP{0,1}NTF field descriptions | | | Table 507. | SEMA4_RSTGT field descriptions | | | Table 500. | SEMA4 RSTNTF field descriptions | | | Table 509. | eTimer memory map. | | | Table 510. | COMP1 field descriptions | | | Table 511. | COMP2 field descriptions | | | Table 512. | CAPT1 field descriptions | | | Table 513. | CAPT2 field descriptions | | | Table 514. | LOAD field descriptions | | | Table 515. | HOLD field descriptions | | | i abic o i o. | - 1 10 ED 11010 000011PUO110 | 000 | | Table 517. | CNTR field descriptions | | |------------|--------------------------------------|-----| | Table 518. | CTRL1 field descriptions | | | Table 519. | Count source values | | | Table 520. | CTRL2 field descriptions | | | Table 521. | CTRL3 field descriptions | | | Table 522. | STS field descriptions | | | Table 523. | INTDMA field descriptions | | | Table 524. | CMPLD1 field descriptions | | | Table 525. | CMPLD2 field descriptions | | | Table 526. | CCCTRL field descriptions | | | Table 527. | FILT field descriptions | | | Table 528. | WDTOL, WDTOH field descriptions | | | Table 529. | ENBL field descriptions | | | Table 530. | DREQ <i>n</i> field descriptions | | | Table 531. | Interrupt summary | | | Table 532. | DMA summary | | | Table 533. | Register protection memory map | | | Table 534. | SLBR <i>n</i> field descriptions | | | Table 535. | Soft Lock Bits vs. Protected Address | | | Table 536. | GCR field descriptions | | | Table 537. | SWT memory map | | | Table 538. | SWT_CR field descriptions | | | Table 539. | SWT_IR field descriptions | | | Table 540. | SWT_TO field descriptions | | | Table 541. | SWT_WN field descriptions | | | Table 542. | SWT_SR field descriptions | | | Table 543. | SWT_CO field descriptions | | | Table 544. | SWT_SK field descriptions | | | Table 545. | Acronyms | | | Table 546. | FCCU memory map | | | Table 547. | FCCU_CTRL field descriptions | | | Table 548. | FCCU_CTRLK field descriptions | | | Table 549. | FCCU_CFG field descriptions | | | Table 550. | FCCU_CF_CFG03 field descriptions | | | Table 551. | FCCU_NCF_CFG03 field descriptions | | | Table 552. | FCCU_CFS_CFG07 field descriptions | | | Table 553. | FCCU_NCFS_CFG07 field descriptions | | | Table 554. | FCCU_CFS03 field descriptions | | | Table 555. | FCCU_CFK field descriptions | | | Table 556. | FCCU_NCFS03 field descriptions | | | Table 557. | FCCU_NCFK field descriptions | | | Table 558. | FCCU_NCFE03 field descriptions | | | Table 559. | FCCU_NCF_TOE03 field descriptions | | | Table 560. | FCCU_NCF_TO field descriptions | | | Table 561. | FCCU_CFG_TO field descriptions | | | Table 562. | FCCU_STAT field descriptions | | | Table 563. | FCCU_CFF field descriptions | | | Table 564. | FCCU_NCFF field descriptions | | | Table 565. | FCCU_IRQ_STAT field descriptions | | | Table 566. | FCCU_IRQ_EN field descriptions | 964 | | Table 567. | Timer state/value | | | Table 568. | FCCU_XTMR field descriptions | 965 | | Table 569. | FCCU_MCS field descriptions | 966 | |------------|------------------------------------------------------------|--------| | Table 570. | Reset sources | 969 | | Table 571. | NVM configuration | 974 | | Table 572. | Dual-rail encoding | | | Table 573. | Time switching encoding | 977 | | Table 574. | Bi-stable encoding | | | Table 575. | FCCU mapping of critical faults | 978 | | Table 576. | FCCU mapping of non-critical faults | | | Table 577. | WKPU memory map | 980 | | Table 578. | NSR field descriptions | | | Table 579. | NCR field descriptions | | | Table 580. | PIT memory map | | | Table 581. | PITMCR field descriptions | 987 | | Table 582. | LDVAL <i>n</i> field descriptions | 988 | | Table 583. | CVAL <i>n</i> field descriptions | 989 | | Table 584. | TCTRLn field descriptions | 990 | | Table 585. | TFLG <i>n</i> field descriptions | | | Table 586. | STM memory map | 995 | | Table 587. | STM_CR field descriptions | 996 | | Table 588. | STM_CNT field descriptions | 997 | | Table 589. | STM_CCR <i>n</i> field descriptions | 997 | | Table 590. | STM_CIR <i>n</i> field descriptions | | | Table 591. | STM_CMP <i>n</i> field descriptions | | | Table 592. | CRC memory map | | | Table 593. | CRC_CFG field descriptions | . 1005 | | Table 594. | CRC_INP field descriptions | . 1006 | | Table 595. | CRC_CSTAT field descriptions | . 1006 | | Table 596. | CRC_OUTP field descriptions | | | Table 597. | CRC_OUTP_CHK field descriptions | | | Table 598. | BAM memory organization | . 1012 | | Table 599. | Hardware configuration to select boot mode | . 1014 | | Table 600. | SPC56xP60x/54x boot pins | | | Table 601. | RCHW field descriptions | . 1015 | | Table 602. | Flash boot sector | | | Table 603. | Fields of SSCM STATUS register used by BAM | | | Table 604. | Serial boot mode without autobaud—baud rates | | | Table 605. | UART boot mode download protocol (autobaud disabled) | | | Table 606. | FlexCAN boot mode download protocol (autobaud disabled) | | | Table 607. | System clock frequency related to external clock frequency | | | Table 608. | Maximum and minimum recommended baud rates | | | Table 609. | Prescaler/divider and time base values | | | Table 610. | FlexCAN standard compliant bit timing segment settings | | | Table 611. | Lookup table for FlexCAN bit timings | | | Table 612. | PRESDIV + 1 = 1 | | | Table 613. | PRESDIV + 1 > 1 (YY = PRESDIV) | | | Table 614. | Examples of legal and illegal passwords | | | Table 615. | Censorship configuration and truth table | | | Table 616. | VREG_CTL field descriptions | | | Table 617. | VREG_STATUS field descriptions | | | Table 618. | JTAG signal properties | | | Table 619. | Device identification register field descriptions | | | Table 620. | JTAG instructions | . 1054 | RM0083 List of tables | Table 621 | e200z0 OnCE register addressing | 1058 | |------------|-----------------------------------------|------| | | Device parameter values | | | | | | | Table 623. | NPC Signal Properties | 1063 | | Table 624. | NPC Registers | 1065 | | Table 625. | DID Field Descriptions | 1066 | | Table 626. | PCR field descriptions | 1067 | | Table 627. | MCKO_DIV Values | 1069 | | Table 628. | NPC Reset Configuration Options | 1069 | | | NPC Output Messages | | | Table 630. | Implemented Instructions | 1072 | | Table 631. | Loading NEXUS-ENABLE instruction | 1075 | | Table 632. | Write to a 32-Bit Nexus Client Register | 1076 | | Table 633. | Registers under protection | 1079 | | Table 634. | Document revision history | 1091 | List of figures RM0083 # List of figures | Figure 1. | Airbag application | 53 | |------------|------------------------------------------------------------------|-----| | Figure 2. | SPC56xP60x/54x block diagram | | | Figure 3. | LQFP176 pinout (top view) | 78 | | Figure 4. | LQFP144 pinout (top view) | 79 | | Figure 5. | LQFP100 pinout (top view) | 80 | | Figure 6. | CTU / ADCs / eTimers / DSPI / FlexRay connections | 98 | | Figure 7. | SPC56xP60x/54x system clock generation | 101 | | Figure 8. | SPC56xP60x/54x system clock distribution Part A | 102 | | Figure 9. | SPC56xP60x/54x system clock distribution Part B | 103 | | Figure 10. | Output Clock Division 256 Select Register (CLK_DIV_256) | 105 | | Figure 11. | RC Control register (RC_CTL) | 109 | | Figure 12. | Crystal Oscillator Control register (OSC_CTL) | 111 | | Figure 13. | FMPLL block diagram | 112 | | Figure 14. | Control Register (CR) | | | Figure 15. | Modulation Register (MR) | 115 | | Figure 16. | Progressive clock switching scheme | 117 | | Figure 17. | Frequency modulation depth spreads | 119 | | Figure 18. | SPC56xP60x/54x with two CMUs | | | Figure 19. | Control Status Register (CMU_0_CSR) | 124 | | Figure 20. | Frequency Display Register (CMU_0_FDR) | 125 | | Figure 21. | High Frequency Reference register FMPLL_0 (CMU_0_HFREFR_0) | 125 | | Figure 22. | Low Frequency Reference Register FMPLL_0 (CMU_0_LFREFR_0) | | | Figure 23. | Interrupt Status Register (CMU_0_ISR) | 126 | | Figure 24. | Measurement Duration Register (CMU_0_MDR) | 127 | | Figure 25. | Control Status Register (CMU_1_CSR) | | | Figure 26. | High Frequency Reference Register SYS_CLK (CMU_1_HFREFR_0) | | | Figure 27. | Low Frequency Reference Register SYS_CLK (CMU_1_LFREFR_0) | 129 | | Figure 28. | Interrupt Status register (CMU_1_ISR) | 129 | | Figure 29. | MC_CGM Block Diagram | 132 | | Figure 30. | Output Clock Enable Register (CGM_OC_EN) | | | Figure 31. | Output Clock Division Select Register (CGM_OCDS_SC) | 138 | | Figure 32. | System Clock Select Status Register (CGM_SC_SS) | 139 | | Figure 33. | Auxiliary Clock 0 Select Control Register (CGM_AC0_SC) | 140 | | Figure 34. | Auxiliary Clock 0 Divider 0 Configuration Register (CGM_AC0_DC0) | | | Figure 35. | Auxiliary Clock 1 Select Control Register (CGM_AC1_SC) | | | Figure 36. | Auxiliary Clock 1 Divider 0 Configuration Register (CGM_AC1_DC0) | | | Figure 37. | Auxiliary Clock 2 Select Control Register (CGM_AC2_SC) | 142 | | Figure 38. | Auxiliary Clock 2 Divider 0 Configuration Register (CGM_AC2_DC0) | | | Figure 39. | Auxiliary Clock 3 Select Control Register (CGM_AC3_SC) | 144 | | Figure 40. | Auxiliary Clock 3 Divider 0 Configuration Register (CGM_AC3_DC0) | 144 | | Figure 41. | MC_CGM System Clock Generation Overview | 145 | | Figure 42. | MC_CGM Auxiliary Clock 0 Generation Overview | | | Figure 43. | MC_CGM Auxiliary Clock 1 Generation Overview | | | Figure 44. | MC_CGM Auxiliary Clock 2 Generation Overview | | | Figure 45. | MC_CGM Auxiliary Clock 3 Generation Overview | | | Figure 46. | MC_CGM Output Clock Multiplexer and PAD[22] Generation | | | Figure 47. | MC_ME Block Diagram | 151 | | Figure 48. | Global Status Register (ME GS) | 162 | RM0083 List of figures | Figure 49. | Mode Control Register (ME_MCTL) | 164 | |-------------|------------------------------------------------------------------|------------| | Figure 50. | Mode Enable Register (ME_ME) | | | Figure 51. | Interrupt Status Register (ME_IS) | | | Figure 52. | Interrupt Mask Register (ME_IM) | | | Figure 53. | Invalid Mode Transition Status Register (ME_IMTS) | | | Figure 54. | Debug Mode Transition Status Register (ME_DMTS) | | | Figure 55. | RESET Mode Configuration Register (ME_RESET_MC) | | | Figure 56. | TEST Mode Configuration Register (ME_TEST_MC) | | | Figure 57. | SAFE Mode Configuration Register (ME_SAFE_MC) | | | Figure 58. | DRUN Mode Configuration Register (ME_DRUN_MC) | | | Figure 59. | RUN03 Mode Configuration Registers (ME_RUN03_MC) | | | Figure 60. | HALTO Mode Configuration Register (ME_HALTO_MC) | | | Figure 61. | STOP0 Mode Configuration Register (ME_STOP0_MC) | | | Figure 62. | Peripheral Status Register 0 (ME_PS0) | | | Figure 63. | Peripheral Status Register 1 (ME_PS1) | | | Figure 64. | Peripheral Status Register 2 (ME_PS2) | | | Figure 65. | Peripheral Status Register 3 (ME_PS3) | | | Figure 66. | Run Peripheral Configuration Registers (ME_RUN_PC07) | | | Figure 67. | Low-Power Peripheral Configuration Registers (ME_LP_PC07) | | | Figure 68. | Peripheral Control Registers (ME_PCTLn) | | | Figure 69. | MC_ME Mode Diagram | | | Figure 70. | MC_ME Transition Diagram | | | Figure 71. | MC_ME Application Example Flow Diagram | | | Figure 72. | MC_PCU Block Diagram | 197 | | Figure 73. | Power Domain #0 Configuration Register (PCU_PCONF0) | 200 | | Figure 74. | Power Domain Status Register (PCU_PSTAT) | | | Figure 75. | MC_RGM Block Diagram | | | Figure 76. | Functional Event Status Register (RGM_FES) | | | Figure 77. | Destructive Event Status Register (RGM_DES) | | | Figure 78. | Functional Event Reset Disable Register (RGM_FERD) | | | Figure 79. | Destructive Event Reset Disable Register (RGM_DERD) | | | Figure 80. | Functional Event Alternate Request Register (RGM_FEAR) | | | Figure 81. | Functional Event Short Sequence Register (RGM_FESS) | | | Figure 82. | Functional Bidirectional Reset Enable Register (RGM_FBRE) | | | Figure 83. | MC_RGM State Machine | | | Figure 84. | INTC block diagram | | | Figure 85. | INTC Module Configuration Register (INTC_MCR) | | | Figure 86. | INTC Current Priority Register (INTC_CPR) | | | Figure 87. | INTC Interrupt Acknowledge Register (INTC_IACKR) | | | Figure 88. | INTC End-of-Interrupt Register (INTC_EOIR) | | | Figure 89. | INTC Software Set/Clear Interrupt Register 0–3 (INTC_SSCIR[0:3]) | | | Figure 90. | INTC Software Set/Clear Interrupt Register 4–7 (INTC_SSCIR[4:7]) | | | Figure 91. | INTC Priority Select Register 0–3 (INTC_PSR[0:3]) | | | Figure 92. | INTC Priority Select Register 260 (INTC_PSR[260]) | | | Figure 93. | Software vector mode handshaking timing diagram | | | Figure 94. | Hardware vector mode handshaking timing diagram | | | Figure 95. | SSCM block diagram | | | Figure 96. | Key to register fields | | | Figure 97. | Status (STATUS) register | | | Figure 98. | System memory configuration (MEMCONFIG) register | | | Figure 99. | Error Configuration (ERROR) register | | | Figure 100. | Debug Status Port (DEBUGPORT) register | <b>202</b> | List of figures RM0083 | | Password Comparison Register High Word (PWCMPH) register | | |-------------|---------------------------------------------------------------------------------------|-----| | | Password Comparison Register Low Word (PWCMPL) register | | | | DPM Boot (DPMBOOT) Register | | | | Boot Key Register (DPMKEY) Register | | | | User Option Status (UOPS) Register | | | | Processor Start Address (PSA) Register | | | | System Integration Unit Lite block diagram | | | | Key to register fields | | | • | MCU ID Register #1 (MIDR1) | | | | MCU ID Register #2 (MIDR2) | | | | Interrupt Status Flag Register (ISR) | | | | Interrupt Request Enable Register (IRER) | | | | Interrupt Rising-Edge Event Enable Register (IREER) | | | | Interrupt Falling-Edge Event Enable Register (IFEER) | | | | Interrupt Filter Enable Register (IFER) | | | | Pad Configuration Registers 0–108 (PCR[0:108]) | | | | Pad Selection for Multiplexed Inputs registers (PSMI[0_3:36_39]) | | | | Port GPIO Pad Data Output registers 0_3–104_107 (GPDO[0_3:104_107]) | | | Figure 119. | GPIO Pad Data Input registers 0_3–104_107 (GPDI[0_3:104_107]) | 282 | | Figure 120. | Parallel GPIO Pad Data Out register 0–3(PGPDO[0:3]) | 283 | | Figure 121. | Parallel GPIO Pad Data In register 0–3 (PGPDI[0:3]) | 284 | | Figure 122. | Masked Parallel GPIO Pad Data Out register 0–6 (MPGPDO[0:6]) | 284 | | Figure 123. | Interrupt Filter Maximum Counter registers 0–31 (IFMC[0:31]) | 285 | | Figure 124. | Interrupt Filter Clock Prescaler Register (IFCPR) | 286 | | Figure 125. | Data port example arrangement showing configuration for different port width accesses | 287 | | Figure 126. | External interrupt pad diagram | 288 | | Figure 127. | e200z0 block diagram | 292 | | | e200z0h block diagram | | | Figure 129. | e200z0 Supervisor mode programmer's model | 296 | | Figure 130. | e200z0h Supervisor mode programmer's model | 297 | | Figure 131. | PBRIDGE interface | 298 | | Figure 132. | MPROT <i>n</i> field structure | 301 | | Figure 133. | PACR <i>n</i> field structure | 301 | | Figure 134. | Key to Register Fields | 309 | | Figure 135. | Master Priority Register n | 311 | | Figure 136. | Slave General Purpose Control Register n | 314 | | Figure 137. | Master General Purpose Control Register n | 316 | | Figure 138. | Low to high priority mastership change | 323 | | Figure 139. | High to low priority mastership change | 324 | | Figure 140. | Round-robin mastership change | 325 | | Figure 141. | Parking on a specific master | 326 | | Figure 142. | Parking on last master | 327 | | Figure 143. | Processor core type (PCT) register | 332 | | Figure 144. | Revision (REV) register | 332 | | Figure 145. | Platform XBAR Master Configuration (PLAMC) register | 333 | | Figure 146. | Platform XBAR Slave Configuration (PLASC) register | 333 | | Figure 147. | IPS Module Configuration (IMC) register | 334 | | Figure 148. | Miscellaneous Reset Status Register (MRSR) | 334 | | | Miscellaneous Interrupt Register (MIR) | | | Figure 150. | Miscellaneous User-Defined Control register (MUDCR) | 336 | | | ECC Configuration register (ECR) | | | | | 339 | RM0083 List of figures | | ECC Error Generation register (EEGR) | | |-------------|-----------------------------------------------------------------------------|-------| | • | Flash ECC Address register (FEAR) | | | - | Flash ECC Master Number Register (FEMR) | | | - | Flash ECC Attributes (FEAT) Register | | | | Flash ECC Data register (FEDR) | | | | RAM ECC Address register (REAR) | | | | RAM ECC Syndrome Register (RESR) | | | - | RAM ECC Master Number register (REMR) | | | - | RAM ECC Attributes (REAT) register | | | | RAM ECC Data Register (REDR) | | | - | SPC56xP60x/54x Flash memory architecture | | | | 1-cycle access, no buffering, no prefetch | | | | 3-cycle access, no prefetch, buffering disabled | | | | 3-cycle access, no prefetch, buffering enabled | | | | 3-cycle access, prefetch and buffering enabled | | | | 3-cycle access, stall-and-retry with BK $n$ _RWWC = 11 $x$ | | | | 3-cycle access, terminate-and-retry with BK $n$ _RWWC = 10 $x$ | | | • | Data Flash module structure | | | | Code Flash module structure | | | • | Module Configuration Register (MCR) | | | | Low/Mid Address Space Block Locking register (LML) | | | | Non-Volatile Low/Mid Address Space Block Locking register (NVLML) | | | | Non-Volatile High Address Space Block Locking register (NVHBL) | | | | Non-Volatile High Address Space Block Locking register (NVHBL) | | | | Secondary Low/mid address space block Locking reg (SLL) | | | | Non-Volatile Secondary Low/Mid Address Space Block Locking register (NVSLL) | | | - | Low/Mid Address Space Block Select register (LMS) | | | - | High Address Space Block Select register (HBS) | | | | Address Register (ADR) | | | | Platform Flash Configuration Register 0 (PFCR0) | | | | Platform Flash Assess Protestion Register (PFARP) | | | | Platform Flash Access Protection Register (PFAPR) | | | | User Test 0 register (UT0) | | | | User Test 1 register (UT1) | | | • | User Test 2 register (UT2) | | | | User Multiple Input Signature Register 0 (UMISR0) | | | • | User Multiple Input Signature Register 1 (UMISR1) | | | | User Multiple Input Signature Register 2 (UMISR2) | | | | User Multiple Input Signature Register 3 (UMISR3) | | | | User Multiple Input Signature Register 4 (UMISR4) | | | | Non-Volatile private Censorship Password 0 register (NVPWD0) | | | | Non-Volatile Private Censorship Password 1 register (NVPWD1) | | | | Non-Volatile System Censoring Information 0 register (NVSCI0) | | | • | Non-Volatile System Censoring Information 1 register (NVSCI1) | | | | Non-Volatile User Options register (NVUSRO). | | | - | MPU block diagram | | | Figure 200. | MPU Control/Error Status Register (MPU_CESR) | . 439 | | | MPU Error Address Register, Slave Port n (MPU_EARn) | | | | MPU Error Detail Register, Slave Port n (MPU_EDRn) | | | | MPU Region Descriptor, Word 0 Register (MPU RGDn.Word0) | | | • | MPU Region Descriptor, Word 1 Register (MPU_RGDn.Word1) | | | | | | List of figures RM0083 | | MPU Region Descriptor, Word 2 Register (MPU_RGDn.Word2) | | |-------------|---------------------------------------------------------------------------------------------------|-----| | | MPU Region Descriptor, Word 3 Register (MPU_RGDn.Word3) | | | - | MPU RGD Alternate Access Control n (MPU_RGDAACn) | | | | MPU access evaluation macro | | | | Access evaluation macro critical timing path | | | | eDMA block diagram | | | | eDMA Control Register (EDMA_CR) | | | | eDMA Error Status Register (EDMA_ESR) | | | | eDMA Enable Request Register (EDMA_ERQRL) | | | | eDMA Enable Error Interrupt Register (EDMA_EEIRL) | | | • | eDMA Set Enable Request Register (EDMA_SERQR) | | | | eDMA Clear Enable Request Register (EDMA_CERQR) | | | | eDMA Set Enable Error Interrupt Register (EDMA_SEEIR) | | | | eDMA Set Enable Error Interrupt Register (EDMA_SEEIR) | | | | eDMA Clear Interrupt Request (EDMA_CIRQR) | | | | | | | - | eDMA Set START Bit Register (EDMA_SSBR) | | | - | eDMA Clear DONE Status Bit Register (EDMA_CDSBR) eDMA Interrupt Request Low Register (EDMA_IRQRL) | | | | eDMA Error Low Register (EDMA_ERL) | | | | EDMA Hardware Request Status Register Low (EDMA_HRSL) | | | Figure 225. | eDMA Channel n Priority Register (EDMA_CPRn) | 470 | | | TCD structure | | | • | eDMA operation, part 1 | | | - | eDMA operation, part 2 | | | | eDMA operation, part 3 | | | | Example of multiple loop iterations | | | | Memory array terms | | | | DMA Mux block diagram | | | - | Channel Configuration Registers (CHCONFIG#n) | | | | DMA mux triggered channels diagram | | | | DMA mux channel triggering: normal operation | | | | DMA mux channel triggering: ignored trigger | | | | DMA mux channel 4–15 block diagram | | | | FlexRay block diagram | | | - | Module Version Register (MVR) | | | | Module Configuration Register (MCR) | | | Figure 242. | System Memory Base Address High Register (SYMBADHR) | 521 | | | System Memory Base Address Low Register (SYMBADLR) | | | Figure 244. | Strobe Signal Control Register (STBSCR) | 521 | | Figure 245. | Message Buffer Data Size Register (MBDSR) | 525 | | Figure 246. | Message Buffer Segment Size and Utilization Register (MBSSUTR) | 525 | | Figure 247. | Protocol Operation Control Register (POCR) | 526 | | Figure 248. | Global Interrupt Flag and Enable Register (GIFER) | 528 | | Figure 249. | Protocol Interrupt Flag Register 0 (PIFR0) | 530 | | Figure 250. | Protocol Interrupt Flag Register 1 (PIFR1) | 533 | | Figure 251. | Protocol Interrupt Enable Register 0 (PIER0) | 534 | | Figure 252. | Protocol Interrupt Enable Register 1 (PIER1) | 535 | | | CHI Error Flag Register (CHIERFR) | | | | Message Buffer Interrupt Vector Register (MBIVEC) | | | | Channel A Status Error Counter Register (CASERCR) | | | Figure 256. | Channel B Status Error Counter Register (CBSERCR) | 540 | RM0083 List of figures | Figure 257. | Protocol Status Register 0 (PSR0) | 540 | |-------------|----------------------------------------------------------------------|-----| | Figure 258. | Protocol Status Register 1 (PSR1) | 542 | | | Protocol Status Register 2 (PSR2) | | | - | Protocol Status Register 3 (PSR3) | | | | Macrotick Counter Register (MTCTR) | | | • | Cycle Counter Register (CYCTR) | | | - | Slot Counter Channel A Register (SLTCTAR) | | | | Slot Counter Channel B Register (SLTCTBR) | | | • | Rate Correction Value Register (RTCORVR) | | | | Offset Correction Value Register (OFCORVR) | | | | Combined Interrupt Flag Register (CIFRR) | | | | System Memory Access Time-Out Register (SYMATOR) | | | | Sync Frame Counter Register (SFCNTR) | | | | Sync Frame Table Offset Register (SFTOR) | | | | Sync Frame Table Configuration, Control, Status Register (SFTCCSR) | | | | Sync Frame ID Rejection Filter Register (SFIDRFR) | | | - | Sync Frame ID Acceptance Filter Value Register (SFIDAFVR) | | | - | Sync Frame ID Acceptance Filter Mask Register (SFIDAFMR) | | | | Network Management Vector Registers (NMVR0–NMVR5) | | | • | Network Management Vector Length Register (NMVLR) | | | | Timer Configuration and Control Register (TICCR) | | | | Timer 1 Cycle Set Register (TI1CYSR) | | | • | Timer 1 Macrotick Offset Register (TI1MTOR) | | | | Timer 2 Configuration Register 0 (TI2CR0) | | | - | Timer 2 Configuration Register 1 (TI2CR1) | | | | Slot Status Selection Register (SSSR) | | | | Slot Status Counter Condition Register (SSCCR) | | | | Slot Status Registers (SSR0–SSR7) | | | - | Slow Status Counter Registers (SSCR0–SSCR3) | | | | MTS A Configuration Register (MTSACFR) | | | | MTS B Configuration Register (MTSBCFR) | | | - | Receive Shadow Buffer Index Register (RSBIR) | | | - | Receive FIFO Selection Register (RFSR) | | | | Receive FIFO Start Index Register (RFSIR) | | | • | Receive FIFO A Read Index Register (RFARIR) | | | - | Receive FIFO B Read Index Register (RFBRIR) | | | | Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) | | | | Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) | | | | Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) | | | - | Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) | | | | Receive FIFO Range Filter Configuration Register (RFRFCFR) | | | | Receive FIFO Range Filter Control Register (RFRFCTR) | | | | Last Dynamic Slot Channel A Register (LDTXSLAR) | | | | Last Dynamic Slot Channel B Register (LDTXSLBR) | | | | Protocol Configuration Register 0 (PCR0) | | | | Protocol Configuration Register 1 (PCR1) | | | | Protocol Configuration Register 2 (PCR2) | | | | Protocol Configuration Register 3 (PCR3) | | | | Protocol Configuration Register 4 (PCR4) | | | | Protocol Configuration Register 5 (PCR5) | | | • | Protocol Configuration Register 6 (PCR6) | | | - | · , , | | List of figures RM0083 | Figure 309. | Protocol Configuration Register 7 (PCR7) | 577 | |-------------|-------------------------------------------------------------------|-----| | Figure 310. | Protocol Configuration Register 8 (PCR8) | 577 | | Figure 311. | Protocol Configuration Register 9 (PCR9) | 577 | | Figure 312. | Protocol Configuration Register 10 (PCR10) | 578 | | Figure 313. | Protocol Configuration Register 11 (PCR11) | 578 | | | Protocol Configuration Register 12 (PCR12) | | | | Protocol Configuration Register 13 (PCR13) | | | | Protocol Configuration Register 14 (PCR14) | | | | Protocol Configuration Register 15 (PCR15) | | | Figure 318. | Protocol Configuration Register 16 (PCR16) | 579 | | Figure 319. | Protocol Configuration Register 17 (PCR17) | 579 | | Figure 320. | Protocol Configuration Register 18 (PCR18) | 579 | | Figure 321. | Protocol Configuration Register 19 (PCR19) | 580 | | Figure 322. | Protocol Configuration Register 20 (PCR20) | 580 | | Figure 323. | Protocol Configuration Register 21 (PCR21) | 580 | | Figure 324. | Protocol Configuration Register 22 (PCR22) | 580 | | Figure 325. | Protocol Configuration Register 23 (PCR23) | 580 | | Figure 326. | Protocol Configuration Register 24 (PCR24) | 581 | | Figure 327. | Protocol Configuration Register 25 (PCR25) | 581 | | Figure 328. | Protocol Configuration Register 26 (PCR26) | 581 | | Figure 329. | Protocol Configuration Register 27 (PCR27) | 581 | | Figure 330. | Protocol Configuration Register 28 (PCR28) | 582 | | Figure 331. | Protocol Configuration Register 29 (PCR29) | 582 | | Figure 332. | Protocol Configuration Register 30 (PCR30) | 582 | | Figure 333. | Message Buffer Configuration, Control, Status Registers (MBCCSRn) | 582 | | Figure 334. | Message Buffer Cycle Counter Filter Registers (MBCCFRn) | 584 | | Figure 335. | Message Buffer Frame ID Registers (MBFIDRn) | 585 | | Figure 336. | Message Buffer Index Registers (MBIDXRn) | 586 | | Figure 337. | Physical message buffer structure | 587 | | Figure 338. | Individual message buffer structure | 589 | | Figure 339. | Receive shadow buffer structure | 590 | | Figure 340. | Receive FIFO structure | 591 | | Figure 341. | Example of FlexRay memory layout | 594 | | Figure 342. | Frame header structure (Receive message buffer and receive FIFO) | 595 | | Figure 343. | Frame header structure (Transmit message buffer) | 596 | | Figure 344. | Frame header structure (Transmit message buffer for key slot) | 596 | | | Receive message buffer slot status structure (ChAB) | | | Figure 346. | Receive message buffer slot status structure (ChA) | 599 | | Figure 347. | Receive message buffer slot status structure (ChB) | 599 | | Figure 348. | Transmit message buffer slot status structure (ChAB) | 601 | | Figure 349. | Transmit message buffer slot status structure (ChA) | 601 | | Figure 350. | Transmit message buffer slot status structure (ChB) | 601 | | Figure 351. | Message buffer data field structure | 603 | | Figure 352. | Single transmit message buffer access regions | 607 | | Figure 353. | Single transmit message buffer states | 608 | | | Message transmission timing | | | Figure 355. | Message transmission from HLck state with unlock | 612 | | • | Null frame transmission from idle state | | | | Null frame transmission from HLck state | | | | Null frame transmission from HLck state with unlock | | | Figure 359. | Null frame transmission from idle state with locking | 614 | | Figure 360 | Receive message buffer access regions | 615 | RM0083 List of figures | Figure 361. | Receive message buffer states | . 616 | |-------------|---------------------------------------------------------------------------------------------|-------| | | Message reception timing | | | • | Double transmit buffer structure and data flow | | | | Double transmit message buffer access regions layout | | | | Double transmit message buffer state diagram (commit side) | | | | Double transmit message buffer state diagram (transmit side) | | | | Internal message transfer in streaming commit mode | | | | Internal message transfer in immediate commit mode | | | | Inconsistent channel assignment | | | • | Message buffer reconfiguration scheme | | | | Received frame FIFO filter path | | | | Dual channel device mode | | | - | Single channel device mode (Channel A) | | | | Single channel device mode (Channel B) | | | | External offset correction write and application timing | | | | External rate correction write and application timing | | | | Sync table memory layout | | | • | Sync frame table trigger and generation timing | | | | Strobe signal timing (type = pulse, clk_offset = -2) | | | | Strobe signal timing (type = pulse, clk_offset = +4) | | | | Slot status vector update | | | | Slot status counting and SSCR <i>n</i> update | | | | Scheme of cascaded interrupt request | | | • | Scheme of combined interrupt flags | | | • | Transmit data not available | | | • | Transmit data not available | | | | DSPI block diagram | | | | DSPI with queues and eDMA | | | | DSPI Module Configuration Register (DSPIx_MCR) | | | | DSPI Transfer Count Register (DSPIx_TCR) | | | | DSPI Clock and Transfer Attributes Registers 0–7 (DSPIx_CTARn) | | | | DSPI Status Register (DSPIx_SR) | | | | DSPI DMA / Interrupt Request Select and Enable Register (DSPIx_RSER) | | | | DSPI PUSH TX FIFO Register (DSPIx_PUSHR) | | | • | DSPI POP RX FIFO Register (DSPIx_POPR) | | | | DSPI Transmit FIFO Register 0–4 (DSPIx_TXFRn) | | | _ | DSPI Receive FIFO Registers 0–4 (DSPIx_RXFRn) | | | | SPI serial protocol overview | | | | DSPI start and stop state diagram | | | | Communications clock prescalers and scalers | | | | Peripheral Chip Select strobe timing | | | | DSPI transfer timing diagram (MTFE = 0, CPHA = 0, FMSZ = 8) | | | | DSPI transfer timing diagram (MTFE = 0, CPHA = 1, FMSZ = 8) | | | | DSPI modified transfer format (MTFE = 1, CPHA = 0, f <sub>SCK</sub> = f <sub>SYS</sub> / 4) | | | | DSPI modified transfer format (MTFE = 1, CPHA = 1, f <sub>SCK</sub> = f <sub>SYS</sub> / 4) | | | | Example of non-continuous format (CPHA = 1, CONT = 0) | | | | Example of continuous transfer (CPHA = 1, CONT = 1) | | | | Polarity switching between frames | | | • | Continuous SCK timing diagram (CONT = 0) | | | | Continuous SCK timing diagram (CONT = 1) | | | • | TX FIFO pointers and counter | | | Figure 412. | LIN topology network | . 717 | | Figure 413. | LINFlex block diagram | 717 | |-------------|-------------------------------------------------|-----| | • | LINFlex operating modes | | | | LINFlex in loop back mode | | | | LINFlex in self test mode | | | | LIN control register 1 (LINCR1) | | | - | LIN interrupt enable register (LINIER) | | | | LIN status register (LINSR) | | | | LIN error status register (LINESR) | | | | UART mode control register (UARTCR) | | | | UART mode status register (UARTSR) | | | - | LIN timeout control status register (LINTCSR) | | | - | LIN output compare register (LINOCR) | | | | LIN timeout control register (LINTOCR) | | | | LIN fractional baud rate register (LINFBRR) | | | | LIN integer baud rate register (LINIBRR) | | | | LIN checksum field register (LINCFR) | | | | LIN control register 2 (LINCR2) | | | | Buffer identifier register (BIDR) | | | | Buffer data register LSB (BDRL) | | | | Buffer data register MSB (BDRM) | | | | Identifier filter enable register (IFER) | | | | Identifier filter match index (IFMI) | | | | Identifier filter mode register (IFMR) | | | | Identifier filter control register (IFCR2n) | | | | Identifier filter control register (IFCR2n + 1) | | | • | UART mode 8-bit data frame | | | • | UART mode 9-bit data frame | | | | Filter configuration—register organization | | | • | Identifier match index | | | | LIN synch field measurement | | | - | Header and response timeout | | | - | FlexCAN block diagram | | | | Message buffer structure | | | | Rx FIFO structure | | | | ID Table 0 - 7 | | | | Module Configuration Register (MCR) | | | | Control Register (CTRL) | | | • | Free Running Timer (TIMER) | | | - | Rx Global Mask register (RXGMASK) | | | | Rx Buffer 14 Mask register (RX14MASK) | | | - | Rx Buffer 15 Mask register (RX15MASK) | | | | Error Counter Register (ECR) | | | | Error and Status Register (ESR) | | | • | Interrupt Masks 1 Register (IMASK1) | | | - | Interrupt Flags 1 Register (IFLAG1) | | | | Rx Individual Mask Registers (RXIMR0–RXIMR31) | | | • | CAN engine clocking scheme | | | • | Segments within the bit time | | | - | Arbitration, match, and move time windows | | | - | ADC implementation diagram | | | • | Normal conversion flow | | | Figure 464. | Injected sample/conversion sequence | 808 | RM0083 List of figures | | Prescaler simplified block diagram | | |-------------|--------------------------------------------------------------|-----| | | Sampling and conversion timings | | | | Presampling sequence | | | | Presampling sequence with PRECONV = 1 | | | | Guarded area | | | | Main Configuration Register (MCR) | | | | Main Status Register (MSR) | | | | Interrupt Status Register (ISR) | | | | Interrupt Mask Register (IMR) | | | | Watchdog Threshold Interrupt Status Register (WTISR) | | | | Watchdog Threshold Interrupt Mask Register (WTIMR) | | | | DMA Enable (DMAE) register | | | - | DMA Channel Select Register 0 (DMAR0) | | | | Threshold Control Register (TRCx, x = [03]) | | | | Threshold Register (THRHLR[0:3]) | | | | Presampling Control Register (PSCR) | | | | Presampling Register 0 (PSR0) | | | | Conversion Timing Registers CTR[0] | | | | Normal Conversion Mask Register 0 (NCMR0) | | | | Injected Conversion Mask Register 0 (JCMR0) | | | | Power-Down Exit Delay Register (PDEDR) | | | | Channel Data Registers (CDR[026]) | | | - | Cross triggering unit diagram | | | Figure 488. | TGS in triggered mode | 835 | | | Example timing for TGS in triggered mode | | | | TGS in sequential mode | | | | Example timing for TGS in sequential mode | | | | TGS counter cases | | | • | Scheduler subunit | | | | Reload error scenario | | | | Trigger Generator Sub-unit Input Selection Register (TGSISR) | | | | Trigger Generator Sub-unit Control Register (TGSCR) | | | | Trigger x Compare Register (TxCR, x = 07) | | | - | TGS Counter Compare Register (TGSCCR) | | | | TGS Counter Reload Register (TGSCRR) | | | | Commands list control register 1 (CLCR1) | | | | Commands list control register 2 (CLCR2) | | | | Trigger handler control register 1 (THCR1) | | | | Trigger handler control register 2 (THCR2) | | | | Commands list register x (x = 1,,24) (CMS = 0) | | | | Commands list register x (x = 1,,24) (CMS = 1) | | | • | FIFO DMA control register (FDCR) | | | | FIFO control register (FCR) | | | | FIFO threshold register (FTH) | | | | FIFO status register (FST) | | | | FIFO Right aligned data x (x = 0,,3) (FRx) | | | | FIFO signed Left aligned data x (x = 0,,3) (FLx) | | | | Cross triggering unit error flag register (CTUEFR) | | | | Cross triggering unit interrupt flag register (CTUIFR) | | | | Cross triggering unit interrupt/DMA register (CTUIR) | | | | Control ON time register (COTR) | | | ⊢ıgure 516. | Cross triggering unit control register (CTUCR) | 871 | List of figures RM0083 | • | Cross triggering unit digital filter (CTUDF) | | |-------------|--------------------------------------------------------------------------|-------| | | Cross triggering unit power control register (CTUPCR) | | | Figure 519. | SEMA4 block diagram | . 874 | | | SEMA4 gate <i>n</i> register (SEMA4_GATE <i>n</i> ) | | | | Semaphores processor <i>n</i> IRQ notification enable (SEMA4_CP{0,1}INE) | | | | Semaphores processor <i>n</i> IRQ notification (SEMA4_CP{0,1}NTF) | | | | Semaphores (secure) reset gate <i>n</i> (SEMA4_RSTGT) | | | | Semaphores (secure) Reset IRQ notification (SEMA4_RSTNTF) | | | • | eTimer block diagram | | | - | eTimer channel block diagram | | | | Compare register 1 (COMP1) | | | - | Compare register 2 (COMP2) | | | | Capture register 1 (CAPT1) | | | | Capture register 2 (CAPT2) | | | | Load register (LOAD) | | | | Hold register (HOLD) | | | | Counter register (CNTR) | | | | Control register 1 (CTRL1) | | | | Control register 2 (CTRL2) | | | Figure 536. | Control register 3 (CTRL3) | . 901 | | | Status register (STS) | | | Figure 538. | Interrupt and DMA enable register (INTDMA) | . 904 | | Figure 539. | Comparator Load 1 (CMPLD1) | . 905 | | Figure 540. | Comparator Load 2 (CMPLD2) | . 905 | | Figure 541. | Compare and Capture Control register (CCCTRL) | . 906 | | | Input Filter register (FILT) | | | Figure 543. | Watchdog Time-out Low Word register (WDTOL) | . 909 | | | Watchdog Time-Out High Word register (WDTOH) | | | Figure 545. | Channel Enable register (ENBL) | . 909 | | Figure 546. | DMA Request 0 Select register (DREQ0) | . 910 | | Figure 547. | DMA Request 1 Select register (DREQ1) | . 910 | | Figure 548. | Quadrature incremental position encoder | . 913 | | Figure 549. | Triggered Count mode (length = 1) | . 914 | | Figure 550. | One-Shot mode (length = 1) | . 914 | | Figure 551. | Pulse Output mode | . 915 | | Figure 552. | Register protection module block diagram | . 920 | | Figure 553. | Register protection memory diagram | . 921 | | Figure 554. | Soft Lock Bit Register (SLBRn) | . 923 | | Figure 555. | Global Configuration Register (GCR) | . 924 | | Figure 556. | Change lock settings directly via area #4 | . 925 | | Figure 557. | Change lock settings for 16-bit protected addresses | . 926 | | Figure 558. | Change lock settings for 32-bit protected addresses | . 926 | | Figure 559. | Change lock settings for mixed protection | . 927 | | Figure 560. | Enable locking via mirror module space (area #3) | . 927 | | Figure 561. | Enable locking for protected and unprotected addresses | . 927 | | Figure 562. | SWT Control Register (SWT_CR) | . 930 | | | SWT Interrupt Register (SWT_IR) | | | | SWT Time-Out register (SWT_TO) | | | | SWT Window register (SWT_WN) | | | Figure 566. | SWT Service Register (SWT_SR) | . 934 | | Figure 567. | SWT Counter Output register (SWT_CO) | . 934 | | Figure 568. | SWT Service Key Register (SWT SK) | . 935 | RM0083 List of figures | Figure 569. | Pseudorandom Key Generator | 936 | |---------------|----------------------------------------------------------|-----| | Figure 570. | FCCU top-level diagram | 940 | | Figure 571. | FCCU Control Register (FCCU_CTRL) | 944 | | | FCCU CTRL Key Register (FCCU_CTRLK) | | | | FCCU Configuration Register (FCCU_CFG) | | | | FCCU CF Configuration Register (FCCU_CF_CFG03) | | | | FCCU NCF Configuration Register (FCCU_NCF_CFG03) | | | | FCCU CFS Configuration Register 0 (FCCU_CFS_CFG0) | | | | FCCU CFS Configuration Register 1 (FCCU_CFS_CFG1) | | | - | FCCU CFS Configuration Register 27 (FCCU_CFS_CFG27) | | | | FCCU NCFS Configuration Register (FCCU_NCFS_CFG07) | | | - | FCCU CF Status Register (FCCU_CFS03) | | | | FCCU CF Key Register (FCCU_CFK) | | | - | FCCU NCF Status Register (FCCU_NCFS03) | | | | FCCU NCF Key Register (FCCU_NCFK) | | | | FCCU NCF Enable Register (FCCU_NCFE03) | | | - | FCCU NCF Time-out Enable Register (FCCU_NCF_TOE03) | | | | FCCU NCF Time-out Register (FCCU_NCF_TO) | | | | FCCU CFG Timeout Register (FCCU_CFG_TO) | | | | FCCU Status Register (FCCU_STAT) | | | • | FCCU CF Fake Register (FCCU_CFF) | | | | FCCU NCF Fake Register (FCCU_NCFF) | | | | FCCU IRQ Status Register (FCCU_IRQ_STAT) | | | | FCCU IRQ Enable Register (FCCU_IRQ_EN) | | | - | FCCU XTMR Register (FCCU_XTMR) | | | | FCCU MCS Register (FCCU_MCS) | | | - | FCCU state diagram | | | | Self-checking reaction | | | - | Critical FAULT recovery (a) | | | | Critical FAULT recovery (b) | | | | Non-critical FAULT (ALARM state) recovery (a) | | | | Non-critical FAULT (ALARM state) recovery (b) | | | | Non-critical FAULT (ALARM -> FAULT state) recovery | | | | Critical FAULT (nesting) recovery | | | | Critical FAULT (and non-critical FAULT nesting) recovery | | | | NVM interface | | | • | Dual-rail protocol (slow switching mode) | | | - | Dual-rail protocol (fast switching mode) | | | • | Time-switching protocol | | | | Bi-stable protocol | | | | NMI Status Flag Register (NSR) | | | - | NMI Configuration Register (NCR) | | | • | NMI pad diagram | | | | PIT block diagram | | | | PIT Module Control Register (PITMCR) | | | | Timer Load Value Register n (LDVALn) | | | | Current Timer Value register n (CVALn) | | | | Timer Control register n (TCTRLn) | | | • | Timer Flag register n (TFLGn) | | | • | Stopping and starting a timer | | | • | Dynamically setting a new load value | | | i igui e 020. | Dynamically setting a new load value | 992 | List of figures RM0083 | Figure 621. | M Control Register (STM_CR) | 996 | |-------------|------------------------------------------------------|------| | Figure 622. | STM Count Register (STM_CNT) | 996 | | Figure 623. | STM Channel Control Register (STM_CCRn) | 997 | | | STM Channel Interrupt Register (STM_CIRn) | | | Figure 625. | STM Channel Compare Register (STM_CMPn) | 998 | | Figure 626. | CRC top level diagram | 1001 | | | CRC-CCITT engine concept scheme | | | | CRC computation flow | | | | CRC Configuration Register (CRC_CFG) | | | Figure 630. | CRC Input Register (CRC_INP) | 005 | | | CRC Current Status Register (CRC_CSTAT) | | | Figure 632. | CRC Output Register (CRC_OUTP) | 1007 | | | CRC Output Check Register (CRC_OUTP_CHK) | | | | DMA-CRC Transmission Sequence | | | • | DMA-CRC Reception Sequence | | | | Boot mode selection | | | | Reset Configuration Half Word (RCHW) | | | | SPC56xP60x/54x Flash partitioning and RCHW search | | | | BAM logic flow | | | | Password check flow | | | | Start address, VLE bit and download size in bytes | | | • | LINFlex bit timing in UART mode | | | | FlexCAN bit timing | | | • | BAM Autoscan code flow | | | • | Baud measurement on UART boot | | | | BAM rate measurement flow during UART boot | | | | Bit time measure | | | | BAM rate measurement flow during FlexCAN boot | | | | Censorship control in flash memory boot mode | | | • | Censorship control in least memory boot mode | | | | Voltage Regulator Control register (VREG_CTL) | | | | Voltage Regulator Status register (VREG_STATUS) | | | • | JTAG controller block diagram | | | • | 5-bit Instruction register | | | • | Device identification register | | | • | Shifting data through a register | | | • | IEEE 1149.1-2001 TAP controller finite state machine | | | • | e200z0 OnCE block diagram | | | • | OnCE Command register (OCMD) | | | • | Nexus Port Controller Block Diagram | | | • | 4-Bit Instruction Register | | | • | Nexus Device ID Register | | | | Port Configuration Register (PCR) | | | | MSEO Transfers (for 2-bit MSEO) | | | • | , | 071 | | • | | 072 | | - | · · · · · · · · · · · · · · · · · · · | 072 | | | IEEE 1149.1-2001 TAP Controller State Machine | - | | • | NEXUS Controller State Machine | | | | IEEE 1149.1 Controller Command Input | | | | | | RM0083 Preface ## **Preface** #### Overview The primary objective of this document is to define the functionality of the SPC56xP60x/54x family of microcontrollers for use by software and hardware developers. The SPC56xP60x/54x family is built on Power Architecture® technology and integrates technologies that are important for today's electrical hydraulic power steering (EHPS), electric power steering (EPS), and airbag applications. As with any technical documentation, it is the reader's responsibility to be sure he or she is using the most recent version of the documentation. To locate any published errata or updates for this document, visit the ST Web site at www.st.com. #### **Audience** This manual is intended for system software and hardware developers and applications programmers who want to develop products with the SPC56xP60x/54x device. It is assumed that the reader understands operating systems, microprocessor system design, basic principles of software and hardware, and basic details of the Power Architecture. # Chapter organization and device-specific information This document includes chapters that describe: - The device as a whole - The functionality of the individual modules on the device In the latter, any device-specific information is presented in the section "Information specific to this device" at the beginning of the chapter. # References In addition to this reference manual, the following documents provide additional information on the operation of the SPC56xP60x/54x: - IEEE-ISTO 5001™ 2003 and 2010, The Nexus 5001™ Forum Standard for a Global Embedded Processor Debug Interface - IEEE 1149.1-2001 standard IEEE Standard Test Access Port and Boundary-Scan Architecture # 1 Introduction # 1.1 The SPC56xP60x/54x microcontroller family The SPC56xP60x/54x microcontroller is built on the Power Architecture<sup>®</sup> platform and targets chassis market segment, specifically the airbag application space. The Power Architecture based 32-bit microcontrollers represent the latest achievement in integrated automotive application controllers. SPC56xP60x/54x devices are built around a dual-core platform for optimized performance-power consumption trade-off but is available also as single-core version. The core selected for the device is the Harvard bus interface version of the e200z0h to cover the low-end chassis application space. The e200 processor family is a set of CPU cores that implement low-cost versions of the Power Architecture technology. The e200 processors are designed for deeply embedded control applications that require low cost solutions rather than maximum performance. The e200z0h processor integrates an integer execution unit, branch control unit, instruction fetch and load/store units, and a multi-ported register file capable to sustaining three read and two write operations per clock. Most integer instructions execute in a single clock cycle. Branch target prefetching is performed by branch unit to allow single-cycle branches in some cases. The e200z0h core is a single-issue, 32-bit Power Architecture technology VLE only design with 32-bit general purpose registers (GPRs). All arithmetic instructions that execute in the core operate on data in the general purpose registers (GPRs). Instead of the base Power Architecture instruction set support, the e200z0h core only implements the VLE (variable length encoding) APU, providing improved code density. The SPC56xP60x/54x has a single level of memory hierarchy consisting of 80 KB on-chip SRAM and 1088 KB (1024 KB program + 64 KB data) of on-chip flash memory. Both the SRAM and the flash memory can hold instructions and data. The timer functions of SPC56xP60x/54x are performed by the eTimer Modular Timer System. The two eTimer modules implement enhanced timer features (six channels each for a total of 12) including dedicated motor control quadrature decode functionality and DMA support. Off-chip communication is performed by a suite of serial protocols including FlexRay, CANs, enhanced SPIs (DSPI), and SCIs (LINFlex). The System Integration Unit Lite (SIUL) performs several chip-wide configuration functions. Pad configuration and general-purpose input/output (GPIO) are controlled from the SIUL. External interrupts and reset control are also found in the SIUL. The internal multiplexer sub-block (IOMUX) provides multiplexing of daisy chaining the DSPIs and external interrupt signal. As the SPC56xP60x/54x is built on a wider legacy of Power Architecture-based devices, when applicable and possible, reusing or enhancement of existing IP, design and concepts is adopted. # 1.2 Application examples *Figure 1* outlines a typical airbag application built around the SPC56xP60x/54x microcontroller. 52/1102 DocID018714 Rev 5 Figure 1. Airbag application # 1.3 SPC56xP60x/54x Device Summary *Table 1* provides a summary of different members of the SPC56xP60x/54x family and their features—relative to Enhanced Full-featured version—to enable a comparison among the family members and an understanding of the range of functionality offered within this family. **Feature** SPC560P54x SPC560P60x SPC56AP54x SPC56AP60x Code Flash memory (with ECC) 768 KB 768 KB 1 MB 1 MB Data Flash / EE (with ECC) 64 KB SRAM (with ECC) 64 KB 80 KB 64 KB 80 KB 32-bit e200z0h 32-bit Dual e200z0h Processor core Instruction set **VLE** 0-64 MHz CPU performance FMPLL (frequency-modulated phase-1 locked loop) modules INTC (interrupt controller) channels 148 PIT (periodic interrupt timer) 1 (includes four 32-bit timers) Enhanced DMA (direct memory 16 access) channels FlexRay Yes (64 message buffer) Table 1. SPC56xP60x/54x device comparison Table 1. SPC56xP60x/54x device comparison(Continued) | | Feature | SPC560P54x | SPC560P60x | SPC56AP54x | SPC56AP60x | |-----------------------------------------------------|-------------------------------------|------------------------------------------------------|--------------------|------------|-----------------------------------------------| | FlexCAN (controller area network) | | 3 <sup>(1)</sup> ,(2) | | | I | | Safety port | | Yes (via third FlexCAN module) | | | | | FCCU (fault collection and control unit) | | Yes <sup>(3)</sup> | | | | | CTU (cross triggering unit) | | Yes | | | | | eTimer chani | nels | 2 × 6 | | | | | FlexPWM (pulse-width modulation) channels | | No | | | | | Analog-to-digital converters (ADC) | | One (10-bit, 27-channel) <sup>(4)</sup> | | | | | LINFlex modules | | 2 (1 × Master/Slave, 1 × Master only) <sup>(5)</sup> | | | | | DSPI (deserial serial peripheral interface) modules | | 5 <sup>(6)</sup> | | | | | CRC (cyclic redundancy check) units | | 2 <sup>(7)</sup> | | | | | JTAG interface | | Yes | | | | | Nexus port controller (NPC) | | Yes (Level 2+) <sup>(8)</sup> | | | | | | Digital power supply <sup>(9)</sup> | 3.3 V or 5 V single supply with external transistor | | nsistor | | | Cupply | Analog power supply | 3.3 V or 5 V | | | | | Supply | Internal RC oscillator | 16 MHz | | | | | | External crystal oscillator | 4–40 MHz | | | | | Packages | | | LQFP100<br>LQFP144 | | LQFP100<br>LQFP144<br>LQFP176 <sup>(10)</sup> | | Temperature | Standard ambient temperature | –40 to 125 °C | | | | - 1. Each FlexCAN module has 32 message buffers. - 2. One FlexCAN module can act as a Safety Port with a bit rate as high as 7.5 Mbit/s. - 3. Enhanced FCCU version. - Same amount of ADC channels as on SPC560P44/50 not considering the internally connected ones. 26 channels on LQFP144 and 16 channels on LQFP100. - 5. LinFlex\_1 is Master Only. 54/1102 - 6. Increased number of CS for DSPI\_1. - 7. Upgraded specification with addition of 8-bits polynomial (CRC-8 VDA CAN) support and 3rd context. - 8. Improved debugging capability with data trace capability and increased Nexus throughput available on emulation package. - 9. 3.3 V range and 5 V range correspond to different orderable parts. - 10. Software development package only. Not available for production. SPC56xP60x/54x is present on the market in three different options enabling different features: Enhanced Full-featured, Full-featured, and Airbag configuration. *Table 2* shows the main differences between the three versions. Table 2. SPC56xP60x/54x device configuration difference | Feature | Enhanced<br>Full-featured | Full-featured | Airbag | |-----------------------------------------------------|---------------------------|---------------|--------| | FlexCAN (controller area network) | 3 | 2 | 2 | | CTU (cross triggering unit) | Ye | es | No | | FlexRay | Yes (64 mes | sage buffer) | No | | DSPI (deserial serial peripheral interface) modules | ţ | 5 | 4 | | CRC (cyclic redundancy check) unit | 2 | 2 | 1 | # 1.4 Device block diagram Figure 2 shows a top-level block diagram of the SPC56xP60x/54x MCU. Table 3 summarizes the functions of the blocks. Figure 2. SPC56xP60x/54x block diagram Table 3. SPC56xP60x/54x series block summary | Block | Function | |---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Analog-to-digital converter (ADC) | Multi-channel, 10-bit analog-to-digital converter | | Boot assist module (BAM) | Block of read-only memory containing VLE code which is executed according to the boot mode of the device | | Clock generation module (MC_CGM) | Provides logic and control required for the generation of system and peripheral clocks | | Controller area network (FlexCAN) | Supports the standard CAN communications protocol | | Cross triggering unit (CTU) | Enables synchronization of ADC conversions with a timer event from the eMIOS or from the PIT | | Crossbar switch (XBAR) | Supports simultaneous connections between two master ports and three slave ports. The crossbar supports a 32-bit address bus width and a 32-bit data bus width. | | Cyclic redundancy checker (CRC) unit | Is dedicated to the computation of CRC off-loading the CPU. Each context has a separate CRC computation engine in order to allow the concurrent computation of the CRC of multiple data streams. | | Deserial serial peripheral interface (DSPI) | Provides a synchronous serial interface for communication with external devices | | Enhanced direct memory access (eDMA) | Performs complex data transfers with minimal intervention from a host processor via "n" programmable channels | | Enhanced timer (eTimer) | Provides enhanced programmable up/down modulo counting | | Error correction status module (ECSM) | Provides a myriad of miscellaneous control functions for the device including program-visible information about configuration and revision levels, a reset status register, wakeup control for exiting sleep modes, and optional features such as information on memory errors reported by error-correcting codes | | External oscillator (XOSC) | Provides an output clock used as input reference for FMPLL_0 or as reference clock for specific modules depending on system needs | | Fault collection and control unit (FCCU) | Provides functional safety to the device | | Flash memory | Provides non-volatile storage for program code, constants and variables | | FlexRay (FlexRay communication controller) | Provides high-speed distributed control for advanced automotive applications | | Frequency-modulated phase-<br>locked loop (FMPLL) | Generates high-speed system clocks and supports programmable frequency modulation | | Interrupt controller (INTC) | Provides priority-based preemptive scheduling of interrupt requests | | JTAG controller | Provides the means to test chip functionality and connectivity while remaining transparent to system logic when not in test mode | | LINFlex controller | Manages a high number of LIN (Local Interconnect Network protocol) messages efficiently with a minimum of CPU load | | Mode entry module (MC_ME) | Provides a mechanism for controlling the device operational mode and mode transition sequences in all functional states; also manages the power control unit, reset generation module and clock generation module, and holds the configuration, control and status registers accessible for applications | Table 3. SPC56xP60x/54x series block summary(Continued) | Block | Function | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Peripheral bridge (PBRIDGE) | Is the interface between the system bus and on-chip peripherals | | Periodic interrupt timer (PIT) | Produces periodic interrupts and triggers | | Power control unit (MC_PCU) | Reduces the overall power consumption by disconnecting parts of the device from the power supply via a power switching device; device components are grouped into sections called "power domains" which are controlled by the PCU | | Reset generation module (MC_RGM) | Centralizes reset sources and manages the device reset sequence of the device | | Semaphore unit (SEMA4) | Provides the hardware support needed in multi-core systems for implementing semaphores and provide a simple mechanism to achieve lock/unlock operations via a single write access | | Static random-access memory (SRAM) | Provides storage for program code, constants, and variables | | System integration unit lite (SIUL) | Provides control over all the electrical pad controls and up 32 ports with 16 bits of bidirectional, general-purpose input and output signals and supports up to 32 external interrupts with trigger event configuration | | System status and configuration module (SSCM) | Provides system configuration and status data (such as memory size and status, device mode and security status), device identification data, debug status port enable and selection, and bus and peripheral abort enable/disable | | System timer module (STM) | Provides a set of output compare events to support AUTOSAR <sup>(1)</sup> and operating system tasks | | System watchdog timer (SWT) | Provides protection from runaway code | | Wakeup unit (WKPU) | Supports up to 18 external sources that can generate interrupts or wakeup events, of which 1 can cause non-maskable interrupt requests or wakeup events. | <sup>1.</sup> AUTOSAR: AUTomotive Open System ARchitecture (see autosar.org web site). # 1.5 Critical performance parameters - Fully static operation, 0 64 MHz - -40 °C to 150 °C junction temperature - Low power design - Dynamic clock gating of core and peripherals - Software controlled clock gating of peripherals - HALT and STOP mode available for power reduction - Fabricated in 90 nm process - 1.2 V nominal internal logic - Nexus pins operate at V<sub>DDIO</sub> (no dedicated power supply) - Unused pins configurable as GPIO - 10-bit ADC conversion time < 1 μs - Internal voltage regulator (VREG) with external ballast transistor enables control with a single input rail - 3.0 V–3.6 V or 4.5 V–5.5 V input supply voltage - Configurable pins - Selectable slew rate for EMI reduction - Selectable pull-up, pull-down, or no pull on all pins - Selectable open drain - Support for 3.3 V or 5 V I/O levels # 1.6 Feature summary On-chip modules available within the family include the following features: - 64 MHz, dual issue, 32-bit CPU core complex (e200z0h) - Compliant with Power Architecture<sup>®</sup> embedded category - Variable Length Encoding (VLE) - Memory organization - Up to 1024 KB on-chip code Flash memory with additional 64 KB for EEPROM emulation (data flash), with ECC, with erase/program controller - Up to 80 KB on-chip SRAM with ECC - Fail safe protection - ECC protection on system SRAM and Flash - Safety port - SWT with servicing sequence pseudo-random generator - Power management - Non-maskable interrupt for both cores - Fault collection and control unit (FCCU) - Safe mode of system-on-chip (SoC) - Register protection scheme - Nexus<sup>®</sup> L2+ interface - Single 3.3 V or 5 V supply for I/Os and ADC - 2 on-platform peripherals set with 2 INTC - 16-channel eDMA controller with multiple transfer request sources - General purpose I/Os (80 GPIO + 26 GPI on LQFP144; 49 GPIO + 16 GPI on LQFP100) - 2 general purpose eTimer units - 6 timers, each with up/down count capabilities - 16-bit resolution, cascadeable counters - Quadrature decode with rotation direction flag - Double buffer input capture and output compare - · Communications interfaces - 2 LINFlex modules (LIN 2.1) - 5 DSPI modules with automatic chip select generation - 2 FlexCAN interfaces (2.0B Active) with 32 message buffers - 1 Safety port based on FlexCAN; usable as third CAN when not used as safety port - 1 FlexRay<sup>™</sup> module (V2.1) with dual or single channel, 64 message buffers and up to 10 Mbit/s - 2 CRC units with three contexts and 3 hardwired polynomials(CRC8,CRC32 and CRC-16-CCITT) - 10-bit A/D converter - 27 input channels and pre-sampling feature - Conversion time < 1 μs including sampling time at full precision</li> 60/1102 DocID018714 Rev 5 - Programmable cross triggering unit (CTU) - 4 analog watchdog with interrupt capability - On-chip CAN/UART Bootstrap loader with boot assist module (BAM) - Ambient temperature ranges: –40 to 125 °C or –40 to 105 °C #### 1.7 Features details # 1.7.1 High performance e200z0h core processor The e200z0h Power Architecture core provides the following features: - High performance e200z0 core processor for managing peripherals and interrupts - Single issue 4-stage pipeline in-order execution 32-bit Power Architecture CPU - Harvard architecture - Variable length encoding (VLE), allowing mixed 16-bit and 32-bit instructions - Results in smaller code size footprint - Minimizes impact on performance - Branch processing acceleration using lookahead instruction buffer - Load/store unit - 1-cycle load latency - Misaligned access support - No load-to-use pipeline bubbles - Thirty-two 32-bit general purpose registers (GPRs) - Separate instruction bus and load/store bus Harvard architecture - Hardware vectored interrupt support - Reservation instructions for implementing read-modify-write constructs - Long cycle time instructions, except for guarded loads, do not increase interrupt latency - Extensive system development support through Nexus debug port - Non maskable Interrupt support ### 1.7.2 Crossbar switch (XBAR) The XBAR multi-port crossbar switch supports simultaneous connections between six master ports and six slave ports. The crossbar supports a 32-bit address bus width and a 32-bit data bus width. The crossbar allows for two concurrent transactions to occur from any master port to any slave port; but one of those transfers must be an instruction fetch from internal flash memory. If a slave port is simultaneously requested by more than one master port, arbitration logic selects the higher priority master and grant it ownership of the slave port. All other masters requesting that slave port are stalled until the higher priority master completes its transactions. Requesting masters are treated with equal priority and will be granted access to a slave port in round-robin fashion, based upon the ID of the last master to be granted access. The crossbar provides the following features: - 6 master ports: - 2 e200z0 core complex Instruction ports - 2 e200z0 core complex Load/Store Data ports - eDMA - FlexRay - 6 slave ports: - 2 Flash memory (code flash and data flash) - 2 SRAM (48 KB + 32 KB) - 2 PBRIDGE - 32-bit internal address, 32-bit internal data paths - Fixed Priority Arbitration based on Port Master - Temporary dynamic priority elevation of masters # 1.7.3 Enhanced direct memory access (eDMA) The enhanced direct memory access (eDMA) controller is a second-generation module capable of performing complex data movements via 16 programmable channels, with minimal intervention from the host processor. The hardware micro architecture includes a DMA engine which performs source and destination address calculations, and the actual data movement operations, along with an SRAM-based memory containing the transfer control descriptors (TCD) for the channels. This implementation is utilized to minimize the overall block size. The eDMA module provides the following features: - 16 channels support independent 8, 16 or 32-bit single value or block transfers - Supports variable sized queues and circular queues - Source and destination address registers are independently configured to postincrement or remain constant - Each transfer is initiated by a peripheral, CPU, or eDMA channel request - Each eDMA channel can optionally send an interrupt request to the CPU on completion of a single value or block transfer - DMA transfers possible between system memories, DSPIs, ADC, eTimer and CTU - Programmable DMA Channel Multiplexer for assignment of any DMA source to any available DMA channel with up to 30 potential request sources - eDMA abort operation through software #### 1.7.4 On-chip flash memory with ECC The SPC56xP60x/54x provides up to 1024 KB of programmable, non-volatile, flash memory. The non-volatile memory (NVM) can be used for instruction and/or data storage. The flash memory module interfaces the system bus to a dedicated flash memory array controller. It supports a 32-bit data bus width at the system bus port, and a 128-bit read data interface to flash memory. The module contains a four-entry, 4x128-bit prefetch buffers. Prefetch buffer hits allow no-wait responses. Normal flash memory array accesses are registered and are forwarded to the system bus on the following cycle, incurring 2 wait states. 62/1102 DocID018714 Rev 5 The flash memory module provides the following features: - Up to 1024 KB flash memory - 14 blocks (2×16 KB + 2×32 KB + 2×16 KB + 2×64 KB + 6×128 KB) code flash - 4 blocks (16 KB + 16 KB + 16 KB + 16 KB) data flash - Full Read While Write (RWW) capability between code and data flash - Four 128-bit wide prefetch buffers to provide single cycle in-line accesses (prefetch buffers can be configured to prefetch code or data or both) - Typical flash memory access time: 0 wait states for buffer hits, 2 wait states for page buffer miss at 64 MHz - Hardware managed flash memory writes handled by 32-bit RISC Krypton engine - Hardware and software configurable read and write access protections on a per-master basis. - Configurable access timing allowing use in a wide range of system frequencies. - Multiple-mapping support and mapping-based block access timing (0–31 additional cycles) allowing use for emulation of other memory types. - Software programmable block program/erase restriction control. - Erase of selected block(s) - Read page size of 128 bits (4 words) - 64-bit ECC with single-bit correction, double-bit detection for data integrity - Embedded hardware program and erase algorithm - Erase suspend, program suspend and erase-suspended program - Censorship protection scheme to prevent flash memory content visibility - Hardware support for EEPROM emulation #### 1.7.5 On-chip SRAM with ECC The SPC56xP60x/54x SRAM module provides a general-purpose memory of up to 80 KB. The SRAM module provides the following features: - Supports read/write accesses mapped to the SRAM memory from any master - Up to 80 KB general purpose RAM - 2 blocks (48 KB + 32 KB) - Supports byte (8-bit), half word (16-bit), and word (32-bit) writes for optimal use of memory - Typical SRAM access time: 0 wait state for reads and 32-bit writes; 1 wait state for 8and 16-bit writes if back to back with a read to same memory block ### 1.7.6 Interrupt controller (INTC) The INTC (interrupt controller) provides priority-based preemptive scheduling of interrupt requests, suitable for statically scheduled hard real-time systems. For high priority interrupt requests, the time from the assertion of the interrupt request from the peripheral to when the processor is executing the interrupt service routine (ISR) has been minimized. The INTC provides a unique vector for each interrupt request source for quick determination of which ISR needs to be executed. It also provides an ample number of priorities so that lower priority ISRs do not delay the execution of higher priority ISRs. To allow the appropriate priorities for each source of interrupt request, the priority of each interrupt request is software configurable. When multiple tasks share a resource, coherent accesses to that resource need to be supported. The INTC supports the priority ceiling protocol for coherent accesses. By providing a modifiable priority mask, the priority can be raised temporarily so that all tasks which share the resource can not preempt each other. The INTC provides the following features: - Unique 9-bit vector for each separate interrupt source - 8 software triggerable interrupt sources - 16 priority levels with fixed hardware arbitration within priority levels for each interrupt source - Ability to modify the ISR or task priority. - Modifying the priority can be used to implement the Priority Ceiling Protocol for accessing shared resources. - 2 external high priority interrupts directly accessing the main core and IOP critical interrupt mechanism The INTC module is replicated for each processor. ## 1.7.7 System clocks and clock generation The following list summarizes the system clock and clock generation on the SPC56xP60x/54x: - Lock detect circuitry continuously monitors lock status - Loss of clock (LOC) detection for PLL outputs - Programmable output clock divider (÷1, ÷2, ÷4, ÷8) - Programmable output clock divider (÷1, ÷2, ÷3 to ÷256) - eTimer module running at the same frequency as the e200z0h core - On-chip oscillator with automatic level control - Internal 16 MHz RC oscillator for rapid start-up and safe mode - Supports frequency trimming by user application #### 1.7.8 Frequency modulated phase-locked loop (FMPLL) The FMPLL allows the user to generate high speed system clocks from a 4 MHz to 40 MHz input clock. Further, the FMPLL supports programmable frequency modulation of the system clock. The FMPLL multiplication factor, output clock divider ratio are all software configurable. The FMPLL has the following major features: - Input clock frequency from 4 MHz to 40 MHz - Voltage controlled oscillator (VCO) range from 256 MHz to 512 MHz - Reduced frequency divider (RFD) for reduced frequency operation without forcing the PLL to relock - Modulation enabled/disabled through software - Triangle wave modulation - Programmable modulation depth (±0.25% to ±4% deviation from center frequency) - Programmable modulation frequency dependent on reference frequency - Self-clocked mode (SCM) operation #### 1.7.9 Main oscillator The main oscillator provides these features: - Input frequency range 4 MHz to 40 MHz - Crystal input mode or Oscillator input mode - PLL reference #### 1.7.10 Internal RC oscillator This device has an RC ladder phase-shift oscillator. The architecture uses constant current charging of a capacitor. The voltage at the capacitor is compared by the stable bandgap reference voltage. The RC Oscillator provides these features: - Nominal frequency 16 MHz - ±5% variation over voltage and temperature after process trim - Clock output of the RC oscillator serves as system clock source in case loss of lock or loss of clock is detected by the PLL - RC oscillator is used as the default system clock during startup ## 1.7.11 Periodic interrupt timer (PIT) The PIT module implements these features: - Up to four general purpose interrupt timers - 32-bit counter resolution - Clocked by system clock frequency - Each channel can be used as trigger for a DMA request # 1.7.12 System timer module (STM) The STM module implements these features: - 32-bit up counter with 8-bit prescaler - Four 32-bit compare channels - Independent interrupt source for each channel - Counter can be stopped in debug mode The STM module is replicated for each processor. ### 1.7.13 Software watchdog timer (SWT) The SWT has the following features: - Fault tolerant output - Safe internal RC oscillator as reference clock - Windowed watchdog - Program flow control monitor with 16-bit pseudorandom key generation The SWT module is replicated for each processor. #### 1.7.14 Fault collection and control unit (FCCU) The FCCU provides an independent fault reporting mechanism even if the CPU is exhibiting unstable behaviors. The FCCU module has the following features: - Redundant collection of hardware checker results - Redundant collection of error information and latch of faults from critical modules on the device - Collection of self-test results - Configurable and graded fault control - Internal reactions (no internal reaction, IRQ) - External reaction (failure is reported to the external/surrounding system via configurable output pins) ## 1.7.15 System integration unit (SIUL) The SPC56xP60x/54x SIUL controls MCU pad configuration, external interrupts, general purpose I/O (GPIO) pin configuration, and internal peripheral multiplexing. The pad configuration block controls the static electrical characteristics of I/O pins. The GPIO block provides uniform and discrete input/output control of the I/O pins of the MCU. The SIUL provides the following features: - Centralized general purpose input output (GPIO) control of input/output pins and analog input-only pads (package dependent) - All GPIO pins can be independently configured to support pull-up, pull down, or no pull - Reading and writing to GPIO supported both as individual pins and 16-bit wide ports - All peripheral pins (except ADC channels) can be alternatively configured as both general purpose input or output pins - ADC channels support alternative configuration as general purpose inputs - Direct readback of the pin value is supported on all pins through the SIU - Configurable digital input filter that can be applied to some general purpose input pins for noise elimination - Up to 4 internal functions can be multiplexed onto one pin ### 1.7.16 Boot and censorship Different booting modes are available in the SPC56xP60x/54x: - From internal flash memory - Via a serial link 66/1102 DocID018714 Rev 5 The default booting scheme is the one which uses the internal flash memory (an internal pull-down is used to select this mode). The alternate option allows the user to boot via FlexCAN or LINFlex (using the boot assist module software). A censorship scheme is provided to protect the contents of the flash memory and offer increased security for the entire device. A password mechanism is designed to grant the legitimate user access to the non-volatile memory. #### 1.7.16.1 Boot assist module (BAM) The BAM is a block of read-only one-time programmed memory and is identical for all SPC56xP60x/54x devices that are based on the e200z0h core. The BAM program is executed every time the device is powered on if the alternate boot mode has been selected by the user. The BAM provides the following features: - Serial bootloading via FlexCAN or LINFlex - BAM can accept a password via the used serial communication channel to grant the legitimate user access to the non-volatile memory # 1.7.17 Error correction status module (ECSM) The ECSM on this device features the following: - Platform configuration and revision - ECC error reporting for flash memory and SRAM - ECC error injection for SRAM The ECSM module is replicated for each processor. #### 1.7.18 FlexCAN The FlexCAN module is a communication controller implementing the CAN protocol according to Bosch Specification version 2.0B. The CAN protocol was designed to be used primarily as a vehicle serial data bus, meeting the specific requirements of this field: real-time processing, reliable operation in the EMI environment of a vehicle, cost-effectiveness and required bandwidth. FlexCAN module contains 32 message buffers. The FlexCAN module provides the following features: - Full implementation of the CAN protocol specification, Version 2.0B - Standard data and remote frames - Extended data and remote frames - 0 to 8 bytes data length - Programmable bit rate as fast as 1 Mbit/s - 32 message buffers of 0 to 8 bytes data length - Each message buffer configurable as Rx or Tx, all supporting standard and extended messages - Programmable loop-back mode supporting self-test operation - 3 programmable mask registers - Programmable transmit-first scheme: lowest ID or lowest buffer number - Time stamp based on 16-bit free-running timer - Global network time, synchronized by a specific message - Maskable interrupts - Independent of the transmission medium (an external transceiver is assumed) - High immunity to EMI - Short latency time due to an arbitration scheme for high-priority messages - Transmit features - Supports configuration of multiple mailboxes to form message queues of scalable depth - Arbitration scheme according to message ID or message buffer number - Internal arbitration to guarantee no inner or outer priority inversion - Transmit abort procedure and notification - Receive features - Individual programmable filters for each mailbox - 8 mailboxes configurable as a six-entry receive FIFO - 8 programmable acceptance filters for receive FIFO - Programmable clock source - System clock - Direct oscillator clock to avoid PLL jitter ## 1.7.19 Safety port (FlexCAN) The SPC56xP60x/54x MCU has a second CAN controller synthesized to run at high bit rates to be used as a safety port. The CAN module of the safety port provides the following features: - Identical to the FlexCAN module - Bit rate as fast as 7.5 Mb at 60 MHz CPU clock using direct connection between CAN modules (no physical transceiver required) - 32 Message buffers of 0 to 8 bytes data length - Can be used as a third independent CAN module # 1.7.20 FlexRay The FlexRay module provides the following features: - Full implementation of FlexRay Protocol Specification 2.1 - 64 configurable message buffers can be handled - Dual channel or single channel mode of operation, each as fast as 10 Mbit/s data rate - Message buffers configurable as Tx, Rx or RxFIFO - Message buffer size configurable - Message filtering for all message buffers based on FrameID, cycle count and message ID - Programmable acceptance filters for RxFIFO message buffers 57 ### 1.7.21 Serial communication interface module (LINFlex) The LINFlex on the SPC56xP60x/54x features the following: Supports LIN Master mode (on both modules), LIN Slave mode (on one module) and UART mode - LIN state machine compliant to LIN1.3, 2.0, and 2.1 Specifications - Handles LIN frame transmission and reception without CPU intervention - LIN features - Autonomous LIN frame handling - Message buffer to store Identifier and up to 8 data bytes - Supports message length as long as 64 bytes - Detection and flagging of LIN errors: Sync field; Delimiter; ID parity; Bit; Framing; Checksum and Time-out errors - Classic or extended checksum calculation - Configurable Break duration as long as 36-bit times - Programmable Baud rate prescalers (13-bit mantissa, 4-bit fractional) - Diagnostic features: Loop back; Self Test; LIN bus stuck dominant detection - Interrupt-driven operation with 16 interrupt sources - LIN slave mode features - Autonomous LIN header handling - Autonomous LIN response handling - UART mode - Full-duplex operation - Standard non return-to-zero (NRZ) mark/space format - Data buffers with 4-byte receive, 4-byte transmit - Configurable word length (8-bit or 9-bit words) - Error detection and flagging - Parity, Noise and Framing errors - Interrupt-driven operation with four interrupt sources - Separate transmitter and receiver CPU interrupt sources - 16-bit programmable baud-rate modulus counter and 16-bit fractional - 2 receiver wake-up methods # 1.7.22 Deserial serial peripheral interface (DSPI) The deserial serial peripheral interface (DSPI) module provides a synchronous serial interface for communication between the SPC56xP60x/54x MCU and external devices. The DSPI modules provide these features: - Full duplex, synchronous transfers - Master or slave operation - Programmable master bit rates - · Programmable clock polarity and phase - End-of-transmission interrupt flag - Programmable transfer baud rate - Programmable data frames from 4 to 16 bits - Up to 28 chip select lines available - 8 each on DSPI\_0 and DSPI\_1 - 4 each on DSPI\_2, DSPI\_3, and DSPI\_4 - 8 clock and transfer attributes registers - Chip select strobe available as alternate function on one of the chip select pins for deglitching - FIFOs for buffering up to 5 transfers on the transmit and receive side - Queueing operation possible through use of the eDMA - General purpose I/O functionality on pins when not used for SPI #### 1.7.23 eTimer Two eTimer modules are provided, each with six 16-bit general purpose up/down timer/counter per module. The following features are implemented: - Individual channel capability - Input capture trigger - Output compare - Double buffer (to capture rising edge and falling edge) - Separate prescaler for each counter - Selectable clock source - 0% to 100% pulse measurement - Rotation direction flag (Quad decoder mode) - Maximum count rate - Equals peripheral clock/2 for external event counting - Equals peripheral clock for internal clock counting - Cascadeable counters - Programmable count modulo - Quadrature decode capabilities - Counters can share available input pins - · Count once or repeatedly - Preloadable counters - Pins available as GPIO when timer functionality not in use #### 1.7.24 Analog-to-digital converter (ADC) The ADC module provides the following features: 70/1102 DocID018714 Rev 5 #### Analog part: - 1 on-chip analog-to-digital converter - 10-bit AD resolution - 1 sample and hold unit per ADC - Conversion time, including sampling time, less than 1 μs (at full precision) - Typical sampling time is 150 ns min. (at full precision) - Differential non-linearity error (DNL) ±1 LSB - Integral non-linearity error (INL) ±1.5 LSB - Total unadjusted error (TUE) <3 LSB</li> - Single-ended input signal range from 0 to 3.3 V / 5.0 V - The ADC and its reference can be supplied with a voltage independent from V<sub>DDIO</sub> - The ADC supply can be equal or higher than V<sub>DDIO</sub> - The ADC supply and the ADC reference are not independent from each other (they are internally bonded to the same pad) - Sample times of 2 (default), 8, 64, or 128 ADC clock cycles #### Digital part: - 27 input channels (26 + 1 internally connected) - 4 analog watchdogs to compare ADC results against predefined levels (low, high, range) before results are stored - 2 modes of operation: Normal mode or CTU control mode - Normal mode features - Register-based interface with the CPU: control reg., status reg., 1 result register per channel - ADC state machine managing 3 request flows: regular command, hardware injected command, software injected command - Selectable priority between software and hardware injected commands - DMA compatible interface - CTU control mode features - Triggered mode only - 4 independent result queues (2 × 16 entries, 2 × 4 entries) - Result alignment circuitry (left justified; right justified) - 32-bit read mode allows to have channel ID on one of the 16-bit part - DMA compatible interfaces ### 1.7.25 Cross triggering unit (CTU) The Cross Triggering Unit (CTU) allows automatic generation of ADC conversion requests on user selected conditions with minimized CPU load for dynamic configuration. It implements the following features: Double buffered trigger generation unit with up to eight independent triggers generated from external triggers - Trigger generation unit configurable in sequential mode or in triggered mode - Each Trigger can be appropriately delayed to compensate the delay of external low pass filter - Double buffered global trigger unit allowing eTimer synchronization and/or ADC command generation - Double buffered ADC command list pointers to minimize ADC-trigger unit update - Double buffered ADC conversion command list with up to 24 ADC commands - Each trigger has the capability to generate consecutive commands - ADC conversion command allows to control ADC channel from each ADC, single or synchronous sampling, independent result queue selection # 1.7.26 Cyclic redundancy check (CRC) - 3 contexts for the concurrent CRC computation - Separate CRC engine for each context - Zero-wait states during the CRC computation (pipeline scheme) - 3 hard-wired polynomials (CRC-8 VDA CAN, CRC-32 Ethernet and CRC-16-CCITT) - Support for byte/half-word/word width of the input data stream - Support for expected and actual CRC comparison # 1.7.27 Nexus development interface (NDI) The NDI block provides real-time development support capabilities for the SPC56xP60x/54x Power Architecture based MCU in compliance with the IEEE-ISTO 5001-2003 standard. This development support is supplied for MCUs without requiring external address and data pins for internal visibility. The NDI block is an integration of several individual Nexus blocks that are selected to provide the development support interface for this device. The NDI block interfaces to the host processor and internal buses to provide development support as per the IEEE-ISTO 5001-2003 Class 2+ standard. The development support provided includes access to the MCU's internal memory map and access to the processor's internal registers during run time. The Nexus Interface provides the following features: - Configured via the IEEE 1149.1 - All Nexus port pins operate at V<sub>DDIO</sub> (no dedicated power supply) - Nexus 2+ features supported - Static debug - Watchpoint messaging - Ownership trace messaging - Program trace messaging - Real time read/write of any internally memory mapped resources through JTAG pins 72/1102 DocID018714 Rev 5 RM0083 Introduction Overrun control, which selects whether to stall before Nexus overruns or keep executing and allow overwrite of information - Watchpoint triggering, watchpoint triggers program tracing - DDR - Auxiliary Output Port - 4 MDO (Message Data Out) pins - MCKO (Message Clock Out) pin - 2 MSEO (Message Start/End Out) pins - EVTO (Event Out) pin - Auxiliary Input Port - EVTI (Event In) pin<sup>(a)</sup> ### 1.7.28 IEEE 1149.1 (JTAG) controller The JTAG controller (JTAGC) block provides the means to test chip functionality and connectivity while remaining transparent to system logic when not in test mode. All data input to and output from the JTAGC block is communicated in serial format. The JTAGC block is compliant with the IEEE standard. The JTAG controller provides the following features: - IEEE Test Access Port (TAP) interface with four pins (TDI, TMS, TCK, TDO) - Selectable modes of operation include JTAGC/debug or normal system operation. - A 5-bit instruction register that supports the following IEEE 1149.1-2001 defined instructions: - BYPASS, IDCODE, EXTEST, SAMPLE, SAMPLE/PRELOAD - A 5-bit instruction register that supports the additional following public instructions: - ACCESS\_AUX\_TAP\_NPC, ACCESS\_AUX\_TAP\_CORE0, ACCESS\_AUX\_TAP\_CORE1, ACCESS\_AUX\_TAP\_NASPS\_0, ACCESS\_AUX\_TAP\_NASPS\_1 - Three test data registers: a bypass register, a boundary scan register, and a device identification register. - A TAP controller state machine that controls the operation of the data registers, instruction register and associated circuitry. #### 1.7.29 On-chip voltage regulator (VREG) The on-chip voltage regulator module provides the following features: - Uses external NPN transistor - Regulates external 3.3 V to 5.0 V down to 1.2 V for the core logic - Low voltage detection on the internal 1.2 V and I/O voltage 3.3 V a. At least one TCK clock is necessary for the EVTI signal to be recognized by the MCU. DocID018714 Rev 5 73/1102 Introduction RM0083 ## 1.8 Developer environment The SPC56xP60x/54x MCU tools and third-party developers offer a widespread, established network of tool and software vendors. The device also features a high-performance Nexus debug interface. The following development support will be available: - Automotive Evaluation Boards (EVB) featuring CAN, LIN interfaces, and more - Compilers - Debuggers - JTAG and Nexus interfaces - Autocode generation tools - Initialization tools The following software support will be available: - AUTOSAR<sup>(b)</sup> OS solutions from multiple third parties - LIN drivers - AUTOSAR BSW (Basic Software) Package and Configuration Tool from multiple third parties - Core and peripheral self test(C) b. Automotive Open System Architecture. c. Available in third quarter of 2010. RM0083 Memory Map # 2 Memory Map *Table 4* shows the memory map for the SPC56xP60x/54x. All addresses on the SPC56xP60x/54x, including those that are reserved, are identified in the table. The addresses represent the physical addresses assigned to each region or module name. Table 4. Memory map | Start address | End address | Size<br>(KB) | Region name | |---------------|-------------|--------------|------------------------------------| | | | | On-chip memory | | 0x0000_0000 | 0x0007_FFFF | 512 | Code Flash Array 0 | | 0x0008_0000 | 0x000F_FFFF | 512 | Code Flash Array 1 | | 0x0010_0000 | 0x001F_FFFF | 1024 | Reserved | | 0x0020_0000 | 0x0020_3FFF | 16 | Code Flash Array 0 Shadow Sector | | 0x0020_4000 | 0x003F_FFFF | 2032 | Reserved | | 0x0040_0000 | 0x0040_3FFF | 16 | Code Flash Array 0 Test Sector | | 0x0040_4000 | 0x007F_FFFF | 4080 | Reserved | | 0x0080_0000 | 0x0080_FFFF | 64 | Data Flash Array 0 | | 0x0081_0000 | 0x00C0_1FFF | 4040 | Reserved | | 0x00C0_2000 | 0x00C0_3FFF | 8 | Data Flash Array 0 Test Sector | | 0x00C0_4000 | 0x00FF_FFFF | 4080 | Reserved | | 0x0100_0000 | 0x1FFF_FFFF | 507904 | Flash Emulation Mapping | | 0x2000_0000 | 0x3FFF_FFFF | 524288 | Reserved | | 0x4000_0000 | 0x4000_BFFF | 48 | SRAM <sup>(1)</sup> | | 0x4000_C000 | 0x4FFF_FFFF | 262096 | Reserved | | 0x5000_0000 | 0x5000_7FFF | 32 | SRAM <sup>(1)</sup> | | 0x5000_8000 | 0x7FFF_FFFF | 786368 | Reserved | | | | | On-chip Peripherals <sup>(2)</sup> | | 0x8000_0000 | 0x8FEFFFFF | 261120 | Reserved | | 0x8FF0_0000 | 0x8FF0_3FFF | 16 | Peripheral Bridge (AIPS_1) | | 0x8FF0_4000 | 0x8FF0_FFFF | 48 | Reserved | | 0x8FF1_0000 | 0x8FF1_3FFF | 16 | Memory Protection Unit (MPU_1) | | 0x8FF1_4000 | 0x8FF2_3FFF | 64 | Reserved | | 0x8FF2_4000 | 0x8FF2_7FFF | 16 | Semaphores (SEMA4_1) | | 0x8FF2_8000 | 0x8FF3_7FFF | 64 | Reserved | | 0x8FF3_8000 | 0x8FF3_BFFF | 16 | Software Watchdog (SWT_1) | Memory Map RM0083 Table 4. Memory map(Continued) | Start address | End address | Size<br>(KB) | Region name | |---------------|-------------|--------------|-----------------------------------------------| | 0x8FF3_C000 | 0x8FF3_FFFF | 16 | System Timer Module (STM_1) | | 0x8FF4_0000 | 0x8FF4_3FFF | 16 | Error Correction Status Module (ECSM_1) | | 0x8FF4_4000 | 0x8FF4_7FFF | 16 | Reserved | | 0x8FF4_8000 | 0x8FF4_BFFF | 16 | Interrupt Controller (INTC_1) | | 0x8FF4_C000 | 0x8FF9_FFFF | 336 | Reserved | | 0x8FFA_0000 | 0x8FFA_3FFF | 16 | Deserial Serial Peripheral Interface (DSPI_4) | | 0x8FFA_4000 | 0x8FFC_3FFF | 128 | Reserved | | 0x8FFC_4000 | 0x8FFC_7FFF | 16 | FlexCAN 1 (CAN_1) | | 0x8FFC_8000 | 0x9FE6_BFFF | 260752 | Reserved | | 0x9FE6_C000 | 0x9FE6_FFFF | 16 | Fault Collection and Control Unit (FCCU) | | 0x9FE7_0000 | 0x9FE7_3FFF | 16 | Cyclic Redundancy Check Unit (CRC_1) | | 0x9FE7_4000 | 0xC3F8_7FFF | 590928 | Reserved | | 0xC3F8_8000 | 0xC3F8_BFFF | 16 | Code Flash 0 Configuration (CFLASH0) | | 0xC3F8_C000 | 0xC3F8_FFFF | 16 | Data Flash 0 Configuration (DFLASH0) | | 0xC3F9_0000 | 0xC3F9_3FFF | 16 | System Integration Unit Lite (SIUL) | | 0xC3F9_4000 | 0xC3F9_7FFF | 16 | WakeUp Unit (WKPU) | | 0xC3F9_8000 | 0xC3FD_7FFF | 256 | Reserved | | 0xC3FD_8000 | 0xC3FD_BFFF | 16 | System Status and Configuration Module (SSCM) | | 0xC3FD_C000 | 0xC3FD_FFFF | 16 | Mode Entry Module (MC_ME) | | 0xC3FE_0000 | 0xC3FE_3FFF | 16 | Clock Generation Module (MC_CGM) | | 0xC3FE_4000 | 0xC3FE_7FFF | 16 | Reset Generation Module (MC_RGM) | | 0xC3FE_8000 | 0xC3FE_BFFF | 16 | Power Control Unit (MC_PCU) <sup>(3)</sup> | | 0xC3FE_C000 | 0xC3FE_FFFF | 16 | Reserved | | 0xC3FF_0000 | 0xC3FF_3FFF | 16 | Periodic Interrupt Timer (PIT) | | 0xC3FF_4000 | 0xC3FF_FFFF | 48 | Reserved | | 0xFFE0_0000 | 0xFFE0_3FFF | 16 | Analog-to-digital Converter 0 (ADC_0) | | 0xFFE0_4000 | 0xFFE0_BFFF | 32 | Reserved | | 0xFFE0_C000 | 0xFFE0_FFFF | 16 | СТU_0 | | 0xFFE1_0000 | 0xFFE1_7FFF | 32 | Reserved | | 0xFFE1_8000 | 0xFFE1_BFFF | 16 | eTimer_0 | | 0xFFE1_C000 | 0xFFE1_FFFF | 16 | eTimer_1 | | 0xFFE2_0000 | 0xFFE3_FFFF | 128 | Reserved | | 0xFFE4_0000 | 0xFFE4_3FFF | 16 | LINFlex_0 | | 0xFFE4_4000 | 0xFFE4_7FFF | 16 | LINFlex_1 | RM0083 Memory Map **Table 4. Memory map(Continued)** | | I | Table | : 4. Memory map(Continued) | |---------------|-------------|--------------|-------------------------------------------------| | Start address | End address | Size<br>(KB) | Region name | | 0xFFE5_0000 | 0xFFE6_7FFF | 128 | Reserved | | 0xFFE6_8000 | 0xFFE6_BFFF | 16 | Cyclic Redundancy Check (CRC_0) | | 0xFFE6_C000 | 0xFFE7_FFFF | 80 | Reserved | | 0xFFE8_0000 | 0xFFEF_FFFF | 512 | Mirrored (range 0xC3F8_0000 – 0xC3FF_FFFF) | | 0xFFF0_0000 | 0xFFF0_3FFF | 16 | Peripheral Bridge (AIPS_0) | | 0xFFF0_4000 | 0xFFF0_7FFF | 16 | Crossbar switch (XBAR_0) | | 0xFFF0_8000 | 0xFFF0_FFFF | 32 | Reserved | | 0xFFF1_0000 | 0xFFF1_3FFF | 16 | Memory Protection Unit (MPU_0) | | 0xFFF1_4000 | 0xFFF2_3FFF | 64 | Reserved | | 0xFFF2_4000 | 0xFFF2_7FFF | 16 | Semaphores (SEMA4_0) | | 0xFFF2_8000 | 0xFFF3_7FFF | 64 | Reserved | | 0xFFF3_8000 | 0xFFF3_BFFF | 16 | Software Watchdog Timer (SWT_0) | | 0xFFF3_C000 | 0xFFF3_FFFF | 16 | System Timer Module (STM_0) | | 0xFFF4_0000 | 0xFFF4_3FFF | 16 | Error Correction Status Module (ECSM) | | 0xFFF4_4000 | 0xFFF4_7FFF | 16 | Enhanced Direct Memory Access Controller (eDMA) | | 0xFFF4_8000 | 0xFFF4_BFFF | 16 | Interrupt Controller (INTC_0) | | 0xFFF4_C000 | 0xFFF8_FFFF | 272 | Reserved | | 0xFFF9_0000 | 0xFFF9_3FFF | 16 | DSPI_0 | | 0xFFF9_4000 | 0xFFF9_7FFF | 16 | DSPI_1 | | 0xFFF9_8000 | 0xFFF9_BFFF | 16 | DSPI_2 | | 0xFFF9_C000 | 0xFFF9_FFFF | 16 | DSPI_3 | | 0xFFFA_0000 | 0xFFFB_FFFF | 128 | Reserved | | 0xFFFC_0000 | 0xFFFC_3FFF | 16 | FlexCAN 0 (CAN_0) | | 0xFFFC_4000 | 0xFFFD_BFFF | 96 | Reserved | | 0xFFFD_C000 | 0xFFFD_FFFF | 16 | DMA Channel Mux (DMA_MUX) | | 0xFFFE_0000 | 0xFFFE_3FFF | 16 | FlexRay Controller (FlexRay) | | 0xFFFE_4000 | 0xFFFE_7FFF | 16 | Reserved | | 0xFFFE_8000 | 0xFFFE_BFFF | 16 | Safety Port (FlexCAN) | | 0xFFFE_C000 | 0xFFFF_BFFF | 64 | Reserved | | 0xFFFF_C000 | 0xFFFF_FFFF | 16 | Boot Assist Module (BAM) | | | | | | <sup>1.</sup> For SRAM details please see Chapter 16: Internal Static RAM (SRAM). In order to produce Data Abort exception by accessing to the Reserved blocks inside memory 0x8000\_0000 0xFFFF\_FFFF, the SSCM.ERROR[PAE] bit has to be set to one. See Section 10.2.2.3: Error Configuration (ERROR) register. <sup>3.</sup> This address space contains also VREG registers. See Chapter 36: Voltage Regulators and Power Supplies. # 3 Signal Description This chapter describes the signals of the SPC56xP60x/54x. It includes a table of signal properties and detailed descriptions of signals. # 3.1 176-pin LQFP pinout Figure 3 shows the pinout of the 176-pin LQFP. Figure 3. LQFP176 pinout (top view)<sup>(d)</sup> d. Software development package only. Not available for production. # 3.2 144-pin LQFP pinout Figure 4 shows the pinout of the 144-pin LQFP. Figure 4. LQFP144 pinout (top view)<sup>(e)</sup> ## 3.3 100-pin LQFP pinout Figure 5 shows the pinout of the 100-pin LQFP. 57/ e. Availability of port pin alternate functions depends on product selection. Figure 5. LQFP100 pinout (top view)(f) ## 3.4 Pin descriptions The following sections provide signal descriptions and related information about the functionality and configuration of the SPC56xP60x/54x devices. ### 3.4.1 Power supply and reference voltage pins Table 5 lists the power supply and reference voltage for the SPC56xP60x/54x devices. Pin Supply **LQFP LQFP LQFP Symbol** Description 176<sup>(1)</sup> 100 144 VREG control and power supply pins **BCTRL** Voltage regulator external NPN Ballast base control pin 47 69 $V_{DD\_HV\_REG}$ (3.3 V or Voltage regulator supply voltage 50 72 86 1.2 V decoupling<sup>(2)</sup> pins for core logic supply and voltage regulator feedback. Decoupling capacitor must be connected 48 70 82 V<sub>DD\_LV\_REGCOR</sub> between this pins and V<sub>SS LV REGCOR.</sub> Table 5. Supply pins f. Availability of port pin alternate functions depends on product selection. **Table 5. Supply pins(Continued)** | | Supply | | Pin | | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|----------------------------| | Symbol | Description | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(1)</sup> | | V <sub>SS_LV_REGCOR</sub> | 1.2 V decoupling <sup>(2)</sup> pins for core logic GND and voltage regulator feedback. Decoupling capacitor must be connected between this pins and V <sub>DD_LV_REGCOR</sub> . | 49 | 71 | 85 | | | ADC0 reference and supply voltage | | | | | V <sub>DD_HV_AD</sub> | ADC supply and high reference voltage | 39 | 56 | 64 | | V <sub>SS_HV_AD</sub> | ADC ground and low reference voltage | 40 | 57 | 65 | | | Power supply pins (3.3 V or 5.0 V) | ļ | | | | V <sub>DD_HV_IO0</sub> | Input/Output supply voltage | _ | 6 | 14 | | V <sub>SS_HV_IO0</sub> | Input/Output ground | _ | 7 | 15 | | V <sub>DD_HV_IO1</sub> | Input/Output supply voltage | 13 | 21 | 29 | | V <sub>SS_HV_IO1</sub> | Input/Output ground | 14 | 22 | 30 | | V <sub>DD_HV_IO2</sub> | Input/Output supply voltage | 63 | 91 | 115 | | V <sub>SS_HV_IO2</sub> | Input/Output ground | 62 | 90 | 114 | | V <sub>DD_HV_IO3</sub> | Input/Output supply voltage | 87 | 126 | 150 | | V <sub>SS_HV_IO3</sub> | Input/Output ground | 88 | 127 | 151 | | V <sub>DD_HV_IO4</sub> | Input/Output supply voltage | _ | _ | 169 | | V <sub>SS_HV_IO4</sub> | Input/Output ground | _ | _ | 170 | | V <sub>DD_HV_IO5</sub> | Input/Output supply voltage | _ | _ | 5 | | V <sub>SS_HV_IO5</sub> | Input/Output ground | _ | _ | 6 | | V <sub>DD_HV_IO6</sub> | Input/Output supply voltage | _ | _ | 108 | | V <sub>SS_HV_IO6</sub> | Input/Output ground | _ | _ | 109 | | $V_{DD\_HV\_FL}$ | Code and data flash supply voltage | 69 | 97 | 121 | | V <sub>SS_HV_FL</sub> | Code and data flash supply ground | 68 | 96 | 120 | | $V_{DD\_HV\_OSC}$ | Crystal oscillator amplifier supply voltage | 16 | 27 | 35 | | V <sub>SS_HV_OSC</sub> | Crystal oscillator amplifier ground | 17 | 28 | 36 | | | Power supply pins (1.2 V) | | | | | V <sub>DD_LV_COR0</sub> | 1.2 V Decoupling pins for core logic supply. Decoupling capacitor must be connected between these pins and the nearest V <sub>SS_LV_COR0</sub> pin. | 12 | 18 | 26 | | V <sub>SS_LV_COR0</sub> | 1.2 V Decoupling pins for core logic GND. Decoupling capacitor must be connected between these pins and the nearest V <sub>DD_LV_COR0</sub> pin. | 11 | 17 | 25 | | V <sub>DD_LV_COR1</sub> | 1.2 V Decoupling pins for core logic supply. Decoupling capacitor must be connected between these pins and the nearest $V_{\rm SS\_LV\_COR1}$ pin. | 65 | 93 | 117 | Table 5. Supply pins(Continued) | | Supply | Pin | | | | |-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|----------------------------|--| | Symbol | Description | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(1)</sup> | | | V <sub>SS_LV_COR1</sub> | 1.2 V Decoupling pins for core logic GND. Decoupling capacitor must be connected between these pins and the nearest $V_{DD\_LV\_COR1}$ pin. | 66 | 94 | 118 | | | V <sub>DD_LV_COR2</sub> | 1.2 V Decoupling pins for core logic supply. Decoupling capacitor must be connected between these pins and the nearest $V_{SS\_LV\_COR2}$ pin. | 92 | 131 | 155 | | | V <sub>SS_LV_COR2</sub> | 1.2 V Decoupling pins for core logic GND. Decoupling capacitor must be connected between these pins and the nearest $V_{DD\_LV\_COR\ 2}$ pin. | 93 | 132 | 156 | | | V <sub>DD_LV_COR3</sub> | 1.2 V Decoupling pins for core logic supply. Decoupling capacitor must be connected between these pins and the nearest V <sub>SS_LV_COR3</sub> pin. | 25 | 36 | 44 | | | V <sub>SS_LV_COR3</sub> | 1.2 V Decoupling pins for core logic GND. Decoupling capacitor must be connected between these pins and the nearest $V_{DD\_LV\_COR~3}$ pin. | 24 | 35 | 43 | | <sup>1.</sup> LQFP176 available only as development package. ## 3.4.2 System pins *Table 6* and *Table 7* contain information on pin functions for the SPC56xP60x/54x devices. The pins listed in *Table 6* are single-function pins. The pins shown in *Table 7* are multifunction pins, programmable via their respective Pad Configuration Register (PCR) values. Table 6. System pins | | | | Pad Sp | eed <sup>(1)</sup> | | Pin | | |--------|---------------------------------------------------|----------------|--------|--------------------|-------------|-------------|----------------------------| | Symbol | Description | Direction | SRC=0 | SRC= | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(2)</sup> | | | Dedicated | l pins | | | | | | | MDO0 | Nexus Message Data Output—line 0 | Output<br>Only | Fa | st | _ | 9 | 17 | | MDO4 | Nexus Message Data Output—line 4 Output Only Fast | | | | _ | _ | 7 | | MDO5 | Nexus Message Data Output—line 5 | Output<br>Only | Fast | | _ | _ | 8 | | MDO6 | Nexus Message Data Output—line 6 | Output<br>Only | Fast | | _ | _ | 9 | | MDO7 | Nexus Message Data Output—line 7 | Output<br>Only | Fast | | _ | _ | 110 | | MDO8 | Nexus Message Data Output—line 8 | Output<br>Only | Fa | st | _ | _ | 111 | <sup>2.</sup> See datasheet Voltage Regulator Electrical Characteristics section for more details. Table 6. System pins(Continued) | | Tuble C. Dystelli pi | | Pad Sp | peed <sup>(1)</sup> | | Pin | | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------|---------------------|-------------|-------------|----------------------------| | Symbol | Description | Direction | SRC=0 | SRC= | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(2)</sup> | | MDO9 | Nexus Message Data Output—line 9 | Output<br>Only | Fa | st | _ | _ | 112 | | MDO10 | Nexus Message Data Output—line 10 | Output<br>Only | Fa | ıst | _ | _ | 166 | | MDO11 | Nexus Message Data Output—line 11 | Output<br>Only | Fa | ıst | _ | _ | 171 | | RDY | Nexus ready output | Output<br>Only | _ | _ | _ | _ | 172 | | NMI | Non-Maskable Interrupt | Input Only | _ | _ | 1 | 1 | 1 | | XTAL | Analog output of the oscillator amplifier circuit. Needs to be grounded if oscillator is used in bypass mode. | _ | _ | _ | 18 | 29 | 37 | | EXTAL | Analog input of the oscillator amplifier circuit, when the oscillator is not in bypass mode. Analog input for the clock generator when the oscillator is in bypass mode. | _ | _ | _ | 19 | 30 | 38 | | TMS <sup>(3)</sup> | JTAG state machine control | Input Only | _ | _ | 59 | 87 | 105 | | TCK <sup>(3)</sup> | JTAG clock | Input Only | _ | _ | 60 | 88 | 106 | | TDI <sup>(3)</sup> | JTAG data input | Input Only | _ | _ | 58 | 86 | 104 | | TDO <sup>(3)</sup> | JTAG data output | Output<br>Only | _ | _ | 61 | 89 | 107 | | | Reset | oin | | | | | | | RESET <sup>(4)</sup> | Bidirectional reset with Schmitt trigger characteristics and noise filter | Bidirectiona<br>I | Mediu<br>m | _ | 20 | 31 | 39 | | | Test p | in | | | | | | | V <sub>PP TEST</sub> | Pin for testing purpose only. To be tied to ground in normal operating mode. | _ | _ | _ | 74 | 107 | 131 | | V <sub>REG_BYPASS</sub> | Pin for testing purpose only. To be tied to ground in normal operating mode. | _ | _ | _ | 34 | 51 | 59 | <sup>1.</sup> SRC values refer to the value assigned to the Slew Rate Control bits of the pad configuration register. ## 3.4.3 Pin muxing *Table 7* defines the pin list and muxing for the SPC56xP60x/54x devices relative to Enhanced Full-featured version. <sup>2.</sup> LQFP176 available only as development package. <sup>3.</sup> In this pin there is an internal pull; refer to JTAGC chapter in the device reference manual for pull direction. <sup>4.</sup> Its configuration can be set up by the PCR[108] register inside the SIU module. See Chapter 11: System Integration Unit Lite (SIUL). Each row of *Table 7* shows all the possible ways of configuring each pin, via "alternate functions". The default function assigned to each pin after reset is the ALTO function. Pins marked as external interrupt capable can also be used to resume from STOP and HALT mode. SPC56xP60x/54x devices provide four main I/O pad types depending on the associated functions: - Slow pads are the most common, providing a compromise between transition time and low electromagnetic emission. - *Medium pads* provide fast enough transition for serial communication channels with controlled current to reduce electromagnetic emission. - Fast pads provide maximum speed. They are used for improved NEXUS debugging capability. - Symmetric pads are designed to meet FlexRay requirements. Medium and Fast pads can use slow configuration to reduce electromagnetic emission, at the cost of reducing AC performance. Table 7. Pin muxing<sup>(1)</sup> | Port | PCR | Alternate | | Peripheral | I/O | Pad s | peed <sup>(6)</sup> | | Pin | | |------|---------|------------------------------|-----------|------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | pin | No. | function <sup>(2),</sup> (3) | Functions | (4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | | | Po | ort A | | | | | | | | | ALT0 | GPIO[0] | SIUL | I/O | | | | | | | | PCR[0] | ALT1 | ETC[0] | eTimer_0 | I/O | | | | | | | A[0] | | ALT2 | SCK_2 | DSPI_2 | I/O | Slow | Medium | 51 | 73 | 89 | | | | ALT3 | F[0] | FCCU | 0 | | | | | | | | | _ | EIRQ[0] | SIUL | I | | | | | | | | | ALT0 | GPIO[1] | SIUL | I/O | | | | | | | | | ALT1 | ETC[1] | eTimer_0 | I/O | | | | | | | A[1] | PCR[1] | ALT2 | SOUT_2 | DSPI_2 | 0 | Slow | Medium | 52 | 74 | 90 | | | | ALT3 | F[1] | FCCU | 0 | | | | | | | | | _ | EIRQ[1] | SIUL | 1 | | | | | | | | | ALT0 | GPIO[2] | SIUL | I/O | | | | | | | | | ALT1 | ETC[2] | eTimer_0 | I/O | | | | | | | 101 | | ALT2 | CS3_4 | DSPI_4 | 0 | | | | | | | A[2] | PCR[2] | ALT3 | _ | _ | _ | Slow | Medium | 57 | 84 | 102 | | | | _ | SIN_2 | DSPI_2 | I | | | | | | | | | _ | ABS[0] | MC_RGM | I | | | | | | | | | _ | EIRQ[2] | SIUL | I | | | | | | | | | ALT0 | GPIO[3] | SIUL | I/O | | | | | | | | | ALT1 | ETC[3] | eTimer_0 | I/O | | | | | | | A[3] | PCR[3] | ALT2 | CS0_2 | DSPI_2 | I/O | Slow | Medium | 64 | 92 | 116 | | (8) | i CN[3] | ALT3 | _ | _ | _ | Slow | MEGIUIII | 04 | 32 | 110 | | | | _ | ABS[1] | MC_RGM | 1 | | | | | | | | | _ | EIRQ[3] | SIUL | I | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | | 1/0 | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|------------------------------|-----------|-------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | ALT0 | GPIO[4] | SIUL | I/O | | | | | | | | | ALT1 | ETC[0] | eTimer_1 | I/O | | | | | | | A[4] | PCR[4] | ALT2 | CS1_2 | DSPI_2 | 0 | Slow | Medium | 75 | 108 | 132 | | (0) | . 0.4[.] | ALT3 | ETC[4] | eTimer_0 | I/O | 0.011 | Modiani | , 0 | | .02 | | | | _ | FAB | MC_RGM | I | | | | | | | | | _ | EIRQ[4] | SIUL | I | | | | | | | | | ALT0 | GPIO[5] | SIUL | I/O | | | | | | | | | ALT1 | CS0_1 | DSPI_1 | I/O | | | | | | | A[5] | PCR[5] | ALT2 | ETC[5] | eTimer_1 | I/O | Slow | Medium | 8 | 14 | 22 | | | | ALT3 | CS7_0 | DSPI_0 | 0 | | | | | | | | | _ | EIRQ[5] | SIUL | I | | | | | | | | | ALT0 | GPIO[6] | SIUL | I/O | | | | | | | | | ALT1 | SCK_1 | DSPI_1 | I/O | | | | | | | A[6] | PCR[6] | ALT2 | CS2_4 | DSPI_4 | I/O | Slow | Medium | 2 | 2 | 2 | | | | ALT3 | _ | _ | _ | | | | | | | | | _ | EIRQ[6] | SIUL | I | | | | | | | | PCR[7] | ALT0 | GPIO[7] | SIUL | I/O | Slow | | | | | | | | ALT1 | SOUT_1 | DSPI_1 | 0 | | | | 10 | | | A[7] | | ALT2 | CS1_4 | DSPI_4 | I/O | | Medium | 4 | | 18 | | | | ALT3 | _ | _ | _ | | | | | | | | | _ | EIRQ[7] | SIUL | I | | | | | | | | | ALT0 | GPIO[8] | SIUL | I/O | | | | | | | | | ALT1 | _ | _ | _ | | | | | | | A[8] | PCR[8] | ALT2 | CS0_4 | DSPI_4 | I/O | Slow | Medium | 6 | 12 | 20 | | , (0) | . 0[0] | ALT3 | _ | _ | | 0.011 | modiam | | | | | | | _ | SIN_1 | DSPI_1 | 1 | | | | | | | | | _ | EIRQ[8] | SIUL | l | | | | | | | | | ALT0 | GPIO[9] | SIUL | I/O | | | | | | | | | ALT1 | CS1_2 | DSPI_2 | 0 | | | | | | | A[9] | PCR[9] | ALT2 | _ | _ | | Slow | Medium | 94 | 134 | 158 | | | | ALT3 | _ | _ | _ | | | | | | | | | _ | SIN_4 | DSPI_4 | I | | | | | | | | | ALT0 | GPIO[10] | SIUL | I/O | | | | | | | | | ALT1 | CS0_2 | DSPI_2 | I/O | | | | | | | A[10] | PCR[10] | ALT2 | _ | _ | _ | Slow | Medium | 81 | 118 | 142 | | | | ALT3 | | _ | _ | | | | | | | | | _ | EIRQ[9] | SIUL | I | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | | 1/0 | 1 | peed <sup>(6)</sup> | | Pin | | |---------------------|------------------------|------------------------------|-----------------|---------------------|------------------|----------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | ALT0 | GPIO[11] | SIUL | I/O | | | | | | | | | ALT1 | SCK_2 | DSPI_2 | I/O | | | | | | | A[11] | PCR[11] | ALT2 | _ | _ | _ | Slow | Medium | 82 | 120 | 144 | | | | ALT3 | —<br>— | _ | _ | | | | | | | | | _ | EIRQ[10] | SIUL | I | | | | | | | | | ALT0 | GPIO[12] | SIUL | I/O | | | | | | | | | ALT1 | SOUT_2 | DSPI_2 | 0 | | | | | | | A[12] | PCR[12] | ALT2 | _ | _ | _ | Slow | Medium | 83 | 122 | 146 | | | | ALT3 | —<br> | —<br>SIUL | _<br> | | | | | | | | | _ | EIRQ[11] | | | | | | | | | | | ALT0 | GPIO[13] | SIUL | I/O | | | | | | | | | ALT1 | CS4_1 | DSPI_1 | 0 | | | | | | | A[13] | PCR[13] | ALT2 | _ | _ | _ | Slow | Medium | 95 | 136 | 160 | | | | ALT3 | SIN 2 | DSPI 2 | _<br> | <br> - | | | | | | | | | EIRQ[12] | SIUL | l<br>I | | | | | | | | | ALTO | | | | | | | | | | | | ALT0<br>ALT1 | GPIO[14]<br>TXD | SIUL<br>Safety Port | I/O<br>O | | | | | | | A[14] | PCR[14] | ALT1 | ETC[4] | eTimer_1 | 1/0 | Slow | Medium | 99 | 143 | 175 | | ^[ 1 <del>4</del> ] | i Cit[1 <del>4</del> ] | ALT3 | CS5_1 | DSPI_1 | 0 | Slow | Mediaiii | 33 | 143 | 173 | | | | _ | EIRQ[13] | SIUL | Ī | | | | | | | | | ALT0 | GPIO[15] | SIUL | I/O | | | | | | | | | ALT1 | CS6_1 | DSPI_1 | 0 | | | | | | | | | ALT2 | ETC[5] | eTimer_1 | I/O | | | | | | | A[15] | PCR[15] | ALT3 | | _ | _ | Slow | Medium | 100 | 144 | 176 | | | | _ | RXD | Safety Port | I | | | | | | | | | _ | EIRQ[14] | SIUL | I | | | | | | | | | L | | Po | ort B | <u>l</u> | | | | | | | | ALT0 | GPIO[16] | SIUL | I/O | | | | | | | | | ALT1 | TXD | FlexCAN_0 | 0 | | | | | | | B[0] | PCR[16] | ALT2 | ETC[2] | eTimer_1 | I/O | Slow | Medium | 76 | 109 | 133 | | | - <u>-</u> | ALT3 | DEBUG[0] | SSCM | _ | | | | | | | | | _ | EIRQ[15] | SIUL | 1 | | | | | | | | | ALT0 | GPIO[17] | SIUL | I/O | | | | | | | | | ALT1 | CS7_1 | DSPI_1 | 0 | | | | | | | BI41 | DCD[17] | ALT2 | ETC[3] | eTimer_1 | I/O | Slow | Medium | 77 | 110 | 134 | | | B[1] PCR[17] | ALT3 | DEBUG[1] | SSCM | _ | SIUW | | m 77 | 110 | 134 | | | | - | RXD | FlexCAN_0 | I | | | | | | | | | _ | EIRQ[16] | SIUL | I | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | 1/0 | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|------------------------------|--------------------|---------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | ALT0 | GPIO[18] | SIUL | 1/0 | | | | | | | B[2] | PCR[18] | ALT1<br>ALT2 | TXD<br>SOUT_4 | LINFlex_0<br>DSPI_4 | O<br>I/O | Slow | Medium | 79 | 114 | 138 | | اکارکا | i Cit[10] | ALT3 | DEBUG[2] | SSCM | 1/O | Slow | Medium | 13 | 114 | 130 | | | | _ | EIRQ[17] | SIUL | I | | | | | | | | | ALT0 | GPIO[19] | SIUL | I/O | | | | | | | | | ALT1 | _ | _ | _ | | | | | | | B[3] | PCR[19] | ALT2 | SCK_4 | DSPI_4 | I/O | Slow | Medium | 80 | 116 | 140 | | | | ALT3 | DEBUG[3] | SSCM | _ | | | | | | | | | _ | RXD | LINFlex_0 | I | | | | | | | | | ALT0 | GPIO[22] | SIUL | I/O | | | | | | | | | ALT1 | clk_out | MC_CGL | 0 | | | | | | | B[6] | PCR[22] | ALT2 | CS2_2 | DSPI_2 | 0 | Slow | Medium | 96 | 138 | 162 | | | | ALT3 | clk_out_div2<br>56 | MC_CGL | 0 | | | | | | | | | _ | EIRQ[18] | SIUL | I | | | | | | | | | ALT0 | GPIO[23] | SIUL | | | | | | | | | PCR[23] | ALT1 | _ | _ | | | | | | | | B[7] | | ALT2 | _ | _ | Input Only | | _ | 29 | 43 | 51 | | ا ا | | ALT3 | _ | _ | | | | | | 01 | | | | _ | AN[0] | ADC_0 | | | | | | | | | | _ | RXD | LINFlex_0 | | | | | | | | | | ALT0 | GPIO[24] | SIUL | | | | | | | | | | ALT1 | _ | _ | | | | | | | | B[8] | PCR[24] | ALT2 | _ | _ | Input Only | _ | _ | 31 | 47 | 55 | | | | ALT3 | —<br>A N I [ 4 ] | —<br>ADO 0 | | | | | | | | | | | AN[1]<br>ETC[5] | ADC_0<br>eTimer_0 | | | | | | | | | | ALT0 | GPIO[25] | SIUL | | | | | | | | | | ALT1 | — — | — | | | | | | | | B[9] | PCR[25] | ALT2 | _ | _ | Input Only | _ | _ | 35 | 52 | 60 | | | | ALT3 | _ | _ | , , | | | | | | | | | | AN[11] | ADC_0 | | | | | | | | | | ALT0 | GPIO[26] | SIUL | | | | | | | | | | ALT1 | _ | _ | | | | | | | | B[10] | PCR[26] | ALT2 | _ | _ | Input Only | _ | _ | 36 | 53 | 61 | | | | ALT3 | _ | _ | | | | | | | | | | _ | AN[12] | ADC_0 | | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | 1/0 | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|----------------------------------------|-----------------------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | B[11] | PCR[27] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[27]<br>—<br>—<br>—<br>—<br>AN[13] | SIUL<br>—<br>—<br>—<br>—<br>ADC_0 | Input Only | | _ | 37 | 54 | 62 | | B[12] | PCR[28] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[28]<br>—<br>—<br>—<br>—<br>AN[14] | SIUL<br><br><br>ADC_0 | Input Only | _ | _ | 38 | 55 | 63 | | B[13] | PCR[29] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[29] AN[16] RXD | SIUL — — — ADC_0 LINFlex_1 | Input Only | _ | _ | 42 | 60 | 68 | | B[14] | PCR[30] | ALT0 ALT1 ALT2 ALT3 — — — | GPIO[30] — — — AN[17] ETC[4] EIRQ[19] | SIUL ADC_0 eTimer_0 SIUL | Input Only | | _ | 44 | 64 | 76 | | B[15] | PCR[31] | ALT0 ALT1 ALT2 ALT3 — — | GPIO[31] AN[18] EIRQ[20] | SIUL ADC_0 SIUL | Input Only | _ | _ | 43 | 62 | 70 | | | | | | Po | ort C | | | | | | | C[0] | PCR[32] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[32]<br>—<br>—<br>—<br>AN[19] | SIUL<br>—<br>—<br>—<br>ADC_0 | Input Only | _ | _ | 45 | 66 | 78 | | C[1] | PCR[33] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[33]<br>—<br>—<br>—<br>—<br>AN[2] | SIUL ADC_0 | Input Only | _ | _ | 28 | 41 | 49 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | | I/O | Pad s | peed <sup>(6)</sup> | | Pin | | |-------------|------------------------|------------------------------|-----------|-------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | ALT0 | GPIO[34] | SIUL | | | | | | | | | | ALT1 | _ | _ | | | | | | | | C[2] | PCR[34] | ALT2 | _ | _ | Input Only | _ | _ | 30 | 45 | 53 | | | | ALT3 | | _ | | | | | | | | | | _ | AN[3] | ADC_0 | | | | | | | | | | ALT0 | GPIO[35] | SIUL | I/O | | | | | | | | | ALT1 | CS1_0 | DSPI_0 | 0 | | | | | | | C[3] | PCR[35] | ALT2 | ETC[4] | eTimer_1 | I/O | Slow | Medium | 10 | 16 | 24 | | | | ALT3 | TXD | LINFlex_1 | 0 | | | | | | | | | _ | EIRQ[21] | SIUL | l | | | | | | | | | ALT0 | GPIO[36] | SIUL | I/O | | | | | | | | | ALT1 | CS0_0 | DSPI_0 | I/O | | | | | | | C[4] | PCR[36] | ALT2 | _ | _ | _ | Slow | Medium | 5 | 11 | 19 | | | | ALT3 | DEBUG[4] | SSCM | _ | | | | | | | | | _ | EIRQ[22] | SIUL | I | | | | | | | | | ALT0 | GPIO[37] | SIUL | I/O | | | | | | | | | ALT1 | SCK_0 | DSPI_0 | I/O | | | | | | | C[5] | PCR[37] | ALT2 | SCK_4 | DSPI_4 | I/O | Slow | Medium | 7 | 13 | 21 | | | | ALT3 | DEBUG[5] | SSCM | _ | | | | | | | | | _ | EIRQ[23] | SIUL | I | | | | | | | | | ALT0 | GPIO[38] | SIUL | I/O | | | | | | | | | ALT1 | SOUT_0 | DSPI_0 | 0 | | | | | | | C[6] | PCR[38] | ALT2 | _ | _ | _ | Slow | Medium | 98 | 142 | 174 | | | | ALT3 | DEBUG[6] | SSCM | _ | | | | | | | | | _ | EIRQ[24] | SIUL | I | | | | | | | | | ALT0 | GPIO[39] | SIUL | I/O | | | | | | | | | ALT1 | _ | _ | _ | | | | | | | C[7] | PCR[39] | ALT2 | _ | _ | _ | Slow | Medium | 9 | 15 | 23 | | ا ا | 1 011[00] | ALT3 | DEBUG[7] | SSCM | | Olow | Wicalam | | 10 | 20 | | | | _ | SIN_0 | DSPI_0 | I | | | | | | | | | _ | SIN_4 | DSPI_4 | Į | | | | | | | | | ALT0 | GPIO[40] | SIUL | I/O | | | | | | | C[8] | PCR[40] | ALT1 | CS1_1 | DSPI_1 | 0 | Slow | Medium | 91 | 130 | 154 | | ا کری | . 5. (40] | ALT2 | CS1_4 | DSPI_4 | 0 | Slow | Modium | | 100 | 10-7 | | | | ALT3 | CS6_0 | DSPI_0 | 0 | | | | | | | | | ALT0 | GPIO[41] | SIUL | I/O | Slow | | | | | | C[9] | PCR[41] | ALT1 | CS3_2 | DSPI_2 | 0 | | O Slow Medium | 84 | 123 | 147 | | C[a] | 1 OI\[ <del>4</del> 1] | ALT2 | CS0_4 | DSPI_4 | I/O | | | dium 84 123 | 123 | 14/ | | | | ALT3 | | | _ | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | 1/0 | | speed <sup>(6)</sup> | | Pin | | |-------------|------------|------------------------------|-------------------------------------------------|--------------------------------------------------|---------------------------|---------|----------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | C[10] | PCR[42] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[42]<br>CS2_2<br>CS2_4<br>— | SIUL<br>DSPI_2<br>DSPI_4<br>— | 1/O<br>O O | Slow | Medium | 78 | 111 | 135 | | C[11] | PCR[43] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[43]<br>ETC[4]<br>CS2_2<br>CS0_3 | SIUL<br>eTimer_0<br>DSPI_2<br>DSPI_3 | I/O<br>I/O<br>O<br>I/O | Slow | Medium | 55 | 80 | 96 | | C[12] | PCR[44] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[44]<br>ETC[5]<br>CS3_2<br>CS1_3 | SIUL<br>eTimer_0<br>DSPI_2<br>DSPI_3 | I/O<br>I/O<br>O | Slow | Medium | 56 | 82 | 100 | | C[13] | PCR[45] | ALT0 ALT1 ALT2 ALT3 — | GPIO[45] ETC[1] — — EXT_IN RXD | SIUL eTimer_1 CTU_0 FlexCAN_1 | I/O<br>I/O<br>—<br>—<br>I | Slow | Medium | 71 | 101 | 125 | | C[14] | PCR[46] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[46]<br>ETC[2]<br>EXT_TGR<br>TXD | SIUL<br>eTimer_1<br>CTU_0<br>FlexCAN_1 | I/O<br>I/O<br>O | Slow | Medium | 72 | 103 | 127 | | C[15] | PCR[47] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[47] CA_TR_EN ETC[0] — EXT_IN | SIUL FlexRay_0 eTimer_1 — CTU_0 | I/O<br>O<br>I/O<br>—<br>I | Slow | Symmetric | 85 | 124 | 148 | | | | | | Po | ort D | | | | | | | D[0] | PCR[48] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[48]<br>CA_TX<br>ETC[1]<br>— | SIUL<br>FlexRay_0<br>eTimer_1<br>— | I/O<br>O<br>I/O<br>— | Slow | Symmetric | 86 | 125 | 149 | | D[1] | PCR[49] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[49]<br>CS4_1<br>ETC[2]<br>EXT_TRG<br>CA_RX | SIUL<br>DSPI_1<br>eTimer_1<br>CTU_0<br>FlexRay_0 | I/O<br>O<br>I/O<br>O | Slow | Medium | 3 | 3 | 3 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | <b>DOD</b> | Alternate | | 7. FIII IIIu | 1/0 | | speed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|-------------------------------------------|-----------------------------------------|-------------------------|---------|----------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | D[2] | PCR[50] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[50]<br>CS5_1<br>ETC[3]<br>—<br>CB_RX | SIUL DSPI_1 eTimer_1 — FlexRay_0 | 1/0<br>0<br>1/0<br> | Slow | Medium | 97 | 140 | 168 | | D[3] | PCR[51] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[51]<br>CB_TX<br>ETC[4] | SIUL<br>FlexRay_0<br>eTimer_1<br>— | I/O<br>O<br>I/O<br>— | Slow | Symmetric | 89 | 128 | 152 | | D[4] | PCR[52] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[52]<br>CB_TR_EN<br>ETC[5]<br>— | SIUL<br>FlexRay_0<br>eTimer_1<br>— | I/O<br>O<br>I/O<br>— | Slow | Symmetric | 90 | 129 | 153 | | D[5] | PCR[53] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[53]<br>CS3_0<br>—<br>SOUT_3 | SIUL<br>DSPI_0<br>—<br>DSPI_3 | I/O<br>O<br>—<br>O | Slow | Medium | 22 | 33 | 41 | | D[6] | PCR[54] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[54]<br>CS2_0<br>SCK_3<br>SOUT_4 | SIUL<br>DSPI_0<br>DSPI_3<br>DSPI_4 | I/O<br>O<br>I/O<br>O | Slow | Medium | 23 | 34 | 42 | | D[7] | PCR[55] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[55] CS3_1 CS4_0 SIN_3 | SIUL<br>DSPI_1<br>—<br>DSPI_0<br>DSPI_3 | I/O<br>O<br>—<br>O<br>I | Slow | Medium | 26 | 37 | 45 | | D[8] | PCR[56] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[56]<br>CS2_1<br>RDY<br>CS5_0 | SIUL<br>DSPI_1<br>nexus_0<br>DSPI_0 | I/O<br>O<br>O | Slow | Medium | 21 | 32 | 40 | | D[9] | PCR[57] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[57] — TXD CS6_1 | SIUL LINFlex_1 DSPI_1 | I/O<br>—<br>O<br>O | Slow | Medium | 15 | 26 | 34 | | D[10] | PCR[58] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[58]<br>—<br>CS0_3<br>— | SIUL<br>—<br>DSPI_3<br>— | I/O<br>—<br>I/O<br>— | Slow | Medium | 53 | 76 | 92 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | 1/0 | 1 | peed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|----------------------------------------|------------------------------|----------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | D[11] | PCR[59] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[59] — CS1_3 SCK_3 | SIUL — DSPI_3 DSPI_3 | I/O<br>—<br>O<br>I/O | Slow | Medium | 54 | 78 | 94 | | D[12] | PCR[60] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[60] — CS7_1 RXD | SIUL DSPI_1 LINFlex_1 | I/O<br>—<br>—<br>O | Slow | Medium | 70 | 99 | 123 | | D[13] | PCR[61] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[61] — CS2_3 SOUT_3 | SIUL DSPI_3 DSPI_3 | I/O<br>—<br>O<br>O | Slow | Medium | 67 | 95 | 119 | | D[14] | PCR[62] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[62] — CS3_3 — SIN_3 | SIUL DSPI_3 DSPI_3 | I/O<br>—<br>O<br>— | Slow | Medium | 73 | 105 | 129 | | D[15] | PCR[63] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[63]<br>—<br>—<br>—<br>—<br>AN[20] | SIUL ADC_0 | Input Only | _ | _ | 41 | 58 | 66 | | | | | | Po | ort E | | | | | | | E[0] | PCR[64] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[64]<br>—<br>—<br>—<br>—<br>AN[21] | SIUL<br>—<br>—<br>—<br>ADC_0 | Input Only | _ | _ | 46 | 68 | 80 | | E[1] | PCR[65] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[65]<br>—<br>—<br>—<br>—<br>AN[4] | SIUL ADC_0 | Input Only | _ | _ | 27 | 39 | 47 | | E[2] | PCR[66] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[66]<br>—<br>—<br>—<br>—<br>AN[5] | SIUL ADC_0 | Input Only | _ | _ | 32 | 49 | 57 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | 1/0 | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|----------------------------------------|------------------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | E[3] | PCR[67] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[67]<br>—<br>—<br>—<br>—<br>AN[6] | SIUL ADC_0 | Input Only | | _ | _ | 40 | 48 | | E[4] | PCR[68] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[68]<br>—<br>—<br>—<br>—<br>AN[7] | SIUL ADC_0 | Input Only | _ | _ | _ | 42 | 50 | | E[5] | PCR[69] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[69]<br>—<br>—<br>—<br>—<br>AN[8] | SIUL ADC_0 | Input Only | _ | _ | _ | 44 | 52 | | E[6] | PCR[70] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[70]<br>—<br>—<br>—<br>—<br>AN[9] | SIUL ADC_0 | Input Only | _ | _ | _ | 46 | 54 | | E[7] | PCR[71] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[71]<br>—<br>—<br>—<br>—<br>AN[10] | SIUL ADC_0 | Input Only | _ | _ | _ | 48 | 56 | | E[8] | PCR[72] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[72]<br>—<br>—<br>—<br>—<br>AN[22] | SIUL<br>—<br>—<br>—<br>ADC_0 | Input Only | _ | _ | _ | 59 | 67 | | E[9] | PCR[73] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[73]<br>—<br>—<br>—<br>—<br>AN[23] | SIUL<br>—<br>—<br>—<br>ADC_0 | Input Only | _ | _ | _ | 61 | 69 | | E[10] | PCR[74] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[74]<br>—<br>—<br>—<br>—<br>AN[24] | SIUL ADC_0 | Input Only | _ | _ | _ | 63 | 75 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | Dord | DCD | Alternate | | Davimbanal | I/O | Pad s | peed <sup>(6)</sup> | | Pin | | |-------------|------------|------------------------------|---------------|-------------------|------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | | | ALT0 | GPIO[75] | SIUL | | | | | | | | | | ALT1 | _ | _ | | | | | | | | E[11] | PCR[75] | ALT2 | _ | _ | Input Only | _ | _ | _ | 65 | 77 | | | | ALT3 | —<br>AN[25] | ADC_0 | | | | | | | | | | ALT0 | | SIUL | | | | | | | | | | ALTO<br>ALT1 | GPIO[76] | SIUL | | | | | | | | E[12] | PCR[76] | ALT2 | _ | _ | Input Only | _ | _ | _ | 67 | 79 | | _[] | . 0.4.01 | ALT3 | _ | _ | input only | | | | 0. | | | | | _ | AN[26] | ADC_0 | | | | | | | | | | ALT0 | GPIO[77] | SIUL | I/O | | | | | | | | | ALT1 | SCK_3 | DSPI_3 | I/O | | | | | | | E[13] | PCR[77] | ALT2 | _ | _ | _ | Slow | Medium | _ | 117 | 141 | | | | ALT3 | _ | _ | _ | | | | | | | | | _ | EIRQ[25] | SIUL | I | | | | | | | | | ALT0 | GPIO[78] | SIUL | I/O | | | | | | | | | ALT1 | SOUT_3 | DSPI_3 | 0 | | | | | | | E[14] | PCR[78] | ALT2 | _ | _ | _ | Slow | Medium | _ | 119 | 143 | | | | ALT3 | —<br>EIRQ[26] | SIUL | _<br> _ | | | | | | | | | | | | | | | | | | | | | ALT0<br>ALT1 | GPIO[79] | SIUL | I/O | | | | | | | | | ALT1 | | _ | | | | | | | | E[15] | PCR[79] | ALT3 | _ | _ | _ | Slow | Medium | _ | 121 | 145 | | | | _ | SIN_3 | DSPI_3 | I | | | | | | | | | _ | EIRQ[27] | SIUL | I | | | | | | | | | | | Po | ort F | | | • | | | | | | ALT0 | GPIO[80] | SIUL | I/O | | | | | | | | | ALT1 | DBG_0 | FlexRay_0 | 0 | | | | | | | F[0] | PCR[80] | ALT2 | CS3_3 | DSPI_3 | 0 | Slow | Medium | _ | 133 | 157 | | | | ALT3 | _ | _ | _ | | | | | | | | | _ | EIRQ[28] | SIUL | I | | | | | | | | | ALT0 | GPIO[81] | SIUL | I/O | | | | | | | | | ALT1 | DBG_1 | FlexRay_0 | 0 | | | | | | | F[1] | PCR[81] | ALT2 | CS2_3 | DSPI_3 | 0 | Slow | Medium | _ | 135 | 159 | | | | ALT3 | —<br>EIRQ[29] | —<br>SIUL | _<br> | | | | | | | | | | LIING[28] | SIUL | ı | | | | | | Table 7. Pin muxing<sup>(1)</sup>(Continued) | | | Alternate | | 7. Pin mux | I/O | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|------------------------------|---------------------------------|----------------------------------|--------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | F[2] | PCR[82] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[82]<br>DBG_2<br>CS1_3<br>— | SIUL<br>FlexRay_0<br>DSPI_3<br>— | I/O<br>O<br>O | Slow | Medium | _ | 137 | 161 | | F[3] | PCR[83] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[83] DBG_3 CS0_3 — | SIUL<br>FlexRay_0<br>DSPI_3<br>— | I/O<br>O<br>I/O | Slow | Medium | _ | 139 | 167 | | F[4] | PCR[84] | ALT0<br>ALT1<br>ALT2<br>ALT3 | —<br>—<br>MDO[3]<br>— | <br><br>nexus_0<br> | _<br>_<br>0<br>_ | Slow | Fast | _ | 4 | 4 | | F[5] | PCR[85] | ALT0<br>ALT1<br>ALT2<br>ALT3 | —<br>—<br>MDO[2]<br>— | nexus_0 | _<br>_<br>_<br>_ | Slow | Fast | _ | 5 | 13 | | F[6] | PCR[86] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[86]<br>—<br>MDO[1]<br>— | SIUL nexus_0 — | I/O<br>—<br>O<br>— | Slow | Fast | _ | 8 | 16 | | F[7] | PCR[87] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[87] — MCKO — | SIUL<br>—<br>nexus_0<br>— | I/O<br>—<br>O<br>— | Slow | Fast | _ | 19 | 27 | | F[8] | PCR[88] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[88] — MSEO1 — | SIUL nexus_0 — | I/O<br>—<br>O<br>— | Slow | Fast | _ | 20 | 28 | | F[9] | PCR[89] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[89] — MSEO0 — | SIUL nexus_0 — | I/O<br>—<br>O<br>— | Slow | Fast | _ | 23 | 31 | | F[10] | PCR[90] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[90]<br>—<br>EVTO<br>— | SIUL nexus_0 — | I/O<br>—<br>O<br>— | Slow | Fast | _ | 24 | 32 | | F[11] | PCR[91] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[91]<br>EVTI<br>—<br>— | SIUL<br>nexus_0<br>— | I/O<br>I<br>— | Slow | Medium | _ | 25 | 33 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | Dowt | DCD | Alternate | | Powinkowal | 1/0 | | peed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|----------------------------------------|--------------------------------|-------------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | F[12] | PCR[92] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[92]<br>ETC[3]<br>—<br>— | SIUL<br>eTimer_1<br>— | I/O<br>I/O<br>— | Slow | Medium | _ | 106 | 130 | | F[13] | PCR[93] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[93]<br>ETC[4]<br>— | SIUL<br>eTimer_1<br>— | I/O<br>I/O<br>— | Slow | Medium | _ | 112 | 136 | | F[14] | PCR[94] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[94]<br>TXD<br>—<br>— | SIUL<br>LINFlex_1<br>— | I/O<br>O<br>— | Slow | Medium | _ | 115 | 139 | | F[15] | PCR[95] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[95]<br>—<br>—<br>—<br>—<br>RXD | SIUL — — — LINFlex_1 | I/O<br>—<br>—<br>—<br>I | Slow | Medium | _ | 113 | 137 | | | | | | Po | ort G | | | · | | | | G[0] | PCR[96] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[96]<br>F[0]<br>—<br>—<br>EIRQ[30] | SIUL<br>FCCU<br>—<br>—<br>SIUL | I/O<br>O<br>—<br>—<br>I | Slow | Medium | _ | 38 | 46 | | G[1] | PCR[97] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[97]<br>F[1]<br>—<br>—<br>EIRQ[31] | SIUL<br>FCCU<br>—<br>—<br>SIUL | I/O<br>O<br>—<br>—<br>I | Slow | Medium | _ | 141 | 173 | | G[2] | PCR[98] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[98]<br>—<br>—<br>—<br>—<br>SIN_4 | SIUL DSPI_4 | I/O<br>—<br>—<br>—<br>— | Slow | Medium | _ | 102 | 126 | | G[3] | PCR[99] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[99]<br>—<br>SOUT_4<br>— | SIUL — DSPI_4 — | I/O<br>—<br>O<br>— | Slow | Medium | _ | 104 | 128 | Table 7. Pin muxing<sup>(1)</sup>(Continued) | D4 | DOD | Alternate | | Daniah anal | 1/0 | Pad s | peed <sup>(6)</sup> | | Pin | | |-------------|------------|-----------------------------------|------------------------------|--------------------------|-------------------------|---------|---------------------|-------------|-------------|----------------------------| | Port<br>pin | PCR<br>No. | function <sup>(2),</sup> (3) | Functions | Peripheral<br>(4) | direction<br>(5) | SRC = 0 | SRC = 1 | LQFP<br>100 | LQFP<br>144 | LQFP<br>176 <sup>(7)</sup> | | G[4] | PCR[100] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[100]<br>—<br>SCK_4<br>— | SIUL<br>—<br>DSPI_4<br>— | I/O<br>—<br>I/O<br>— | Slow | Medium | _ | 100 | 124 | | G[5] | PCR[101] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[101]<br>—<br>CS0_4<br>— | SIUL<br>—<br>DSPI_4<br>— | I/O<br>—<br>I/O<br>— | Slow | Medium | _ | 85 | 103 | | G[6] | PCR[102] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[102] — CS1_4 — | SIUL — DSPI_4 — | I/O<br>—<br>O<br>— | Slow | Medium | _ | 98 | 122 | | G[7] | PCR[103] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[103] — CS2_4 — | SIUL — DSPI_4 — | I/O<br>—<br>O<br>— | Slow | Medium | _ | 83 | 101 | | G[8] | PCR[104] | ALT0<br>ALT1<br>ALT2<br>ALT3<br>— | GPIO[104]<br>—<br>CS3_4<br>— | SIUL<br>—<br>DSPI_4<br>— | I/O<br>—<br>O<br>— | Slow | Medium | _ | 81 | 97 | | G[9] | PCR[105] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[105] | SIUL — — — FlexCAN_1 | I/O<br>—<br>—<br>—<br>— | Slow | Medium | _ | 79 | 95 | | G[10] | PCR[106] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[106] TXD — | SIUL — FlexCAN_1 — | I/O<br>—<br>O<br>— | Slow | Medium | _ | 77 | 93 | | G[11] | PCR[107] | ALT0<br>ALT1<br>ALT2<br>ALT3 | GPIO[107]<br>—<br>—<br>— | SIUL<br>—<br>—<br>— | I/O<br>—<br>—<br>— | Slow | Medium | _ | 75 | 91 | This table concerns Enhanced Full-featured version. Please refer to "SPC56xP60x/54x device configuration difference" table for difference between Enhanced Full-featured, Full-featured, and Airbag configuration. <sup>4.</sup> Module included on the MCU. <sup>2.</sup> ALT0 is the primary (default) function for each port after reset. <sup>3.</sup> Alternate functions are chosen by setting the values of the PCR[PA] bitfields inside the SIU module. PCR[PA] = 00 → ALT0; PCR[PA] = 01 → ALT1; PCR[PA] = 10 → ALT2; PCR[PA] = 11 → ALT3. This is intended to select the output functions; to use one of the input-only functions, the PCR[IBE] bit must be written to '1', regardless of the values selected in the PCR[PA] bitfields. For this reason, the value corresponding to an input only function is reported as "—". 5. Multiple inputs are routed to all respective modules internally. The input of some modules must be configured by setting the values of the PSMI[PADSELx] bitfields inside the SIUL module. - 6. Programmable via the SRC (Slew Rate Control) bits in the respective Pad Configuration Register. - 7. LQFP176 available only as development package. - 8. Weak pull down during reset. ## 3.5 CTU / ADCs / eTimers / DSPI / FlexRay connections Figure 6 shows the interconnections between the CTU, ADCs, eTimers, DSPI and FlexRay. Figure 6. CTU / ADCs / eTimers / DSPI / FlexRay connections Table 8. CTU / ADCs / eTimers / DSPI / FlexRay connections | Source module<br>(Signal) | Target module<br>(Signal) | Comment | |------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------| | eTimer_0(T2) | CTU(ETMR0_IN) | _ | | eTimer_0(T2) | eTimer_1(AUX_1) | _ | | eTimer_1(T2) | CTU(ETMR1_IN) | _ | | eTimer_1(T2) | eTimer_0(AUX_1) | _ | | eTimer_1(T5) | ADC_0 | A/D conversion injection request signal (for non CTU mode of operation). | | CTU(ETIMER0_TRG) | eTimer_0(AUX_0) | _ | | CTU(ETIMER1_TRG) | eTimer_1(AUX_0) | _ | | CTU(TRIGGER_0) | ADC_0 (Through CTU/ADC IP Interface) | _ | | CTU(ADC_CMD_0) | ADC_0 (Through CTU/ADC IP Interface) | 16-bits signal | | CTU(TRIGGER_1) | Virtual ADC_1 <sup>(1)</sup><br>(Through CTU/ADC IP<br>Interface) | _ | | CTU(ADC_CMD_1) | Virtual ADC_1 <sup>(1)</sup><br>(Through CTU/ADC IP<br>Interface) | 16-bits signal | | CTU(EXT_TGR) | SIU lite | _ | | ADC_0(EOC) | CTU(NEXT_CMD_0)<br>(Through CTU/ADC IP<br>Interface) | End Of Conversion should be used as next command request signal | | ADC_0 | CTU(FIFO_0)<br>(Through CTU/ADC IP<br>Interface) | 18-bits signal | | Virtual ADC_1 <sup>(1)</sup> (EOC) | CTU(NEXT_CMD_1)<br>(Through CTU/ADC IP<br>Interface) | End Of Conversion should be used as next command request signal | | Virtual ADC_1 <sup>(1)</sup> | CTU(FIFO_1)<br>(Through CTU/ADC IP<br>Interface) | 18-bits signal | | SIU lite | CTU(EXT_IN) | The same GPIO pin as used for CTU (EXT_IN) | | DSPI_1(SCK) | eTimer_0(AUX_2) | _ | | FlexRAY(FR_CA_TX) | eTimer_1(AUX_2) | _ | <sup>1.</sup> ADC\_1 commands are translated into ADC\_0 commands. Clock Description RM0083 ## 4 Clock Description This chapter describes the clock architectural implementation for SPC56xP60x/54x. The following clock related modules are implemented on the SPC56xP60x/54x: - · Clock, Reset, and Mode Handling - Clock Generation Module (CGM) (see Chapter 5: Clock Generation Module (MC\_CGM)) - Reset Generation Module (RGM) (see Chapter 8: Reset Generation Module (MC\_RGM)) - Mode Entry Module (ME) (see Chapter 6: Mode Entry Module (MC\_ME)) - High Frequency Oscillator (XOSC) (see Section 4.8: XOSC external crystal oscillator) - High Frequency RC Oscillator (IRC) (see Section 4.7: IRC 16 MHz internal RC oscillator (RC CTL)) - FMPLL (FMPLL\_0) (see Section 4.9: Frequency Modulated Phase Locked Loop (FMPLL)) - CMU (CMU\_0) (see Section 4.10: Clock Monitor Unit (CMU)) - CMU (CMU 1) (see Section 4.10: Clock Monitor Unit (CMU)) - Periodic Interrupt Timer (PIT) (see Chapter 32: Periodic Interrupt Timer (PIT)) - System Timer Module (STM\_0) (see Chapter 33: System Timer Module (STM)) - System Timer Module (STM\_1) (see Chapter 33: System Timer Module (STM)) - Software Watchdog Timer (SWT\_0) (see Section 29.3: Software Watchdog Timer (SWT)) - Software Watchdog Timer (SWT\_1) (see Section 29.3: Software Watchdog Timer (SWT)) #### 4.1 Clock architecture The system and peripheral clocks are generated from three sources: - IRC—internal RC oscillator clock - XOSC—oscillator clock - FMPLL\_0 clock output The clock architecture is shown in Figure 7, Figure 8, and Figure 9. The frequencies shown in Figure 7 represent only one possible setting. Note: MC\_PLL\_CLK and SP\_PLL\_CLK are SYS\_CLK. RM0083 Clock Description Figure 7. SPC56xP60x/54x system clock generation Clock Description RM0083 Figure 8. SPC56xP60x/54x system clock distribution Part A RM0083 Clock Description Figure 9. SPC56xP60x/54x system clock distribution Part B Clock Description RM0083 ### 4.2 Available clock domains This section describes the various clock domains available on SPC56xP60x/54x. #### 4.2.1 FMPLL input reference clock The input reference clock for FMPLL\_0 is always the external crystal oscillator clock (XOSC). #### 4.2.2 Clock selectors ### 4.2.2.1 System clock selector 0 for SYS\_CLK The system clock selector 0 selects the clock source for the system clock (SYS\_CLK) from clock signals: - Internal RC oscillator clock (IRC) - Progressive output clock of FMPLL 0 - Directly from the oscillator clock (XOSC) Its behavior is configured via software through ME\_x\_MC register of the ME module. When the standard boot from internal flash is selected via the boot configuration pins, the clock source for the system clock (SYS\_CLK) after reset (DRUN mode) is the internal RC oscillator (IRC). ### 4.2.3 Auxiliary Clock Selector 0 There is no Auxiliary Clock selector 0 present on SPC56xP60x/54x device, but to maintain the software compatibility, corresponding register in MC\_CGM (CGM\_AC0\_SC) has been implemented through which user can select any clock source from the given auxiliary clock sources. As there is no auxiliary clock, all the auxiliary clock sources have been tied to '0'. ### 4.2.4 Auxiliary Clock Selector 1 There is no Auxiliary Clock selector 1 present on SPC56xP60x/54x device, but to maintain the software compatibility, corresponding register in MC\_CGM (CGM\_AC1\_SC) has been implemented through which user can select any clock source from the given auxiliary clock sources. As there is no auxiliary clock, all the auxiliary clock sources have been tied to '0'. ### 4.2.5 Auxiliary Clock Selector 2 There is no Auxiliary Clock selector 2 present on SPC56xP60x/54x device, but to maintain the software compatibility, corresponding register in MC\_CGM (CGM\_AC2\_SC) has been implemented through which user can select any clock source from the given auxiliary clock sources. As there is no auxiliary clock, all the auxiliary clock sources have been tied to '0'. #### 4.2.5.1 Auxiliary Clock Selector 3 for FR PLL divider (FlexRay clock) Software uses the clock output selector to select one of the following clock sources: - Internal RC oscillator clock (IRC) - Progressive output clock of FMPLL\_0 - Directly from the oscillator clock (XOSC) RM0083 Clock Description The default clock source after reset is the IRC, but the default status is disabled. The clock output can be enabled or disabled by software through the CGM module (CGM\_OC\_EN and CGM\_OCDS\_SC registers). ### 4.2.6 Auxiliary clock dividers The auxiliary clock divider is implemented to generate the FR\_PLL\_CLK and supports these divide options: $\div 1$ , $\div 2$ , $\div 3$ , $\div 4$ , $\div 5$ , $\div 6$ , $\div 7$ , $\div 8$ , $\div 9$ , $\div 10$ , $\div 11$ , $\div 12$ , $\div 13$ , $\div 14$ , $\div 15$ . The clock divider is configured by CGM\_AC3\_DC0 register of the CGM module. To maintain the software compatibility, one divider corresponding to every missing auxiliary clock has been implemented. Corresponding registers have been implemented in MC\_CGM which can be accessed by user but have no impact in device. These registers are CGM\_AC0\_DC0, CGM\_AC1\_DC0, and CGM\_AC2\_DC0 #### 4.2.7 External clock divider The output clock divider provides a nominal 50% duty cycle clock and allows the selected output clock source to be divided with these divide options: - ÷ 1, ÷ 2, ÷ 4, ÷ 8 - ÷ 1, ÷ 2, ÷ 3 to ÷ 256 #### 4.2.7.1 Output Clock Division 256 Select Register (CLK\_DIV\_256) Figure 10. Output Clock Division 256 Select Register (CLK\_DIV\_256) This register is used to select by which factor the selected output source is divided before being delivered at the output clock. Table 9. Output Clock Division 256 Select Register (CLK\_DIV\_256) Field Descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DIV | Output Clock Division 256 Select 0x00 output selected Output Clock without division 0x01 output selected Output Clock divided by 2 0x10 output selected Output Clock divided by 3 0xFF output selected Output Clock divided by 256 | Clock Description RM0083 ### 4.3 Alternate module clock domains This section lists the different clock domains for each module. If not otherwise noted, all modules on the SPC56xP60x/54x device are clocked on the SYS\_CLK. #### 4.3.1 FlexCAN clock domains The FlexCAN modules have two distinct software controlled clock domains. One of the clock domains is always derived from the system clock. This clock domain includes the message buffer logic. The source for the second clock domain can be either the system clock (SYS\_CLK) or a direct feed from the oscillator pin XOSC\_CLK. The logic in the second clock domain controls the CAN interface pins. The CLK\_SRC bit in the FlexCAN CTRL register selects between the system clock and the oscillator clock as the clock source for the second domain. Selecting the oscillator as the clock source ensures very low jitter on the CAN bus. System software can gate both clocks by writing to the MDIS bit in the FlexCAN MCR. *Figure 444* shows the two clock domains in the FlexCAN modules. Refer to Chapter 24: FlexCAN for more information on the FlexCAN modules. ## 4.3.2 FlexRay clock domains The FlexRay block has two distinct clock domains. The first clock domain (Module Clock or CHI clock) is always derived from the SYS\_CLK clock. The source for the second clock domain can either be the FR\_PLL\_CLK clock or the XOSC\_CLK clock. The logic in the second clock domain controls the FlexRay interface pins (Protocol Clock or PE clock). #### 4.3.3 SWT clock domains The SWT module has two distinct clock domains. The first clock domain (Module Clock) is always supplied from the SYS CLK. This clock domain includes the register interface. The source for the second clock domain (Protocol Clock) is always the IRC generated by the internal RC oscillator. ### 4.3.4 Nexus Message Clock (MCKO) The Nexus message clock (MCKO) divider can be programmed to divide the system clock by one, two, four or eight based on the MCKO\_DIV bit field in the port configuration register (PCR) in the Nexus port controller (NPC). The reset value of the MCKO\_DIV selects an MCKO clock frequency one half of the system clock frequency. The MCKO divider is configured by writing to the NPC through the JTAG port. Refer to *Chapter 38: Nexus Port Controller (NPC)* for more information. #### 4.3.5 Cross Triggering Unit (CTU) clock domains The CTU module has two distinct clock domains. The first clock domain (Module Clock) is supplied from the SYS CLK. This clock domain includes the Command Buffer logic. The source for the second clock domain (Protocol Clock) is the MC\_PLL\_CLK. The logic in the Protocol Clock domain controls the CTU interface pins to the eTimer module and the ADC module. RM0083 Clock Description #### 4.3.6 Peripherals #### 4.3.6.1 eTimer\_0 clock domain The eTimer\_0 module has only one clock domain. The eTimer\_0 module is clocked from the MC PLL CLK. #### 4.3.6.2 eTimer 1 clock domain The eTimer\_1 module has only one clock domain. The eTimer\_1 module is clocked from the MC\_PLL\_CLK. #### 4.3.6.3 ADC\_0 clock domain The ADC\_0 module has only one clock domain. The ADC\_0 module is clocked from the MC\_PLL\_CLK. ### 4.3.6.4 Safety Port clock domains The Safety Port module has two distinct software-controlled clock domains. The first clock domain (Module Clock) is always supplied from the SP\_PLL\_CLK. The source for the second clock domain (Protocol Clock) can either be the SP\_PLL\_CLK or the XOSC\_CLK. The user must ensure that the frequency of the first clock domain (Module Clock) clocked from the MC\_PLL\_CLK is always the same or greater than the clock selected for the second clock domain (Protocol Clock). #### 4.3.6.5 Core\_1 switching off The Core\_1 can be switched off (CORE\_1 HALT ENTRY) by the Core\_0 writing into the ME\_PCTLx register, MC\_ME asserts the signal zcor\_halt and this signal from platform is used to gate the clock to Core\_1. The Core\_1 can be switched on (CORE\_1 HALT EXIT) by the Core\_0 writing into the ME\_PCTLx register, Core\_1 clock is enabled by MC\_ME. Together with Core\_1 clock, is switched off or switched on also the clock of all ON-platform\_1 peripherals (INTC, SWT, STM, ECSM, SEMA4). ME PCTL number for Core 1 is 127. #### 4.4 Clock behavior in STOP and HALT mode In this section the term "resume" is used to describe the transition from STOP and HALT mode back to a RUN mode. The SPC56xP60x/54x supports the STOP and the HALT modes. These two modes allow to put the device into a power saving mode with the configuration options defined in the ME module. The following constraints are applied on SPC56xP60x/54x to guarantee that in all modes of operation a resume from STOP or HALT mode is always possible without the need to reset: - STOP and HALT mode: - SIUL clock is not gateable - FCCU clock must not be gateable - SIUL filter for external interrupt capable pins is always clocked with IRC Clock Description RM0083 Resume via interrupt that can be generated by any peripheral that clock is not gated Resume via NMI pin is always possible if once enabled after reset (no software configuration that could block resume afterwards) #### STOP mode: - IRC can NOT be switched off - The System Clock Selector 0 is switched to the IRC and therefore the SYS\_CLK is feed by the IRC signal - Resume via external interrupt pin is always possible (if not masked) #### HALT mode: - The output of the System Clock Selector 0 can only be switched to a running clock input - Resume via external interrupt pin is always possible (if not masked) and IRC is not switched off ## 4.5 Software controlled power management/clock gating Some of the IP modules on this device support software controlled power management/clock gating whereby the application software can disable the non-memory-mapped portions of the modules by writing to module disable (MDIS) bits in registers within the modules. The memory-mapped portions of the modules are clocked by the system clock when they are being accessed. The NPC can be configured to disable the MCKO signal when there are no Nexus messages pending. The modules that implemented software controlled power management/clock gating are listed in *Table 10* along with the registers and bits that disable each module. The software controlled clocks are enabled when the MCU comes out of reset. Table 10. Software controlled power management/clock gating support | Module name | Register name | Bit names | |-------------|---------------|---------------------------------| | NPC | NPC_PCR | MCKO_EN, MCKO_GT <sup>(1)</sup> | <sup>1.</sup> Refer to Chapter 38: Nexus Port Controller (NPC). # 4.6 System clock functional safety This section shows the SPC56xP60x/54x modules used to detect clock failures: - The Clock Monitoring Unit (CMU\_0) monitors the clock frequency of the FMPLL\_0 and the XOSC signal against the IRC and provides clock out of range information about the monitored clock signals. - FMPLL\_0 provides a signal that indicates a loss of lock. Each loss of lock signal is sent to the CGM module. Upon the detection of one of the above mentioned failures, the SPC56xP60x/54x device either asserts a reset, generates an interrupt, or sends the device into the SAFE state. The reaction to each of the clock failures and system parameters (like active clocks and SYS\_CLK clock source) that become active in SAFE state are under software control and can be configured in the ME module. # 4.7 IRC 16 MHz internal RC oscillator (RC CTL) The IRC output frequency can be trimmed using RCTRIM bits. After a power-on reset, the IRC is trimmed using a factory test value stored in test flash memory. However, after a power-on reset the test flash memory value is not visible at RC\_CTL[RCTRIM], and this field shows a value of zero. Therefore, be aware that the RC\_CTL[RCTRIM] field does not reflect the current trim value until you have written to it. Pay particular attention to this feature when you initiate a read-modify-write operation on RC\_CTL, because a RCTRIM value of zero may be unintentionally written back and this may alter the IRC frequency. In this case, you should calibrate the IRC using the CMU. In this oscillator, two's complement trimming method is implemented. So the trimming code increases from -32 to 31. As the trimming code increases, the internal time constant increases and frequency reduces. Please refer to device datasheet for average frequency variation of the trimming step. Figure 11. RC Control register (RC\_CTL) Table 11. RC\_CTL field descriptions | Field | Description | |-------------|-----------------------| | RCTRIM[5:0] | Main RC trimming bits | # 4.8 XOSC external crystal oscillator The external crystal oscillator (XOSC) operates in the range of 4 MHz to 40 MHz. The XOSC digital interface contains the control and status registers accessible for the external crystal oscillator. Main features are: - Oscillator clock available interrupt - Oscillator bypass mode #### 4.8.1 Functional description The crystal oscillator circuit includes an internal oscillator driver and an external crystal circuitry. The XOSC provides an output clock to the PLL or it is used as a reference clock to specific modules depending on system needs. The crystal oscillator can be controlled by the ME: Control by ME module. The OSCON bit of the ME\_xxx\_MCRs controls the powerdown of oscillator based on the current device mode while S\_OSC of ME\_GS register provides the oscillator clock available status. After system reset, the oscillator is put to power down state and software has to switch on when required. Whenever the crystal oscillator is switched on from off state, OSCCNT counter starts and when it reaches the value EOCV[7:0] × 512, oscillator clock is made available to the system. Also an interrupt pending bit I\_OSC of OSC\_CTL register is set. An interrupt will be generated if the interrupt mask bit M\_OSC is set. The oscillator circuit can be bypassed by setting OSC\_CTL[OSCBYP]. This bit can only be set by the software. System reset is needed to reset this bit. In this bypass mode, the output clock has the same polarity as external clock applied on EXTAL pin and the oscillator status is forced to '1'. The bypass configuration is independent of the powerdown mode of the oscillator. Table 12 shows the truth table of different configurations of oscillator. | , , , , , , , , , , , , , , , , , , , | | | | | | |---------------------------------------|-----|-----------------------|-----------------------|---------|-----------------------| | ENABLE | ВҮР | XTALIN | EXTAL | CK_OSCM | XOSC Mode | | 0 | 0 | No crystal,<br>High Z | No crystal,<br>High Z | 0 | Power down, IDDQ | | х | 1 | х | Ext clock | EXTAL | Bypass, XOSC disabled | | 1 | 0 | Crystal | Crystal | EXTAL | Normal, XOSC enabled | Table 12. Crystal oscillator truth table # 4.8.2 Register description Table 13. OSC CTL memory map | Offset from OSC_CTL_BASE (0xC3FE_0000) | Register | Location | |----------------------------------------|-------------------------------------|-------------| | 0x0000 | OSC_CTL—Oscillator control register | on page 110 | | 0x0004-0x000F | Reserved | | Figure 12. Crystal Oscillator Control register (OSC\_CTL) Table 14. OSC\_CTL field descriptions | Field | Description | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OSCBYP | Crystal Oscillator bypass This bit specifies whether the oscillator should be bypassed or not. Software can only set this bit. System reset is needed to reset this bit. 0: Oscillator output is used as root clock. 1: EXTAL is used as root clock. | | EOCV[7:0] | End of Count Value These bits specify the end of count value to be used for comparison by the oscillator stabilization counter OSCCNT after reset or whenever it is switched on from the off state. This counting period ensures that external oscillator clock signal is stable before it can be selected by the system. When oscillator counter reaches the value EOCV[7:0]*512, oscillator available interrupt request is generated. The reset value of this field depends on the device specification. The OSCCNT counter will be kept under reset if oscillator bypass mode is selected. | | M_OSC | Crystal oscillator clock interrupt mask 0: Crystal oscillator clock interrupt masked 1: Crystal oscillator clock interrupt enabled | | I_OSC | Crystal oscillator clock interrupt This bit is set by hardware when OSCCNT counter reaches the count value EOCV[7:0]*512. It is cleared by software by writing 1. 0: No oscillator clock interrupt occurred 1: Oscillator clock interrupt pending | # 4.9 Frequency Modulated Phase Locked Loop (FMPLL) ## 4.9.1 Introduction This section describes the features and functions of the FMPLL module implemented in SPC56xP60x/54x. #### 4.9.2 Overview The FMPLL enables the generation of high speed system clocks from a common 4–40 MHz input clock. Further, the FMPLL supports programmable frequency modulation of the system clock. The PLL multiplication factor and output clock divider ratio are all software configurable. The FMPLL block diagram is shown in Figure 13. Output Division Factor IDF Charge (ODF) XOSC Pump Low Pass PHI BUFFER CR[ODF] VCO Filter DIV2 DIV4 Loop Division Factor (LDF) CR[NDIV] Figure 13. FMPLL block diagram #### 4.9.3 Features The FMPLL has the following major features: - Input clock frequency 4–40 MHz - Voltage controlled oscillator (VCO) range from 256 MHz to 512 MHz - Reduced frequency divider (RFD) for reduced frequency operation without forcing the FMPLL to relock - Frequency modulated PLL - Modulation enabled/disabled through software - Triangle wave modulation - Programmable modulation depth - ±0.25% to ±4% deviation from center spread frequency - –0.5% to +8% deviation from down spread frequency - Programmable modulation frequency dependent on reference frequency - Self-clocked mode (SCM) operation - 4 available modes - Normal mode - Progressive clock switching - Normal Mode with SSCG - Powerdown mode ## 4.9.4 Memory map *Table 15* shows the memory map locations. Addresses are given as offsets of the module base address. | Table | 15. | <b>FMPL</b> | .L mer | nory | map | |-------|-----|-------------|--------|------|-----| |-------|-----|-------------|--------|------|-----| | Offset from ME_CGM_BASE <sup>(1)</sup> FMPLL_0: 0xC3FE_00A0 | Register | Location | |-------------------------------------------------------------|------------------------|-------------| | 0x0000 | CR—Control Register | on page 113 | | 0x0004 | MR—Modulation register | on page 115 | | 0x0004-0x000F | Reserved | | <sup>1.</sup> FMPLL\_x are mapped through the ME\_CGM Register Slot. # 4.9.5 Register description The PLL operation is controlled by two registers. Those registers can only be written in supervisor mode. ## 4.9.5.1 Control Register (CR) Figure 14. Control Register (CR) Table 16. CR field descriptions | Field | Table 16. CR field descriptions Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IDF[3:0] | Input Division Factor The value of this field sets the PLL input division factor. 0000: Divide by 1 0001: Divide by 2 0010: Divide by 3 0011: Divide by 4 0100: Divide by 5 0101: Divide by 6 0110: Divide by 7 0111: Divide by 8 1000: Divide by 9 1001: Divide by 10 1010: Divide by 11 1011: Divide by 12 1100: Divide by 13 1101: Divide by 14 1110: Divide by 15 1111: Clock Inhibit | | ODF[1:0] | Output Division Factor The value of this field sets the PLL output division factor. 00: Divide by 2 01: Divide by 4 10: Divide by 8 11: Divide by 16 | | NDIV[6:0] | Loop Division Factor The value of this field sets the PLL loop division factor. 0000000–0011111: Reserved 0100000: Divide by 32 0100001: Divide by 33 0100010: Divide by 34 1011111: Divide by 95 1100000: Divide by 96 1100001–1111111: Reserved | | en_pll_sw | This bit is used to enable progressive clock switching. After the PLL locks, the PLL output initially is divided by 8, and then progressively decreases until it reaches divide-by-1. Note: The PLL output should not be used if a non-changing clock is needed, such as for serial communications, until the division has finished. 0: Progressive clock switching disabled 1: Progressive clock switching enabled | | unlock_once | This bit is a sticky indication of PLL loss of lock condition. Unlock_once is set when the PLL loses lock. Whenever the PLL reacquires lock, unlock_once remains set. unlock_once is cleared after a POR event. | 114/1102 Table 16. CR field descriptions(Continued) | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | i_lock | This bit is set by hardware whenever there is a lock/unlock event.It is cleared by software, writing 1. | | s_lock | This bit indicates whether the PLL has acquired lock. 0: PLL unlocked 1: PLL locked | | pll_fail_mask | This bit masks the pll_fail output. 0: pll_fail not masked 1: pll_fail masked | | pll_fail_flag | This bit is asynchronously set by hardware whenever a loss of lock event occurs while PLL is switched on. It is cleared by software, writing 1. | # 4.9.5.2 Modulation Register (MR) Figure 15. Modulation Register (MR) Table 17. MR field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STRB_BYPASS | Strobe bypass The STRB_BYPASS signal bypasses the STRB signal used inside the PLL to latch the correct values for control bits (INC_STEP, MOD_PERIOD and SPRD_SEL). 0: STRB latches the PLL modulation control bits. 1: STRB is bypassed. In this case, the control bits need to be static. The control bits must be changed only when PLL is in power down mode. | | SPRD_SEL | Spread type selection The SPRD_SEL bit selects the spread type in Frequency Modulation mode. 0: Center spread 1: Down spread | Table 17. MR field descriptions(Continued) | Description | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Modulation period The MOD_PERIOD field is the binary equivalent of the value modperiod derived from following formula: | | $modperiod = \frac{f_{ref}}{4 \times f_{mod}}$ | | where: fref: represents the frequency of the feedback divider fmod: represents the modulation frequency | | Frequency modulation enable The FM_EN bit enables the frequency modulation. 0: Frequency Modulation disabled 1: Frequency Modulation enabled | | Increment step The INC_STEP field is the binary equivalent of the value incstep derived from following formula: | | incstep = round $\left(\frac{(2^{15}-1)\times md \times MDF}{100\times 5\times MODPERIOD}\right)$ where:<br>md: represents the peak modulation depth in percentage | | (Center spread — pk-pk = ±md, Downspread — pk-pk = -2 × md) MDF: represents the nominal value of loop divider (NDIV in PLL Control Register). | | | ## 4.9.6 Functional description #### 4.9.6.1 Normal mode In Normal mode, the PLL inputs are driven by the Control Register (CR). This means that when the PLL is locked, the PLL output clock (PHI) is derived from the reference clock (XOSC) through this relationship: #### **Equation 1** $$phi = \frac{xosc \cdot ldf}{idf \cdot odf}$$ where the value of *idf* (Input Division Factor), *Idf* (Loop Division Factor), and *odf* (Output Division Factor) are set in the CR as shown in *Table 16. idf* and *odf* are specified in the IDF and ODF bitfields, respectively; *Idf* is specified in the NDIV bitfield. #### 4.9.6.2 Progressive clock switching Progressive clock switching allows to switch system clock to PLL output clock stepping through different division factors. This means that the current consumption gradually increases and, in turn, voltage regulator response is improved. This feature can be enabled by programming bit en\_pll\_sw in the CR. Then, when the PLL is selected as the system clock, the output clock progressively increases its frequency as shown in *Table 18*. | <u> </u> | <u> </u> | |-----------------------------------|---------------------------------------------| | Number of PLL output clock cycles | ck_pll_div frequency (PLL output frequency) | | 8 | (ck_pll_out frequency) ÷ 8 | | 16 | (ck_pll_out frequency) ÷ 4 | | 32 | (ck_pll_out frequency) ÷ 2 | | onward | (ck_pll_out frequency) | Table 18. Progressive clock switching on pll select rising edge Figure 16. Progressive clock switching scheme #### 4.9.6.3 Normal Mode with frequency modulation The FMPLL default mode is without frequency modulation enabled. When frequency modulation is enabled, however, two parameters must be set to generate the desired level of modulation: the PERIOD, and the STEP. The modulation waveform is always a triangle wave and its shape is not programmable. Frequency modulation is activated as follows: - 1. Configure the FM modulation characteristics: MOD\_PERIOD, INC\_STEP. - 2. Enable the FM modulation by programming bit SSCG\_EN of the MR to '1'. FM modulated mode can be enabled only when PLL is in lock state. There are two ways to latch these values inside the FMPLL, depending on the value of bit STRB BYPASS in the MR. If STRB\_BYPASS is low, the modulation parameters are latched in the PLL only when the strobe signal goes high. The strobe signal is automatically generated in the FMPLL when the modulation is enabled (SSCG\_EN goes high) if the PLL is locked (s\_lock = 1) or when the modulation has been enabled (SSCG\_EN = 1) and PLL enters in lock state (s\_lock goes high). If STRB\_BYPASS is high, the strobe signal is bypassed. In this case, control bits (MOD\_PERIOD[12:0], INC\_STEP[14:0], SPREAD\_CONTROL) must be changed only when the PLL is in power down mode. The modulation depth in % is #### **Equation 2** $$ModulationDepth = \left(\frac{100 \times 5 \times INCSTEPxMODPERIOD}{(2^{15} - 1) \times MDF}\right)$$ Note: The user must ensure that the product of INCSTEP and MODPERIOD is less than $(2^{15} - 1)$ . The following values show the input setting for one possible configuration of the PLL: - PLL input frequency: 4 MHz - Loop divider (LDF): 64 - Input divider (IDF): 1 - VCO frequency = 4 MHz × 64 = 256 MHz - PLL output frequency = 256 MHz/ODF - Spread: Center spread (SPREAD CONTROL = 0) - Modulation frequency = 24 kHz - Modulation depth = ±2.0% (4% pk-pk) Using the formula for MODPERIOD and INCSTEP: #### **Equation 3** $MODPERIOD = Round [(4e06) / (4 \times 24e03)] = Round [41.66] = 42$ #### **Equation 4** INCSTEP = Round $[((2^{15} - 1) \times 2 \times 64) / (100 \times 5 \times 42)]$ = Round [199.722] = 200 #### **Equation 5** MODPERIOD × INCSTEP = $42 \times 200 = 8400$ (which is less than $2^{15}$ ) #### **Equation 6** $md(quantized)\% = ((42*200*100*5) / ((2^15-1)*64) = 2.00278\% (peak)$ #### **Equation 7** Error in modulation depth = 2.00278 - 2.0 = 0.00278% If we choose MODPERIOD = 41, #### **Equation 8** INCSTEP = Round $[((2^{15} - 1) \times 2 \times 64) / (100 \times 5 \times 41)]$ = Round [204.878] = 205 #### **Equation 9** MODPERIOD × INCSTEP = $41 \times 205 = 8405$ (which is less than $2^{15}$ ) #### **Equation 10** $md(quantized)\% = ((41 \times 205 \times 100 \times 5) / ((2^{15} - 1) \times 64) = 2.00397\% (peak)$ #### **Equation 11** Error in modulation depth = 2.00397 - 2.0 = 0.00397% The above calculations show that the quantization error in the modulation depth depends on the flooring and rounding of MODPERIOD and INCSTEP. For this reason, the MODPERIOD and INCSTEP should be judiciously rounded/floored to minimize the quantization error in the modulation depth. Figure 17. Frequency modulation depth spreads #### 4.9.6.4 Powerdown mode To reduce consumption, the FMPLL can be switched off when not required by programming the registers ME $\,$ x MC on the ME module. #### 4.9.7 Recommendations To avoid any unpredictable behavior of the PLL clock, it is recommended to follow these guidelines: - The PLL VCO frequency should reside in the range 256 MHz to 512 MHz. Care is required when programming the multiplication and division factors to respect this requirement. - The user must change the multiplication, division factors only when the PLL output clock is not selected as system clock. MOD\_PERIOD, INC\_STEP, SPREAD\_SEL bits should be modified before activating the FM modulated mode. Then strobe has to be generated to enable the new settings. If STRB\_BYP is set to '1' then MOD\_PERIOD, INC\_STEP and SPREAD\_SEL can be modified only when PLL is in power down mode. - Use progressive clock switching. # 4.10 Clock Monitor Unit (CMU) #### 4.10.1 Overview The Clock Monitor Unit (CMU) serves three purposes: Selected clock monitoring: detect if the monitored clock leaves an upper or lower frequency boundary - XOSC clock monitoring: monitor the XOSC clock, which must be greater than the IRCOSC clock divided by a division factor given by CMU\_CSR[RCDIV] - Frequency meter: measure the frequency of the IRCOSC clock versus the reference XOSC clock frequency When mismatch occurs in the CMU either with the PLL monitor or the XOSC monitor, the CMU notifies the RGM, ME and the FCCU (Fault Collection and Control Unit) modules. The default behavior is such that a reset occurs and a status bit is set in the RGM. The user also has the option to change the behavior of the action by disabling the reset and selecting an alternate action. The alternate action can be either entering safe mode or generating an interrupt. Table 19. CMU module summary | Module | Monitored clocks | |--------|-----------------------------------------------------------------------------------------------------------------| | CMU_0 | <ul><li>XOSC integrity supervisor</li><li>FMPLL_0 integrity supervisor</li><li>IRCOSC frequency meter</li></ul> | | CMU_1 | System clock integrity supervisor | Figure 18. SPC56xP60x/54x with two CMUs ### 4.10.2 Main features - RC oscillator frequency measurement - External oscillator clock monitoring with respect to CK\_IRC/n clock - PLL clock frequency monitoring with respect to CK IRC/4 clock - Event generation for various failures detected inside monitoring unit ## 4.10.3 Functional description The clock and frequency names referenced in this block are defined as follows: - CK\_XOSC: clock coming from the external crystal oscillator - CK\_IRC: clock coming from the low frequency internal RC oscillator - CK\_PLL: clock coming from the PLL - f<sub>XOSC</sub>: frequency of external crystal oscillator clock - f<sub>RC</sub>: frequency of low frequency internal RC oscillator - f<sub>PLL</sub>: frequency of FMPLL clock ## 4.10.3.1 Crystal clock monitor<sup>(g)</sup> If $f_{XOSC}$ is smaller than $f_{RC}$ divided by $2^{RCDIV}$ bits of CMU\_0\_CSR and the CK\_XOSC is 'ON' and stable as signaled by the ME, then: - An event pending bit OLRI in CMU\_0\_ISR is set - A failure event OLR is signaled to the RGM and FCCU, which in turn can generate either an interrupt, a reset, or a SAFE mode request. #### 4.10.3.2 PLL clock monitor The PLL clock CK\_PLL frequency can be monitored by programming bit CME\_0 of the CMU\_0\_CSR to '1'. The CK\_PLL monitor starts as soon as bit CME\_0 is set. This monitor can be disabled at any time by writing bit CME\_0 to '0'. If the CK\_PLL frequency (f<sub>PLL</sub>) is greater than a reference value determined by bits HFREF[11:0] of the CMU\_HFREFR and the CK\_PLL is 'ON' and the PLL locked as signaled by the ME then: - An event pending bit FHHI\_0 in the CMU\_0\_ISR is set. - A failure event FHH is signaled to the RGM and FCCU, which in turn can generate either an interrupt, a reset, or a SAFE mode request. If $f_{PLL}$ is less than a reference clock frequency ( $f_{RC}/4$ ) and the CK\_PLL is 'ON' and the PLL locked as signaled by the ME, then an event pending bit FLCI\_0 in the CMU\_0\_ISR is set. If $f_{PLL}$ is less than a reference value determined by bits LFREF[11:0] of the CMU\_LFREFR and the CK\_PLL is 'ON' and the PLL locked as signaled by the ME, then: - An event pending bit FLLI\_0 in the CMU\_0\_ISR is set. - A failure event FLL is signaled to the RGM and FCCU, which in turn can generate either an interrupt, a reset, or a SAFE mode request. Note: It is possible for either the XOSC or PLL monitors to produce a false event when the XOSC or PLL frequency is too close to RC/2<sup>RCDIV</sup> frequency due to an accuracy limitation of the compare circuitry. #### 4.10.3.3 System clock monitor The system clock is monitored by CMU\_1. The $f_{SYS\_CLK}$ frequency can be monitored by programming CMU\_1\_CSR[CME] = 1. SYS\_CLK monitoring starts as soon as CMU\_1\_CSR[CME] = 1. This monitor can be disabled at any time by writing CME bit to 0. If f<sub>SYS\_CLK</sub> is greater than a reference value determined by the CMU\_1\_HFREFR\_0[HFREF] bits and the system clock is enabled, then: - CMU 1 ISR[FHHI] is set - A failure event is signaled to the MC\_RGM and FCCU, which in turn can generate a 'functional' reset, a SAFE mode request, or an interrupt If f<sub>SYS\_CLK</sub> is less than a reference clock frequency (F<sub>IRCOSC\_CLK</sub>÷4) and the system clock is enabled, then CMU\_1\_ISR[FLCI] is set. g. Enabled only in CMU\_0. If $f_{SYS\_CLK}$ is less than a reference value determined by the CMU\_1\_LFREFR\_0[LFREF] bits and the system clock is enabled, then: - CMU\_1\_ISR[FLLI] is set - A failure event is signaled to the MC\_RGM and FCCU, which in turn can generate a 'functional' reset, a SAFE mode request, or an interrupt Note: The system clock monitor may produce a false event when $f_{SYS\_CLK}$ is less than $2 \times f_{IRCOSC\_CLK}/2^{CMU\_1\_CSR[RCDIV]}$ due to an accuracy limitation of the compare circuitry. #### 4.10.3.4 Frequency meter The frequency meter calibrates the internal RC oscillator (CK\_IRC) using a known frequency. The frequency meter is implemented only on CMU\_0. Note: This value can then be stored into the flash so that application software can reuse it later on. The reference clock will be always the XOSC. A simple frequency meter returns a draft value of CK\_IRC. The measure starts when bit SFM (Start Frequency Measure) in the CMU\_CSR is set to '1'. The measurement duration is given by the CMU\_MDR in numbers of IRC clock cycles with a width of 20 bits. Bit SFM is reset to '0' by hardware once the frequency measurement is done and the count is loaded in the CMU\_FDR. The frequency $f_{RC}$ can be derived from the value loaded in the CMU\_FDR as follows: #### **Equation 12** $f_{RC} = (f_{OSC} \times MD) / n$ where *n* is the value in the CMU\_FDR and MD is the value in the CMU\_MDR. ### 4.10.4 Memory map and register description Table 20 shows the memory map of the CMU. Table 20. CMU memory map | Offset from<br>CMU_BASE<br>(0xC3FE_0100) | Register | Location | |------------------------------------------|------------------------------------------------------------|-------------| | 0x0000 | Control Status Register (CMU_0_CSR) | on page 124 | | 0x0004 | Frequency Display Register (CMU_0_FDR) | on page 125 | | 0x0008 | High Frequency Reference Register FMPLL_0 (CMU_0_HFREFR_0) | on page 125 | | 0x000C | Low Frequency Reference Register FMPLL_0 (CMU_0_LFREFR_0) | on page 126 | | 0x0010 | Interrupt Status Register (CMU_0_ISR) | on page 126 | | 0x0014 | Reserved | | | 0x0018 | Measurement Duration Register (CMU_0_MDR) | on page 127 | | 0x001C | Reserved | | | 0x0020 | Control Status Register (CMU_1_CSR) | on page 128 | | 0x0024 | Reserved | | | Table 20. CMU memory map(Continued) | Table 20. | CMU | memory | / map | (Continued) | |-------------------------------------|-----------|-----|--------|-------|-------------| |-------------------------------------|-----------|-----|--------|-------|-------------| | Offset from<br>CMU_BASE<br>(0xC3FE_0100) | Register | Location | |------------------------------------------|------------------------------------------------------------|-------------| | 0x0028 | High Frequency Reference Register SYS_CLK (CMU_1_HFREFR_0) | on page 128 | | 0x002C | Low Frequency Reference Register SYS_CLK (CMU_1_LFREFR_0) | on page 129 | | 0x0030 | Interrupt Status Register (CMU_1_ISR) | on page 129 | | 0x0034-0x3FFF | Reserved | | # 4.10.4.1 Control Status Register (CMU\_0\_CSR) Figure 19. Control Status Register (CMU\_0\_CSR) Table 21. CMU\_0\_CSR field descriptions | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SFM | Start frequency measure The software can only set this bit to start a clock frequency measure. It is reset by hardware when the measure is ready in the CMU_FDR. 0: Frequency measurement completed or not yet started 1: Frequency measurement not completed | | RCDIV[1:0] | RC clock division factor These bits specify the RC clock division factor. The output clock is CK_IRC divided by the factor 2 <sup>RCDIV</sup> . This output clock is compared with CK_XOSC for crystal clock monitor feature. The clock division coding is as follows. 00: Clock divided by 1 (no division) 01: Clock divided by 2 10: Clock divided by 4 11: Clock divided by 8 | | CME_0 | FMPLL_0 clock monitor enable 0: FMPLL_0 monitor disabled 1: FMPLL_0 monitor enabled | ## 4.10.4.2 Frequency Display Register (CMU\_0\_FDR) Figure 20. Frequency Display Register (CMU\_0\_FDR) Table 22. CMU\_0\_FDR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Measured frequency bits This register displays the measured frequency $f_{RC}$ with respect to $f_{OSC}$ . The measured value is given by the following formula: $f_{RC} = (f_{OSC} \times MD) / n$ , where n is the value in CMU_FDR. | # 4.10.4.3 High Frequency Reference Register FMPLL\_0 (CMU\_0\_HFREFR\_0) Figure 21. High Frequency Reference register FMPLL\_0 (CMU\_0\_HFREFR\_0) Table 23. CMU\_0\_HFREFR\_0 field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HFREF | High Frequency reference value These bits determine the high reference value for the FMPLL_0 clock. The reference value is given by: $(HFREF[11:0]/16) \times (f_{RC}/4)$ . | ## 4.10.4.4 Low Frequency Reference Register FMPLL\_0 (CMU\_0\_LFREFR\_0) | Address: | Address: Base + 0x000C Access: User read/write | | | | | | | | | | | | | | | | |----------|------------------------------------------------|----|----|----|----|----|----|----|----|------|---------|----|----|----|----|----| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | I | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | 0 | 0 | 0 | 0 | | | | | | LFRE | =[11.01 | | | | | | | W | | | | | | | | | | LINE | [11.0] | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 22. Low Frequency Reference Register FMPLL\_0 (CMU\_0\_LFREFR\_0) Table 24. CMU\_0\_LFREFR\_0 fields descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LFREF | Low Frequency reference value These bits determine the low reference value for the FMPLL_0. The reference value is given by: (LFREF[11:0]/16) * (f <sub>RC</sub> /4). | # 4.10.4.5 Interrupt Status Register (CMU\_0\_ISR) Figure 23. Interrupt Status Register (CMU\_0\_ISR) Table 25. CMU\_0\_ISR field descriptions | Field | Description | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FLCI_0 | FMPLL_0 Clock frequency less than reference clock interrupt This bit is set by hardware when CK_FMPLL_0 frequency becomes lower than reference clock frequency (f <sub>RC</sub> /4) value and CK_FMPLL_0 is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0: No FLC event 1: FLC event pending | Table 25. CMU\_0\_ISR field descriptions(Continued) | Field | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FHHI_0 | FMPLL_0 Clock frequency higher than high reference interrupt This bit is set by hardware when CK_FMPLL_0 frequency becomes higher than HFREF value and CK_FMPLL_0 is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0: No FHH event 1: FHH event pending | | FLLI_0 | FMPLL_0 Clock frequency less than low reference event This bit is set by hardware when CK_FMPLL_0 frequency becomes lower than LFREF value and CK_FMPLL_0 is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0: No FLL event 1: FLL event pending | | OLRI | Oscillator frequency less than RC frequency event This bit is set by hardware when the frequency of CK_XOSC is less than CK_IRC/2RCDIV frequency and CK_XOSC is 'ON' and stable as signaled by the ME. It can be cleared by software by writing 1. 0: No OLR event 1: OLR event pending | # 4.10.4.6 Measurement Duration Register (CMU\_0\_MDR) Figure 24. Measurement Duration Register (CMU\_0\_MDR) Table 26. CMU\_0\_MDR field descriptions | Field | Description | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MD[19:0] | Measurement duration bits This register displays the measured duration in term of IRC clock cycles. This value is loaded in the frequency meter downcounter. When SFM bit is set to '1', downcounter starts counting. | ## 4.10.4.7 Control Status Register (CMU\_1\_CSR) Figure 25. Control Status Register (CMU\_1\_CSR) Table 27. CMU\_1\_CSR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------| | CME_1 | SYS_CLK clock monitor enable 0 SYS_CLK monitor disabled 1 SYS_CLK monitor enabled | # 4.10.4.8 High Frequency Reference Register SYS\_CLK (CMU\_1\_HFREFR\_0) Figure 26. High Frequency Reference Register SYS\_CLK (CMU\_1\_HFREFR\_0) Table 28. CMU\_1\_HFREFR\_0 field descriptions | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HFREF[11:0] | High Frequency reference value These bits determine the high reference value for the SYS_CLK clock. The reference value is given by: $(HFREF[11:0]/16) \times (F_{RC}/4)$ . | # 4.10.4.9 Low Frequency Reference Register SYS\_CLK (CMU\_1\_LFREFR\_0) Figure 27. Low Frequency Reference Register SYS\_CLK (CMU\_1\_LFREFR\_0) #### Table 29. CMU\_1\_LFREFR\_0 field descriptions | Field | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LFREF[11:0] | Low Frequency reference value These bits determine the low reference value for the SYS_CLK clock. The reference value is given by: (LFREF[11:0]/16) × (f <sub>RC</sub> /4). | ## 4.10.4.10 Interrupt Status Register (CMU\_1\_ISR) Figure 28. Interrupt Status register (CMU\_1\_ISR) Table 30. CMU\_1\_ISR field descriptions | Field | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FLCI_1 | SYS_CLK clock frequency less than reference clock event. This bit is set by hardware when the SYS_CLK clock frequency is lower than the reference clock frequency (FRC/4) value and SYS_CLK is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0 No FLC event. 1 FLC event is pending. | Table 30. CMU\_1\_ISR field descriptions(Continued) | Field | Description | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FHHI_1 | SYS_CLK clock frequency higher than high reference event. This bit is set by hardware when the SYS_CLK frequency is higher than the HFREF value and SYS_CLK is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0 No FHH event. 1 FHH event is pending. | | FLLI_1 | SYS_CLK clock frequency less than low reference event. This bit is set by hardware when the SYS_CLK frequency becomes lower than LFREF value and SYS_CLK is 'ON' and the PLL locked as signaled by the ME. It can be cleared by software by writing 1. 0 No FLL event. 1 FLL event is pending. | # 5 Clock Generation Module (MC\_CGM) #### 5.1 Introduction ## 5.1.1 Overview The clock generation module (MC\_CGM) generates reference clocks for all the chip blocks. The MC\_CGM selects one of the system clock sources to supply the system clock. The MC\_ME controls the system clock selection (see the MC\_ME chapter for more details). A set of MC\_CGM registers controls the clock dividers which are used for divided system and peripheral clock generation. The memory spaces of system and peripheral clock sources which have addressable memory spaces are accessed through the MC\_CGM memory space. The MC\_CGM also selects and generates an output clock. Figure 29 shows the MC\_CGM block diagram. Figure 29. MC\_CGM Block Diagram #### 5.1.2 Features The MC\_CGM includes the following features: - generates system and peripheral clocks - selects and enables/disables the system clock supply from system clock sources according to MC\_ME control - contains a set of registers to control clock dividers for divided clock generation - supports multiple clock sources and maps their address spaces to its memory map - generates an output clock - guarantees glitch-less clock transitions when changing the system clock selection - supports 8, 16, and 32-bit wide read/write accesses # 5.2 External Signal Description The MC\_CGM delivers an output clock to the PAD[22] pin for off-chip use and/or observation. # 5.3 Memory Map and Register Definition Table 31. MC\_CGM Register Description | Address | Name | Description | Size | | Access | | Location | |-----------------|-------------|----------------------------------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FE<br>_0370 | CGM_OC_EN | Output Clock Enable | word | read | read/write | read/write | on page 137 | | 0xC3FE<br>_0374 | CGM_OCDS_SC | Output Clock Division<br>Select | byte | read | read/write | read/write | on page 138 | | 0xC3FE<br>_0378 | CGM_SC_SS | System Clock Select<br>Status | byte | read | read | read | on page 139 | | 0xC3FE<br>_0380 | CGM_AC0_SC | Aux Clock 0 Select<br>Control | word | read | read/write | read/write | on page 140 | | 0xC3FE<br>_0384 | CGM_AC0_DC0 | Aux Clock 0 Divider<br>Configuration 0 | byte | read | read/write | read/write | on page 140 | | 0xC3FE<br>_0388 | CGM_AC1_SC | Aux Clock 1 Select<br>Control | word | read | read/write | read/write | on page 141 | | 0xC3FE<br>_038C | CGM_AC1_DC0 | Aux Clock 1 Divider<br>Configuration 0 | byte | read | read/write | read/write | on page 142 | | 0xC3FE<br>_0390 | CGM_AC2_SC | Aux Clock 2 Select<br>Control | word | read | read/write | read/write | on page 142 | | 0xC3FE<br>_0394 | CGM_AC2_DC0 | Aux Clock 2 Divider<br>Configuration 0 | byte | read | read/write | read/write | on page 143 | Table 31. MC\_CGM Register Description(Continued) | Address | Name | Description | Size | | Access | | Location | |-----------------|-------------|----------------------------------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FE<br>_0398 | CGM_AC3_SC | Aux Clock 3 Select<br>Control | word | read | read/write | read/write | on page 144 | | 0xC3FE<br>_039C | CGM_AC3_DC0 | Aux Clock 3 Divider<br>Configuration 0 | byte | read | read/write | read/write | on page 144 | Note: Any access to unused registers as well as write accesses to read-only registers will: - not change register content - cause a transfer error ## Table 32, MC CGM Memory Map | | | | ıa | bie 3 | 52. IVI | <u>C_C</u> | GIVI I | vieme | ory IV | пар | | | | | | | | |-----------------------------------------------------------|------|---|----|-------|---------|------------|---------|---------|--------|-----|---------|----|----------|----------|----------|----------|----------| | Address | Name | 0 | 1 | 2 | 3<br>19 | 4 20 | 5<br>21 | 6<br>22 | 7 23 | 8 | 9<br>25 | 10 | 11<br>27 | 12<br>28 | 13<br>29 | 14<br>30 | 15<br>31 | | 0xC3FE_<br>0000<br><br>0xC3FE_<br>001C<br>0xC3FE_<br>0020 | | 1 | 1 | | | | | regist | | | | 1 | 1 | 1 - | | | | | <br>0xC3FE_<br>005F | | | | | | | res | erved | | | | | | | | | | | 0xC3FE_<br>0060<br><br>0xC3FE_<br>007C | | | | | | | IRC r | egiste | rs | | | | | | | | | | 0xC3FE_<br>0080<br><br>0xC3FE_<br>009F | | | | | | | res | erved | | | | | | | | | | | 0xC3FE_<br>00A0<br><br>0xC3FE_<br>00BC | | | | | | FM | IPLL_ | 0 regi | sters | | | | | | | | | | 0xC3FE_<br>00C0<br><br>0xC3FE_<br>00FF | | | | | | | res | erved | | | | | | | | | | # Table 32. MC\_CGM Memory Map(Continued) | | | | 1 | 16 32 | | _ | | | _ | | | · · | ,<br> | | | | | | |-----------------|-----------|-----------------------|----|-------|-----|-----|----|-----|--------|-----|----|-----|-------|----|----|----|----|----| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | 0xC3FE_ | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0100 | | CMU0 registers | | | | | | | | | | | | | | | | | | 0xC3FE_<br>011C | | | | | | | | | | | | | | | | | | | | 0xC3FE_<br>0120 | | | | | | | C | MU1 | regist | ers | | | | | | | | | | 0xC3FE_<br>013C | | - | | | | | | | | | | | | | | | | | | 0xC3FE_<br>0140 | | ronanyad | | | | | | | | | | | | | | | | | | 0xC3FE_<br>015C | | reserved | | | | | | | | | | | | | | | | | | 0xC3FE_<br>0160 | | OLK DIV 050 vel ten | | | | | | | | | | | | | | | | | | 0xC3FE_<br>017C | | CLK_DIV_256 registers | | | | | | | | | | | | | | | | | | 0xC3FE_<br>0180 | | | | | | | | ros | erved | | | | | | | | | | | 0xC3FE_<br>036F | | | | | | | | 103 | ei veu | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE_ | CGM_OC_EN | W | | | | | | | | | | | | | | | | | | 0370 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | EN | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | SEL | DIV | | SEL | CTL | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE_ | CGM_OCDS_ | W | | | | ı | | 1 | П | | | | | | | | | | | 0374 | sc | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | | SEL | STAT | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE_ | CGM_SC_SS | W | | | | | | | | | | | | | | | | | | 0378 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE_<br>037C | | | | | | | | res | erved | | | | | | | | | | Table 32. MC\_CGM Memory Map(Continued) | | | | IUN | | | | , 141 141 | | _ | • ` | | | | | | | | | |---------|-----------|---|-----|----|----|----|-----------|--------|--------|-----|----|----|----|----|----|----|----|----| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | R | 0 | 0 | 0 | 0 | | SEL | СТІ | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | CGM_AC0_S | W | | | | | | OLL | SELOTE | | | | | | | | | | | 0380 | С | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | CGM_AC0_D | R | DE0 | 0 | 0 | 0 | | DI | \/O | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0384 | C0 | W | ۵ | | | | | ы | VU | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | | SEL | CTI | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE_ | CGM_AC1_S | W | | | | | | SEL | CIL | | | | | | | | | | | 0388 | C | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | CGM_AC1_D | R | 0. | 0 | 0 | 0 | | DIV0 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | C0 | W | DE0 | | | | | DI | VU | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | | SELCTL | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE | CGM_AC2_S | W | | | | | | SEL | CIL | | | | | | | | | | | 0390 | с | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE | CGM_AC2_D | R | 0. | 0 | 0 | 0 | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0394 | C0 | W | DE0 | | | | | DI | VU | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | | 0=: | O.T. | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FF | CGM_AC3_S | W | | | | | | SEL | CTL | | | | | | | | | | | 0398 | C C | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | L | L | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | - 7 9- | | | | | | | | | |---------------------|-----------|---|-----|----|----|----|----|------|-------|--------|----|----|----|----|----|----|----|----| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | Addiess | Hame | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FE_ | CGM_AC3_D | R | DE0 | 0 | 0 | 0 | | DI | V0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 039C | C0 | W | DE | | | | | וט | VU | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE_<br>0400 | | | | | | | | | | | | | | | | | | | | <br>0xC3FE_<br>3FFC | | | | | | | | rese | erved | | | | | | | | | | Table 32. MC CGM Memory Map(Continued) # 5.3.1 Register Descriptions All registers may be accessed as 32-bit words, 16-bit half-words, or 8-bit bytes. The bytes are ordered according to big endian. For example, the **CGM\_OC\_EN** register may be accessed as a word at address 0xC3FE\_0370, as a half-word at address 0xC3FE\_0372, or as a byte at address 0xC3FE\_0373. ## 5.3.1.1 Output Clock Enable Register (CGM\_OC\_EN) Figure 30. Output Clock Enable Register (CGM\_OC\_EN) This register is used to enable and disable the output clock. Table 33. Output Clock Enable Register (CGM\_OC\_EN) Field Descriptions | Field | Description | |-------|-----------------------------| | | Output Clock Enable control | | EN | 0 Output Clock is disabled | | | 1 Output Clock is enabled | # 5.3.1.2 Output Clock Division Select Register (CGM\_OCDS\_SC) Figure 31. Output Clock Division Select Register (CGM\_OCDS\_SC) This register is used to select the current output clock source and by which factor it is divided before being delivered at the output clock. Table 34. Output Clock Division Select Register (CGM\_OCDS\_SC) Field Descriptions | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SELDIV | Output Clock Division Select 00 output selected Output Clock without division 01 output selected Output Clock divided by 2 10 output selected Output Clock divided by 4 11 output selected Output Clock divided by 8 | | SELCTL | Output Clock Source Selection Control — This value selects the current source for the output clock. 0000 IRC 0001 XOSC 0010 FMPLL_0 0011 reserved 0100 reserved 0101 reserved 0111 reserved 1010 reserved 1000 reserved 1001 reserved 1001 reserved 1001 reserved 1101 | # 5.3.1.3 System Clock Select Status Register (CGM\_SC\_SS) Figure 32. System Clock Select Status Register (CGM\_SC\_SS) This register provides the current system clock source selection. Table 35. System Clock Select Status Register (CGM\_SC\_SS) Field Descriptions | Field | Description | |---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SELSTAT | System Clock Source Selection Status — This value indicates the current source for the system clock. 0000 IRC 0001 reserved 0010 XOSC 0011 reserved 0100 FMPLL_0 PCS 0101 reserved 0110 reserved 0111 reserved 1010 reserved 1001 reserved 1001 reserved 1001 reserved 1011 reserved 1011 reserved 1011 reserved 1011 reserved 1011 reserved 1101 reserved 1101 reserved 1101 reserved 1101 reserved 1101 reserved 1101 reserved | ## 5.3.1.4 Auxiliary Clock 0 Select Control Register (CGM\_AC0\_SC) | Address 0xC3FE_0380 | | | | | Access: User read, Supervisor read/write, Test read/write | | | | | | d/write | | | | | | |---------------------|----|----|----|----|-----------------------------------------------------------|-----|-----|----|----|----|---------|----|----|----|----|----| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | | SEL | CTI | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | JLL | OIL | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | _ | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 33. Auxiliary Clock 0 Select Control Register (CGM\_AC0\_SC) This register is used to select the current clock source for the following clocks: - undivided: (unused) - divided by auxiliary clock 0 divider 0: (unused) See Figure 42 for details. Table 36. Auxiliary Clock 0 Select Control Register (CGM\_AC0\_SC) Field Descriptions | Field | |--------| | SELCTL | | | ## 5.3.1.5 Auxiliary Clock 0 Divider 0 Configuration Register (CGM\_AC0\_DC0) Figure 34. Auxiliary Clock 0 Divider 0 Configuration Register (CGM\_AC0\_DC0) This register controls auxiliary clock 0 divider 0. Table 37. Auxiliary Clock 0 Divider 0 Configuration Register (CGM\_AC0\_DC0) Field Descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DE0 | Divider 0 Enable 0 Disable auxiliary clock 0 divider 0 1 Enable auxiliary clock 0 divider 0 | | DIV0 | Divider 0 Division Value — The resultant (unused) will have a period 'DIV0 + 1' times that of auxiliary clock 0. If the DE0 is set to 0 (Divider 0 is disabled), any write access to the DIV0 field is ignored and the (unused) remains disabled. | ## 5.3.1.6 Auxiliary Clock 1 Select Control Register (CGM\_AC1\_SC) Figure 35. Auxiliary Clock 1 Select Control Register (CGM\_AC1\_SC) This register is used to select the current clock source for the following clocks: - undivided: (unused) - divided by auxiliary clock 1 divider 0: (unused) Table 38. Auxiliary Clock 1 Select Control Register (CGM\_AC1\_SC) Field Descriptions | Field | Description | |--------|--------------------------------------------------------------------------------------------------------| | | Auxiliary Clock 1 Source Selection Control — This value selects the current source for auxiliary clock | | | | | | 0000 (no clock) | | | 0001 reserved | | | 0010 reserved | | | 0011 reserved | | | 0100 reserved | | | 0101 reserved | | SELCTL | 0110 reserved | | 022012 | 0111 reserved | | | 1000 reserved | | | 1001 reserved | | | 1010 reserved | | | 1011 reserved | | | 1100 reserved | | | 1101 reserved | | | 1110 reserved | | | 1111 reserved | ## 5.3.1.7 Auxiliary Clock 1 Divider 0 Configuration Register (CGM\_AC1\_DC0) Address0xC3FE\_038C Access: User read, Supervisor read/write, Test read/write 0 0 0 0 R DIV0 DE0 0 0 0 0 0 0 Reset 1 0 Figure 36. Auxiliary Clock 1 Divider 0 Configuration Register (CGM\_AC1\_DC0) These registers controls auxiliary clock 1 divider 0. Table 39. Auxiliary Clock 1 Divider 0 Configuration Register (CGM\_AC1\_DC0) Field Descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DE0 | Divider 0 Enable 0 Disable auxiliary clock 1 divider 0 1 Enable auxiliary clock 1 divider 0 | | DIV0 | Divider 0 Division Value — The resultant (unused) will have a period 'DIV0 + 1' times that of auxiliary clock 1. If the DE0 is set to 0 (Divider 0 is disabled), any write access to the DIV0 field is ignored and the (unused) remains disabled. | #### 5.3.1.8 Auxiliary Clock 2 Select Control Register (CGM\_AC2\_SC) Figure 37. Auxiliary Clock 2 Select Control Register (CGM\_AC2\_SC) This register is used to select the current clock source for the following clocks: - undivided: (unused) - divided by auxiliary clock 2 divider 0: (unused) See Figure 44 for details. Table 40. Auxiliary Clock 2 Select Control Register (CGM\_AC2\_SC) Field Descriptions | Field | Description | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SELCTL ( | Auxiliary Clock 2 Source Selection Control — This value selects the current source for auxiliary clock 2. 0000 (no clock) 0001 reserved 0010 (no clock) 0011 reserved 0100 (no clock) 0101 reserved 0110 reserved 0110 reserved 1010 reserved 1001 reserved 1001 reserved 1001 reserved 1001 reserved 1001 reserved 1011 reserved 1011 reserved 1011 reserved 1011 reserved 1011 reserved 1111 reserved 1111 reserved | ## 5.3.1.9 Auxiliary Clock 2 Divider 0 Configuration Register (CGM\_AC2\_DC0) Figure 38. Auxiliary Clock 2 Divider 0 Configuration Register (CGM\_AC2\_DC0) These registers controls auxiliary clock 2 divider 0. Table 41. Auxiliary Clock 2 Divider 0 Configuration Register (CGM\_AC2\_DC0) Field Descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DE0 | Divider 0 Enable 0 Disable auxiliary clock 2 divider 0 1 Enable auxiliary clock 2 divider 0 | | DIV0 | Divider 0 Division Value — The resultant (unused) will have a period 'DIV0 + 1' times that of auxiliary clock 2. If the DE0 is set to 0 (Divider 0 is disabled), any write access to the DIV0 field is ignored and the (unused) remains disabled. | ## 5.3.1.10 Auxiliary Clock 3 Select Control Register (CGM\_AC3\_SC) | Address: 0xC3FE_0398 | | | | | | | Access: User read, Supervisor read/write, Test read/write | | | | | | | | | | |----------------------|----|----|----|----|----|-----|-----------------------------------------------------------|----|----|----|----|----|----|----|----|----| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | | SEL | CTI | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | SEL | CIL | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | I | | | | I | | | | I | | | | | _ | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 39. Auxiliary Clock 3 Select Control Register (CGM\_AC3\_SC) This register is used to select the current clock source for the following clocks: - undivided: (unused) - divided by auxiliary clock 3 divider 0: FlexRay clock See Figure 45 for details. Table 42. Auxiliary Clock 3 Select Control Register (CGM\_AC3\_SC) Field Descriptions | Field | Description | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SELCTL | Auxiliary Clock 3 Source Selection Control — This value selects the current source for auxiliary clock 3. 0000 IRC 0001 reserved 0010 XOSC 0011 reserved 0100 FMPLL_0 0101 reserved 0110 reserved 0111 reserved 1000 FMPLL_0_D1 1001 reserved 1101 | # 5.3.1.11 Auxiliary Clock 3 Divider 0 Configuration Register (CGM\_AC3\_DC0) Figure 40. Auxiliary Clock 3 Divider 0 Configuration Register (CGM\_AC3\_DC0) These registers controls auxiliary clock 3 dividers 0. Table 43. Auxiliary Clock 3 Divider 0 Configuration Register (CGM\_AC3\_DC0) Field Descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DE0 | Divider 0 Enable 0 Disable auxiliary clock 3 divider 0 1 Enable auxiliary clock 3 divider 0 | | DIV0 | Divider 0 Division Value — The resultant FlexRay clock will have a period 'DIV0 + 1' times that of auxiliary clock 3. If the DE0 is set to 0 (Divider 0 is disabled), any write access to the DIV0 field is ignored and the FlexRay clock remains disabled. | ## 5.4 Functional Description ### 5.4.1 System Clock Generation Figure 41 shows the block diagram of the system clock generation logic. The MC\_ME provides the system clock select and switch mask (see MC\_ME chapter for more details), and the MC\_RGM provides the safe clock request (see MC\_RGM chapter for more details). The safe clock request forces the selector to select the IRC as the system clock and to ignore the system clock select. Figure 41. MC\_CGM System Clock Generation Overview ### 5.4.1.1 System Clock Source Selection During normal operation, the system clock selection is controlled - on a **SAFE** mode or reset event, by the MC\_RGM - otherwise, by the MC\_ME ### 5.4.1.2 System Clock Disable During the *TEST* mode, the system clock can be disabled by the MC\_ME. ### 5.4.2 Auxiliary Clock Generation Figure 42 shows the block diagram of the auxiliary clock generation logic. See Section 5.3.1.4: Auxiliary Clock 0 Select Control Register (CGM\_AC0\_SC), Section 5.3.1.6: Auxiliary Clock 1 Select Control Register (CGM\_AC1\_SC), Section 5.3.1.8: Auxiliary Clock 2 Select Control Register (CGM\_AC2\_SC), and Section 5.3.1.10: Auxiliary Clock 3 Select Control Register (CGM\_AC3\_SC) for auxiliary clock selection control. Figure 42. MC\_CGM Auxiliary Clock 0 Generation Overview Figure 43. MC\_CGM Auxiliary Clock 1 Generation Overview Figure 45. MC\_CGM Auxiliary Clock 3 Generation Overview ### 5.4.2.1 Auxiliary Clock Dividers The MC CGM generates the following derived clocks: - (unused) controlled by the CGM\_AC0\_DC0 register - (unused) controlled by the CGM\_AC1\_DC0 register - (unused) controlled by the CGM\_AC2\_DC0 register - FlexRay clock controlled by the CGM\_AC3\_DC0 register ### 5.4.3 Dividers Functional Description Dividers are used for the generation of divided system and peripheral clocks. The MC\_CGM has the following control registers for built-in dividers: - Section 5.3.1.5: Auxiliary Clock 0 Divider 0 Configuration Register (CGM\_ACO\_DC0) - Section 5.3.1.7: Auxiliary Clock 1 Divider 0 Configuration Register (CGM AC1 DC0) - Section 5.3.1.9: Auxiliary Clock 2 Divider 0 Configuration Register (CGM\_AC2\_DC0) - Section 5.3.1.11: Auxiliary Clock 3 Divider 0 Configuration Register (CGM\_AC3\_DC0) The reset value of all counters is '1'. If a divider has its **DE** bit in the respective configuration register set to '0' (the divider is disabled), any value in its **DIV***n* field is ignored. ### 5.4.4 Output Clock Multiplexing The MC\_CGM contains a multiplexing function for a number of clock sources which can then be used as output clock sources. The selection is done via the **CGM\_OCDS\_SC** register. ### 5.4.5 Output Clock Division Selection CGM\_OCDS\_SC.SELCTL Register CGM\_OCDS\_SC.SELDIV Register Figure 46. MC\_CGM Output Clock Multiplexer and PAD[22] Generation The MC CGM provides the following output signal for the output clock generation: PAD[22] (see Figure 46). This signal is generated by using one of the 3-stage ripple counter outputs or the selected signal without division. The non-divided signal is not guaranteed to be 50% duty cycle by the MC\_CGM. The MC\_CGM also has an output clock enable register (see Section 5.3.1.1: Output Clock Enable Register (CGM\_OC\_EN)) that contains the output clock enable/disable control bit. # 6 Mode Entry Module (MC\_ME) ### 6.1 Introduction ### 6.1.1 Overview The MC\_ME controls the chip mode and mode transition sequences in all functional states. It also contains configuration, control and status registers accessible for the application. Figure 47 shows the MC\_ME block diagram. MC\_ME **VREG** Flashes Registers Register Interface $MC\_RGM$ **IRC** XOSC MC\_CGM FMPLL\_0 core Chip Mode State Machine peripherals WKPU Figure 47. MC\_ME Block Diagram ### 6.1.2 Features The MC ME includes the following features: - control of the available modes by the ME ME register - definition of various chip mode configurations by the ME\_<mode>\_MC registers - control of the actual chip mode by the ME\_MCTL register - capture of the current mode and various resource status within the contents of the ME\_GS register - optional generation of various mode transition interrupts - status bits for each cause of invalid mode transitions - peripheral clock gating control based on the ME\_RUN\_PC0...7, ME\_LP\_PC0...7, and ME\_PCTLn registers - · capture of current peripheral clock gated/enabled status ### 6.1.3 Modes of Operation The MC\_ME is based on several chip modes corresponding to different usage models of the chip. Each mode is configurable and can define a policy for energy and processing power management to fit particular system requirements. An application can easily switch from one mode to another depending on the current needs of the system. The operating modes controlled by the MC\_ME are divided into system and user modes. The system modes are modes such as *RESET*, *DRUN*, *SAFE*, and *TEST*. These modes aim to ease the configuration and monitoring of the system. The user modes are modes such as *RUN0...3*, *HALT0*, and *STOP0* which can be configured to meet the application requirements in terms of energy management and available processing power. The modes *DRUN*, *SAFE*, *TEST*, and *RUN0...3* are the chip software running modes. Table 44 describes the MC\_ME modes. Table 44. MC\_ME Mode Descriptions | Name | Description | Entry | Exit | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | RESET | This is a chip-wide virtual mode during which the application is not active. The system remains in this mode until all resources are available for the embedded software to take control of the chip. It manages hardware initialization of chip configuration, voltage regulators, clock sources, and flash modules. | system reset<br>assertion from<br>MC_RGM | system reset<br>deassertion from<br>MC_RGM | | DRUN | This is the entry mode for the embedded software. It provides full accessibility to the system and enables the configuration of the system at startup. It provides the unique gate to enter user modes. BAM when present is executed in <b>DRUN</b> mode. | system reset<br>deassertion from<br>MC_RGM,<br>software request<br>from SAFE, TEST<br>and RUN03 | system reset<br>assertion,<br><i>RUN03</i> , <i>TEST</i><br>via software,<br><i>SAFE</i> via software<br>or hardware<br>failure. | | SAFE | This is a chip-wide service mode which may be entered on the detection of a recoverable error. It forces the system into a pre-defined safe configuration from which the system may try to recover. | hardware failure,<br>software request<br>from <b>DRUN</b> , <b>TEST</b> ,<br>and <b>RUN03</b> | system reset<br>assertion, <b>DRUN</b><br>via software | | Name | Description | Entry | Exit | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | TEST | This is a chip-wide service mode which is intended to provide a control environment for chip software testing. | software request from <b>DRUN</b> | system reset<br>assertion, <b>DRUN</b><br>via software | | RUN03 | These are software running modes where most processing activity is done. These various run modes allow to enable different clock & power configurations of the system with respect to each other. | software request from <i>DRUN</i> or other <i>RUN03</i> , interrupt event from <i>HALT0</i> , interrupt or wakeup event from <i>STOP0</i> | system reset assertion, SAFE via software or hardware failure, other RUN03 modes, HALTO, STOPO via software | | HALT0 | This is a reduced-activity low-power mode during which the clock to the core is disabled. It can be configured to switch off analog peripherals like clock sources, flash, main regulator, etc. for efficient power management at the cost of higher wakeup latency. | software request from <i>RUN03</i> | system reset<br>assertion, <b>SAFE</b><br>on hardware<br>failure, <b>RUN03</b><br>on interrupt event | | STOP0 | This is an advanced low-power mode during which the clock to the core is disabled. It may be configured to switch off most of the peripherals including clock sources for efficient power management at the cost of higher wakeup latency. | software request from <i>RUN03</i> | system reset<br>assertion, <b>SAFE</b><br>on hardware<br>failure, <b>RUN03</b><br>on interrupt event<br>or wakeup event | Table 44. MC\_ME Mode Descriptions(Continued) # 6.2 External Signal Description The MC\_ME has no connections to any external pins. # 6.3 Memory Map and Register Definition The MC\_ME contains registers for: - Mode selection and status reporting - Mode configuration - Mode transition interrupts status and mask control - Scalable number of peripheral sub-mode selection and status reporting ### 6.3.1 Memory Map Table 45. MC\_ME Register Description | Address | Name | Description | Size | | Access | | Location | |-----------------|---------|---------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FD<br>_C000 | ME_GS | Global Status | word | read | read | read | on page 162 | | 0xC3FD<br>_C004 | ME_MCTL | Mode Control | word | read | read/write | read/write | on page 164 | Table 45. MC\_ME Register Description(Continued) | | | e 43. MC_ME Register | | | Access | • | | |-----------------|-------------|-----------------------------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FD<br>_C008 | ME_ME | Mode Enable | word | read | read/write | read/write | on page 165 | | 0xC3FD<br>_C00C | ME_IS | Interrupt Status | word | read | read/write | read/write | on page 166 | | 0xC3FD<br>_C010 | ME_IM | Interrupt Mask | word | read | read/write | read/write | on page 167 | | 0xC3FD<br>_C014 | ME_IMTS | Invalid Mode Transition<br>Status | word | read | read/write | read/write | on page 168 | | 0xC3FD<br>_C018 | ME_DMTS | Debug Mode Transition<br>Status | word | read | read | read | on page 169 | | 0xC3FD<br>_C020 | ME_RESET_MC | RESET Mode<br>Configuration | word | read | read | read | on page 172 | | 0xC3FD<br>_C024 | ME_TEST_MC | TEST Mode<br>Configuration | word | read | read/write | read/write | on page 173 | | 0xC3FD<br>_C028 | ME_SAFE_MC | SAFE Mode<br>Configuration | word | read | read/write | read/write | on page 173 | | 0xC3FD<br>_C02C | ME_DRUN_MC | <b>DRUN</b> Mode Configuration | word | read | read/write | read/write | on page 174 | | 0xC3FD<br>_C030 | ME_RUN0_MC | <b>RUN0</b> Mode<br>Configuration | word | read | read/write | read/write | on page 174 | | 0xC3FD<br>_C034 | ME_RUN1_MC | <b>RUN1</b> Mode Configuration | word | read | read/write | read/write | on page 174 | | 0xC3FD<br>_C038 | ME_RUN2_MC | <b>RUN2</b> Mode<br>Configuration | word | read | read/write | read/write | on page 174 | | 0xC3FD<br>_C03C | ME_RUN3_MC | <b>RUN3</b> Mode<br>Configuration | word | read | read/write | read/write | on page 174 | | 0xC3FD<br>_C040 | ME_HALT0_MC | HALTO Mode<br>Configuration | word | read | read/write | read/write | on page 175 | | 0xC3FD<br>_C048 | ME_STOP0_MC | STOP0 Mode<br>Configuration | word | read | read/write | read/write | on page 175 | | 0xC3FD<br>_C060 | ME_PS0 | Peripheral Status 0 | word | read | read | read | on page 177 | | 0xC3FD<br>_C064 | ME_PS1 | Peripheral Status 1 | word | read | read | read | on page 177 | | 0xC3FD<br>_C068 | ME_PS2 | Peripheral Status 2 | | read | read | read | on page 178 | | 0xC3FD<br>_C06C | ME_PS3 | Peripheral Status 3 | word | read | read | read | on page 178 | | 0xC3FD<br>_C080 | ME_RUN_PC0 | Run Peripheral<br>Configuration 0 | word | read | read/write | read/write | on page 179 | Table 45. MC\_ME Register Description(Continued) | Address | Nome | Description | Size | | Access | | Location | |-----------------|------------|-----------------------------------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FD<br>_C084 | ME_RUN_PC1 | Run Peripheral<br>Configuration 1 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C088 | ME_RUN_PC2 | Run Peripheral<br>Configuration 2 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C08C | ME_RUN_PC3 | Run Peripheral<br>Configuration 3 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C090 | ME_RUN_PC4 | Run Peripheral<br>Configuration 4 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C094 | ME_RUN_PC5 | Run Peripheral<br>Configuration 5 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C048 | ME_RUN_PC6 | Run Peripheral<br>Configuration 6 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C09C | ME_RUN_PC7 | Run Peripheral<br>Configuration 7 | word | read | read/write | read/write | on page 179 | | 0xC3FD<br>_C0A0 | ME_LP_PC0 | Low-Power Peripheral<br>Configuration 0 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0A4 | ME_LP_PC1 | Low-Power Peripheral<br>Configuration 1 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0A8 | ME_LP_PC2 | Low-Power Peripheral<br>Configuration 2 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0AC | ME_LP_PC3 | Low-Power Peripheral<br>Configuration 3 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0B0 | ME_LP_PC4 | Low-Power Peripheral<br>Configuration 4 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0B4 | ME_LP_PC5 | Low-Power Peripheral<br>Configuration 5 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0B8 | ME_LP_PC6 | Low-Power Peripheral<br>Configuration 6 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0BC | ME_LP_PC7 | Low-Power Peripheral<br>Configuration 7 | word | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0C4 | ME_PCTL4 | DSPI0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0C5 | ME_PCTL5 | DSPI1 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0C6 | ME_PCTL6 | DSPI2 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0C7 | ME_PCTL7 | DSPI3 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0C8 | ME_PCTL8 | DSPI4 Control | byte | read | read/write | read/write | on page 180 | Table 45. MC\_ME Register Description(Continued) | Address | Name | Description | Size | | Access | | Location | |-----------------|------------|--------------------|------|------|------------|------------|-------------| | Address | Name | Description | Size | User | Supervisor | Test | Location | | 0xC3FD<br>_C0D0 | ME_PCTL16 | FlexCAN0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0D1 | ME_PCTL17 | FlexCAN1 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0D8 | ME_PCTL24 | FlexRay Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0DA | ME_PCTL26 | SafetyPort Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0E0 | ME_PCTL32 | ADC0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0E3 | ME_PCTL35 | CTU0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0E6 | ME_PCTL38 | eTimer0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0E7 | ME_PCTL39 | eTimer1 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0F0 | ME_PCTL48 | LIN_FLEX0 Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C0F1 | ME_PCTL49 | LIN_FLEX1 Control | byte | read | read/write | read/write | on page 180 | | | | | | | | | | | 0xC3FD<br>_C11C | ME_PCTL92 | PIT_RTI Control | byte | read | read/write | read/write | on page 180 | | 0xC3FD<br>_C13F | ME_PCTL127 | CORE1 Control | | read | read/write | read/write | on page 180 | Note: Any access to unused registers as well as write accesses to read-only registers will: - not change register content - cause a transfer error Table 46. MC\_ME Memory Map | | 1 able 46. MC_ME Memory Map | | | | | | | | | | | | | | | | | | |-----------------|-----------------------------|---|------|------|--------|------------|----------|-------|----|-------|-------|-----------|--------|------------|---------|---------|--------|------------| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | R | S_Cl | JRRE | NT_M | ODE | S_MTRANS | 1 | 0 | 0 | oad-s | 0 | 0 | S_MVR | S_D | FLA | S_C | FLA | | 0xC3FD | ME 00 | W | | | | | | | | | | | | | | | | | | _C000 | ME_GS | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S_FMPLL_0 | osox-s | S_IRC | | S_SY | SCLK | | | | | W | | | | | | | | | | | | | | | | | | | | R | ТΛ | DCET | MOI | )E | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FD | ME_MCTL | W | IA | NGE | _IVIOL | <i>J</i> L | | | | | | | | | | | | | | _C004 | IVIL_IVICTE | R | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | W | | | | | | | | K | ΈY | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ME_ME R | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C008 | | R | 0 | 0 | 0 | 0 | 0 | STOP0 | 0 | HALTO | RUN3 | RUN2 | RUN1 | RUNO | DRUN | SAFE | TEST | RESET_FUNC | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C00C | ME_IS | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | I_ICONF_CU | I_ICONF | I_IMODE | I_SAFE | I_MTC | | | | W | | | | | | | | | | | | w1c | w1c | w1c | w1c | w1c | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | _ | | | | | | 0xC3FD | ME IM | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | no. | ш | Е | 111 | | | OXC3FD<br>_C010 | ME_IM | W | | | | | | | | | | | | M_ICONF_CU | M_ICONF | M_IMODE | M_SAFE | M_MTC | | | | | | | ). IVIC | | | | | | | | | 4.4 | 4.0 | 4.0 | 4.4 | 4- | |-----------------|-----------------|---|-----|--------------|--------------|-----------------|----------|-----------|-----------|-----------|----------------|-----------|----------|----------|-----------------|----------------|----------------|---------------| | Address | Name | | 16 | 17 | 18 | 3<br>19 | 20 | 5<br>21 | 22 | 7<br>23 | 24 | 9<br>25 | 10<br>26 | 11<br>27 | 12<br>28 | 13<br>29 | 14<br>30 | 15<br>31 | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C014 | ME_IMTS | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S_MTI | S_MRI | S_DMA | S_NMA | S_SEA | | | | W | | | | | | | | | | | | w1c | w1c | w1c | w1c | w1c | | | | R | PRE | EVIOL | JS_MC | DDE | 0 | 0 | 0 | 0 | MPH_BUSY | 0 | 0 | PMC_PROG | CORE_DBG | 0 | 0 | SMR | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C018 | ME_DMTS | R | 0 | VREG_CSRC_SC | csrc_csrc_sc | IRC_SC | scsrc_sc | SYSCLK_SW | DFLASH_SC | CFLASH_SC | CDP_PRPH_0_143 | 0 | 0 | 0 | CDP_PRPH_96_127 | CDP_PRPH_64_95 | CDP_PRPH_32_63 | CDP_PRPH_0_31 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C01C | | I | | | | | | rese | rved | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 0 0 0 0 0 0 0 | | MVRON | DFL | AON | CFL | AON | | | | | | | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C020 | ME_RESET_<br>MC | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FMPLL_00N | XOSCON | IRCON | | SYS | CLK | | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | 0xC3FD | ME_TEST_M | W | | | | | | | | | | | | | | | | | | _C024 | С | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00<br>NO0 | NC | z | | | | | | | w | | | | | | | | | | | FMPLL_00N | XOSCON | IRCON | | SYS | CLK | | | | | | | JIE 40 | | | _ | . , | _ | 1- ( | | | , | | 1 | | | | |-----------------|-----------------|---|----|--------|----|----|----|------|------|------|-----|-----------|--------|-------|--------|-----|-----|-----| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FD<br>_C028 | ME_SAFE_M<br>C | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FMPLL_00N | XOSCON | IRCON | | SYS | CLK | | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C02C | ME_DRUN_M<br>C | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FMPLL_00N | XOSCON | IRCON | SYSCLK | | | | | | | W | | | | | | | | | | -MP | X | | | | | | | 0xC3FD<br>_C030 | ME_RUN03<br>_MC | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | 0xC3FD<br>_C03C | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FMPLL_00N | XOSCON | IRCON | | SYS | CLK | | | | | W | | | | | | | | | | FMP | × | | | | | | | | ME_HALT0_<br>MC | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | _ | | W | | | | | | | | | | | | | 1 | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Z | 7 | | | | | | | | | W | | | | | | | | | | FMPLL_00N | XOSCON | IRCON | SYSCLK | | | | | 0xC3FD<br>_C044 | | | | | | | | rese | rved | | | | | | | | | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |----------------------------------------|-----------------|---|----|----|----|-----------|----|--------------|------|-----------|-----------|-----------|---------|---------|--------|-----|-------------|-------------| | Address | Name | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FD<br>_C048 | ME_STOP0_<br>MC | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | | AON | CFL | | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FMPLL_00N | XOSCON | IRCON | | SYS | CLK | | | | | W | | | | | | | | | | FMP | X | | | | | | | 0xC3FD<br>_C04C<br><br>0xC3FD<br>_C05C | | | | | | | | rese | rved | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | S_SafetyPort | 0 | S_FlexRay | 0 | 0 | 0 | 0 | 0 | 0 | S_FlexCAN1 | S_FIexCAN0 | | 0xC3FD | ME_PS0 | W | | | | | | | | | | | | | | | | | | _C060 | ME_PS0 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S_DSPI4 | S_DSP13 | S_DSP12 | S_DSP11 | S_DSP10 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | S_CRC1 | 0 | S_CRC0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S_LIN_FLEX1 | S_LIN_FLEX0 | | 0xC3FD<br>_C064 | ME_PS1 | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S_eTimer1 | S_eTimer0 | 0 | 0 | s_ctu0 | 0 | 0 | S_ADC0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD | ME_PS2 | R | 0 | 0 | 0 | S_PIT_RTI | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | _C068 | WL_1 02 | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | I | | | | | _''''_ | | , | | F ( - | 1 | | -, | | | | | | |----------------------------------------|--------------------|---|---------|-------|-----|--------|----|-------|------|-------|------|----------------|------|--------|------|------|--------|-------| | Address | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FD | ME DOO | R | S_CORE1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | _C06C | ME_PS3 | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C070 | | | | | | | | rese | rved | | | | | | | | | | | 0xC3FD<br>_C074<br><br>0xC3FD<br>_C07C | | | | | | | | rese | rved | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FD<br>_C080 | | W | | | | | | | | | | | | | | | | | | 0xC3FD<br>_C09C | ME_RUN_PC<br>07 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | RUN3 | RUN2 | RUN1 | RUNO | DRUN | SAFE | TEST | RESET | | | | W | | | | | | | | | | | | | | | | | | 0xC3FD | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | _C0A0 | ME_LP_PC0 | W | | | | | | | | | | | | | | | | | | 0xC3FD | 7 | R | 0 | 0 | 0 | 0 | 0 | STOP0 | 0 | HALT0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | _C0BC | | W | | | | | | ST | | ¥ | | | | | | | | | | 0xC3FD | | R | 0 | DBG_F | | CFC | 2 | DII | N_C | -EC | 0 | H <sub>1</sub> | | _P_CF | :C | DI | JN_CF | -G | | _C0C0 | ME_PCTL0 | W | | | LI | _0, 0 | , | 110 | IN_C | 1 0 | | _bag_ | | _1 _01 | G | IXC | JIN_CI | G | | 0xC3FD | 143 <sup>(1)</sup> | R | 0 | DBG_F | 1.5 | CFC | _ | יום | N_C | ·FC | 0 | 3_F | | _P_CF | | Di | JN_CF | | | _C14C | | W | | DBC | LF | | פ | KU | IN_C | rG | | DBG_ | | _P_CF | ·G | K | JIN_CI | -G | | 0xC3FD<br>_C150<br><br>0xC3FD<br>FFFC | reserved | | | | | | | | | | | | | | | | | | | _ | l | | | | | | | | | | | | | | | | | | There is space in the register map for 144 peripherals. Please refer to Table 45 for the ME\_PCTLn locations actually occupied. The unoccupied locations contain a read-only byte value of 0x00. ## 6.3.2 Register Description Unless otherwise noted, all registers may be accessed as 32-bit words, 16-bit half-words, or 8-bit bytes. The bytes are ordered according to big endian. For example, the **ME\_RUN\_PC0** register may be accessed as a word at address 0xC3FD\_C080, as a half-word at address 0xC3FD\_C082, or as a byte at address 0xC3FD\_C083. Some fields may be read-only, and their reset value of '1' or '0' and the corresponding behavior cannot be changed. ### 6.3.2.1 Global Status Register (ME\_GS) Figure 48. Global Status Register (ME\_GS) This register contains global mode status. Table 47. Global Status Register (ME\_GS) Field Descriptions | Field | Description | |--------------------|-----------------------------------------------------------------------------------------------| | S_CURREN<br>T_MODE | Current chip mode status 0000 | | S_MTRANS | Mode transition status 0 Mode transition process is not active 1 Mode transition is ongoing | Table 47. Global Status Register (ME\_GS) Field Descriptions(Continued) | Field | Description | | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | S_PDO | Output power-down status — This bit specifies output power-down status of I/Os. This bit is asserted whenever outputs of pads are forced to high impedance state or the pads power sequence driver is switched off. O No automatic safe gating of I/Os used and pads power sequence driver is enabled In SAFE/TEST modes, outputs of pads are forced to high impedance state and the pads power sequence driver is disabled. The inputs are level unchanged. In STOPO mode, only the pad power sequence driver is disabled, but the state of the output remains functional. | | | S_MVR | Main voltage regulator status 0 Main voltage regulator is not ready 1 Main voltage regulator is ready for use | | | S_DFLA | Data flash availability status 00 Data flash is not available 01 Data flash is in power-down mode 10 Data flash is not available 11 Data flash is in normal mode and available for use | | | S_CFLA | Code flash availability status 00 Code flash is not available 01 Code flash is in power-down mode 10 Code flash is in low-power mode 11 Code flash is in normal mode and available for use | | | S_FMPLL_0 | system PLL status 0 0 system PLL is not stable 1 system PLL is providing a stable clock | | | s_xosc | external oscillator status 0 external oscillator is not stable 1 external oscillator is providing a stable clock | | | S_IRC | internal RC oscillator status 0 internal RC oscillator is not stable 1 internal RC oscillator is providing a stable clock | | | S_SYSCLK | System clock switch status — These bits specify the system clock currently used by the system. 0000 IRC 0001 reserved 0010 XOSC 0011 reserved 0100 FMPLL_0 PCS 0101 reserved 0110 reserved 1010 reserved 1001 reserved 1001 reserved 1001 reserved 1001 reserved 1001 reserved 1010 reserved 1011 reserved 1011 reserved 1101 reserved 1101 reserved 1101 reserved 1101 reserved 1101 reserved 1101 system clock is disabled | | ### 6.3.2.2 Mode Control Register (ME\_MCTL) Figure 49. Mode Control Register (ME\_MCTL) This register is used to trigger software-controlled mode changes. Depending on the modes as enabled by **ME\_ME** register bits, configurations corresponding to unavailable modes are reserved and access to **ME\_<mode>\_MC** registers must respect this for successful mode requests. Note: Byte and half-word write accesses are not allowed for this register as a predefined key is required to change its value. Table 48. Mode Control Register (ME\_MCTL) Field Descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TARGET_M<br>ODE | Target chip mode — These bits provide the target chip mode to be entered by software programming. The mechanism to enter into any mode by software requires the write operation twice: first time with key, and second time with inverted key. These bits are automatically updated by hardware while entering SAFE on hardware request. Also, while exiting from the HALTO and STOPO modes on hardware exit events, these are updated with the appropriate RUNO3 mode value. 0000 RESET (triggers a 'functional' reset event) 0001 TEST 0010 SAFE 0011 DRUN 0100 RUNO 0101 RUN1 0110 RUN2 0111 RUN3 1000 HALTO 1001 reserved 1101 reserved 1101 reserved 1101 reserved 1111 reserved | | KEY | Control key — These bits enable write access to this register. Any write access to the register with a value different from the keys is ignored. Read access will always return inverted key. KEY:0101101011110000 (0x5AF0) INVERTED KEY:1010010100001111 (0xA50F) | ### Address 0xC3FD\_C008 Access: User read, Supervisor read/write, Test read/write R Reset ### 6.3.2.3 Mode Enable Register (ME\_ME) Figure 50. Mode Enable Register (ME\_ME) This register allows a way to disable the chip modes which are not required for a given chip. RESET, SAFE, DRUN, and RUN0 modes are always enabled. Table 49. Mode Enable Register (ME\_ME) Field Descriptions | Field | Description | |-------|--------------------------------------------------------------------| | STOP0 | STOP0 mode enable 0 STOP0 mode is disabled 1 STOP0 mode is enabled | | HALT0 | HALTO mode enable 0 HALTO mode is disabled 1 HALTO mode is enabled | | RUN3 | RUN3 mode enable 0 RUN3 mode is disabled 1 RUN3 mode is enabled | | RUN2 | RUN2 mode enable 0 RUN2 mode is disabled 1 RUN2 mode is enabled | | RUN1 | RUN1 mode enable 0 RUN1 mode is disabled 1 RUN1 mode is enabled | | RUN0 | RUN0 mode enable 1 RUN0 mode is enabled | | DRUN | DRUN mode enable 1 DRUN mode is enabled | | SAFE | SAFE mode enable 1 SAFE mode is enabled | Table 49. Mode Enable Register (ME\_ME) Field Descriptions(Continued) | Field | Description | |------------|------------------------------------------------------------------------------------| | TEST | TEST mode enable 0 TEST mode is disabled 1 TEST mode is enabled | | RESET_FUNC | 'functional' <i>RESET</i> mode enable 1 'functional' <i>RESET</i> mode is enabled | ### 6.3.2.4 Interrupt Status Register (ME\_IS) Figure 51. Interrupt Status Register (ME\_IS) This register provides the current interrupt status. Table 50. Interrupt Status Register (ME\_IS) Field Descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | I_ICONF_CU | Invalid mode configuration interrupt (Clock Usage) — This bit is set during a mode transition if a clock which is required to be on by an enabled peripheral is configured to be turned off. It is cleared by writing a '1' to this bit. No invalid mode configuration (clock usage) interrupt occurred Invalid mode configuration (clock usage) interrupt is pending | | I_ICONF | Invalid mode configuration interrupt — This bit is set whenever a write operation to ME_ <mode>_MC registers with invalid mode configuration is attempted. It is cleared by writing a '1' to this bit. 0 No invalid mode configuration interrupt occurred 1 Invalid mode configuration interrupt is pending</mode> | | I_IMODE | Invalid mode interrupt — This bit is set whenever an invalid mode transition is requested. It is cleared by writing a '1' to this bit. 0 No invalid mode interrupt occurred 1 Invalid mode interrupt is pending | Table 50. Interrupt Status Register (ME\_IS) Field Descriptions(Continued) | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | I_SAFE | SAFE mode interrupt — This bit is set whenever the chip enters SAFE mode on hardware requests generated in the system. It is cleared by writing a '1' to this bit. 0 No SAFE mode interrupt occurred 1 SAFE mode interrupt is pending | | I_MTC | Mode transition complete interrupt — This bit is set whenever the mode transition process completes (S_MTRANS transits from 1 to 0). It is cleared by writing a '1' to this bit. This mode transition interrupt bit will not be set while entering low-power modes <i>HALT0</i> , or <i>STOP0</i> . O No mode transition complete interrupt occurred Mode transition complete interrupt is pending | ### 6.3.2.5 Interrupt Mask Register (ME\_IM) Figure 52. Interrupt Mask Register (ME\_IM) This register controls whether an event generates an interrupt or not. Table 51. Interrupt Mask Register (ME\_IM) Field Descriptions | Field | Description | |------------|----------------------------------------------------------------------------------------------------------------------------------| | M_ICONF_CU | Invalid mode configuration (clock usage) interrupt mask 0 Invalid mode interrupt is masked 1 Invalid mode interrupt is enabled | | M_ICONF | Invalid mode configuration interrupt mask 0 Invalid mode interrupt is masked 1 Invalid mode interrupt is enabled | | M_IMODE | Invalid mode interrupt mask 0 Invalid mode interrupt is masked 1 Invalid mode interrupt is enabled | Table 51. Interrupt Mask Register (ME\_IM) Field Descriptions(Continued) | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------| | M_SAFE | SAFE mode interrupt mask 0 SAFE mode interrupt is masked 1 SAFE mode interrupt is enabled | | M_MTC | Mode transition complete interrupt mask 0 Mode transition complete interrupt is masked 1 Mode transition complete interrupt is enabled | ### 6.3.2.6 Invalid Mode Transition Status Register (ME\_IMTS) Figure 53. Invalid Mode Transition Status Register (ME\_IMTS) This register provides the status bits for the possible causes of an invalid mode interrupt. Table 52. Invalid Mode Transition Status Register (ME\_IMTS) Field Descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S_MTI | Mode Transition Illegal status — This bit is set whenever a new mode is requested while some other mode transition process is active (S_MTRANS is '1'). Please refer to Section 6.4.5: Mode Transition Interrupts for the exceptions to this behavior. It is cleared by writing a '1' to this bit. 0 Mode transition requested is not illegal 1 Mode transition requested is illegal | | S_MRI | Mode Request Illegal status — This bit is set whenever the target mode requested is not a valid mode with respect to current mode. It is cleared by writing a '1' to this bit. O Target mode requested is not illegal with respect to current mode 1 Target mode requested is illegal with respect to current mode | | S_DMA | Disabled Mode Access status — This bit is set whenever the target mode requested is one of those disabled modes determined by ME_ME register. It is cleared by writing a '1' to this bit. O Target mode requested is not a disabled mode 1 Target mode requested is a disabled mode | Table 52. Invalid Mode Transition Status Register (ME IMTS) Field Descriptions(Continued) | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S_NMA | Non-existing Mode Access status — This bit is set whenever the target mode requested is one of those non existing modes determined by ME_ME register. It is cleared by writing a '1' to this bit. O Target mode requested is an existing mode 1 Target mode requested is a non-existing mode | | S_SEA | SAFE Event Active status — This bit is set whenever the chip is in SAFE mode, SAFE event bit is pending and a new mode requested other than RESET/SAFE modes. It is cleared by writing a '1' to this bit. 0 No new mode requested other than RESET/SAFE while SAFE event is pending 1 New mode requested other than RESET/SAFE while SAFE event is pending | ### 6.3.2.7 Debug Mode Transition Status Register (ME\_DMTS) Figure 54. Debug Mode Transition Status Register (ME\_DMTS) This register provides the status of different factors which influence mode transitions. It is used to give an indication of why a mode transition indicated by **ME\_GS.S\_MTRANS** may be taking longer than expected. Note: The **ME\_DMTS** register does not indicate whether a mode transition is ongoing. Therefore, some **ME\_DMTS** bits may still be asserted after the mode transition has completed. 577 Table 53. Debug Mode Transition Status Register (ME\_DMTS) Field Descriptions | Field | Description Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PREVIOUS_MODE | Previous chip mode — These bits show the mode in which the chip was prior to the latest change to the current mode. 0000 RESET 0001 TEST 0010 SAFE 0011 DRUN 0100 RUN0 0101 RUN1 0110 RUN2 0111 RUN3 1000 HALT0 1001 reserved 1100 reserved 1101 reserved 1111 reserved 1111 reserved | | MPH_BUSY | MC_ME/MC_PCU Handshake Busy indicator — This bit is set if the MC_ME has requested a mode change from the MC_PCU and the MC_PCU has not yet responded. It is cleared when the MC_PCU has responded. 0 Handshake is not busy 1 Handshake is busy | | PMC_PROG | MC_PCU Mode Change in Progress indicator — This bit is set if the MC_PCU is in the process of powering up or down power domains. It is cleared when all power-up/down processes have completed. 0 Power-up/down transition is not in progress 1 Power-up/down transition is in progress | | CORE_DBG | Processor is in Debug mode indicator — This bit is set while the processor is in debug mode. 0 The processor is not in debug mode 1 The processor is in debug mode | | SMR | SAFE mode request from MC_RGM is active indicator — This bit is set if a hardware SAFE mode request has been triggered. It is cleared when the hardware SAFE mode request has been cleared. 0 A SAFE mode request is not active 1 A SAFE mode request is active | | VREG_CSRC_SC | Main VREG dependent Clock Source State Change during mode transition indicator — This bit is set when a clock source which depends on the main voltage regulator to be powered-up is requested to change its power up/down state. It is cleared when the clock source has completed its state change. O No state change is taking place A state change is taking place | | CSRC_CSRC_SC | (Other) Clock Source dependent Clock Source State Change during mode transition indicator — This bit is set when a clock source which depends on another clock source to be powered-up is requested to change its power up/down state. It is cleared when the clock source has completed its state change. O No state change is taking place A state change is taking place | Table 53. Debug Mode Transition Status Register (ME\_DMTS) Field Descriptions(Continued) | Field | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRC_SC | IRC State Change during mode transition indicator — This bit is set when the internal RC oscillator is requested to change its power up/down state. It is cleared when the internal RC oscillator has completed its state change. | | | No state change is taking place A state change is taking place | | SCSRC_SC | Secondary Clock Sources State Change during mode transition indicator — This bit is set when a secondary clock source is requested to change its power up/down state. It is cleared when all secondary system clock sources have completed their state changes. (A 'secondary clock source' is a clock source other than IRC.) 0 No state change is taking place 1 A state change is taking place | | | System Clock Switching pending status — | | SYSCLK_SW | No system clock source switching is pending A system clock source switching is pending | | DFLASH_SC | DFLASH State Change during mode transition indicator — This bit is set when the DFLASH is requested to change its power up/down state. It is cleared when the DFLASH has completed its state change. 0 No state change is taking place | | | 1 A state change is taking place | | CFLASH_SC | CFLASH State Change during mode transition indicator — This bit is set when the CFLASH is requested to change its power up/down state. It is cleared when the DFLASH has completed its state change. 0 No state change is taking place 1 A state change is taking place | | CDP_PRPH_0_143 | Clock Disable Process Pending status for Peripherals 0143 <sup>(1)</sup> — This bit is set when any peripheral has been requested to have its clock disabled. It is cleared when all the peripherals which have been requested to have their clocks disabled have entered the state in which their clocks may be disabled. 0 No peripheral clock disabling is pending 1 Clock disabling is pending for at least one peripheral | | CDP_PRPH_96_127 | Clock Disable Process Pending status for Peripherals 96127 <sup>(1)</sup> — This bit is set when any peripheral appearing in <b>ME_PS3</b> has been requested to have its clock disabled. It is cleared when all these peripherals which have been requested to have their clocks disabled have entered the state in which their clocks may be disabled. 0 No peripheral clock disabling is pending 1 Clock disabling is pending for at least one peripheral | | CDP_PRPH_64_95 | Clock Disable Process Pending status for Peripherals 6495 <sup>(1)</sup> — This bit is set when any peripheral appearing in <b>ME_PS2</b> has been requested to have its clock disabled. It is cleared when all these peripherals which have been requested to have their clocks disabled have entered the state in which their clocks may be disabled. | | | No peripheral clock disabling is pending Clock disabling is pending for at least one peripheral | Table 53. Debug Mode Transition Status Register (ME\_DMTS) Field Descriptions(Continued) | Field | Description | | | | | | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | CDP_PRPH_32_63 | Clock Disable Process Pending status for Peripherals 3263 <sup>(1)</sup> — This bit is set when any peripheral appearing in <b>ME_PS1</b> has been requested to have its clock disabled. It is cleared when all these peripherals which have been requested to have their clocks disabled have entered the state in which their clocks may be disabled. | | | | | | | | No peripheral clock disabling is pending Clock disabling is pending for at least one peripheral | | | | | | | CDP_PRPH_0_31 | Clock Disable Process Pending status for Peripherals 031 <sup>(1)</sup> — This bit is set when any peripheral appearing in <b>ME_PS0</b> has been requested to have its clock disabled. It is cleared when all these peripherals which have been requested to have their clocks disabled have entered the state in which their clocks may be disabled. O No peripheral clock disabling is pending Clock disabling is pending for at least one peripheral | | | | | | Peripheral n corresponds to the ME\_PCTLn register. Please refer to Table 45 for the ME\_PCTLn locations actually occupied, which in turn indicates which peripherals are reported in the ME\_DMTS register. ### 6.3.2.8 *RESET* Mode Configuration Register (ME\_RESET\_MC) Figure 55. RESET Mode Configuration Register (ME\_RESET\_MC) This register configures system behavior during **RESET** mode. Please refer to *Table 54* for details. ### Address 0xC3FD\_C024 Access: User read, Supervisor read/write, Test read/write MVRON R PDO **DFLAON** CFLAON Reset R FMPLL\_00N XOSCON RCON SYSCLK W Reset ### 6.3.2.9 *TEST* Mode Configuration Register (ME\_TEST\_MC) Figure 56. TEST Mode Configuration Register (ME\_TEST\_MC) This register configures system behavior during *TEST* mode. Please refer to *Table 54* for details. Note: Byte write accesses are not allowed to this register. ### 6.3.2.10 SAFE Mode Configuration Register (ME\_SAFE\_MC) Figure 57. SAFE Mode Configuration Register (ME\_SAFE\_MC) This register configures system behavior during **SAFE** mode. Please refer to *Table 54* for details Note: Byte write accesses are not allowed to this register. ### 6.3.2.11 DRUN Mode Configuration Register (ME\_DRUN\_MC) | Address 0xC3FD_C02C Access: User read, Superviso | | | | | | | ervisor | read/v | vrite, Te | est rea | d/write | | | | | | |--------------------------------------------------|----|----|----|----|-------|----|---------|--------|-----------|---------|---------|-------|-----|-----|-----|-----| | • | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PDO | 0 | 0 | MVRON | DFL | AON | CFL | AON | | W | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | | | | | | '<br> | | | | I | | | | | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | T_00N | XOSCON | IRCON | | SYS | CLK | | | W | | | | | | | | | | FMPLL | X | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Figure 58. DRUN Mode Configuration Register (ME\_DRUN\_MC) This register configures system behavior during **DRUN** mode. Please refer to *Table 54* for details. Note: Byte write accesses are not allowed to this register. ### 6.3.2.12 RUN0...3 Mode Configuration Registers (ME\_RUN0...3\_MC) Figure 59. RUN0...3 Mode Configuration Registers (ME\_RUN0...3\_MC) This register configures system behavior during *RUN0...3* modes. Please refer to *Table 54* for details. Note: Byte write accesses are not allowed to this register. Reset ### Address 0xC3FD\_C040 Access: User read, Supervisor read/write, Test read/write MVRON PDO R **DFLAON** CFLAON Reset R FMPLL\_00N XOSCON RCON SYSCLK W ### **HALTO Mode Configuration Register (ME\_HALTO\_MC)** 6.3.2.13 Figure 60. HALTO Mode Configuration Register (ME\_HALTO\_MC) This register configures system behavior during *HALT0* mode. Please refer to *Table 54* for Note: Byte write accesses are not allowed to this register. ### 6.3.2.14 STOP0 Mode Configuration Register (ME\_STOP0\_MC) Figure 61. STOP0 Mode Configuration Register (ME\_STOP0\_MC) This register configures system behavior during STOP0 mode. Please refer to Table 54 for details. Note: Byte write accesses are not allowed to this register. Table 54. Mode Configuration Registers (ME\_<mode>\_MC) Field Descriptions | Field | Description | | | | | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | PDO | <ul> <li>I/O output power-down control — This bit controls the output power-down of I/Os.</li> <li>No automatic safe gating of I/Os used and pads power sequence driver is enabled</li> <li>In SAFE/TEST modes, outputs of pads are forced to high impedance state and pads power sequence driver is disabled. The inputs are level unchanged. In STOP0 mode, only the pad power sequence driver is disabled, but the state of the output remains functional.</li> </ul> | | | | | | MVRON | Main voltage regulator control — This bit specifies whether main voltage regulator is switched off or not while entering this mode. 1 Main voltage regulator is switched on | | | | | | DFLAON | Data flash power-down control — This bit specifies the operating mode of the data flash after entering this mode. 00 reserved 10 Data flash is in power-down mode 10 reserved 11 Data flash is in normal mode | | | | | | CFLAON | Code flash power-down control — This bit specifies the operating mode of the code flash after entering this mode. 00 reserved 01 Code flash is in power-down mode 10 Code flash is in low-power mode 11 Code flash is in normal mode | | | | | | FMPLL_0ON | system PLL control 0 system PLL is switched off 1 system PLL is switched on | | | | | | XOSCON | external oscillator control 0 external oscillator is switched off 1 external oscillator is switched on | | | | | | IRCON | internal RC oscillator control 0 internal RC oscillator is switched off 1 internal RC oscillator is switched on | | | | | | SYSCLK | System clock switch control — These bits specify the system clock to be used by the system. 0000 IRC 0001 reserved 0010 XOSC 0011 reserved 0100 FMPLL_0 PCS 0101 reserved 0110 reserved 1010 reserved 1011 reserved 1000 reserved 1001 reserved 1001 reserved 1011 reserved 1010 reserved 1011 reserved 1101 system clock is disabled in <i>TEST</i> mode, reserved in all other modes | | | | | ### Address 0xC3FD\_C060 Access: User read, Supervisor read, Test read SafetyPort S\_FlexCAN0 S\_FlexCAN1 FlexRay R ဟ Reset DSP12 DSPI3 DSPI0 S\_DSP14 S\_DSP11 R $^{\circ}$ ω<sup>l</sup> Reset ### 6.3.2.15 Peripheral Status Register 0 (ME\_PS0) Figure 62. Peripheral Status Register 0 (ME\_PS0) This register provides the status of the peripherals. Please refer to *Table 55* for details. ### 6.3.2.16 Peripheral Status Register 1 (ME\_PS1) Figure 63. Peripheral Status Register 1 (ME\_PS1) This register provides the status of the peripherals. Please refer to *Table 55* for details. ### 6.3.2.17 Peripheral Status Register 2 (ME\_PS2) Figure 64. Peripheral Status Register 2 (ME\_PS2) This register provides the status of the peripherals. Please refer to *Table 55* for details. ### 6.3.2.18 Peripheral Status Register 3 (ME\_PS3) Figure 65. Peripheral Status Register 3 (ME\_PS3) This register provides the status of the peripherals. Please refer to *Table 55* for details. Table 55. Peripheral Status Registers (ME\_PSn) Field Descriptions | Field | Description | | | | | | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | S_ <periph></periph> | Peripheral status — These bits specify the current status of each peripheral which is controlled by the MC_ME. 0 Peripheral is frozen 1 Peripheral is active | | | | | | ### 6.3.2.19 Run Peripheral Configuration Registers (ME\_RUN\_PC0...7) Figure 66. Run Peripheral Configuration Registers (ME\_RUN\_PC0...7) These registers configure eight different types of peripheral behavior during run modes. Table 56. Run Peripheral Configuration Registers (ME\_RUN\_PC0...7) Field Descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------| | RUN3 | Peripheral control during <i>RUN3</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | RUN2 | Peripheral control during <i>RUN2</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | RUN1 | Peripheral control during <i>RUN1</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | RUN0 | Peripheral control during <i>RUN0</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | DRUN | Peripheral control during <i>DRUN</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | SAFE | Peripheral control during <i>SAFE</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | TEST | Peripheral control during <i>TEST</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | RESET | Peripheral control during <i>RESET</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | ### 6.3.2.20 Low-Power Peripheral Configuration Registers (ME\_LP\_PC0...7) Figure 67. Low-Power Peripheral Configuration Registers (ME\_LP\_PC0...7) These registers configure eight different types of peripheral behavior during non-run modes. Table 57. Low-Power Peripheral Configuration Registers (ME\_LP\_PC0...7) Field Descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------| | STOP0 | Peripheral control during <i>STOP0</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | | HALT0 | Peripheral control during <i>HALT0</i> 0 Peripheral is frozen with clock gated 1 Peripheral is active | ### 6.3.2.21 Peripheral Control Registers (ME\_PCTLn) Figure 68. Peripheral Control Registers (ME\_PCTLn) These registers select the configurations during run and non-run modes for each peripheral. Please refer to *Table 45* for information on which **ME\_PCTL***n* locations are actually occupied. The unoccupied locations contain a read-only byte value of 0x00. Field Description Peripheral control in debug mode — This bit controls the state of the peripheral in debug mode 0 Peripheral state depends on RUN\_CFG/LP\_CFG bits and the chip mode DBG F 1 Peripheral is frozen if not already frozen in chip modes. Note: This feature is useful to freeze the peripheral state while entering debug. For example, this may be used to prevent a reference timer from running while making a debug accesses. Peripheral configuration select for non-run modes — These bits associate a configuration as defined in the ME LP PC0...7 registers to the peripheral. 000 Selects ME LP PC0 configuration 001 Selects ME\_LP\_PC1 configuration 010 Selects ME\_LP\_PC2 configuration LP CFG 011 Selects ME\_LP\_PC3 configuration 100 Selects ME\_LP\_PC4 configuration 101 Selects ME\_LP\_PC5 configuration 110 Selects ME\_LP\_PC6 configuration Selects ME\_LP\_PC7 configuration 111 Peripheral configuration select for run modes — These bits associate a configuration as defined in the ME RUN PC0...7 registers to the peripheral. 000 Selects ME RUN PC0 configuration 001 Selects ME RUN PC1 configuration 010 Selects ME\_RUN\_PC2 configuration RUN\_CFG 011 Selects ME\_RUN\_PC3 configuration 100 Selects ME\_RUN\_PC4 configuration 101 Selects ME\_RUN\_PC5 configuration 110 Selects ME\_RUN\_PC6 configuration 111 Selects ME\_RUN\_PC7 configuration Table 58. Peripheral Control Registers (ME PCTLn) Field Descriptions Note: After modifying any of the **ME\_RUN\_PCO...7**, **ME\_LP\_PCO...7**, and **ME\_PCTLn** registers, software must request a mode change and wait for the mode change to be completed before entering debug mode in order to have consistent behavior between the peripheral clock control process and the clock status reporting in the **ME\_PSn** registers. ### 6.4 Functional Description #### 6.4.1 Mode Transition Request The transition from one mode to another mode is normally handled by software by accessing the mode control register **ME\_MCTL**. But the in case of special events, the mode transition can be automatically managed by hardware. In order to switch from one mode to another, the application should access the **ME\_MCTL** register twice by writing - the first time with the value of the key (0x5AF0) into the KEY bit field and the required target mode into the TARGET\_MODE bit field, - and the second time with the inverted value of the key (0xA50F) into the KEY bit field and the required target mode into the TARGET\_MODE bit field. Once a valid mode transition request is detected, the target mode configuration information is loaded from the corresponding **ME\_<mode>\_MC** register. The mode transition request may require a number of cycles depending on the programmed configuration, and software should check the **S\_CURRENT\_MODE** bit field and the **S\_MTRANS** bit of the global status register **ME\_GS** to verify when the mode has been correctly entered and the transition process has completed. For a description of valid mode requests, please refer to Section 6.4.5: Mode Transition Interrupts. Any modification of the mode configuration register of the currently selected mode will not be taken into account immediately but on the next request to enter this mode. This means that transition requests such as $RUN0...3 \rightarrow RUN0...3$ , $DRUN \rightarrow DRUN$ , $SAFE \rightarrow SAFE$ , and $TEST \rightarrow TEST$ are considered valid mode transition requests. As soon as the mode request is accepted as valid, the $S_NTRANS$ bit is set till the status in the $ME_GS$ register matches the configuration programmed in the respective $ME_{mode} MC$ register. Note: It is recommended that software poll the **S\_MTRANS** bit in the **ME\_GS** register after requesting a transition to **HALT0** or **STOP0** modes. Figure 69. MC\_ME Mode Diagram #### 6.4.2 Modes Details #### 6.4.2.1 RESET Mode The chip enters this mode on the following events: - from SAFE, DRUN, RUN0...3, or TEST mode when the TARGET\_MODE bit field of the ME\_MCTL register is written with "0000" for a 'functional' reset - from any mode due to a system reset by the MC\_RGM because of some nonrecoverable hardware failure in the system (see the MC\_RGM chapter for details) Transition to this mode is instantaneous, and the system remains in this mode until the reset sequence is finished. The mode configuration information for this mode is provided by the **ME\_RESET\_MC** register. This mode has a pre-defined configuration, and the IRC is selected as the system clock. #### 6.4.2.2 DRUN Mode The chip enters this mode on the following events: - automatically from RESET mode after completion of the reset sequence - from RUN0...3, SAFE, or TEST mode when the TARGET\_MODE bit field of the ME\_MCTL register is written with "0011" As soon as any of the above events has occurred, a **DRUN** mode transition request is generated. The mode configuration information for this mode is provided by the **ME\_DRUN\_MC** register. In this mode, the flashes, all clock sources, and the system clock configuration can be controlled by software as required. After system reset, the software execution starts with the default configuration selecting the IRC as the system clock. This mode is intended to be used by software • to initialize all registers as per the system needs Note: Software must ensure that the code executes from RAM before changing to this mode if the flashes are configured to be in the low-power or power-down state in this mode. #### 6.4.2.3 SAFE Mode The chip enters this mode on the following events: - from DRUN, RUN0...3, or TEST mode when the TARGET\_MODE bit field of the ME\_MCTL register is written with "0010" - from any mode except RESET due to a SAFE mode request generated by the MC\_RGM because of some potentially recoverable hardware failure in the system (see the MC\_RGM chapter for details) Note: If a hardware **SAFE** mode request occurs during **RESET**, depending on the timing of the **SAFE** mode request, **SAFE** mode may be entered immediately after the normal completion of the reset sequence or several system clock cycles after **DRUN** entry. The **SAFE** mode request does not have any influence on the execution of the reset sequence itself. As soon as any of the above events has occurred, a **SAFE** mode transition request is generated. The mode configuration information for this mode is provided by the **ME\_SAFE\_MC** register. This mode has a pre-defined configuration, and the IRC is selected as the system clock. If the **SAFE** mode is requested by software while some other mode transition process is ongoing, the new target mode becomes the **SAFE** mode regardless of other pending requests or new requests during the mode transition. No new mode request made during a transition to the SAFE mode will cause an invalid mode interrupt. Note: If software requests to change to the **SAFE** mode and then requests to change back to the parent mode before the mode transition is completed, the chip's final mode after mode transition will be the **SAFE** mode. As long as a **SAFE** event is active, the system remains in the **SAFE** mode, and any software mode request during this time is ignored and lost. This mode is intended to be used by software - to assess the severity of the cause of failure and then to either - re-initialize the chip via the **DRUN** mode, or - completely reset the chip via the *RESET* mode. If the outputs of the system I/Os need to be forced to a high impedance state upon entering this mode, the **PDO** bit of the **ME\_SAFE\_MC** register should be set. The input levels remain unchanged. #### 6.4.2.4 *TEST* Mode The chip enters this mode on the following events: from the DRUN mode when the TARGET\_MODE bit field of the ME\_MCTL register is written with "0001" As soon as any of the above events has occurred, a **TEST** mode transition request is generated. The mode configuration information for this mode is provided by the **ME\_TEST\_MC** register. Except for the main voltage regulator, all resources of the system are configurable in this mode. The system clock to the whole system can be stopped by programming the **SYSCLK** bit field to "1111", and in this case, the only way to exit this mode is via a chip reset. This mode is intended to be used by software to execute software test routines Note: Software must ensure that the code executes from RAM before changing to this mode if the flashes are configured to be in the low-power or power-down state in this mode. #### 6.4.2.5 RUN0...3 Modes The chip enters one of these modes on the following events: - from the DRUN, SAFE, or another RUN0...3 mode when the TARGET\_MODE bit field of the ME\_MCTL register is written with "0100...0111" - from the **HALT0** mode due to an interrupt event - from the **STOP0** mode due to an interrupt or wakeup event As soon as any of the above events has occurred, a **RUN0...3** mode transition request is generated. The mode configuration information for these modes is provided by the **ME\_RUN0...3\_MC** registers. In these modes, the flashes, all clock sources, and the system clock configuration can be controlled by software as required. These modes are intended to be used by software to execute application routines Note: Software must ensure that the code executes from RAM before changing to this mode if the flashes are configured to be in the low-power or power-down state in this mode. #### 6.4.2.6 HALTO Mode The chip enters this mode on the following events: from one of the RUN0...3 modes when the TARGET\_MODE bit field of the ME\_MCTL register is written with "1000". As soon as any of the above events has occurred, a *HALT0* mode transition request is generated. The mode configuration information for this mode is provided by **ME\_HALT0\_MC** register. This mode is quite configurable, and the **ME\_HALT0\_MC** register should be programmed according to the system needs. The flashes can be put in low-power or power-down mode as needed. If there is a *HALT0* mode request while an interrupt request is active, the transition to *HALT0* is aborted with the resultant mode being the current mode, *SAFE* (on *SAFE* mode request), or *DRUN* (on reset), and an invalid mode interrupt is not generated. This mode is intended as a first-level low-power mode with - the core clock frozen - only a few peripherals running and to be used by software to wait until it is required to do something and then to react quickly (i.e., within a few system clock cycles of an interrupt event) Note: It is good practice for software to ensure that the **S\_MTRANS** bit in the **ME\_GS** register has been cleared on **HALT0** mode exit to ensure that the previous **RUN0...3** mode configuration has been fully restored before executing critical code. #### 6.4.2.7 STOP0 Mode The chip enters this mode on the following events: from one of the RUN0...3 modes when the TARGET\_MODE bit field of the ME\_MCTL register is written with "1010". As soon as any of the above events has occurred, a **STOP0** mode transition request is generated. The mode configuration information for this mode is provided by the **ME\_STOP0\_MC** register. This mode is fully configurable, and the **ME\_STOP0\_MC** register should be programmed according to the system needs. The flashes can be put in power-down mode as needed. If there is a **STOP0** mode request while any interrupt or wakeup event is active, the transition to **STOP0** is aborted with the resultant mode being the current mode, **SAFE** (on **SAFE** mode request), or **DRUN** (on reset), and an invalid mode interrupt is not generated. This can be used as an advanced low-power mode with the core clock frozen and almost all peripherals stopped. This mode is intended as an advanced low-power mode with - the core clock frozen - almost all peripherals stopped and to be used by software to wait until it is required to do something with no need to react quickly (e.g., allow for system clock source to be re-started) This mode can be used to stop all clock sources, except internal RC oscillator clock, and thus preserve the chip status. When exiting the **STOP0** mode, the internal RC oscillator clock is selected as the system clock until the target clock is available. Note: It is good practice for software to ensure that the **S\_MTRANS** bit in the **ME\_GS** register has been cleared on **STOP0** mode exit to ensure that the previous **RUN0...3** mode configuration has been fully restored before executing critical code. #### 6.4.3 Mode Transition Process The following subsections describe the mode transition process steps. The steps are followed in a predefined manner depending on the current chip mode and the requested target mode. In many cases of mode transition, not all steps need to be executed based on the mode control information, and some steps may not be applicable according to the mode definition itself. #### 6.4.3.1 Target Mode Request The target mode is requested by accessing the **ME\_MCTL** register with the required keys. This mode transition request by software must be a valid request satisfying a set of predefined rules to initiate the process. If the request fails to satisfy these rules, it is ignored, and the **TARGET\_MODE** bit field is not updated. An optional interrupt can be generated for invalid mode requests. Refer to *Section 6.4.5: Mode Transition Interrupts* for details. In the case of mode transitions occurring because of hardware events such as a reset, a **SAFE** mode request, or interrupt requests and wakeup events to exit from low-power modes, the **TARGET\_MODE** bit field of the **ME\_MCTL** register is automatically updated with the appropriate target mode. The mode change process start is indicated by the setting of the mode transition status bit **S\_MTRANS** of the **ME\_GS** register. A **RESET** mode requested via the **ME\_MCTL** register is passed to the MC\_RGM, which generates a global system reset and initiates the reset sequence. The **RESET** mode request has the highest priority, and the MC\_ME is kept in the **RESET** mode during the entire reset sequence. The **SAFE** mode request has the next highest priority after reset. It can be generated either by software via the **ME\_MCTL** register from all software running modes including **DRUN**, **RUN0...3**, and **TEST** or by the MC\_RGM after the detection of system hardware failures, which may occur in any mode. #### 6.4.3.2 Target Mode Configuration Loading On completion of the *Target Mode Request* step, the target mode configuration from the **ME\_<target mode>\_MC** register is loaded to start the resources (voltage sources, clock sources, flashes, pads, etc.) control process. An overview of resource control possibilities for each mode is shown in *Table 59*. A ' $\sqrt{\phantom{a}}$ ' indicates that a given resource is configurable for a given mode. | Resource | | | | Mode | | | | |-----------|--------|--------------|--------|-----------|-----------|--------------|----------------| | Resource | RESET | TEST | SAFE | DRUN | RUN03 | HALT0 | STOP0 | | IRC | | $\sqrt{}$ | | | | | | | | on | XOSC | | $\checkmark$ | | $\sqrt{}$ | $\sqrt{}$ | $\checkmark$ | $\sqrt{}$ | | XOSC | off | FMPLL_0 | | V | | V | V | V | | | FIVIPLE_U | off | | | V | | V | V | V | V | | CFLASH | normal | normal | normal | normal | normal | low-power | power-<br>down | | | | V | | V | V | V | V | | DFLASH | normal | normal | normal | normal | normal | normal | power-<br>down | | MVREG | | | | | | V | V | | INIVILEG | on | PDO | | V | V | | | | V | | FDO | off | off | on | off | off | off | off | Table 59. MC ME Resource Control Overview #### 6.4.3.3 Peripheral Clocks Disable On completion of the *Target Mode Request* step, the MC\_ME requests each peripheral to enter its stop mode when: the peripheral is configured to be disabled via the target mode, the peripheral configuration registers ME\_RUN\_PC0...7 and ME\_LP\_PC0...7, and the peripheral control registers ME\_PCTLn\_ Note: The MC\_ME automatically requests peripherals to enter their stop modes if the power domains in which they are residing are to be turned off due to a mode change. However, it is good practice for software to ensure that those peripherals that are to be powered down are configured in the MC\_ME to be frozen. Each peripheral acknowledges its stop mode request after closing its internal activity. The MC\_ME then disables the corresponding clock(s) to this peripheral. In the case of a **SAFE** mode transition request, the MC\_ME does not wait for the peripherals to acknowledge the stop requests. The **SAFE** mode clock gating configuration is applied immediately regardless of the status of the peripherals' stop acknowledges. Please refer to Section 6.4.6: Peripheral Clock Gating for more details. Each peripheral that may block or disrupt a communication bus to which it is connected ensures that these outputs are forced to a safe or recessive state when the chip enters the **SAFE** mode. #### 6.4.3.4 Processor Low-Power Mode Entry If, on completion of the *Peripheral Clocks Disable* step, the mode transition is to the *HALT0* mode, the MC\_ME requests the processor to enter its halted state. The processor acknowledges its halt state request after completing all outstanding bus transactions. If, on completion of the *Peripheral Clocks Disable* step, the mode transition is to the *STOP0* mode, the MC\_ME requests the processor to enter its stopped state. The processor acknowledges its stop state request after completing all outstanding bus transactions. #### 6.4.3.5 Processor and System Memory Clock Disable If, on completion of the *Processor Low-Power Mode Entry* step, the mode transition is to the *HALT0* or *STOP0* mode and the processor is in its appropriate halted or stopped state, the MC ME disables the processor and system memory clocks to achieve further power saving. The clocks to the processor and system memory are unaffected while transitioning between software running modes such as **DRUN**, **RUN0...3**, and **SAFE**. Warning: Clocks Clocks to the whole chip including the processor and system memory can be disabled in TEST mode. #### 6.4.3.6 Clock Sources Switch-On On completion of the *Processor Low-Power Mode Entry* step, the MC\_ME switches on all clock sources based on the *<clock source>ON* bits of the ME\_*<current mode>*\_MC and ME\_*<target mode>*\_MC registers. The following clock sources are switched on at this step: - the internal RC oscillator - the external oscillator - the system PLL The clock sources that are required by the target mode are switched on. The duration required for the output clocks to be stable depends on the type of source, and all further steps of mode transition depending on one or more of these clocks waits for the stable status of the respective clocks. The availability status of these clocks is updated in the **S\_<clock source>** bits of **ME\_GS** register. The clock sources which need to be switched off are unaffected during this process in order to not disturb the system clock which might require one of these clocks before switching to a different target clock. #### 6.4.3.7 Flash Modules Switch-On On completion of the step, if one or more of the flashes needs to be switched to normal mode from its low-power or power-down mode based on the CFLAON and DFLAON bit fields of the ME\_<current mode>\_MC and ME\_<target mode>\_MC registers, the MC\_ME requests the flash to exit from its low-power/power-down mode. When the flashes are available for access, the S\_CFLA and S\_DFLA bit fields of the ME\_GS register are updated to "11" by hardware. Warning: It is illegal to switch the CFLASH from low-power mode to power-down mode and from power-down mode to low-power mode. The MC\_ME, however, does not prevent this nor does it flag it. #### 6.4.3.8 Pad Outputs-On On completion of the step, if the **PDO** bit of the **ME\_<**target mode>\_MC register is cleared, then - all pad outputs are enabled to return to their previous state - the I/O pads power sequence driver is switched on #### 6.4.3.9 Peripheral Clocks Enable Based on the current and target chip modes, the peripheral configuration registers **ME\_RUN\_PC0...7**, **ME\_LP\_PC0...7**, and the peripheral control registers **ME\_PCTL***n*, the MC\_ME enables the clocks for selected modules as required. This step is executed only after the process is completed. #### 6.4.3.10 Processor and Memory Clock Enable If the mode transition is from any of the low-power modes *HALT0* or *STOP0* to *RUN0...3*, the clocks to the processor and system memory are enabled. The process of enabling these clocks is executed only after the *Flash Modules Switch-On* process is completed. #### 6.4.3.11 Processor Low-Power Mode Exit If the mode transition is from any of the low-power modes *HALT0* or *STOP0* to *RUN0...3*, the MC\_ME requests the processor to exit from its halted or stopped state. This step is executed only after the *Processor and Memory Clock Enable* process is completed. #### 6.4.3.12 System Clock Switching Based on the SYSCLK bit field of the ME\_<current mode>\_MC and ME\_<target mode>\_MC registers, if the target and current system clock configurations differ, the following method is implemented for clock switching. - The target clock configuration for the IRC takes effect only after the S\_IRC bit of the ME\_GS register is set by hardware (i.e., the internal RC oscillator has stabilized). - The target clock configuration for the XOSC takes effect only after the **S\_XOSC** bit of the **ME\_GS** register is set by hardware (i.e., the external oscillator has stabilized). - The target clock configuration for the FMPLL\_0 PCS takes effect only after the S\_FMPLL\_0 bit of the ME\_GS register is set by hardware (i.e., the system PLL has stabilized). - If the clock is to be disabled, the **SYSCLK** bit field should be programmed with "1111". This is possible only in the *TEST* mode. The current system clock configuration can be observed by reading the **S\_SYSCLK** bit field of the **ME\_GS** register, which is updated after every system clock switching. Until the target clock is available, the system uses the previous clock configuration. System clock switching starts only after - the *Clock Sources Switch-On* process has completed if the target system clock source is one of the following: - the internal RC oscillator - the system PLL - the Peripheral Clocks Disable process has completed in order not to change the system clock frequency before peripherals close their internal activities An overview of system clock source selection possibilities for each mode is shown in *Table 60*. A ' $\sqrt{\phantom{a}}$ ' indicates that a given clock source is selectable for a given mode. | System | | Mode | | | | | | | | | | | | | | | |--------------------------------|-----------|-----------|----------------|-----------|----------------|-------|-------|--|--|--|--|--|--|--|--|--| | Clock<br>Source | RESET | TEST | SAFE | DRUN | RUN03 | HALT0 | STOP0 | | | | | | | | | | | IRC | (default) | (default) | √<br>(default) | (default) | √<br>(default) | | | | | | | | | | | | | XOSC | | √ | | V | √ | V | √ | | | | | | | | | | | FMPLL_0<br>PCS | | V | | V | V | V | | | | | | | | | | | | system<br>clock is<br>disabled | | √(1) | | | | | | | | | | | | | | | Table 60. MC\_ME System Clock Selection Overview #### 6.4.3.13 Pad Switch-Off If the PDO bit of the ME\_<target mode>\_MC register is '1' then the outputs of the pads are forced to the high impedance state if the target mode is SAFE or TEST This step is executed only after the *Peripheral Clocks Disable* process has completed. #### 6.4.3.14 Clock Sources (with no Dependencies) Switch-Off Based on the chip mode and the **<clock source>ON** bits of the **ME\_<mode>\_MC** registers, if a given clock source is to be switched off and no other clock source needs it to be on, the MC\_ME requests the clock source to power down and updates its availability status bit **S\_<clock source>** of the **ME\_GS** register to '0'. The following clock sources switched off at this step: The system PLL This step is executed only after the System Clock Switching process has completed. #### 6.4.3.15 Clock Sources (with Dependencies) Switch-Off Based on the chip mode and the **<clock source>ON** bits of the **ME\_<mode>\_MC** registers, if a given clock source is to be switched off and all clock sources which need this clock source to be on have been switched off, the MC\_ME requests the clock source to power <sup>1.</sup> Disabling the system clock during *TEST* mode will require a reset in order to exit *TEST* mode. down and updates its availability status bit **S\_<clock source>** of the **ME\_GS** register to '0'. The following clock sources switched off at this step: The external oscillator This step is executed only after - The System Clock Switching process has completed in order not to lose the current system clock during mode transition - The Clock Sources (with no Dependencies) Switch-Off process has completed in order to, for example, prevent unwanted lock transitions #### 6.4.3.16 Flash Switch-Off Based on the CFLAON and DFLAON bit fields of the ME\_<current mode>\_MC and ME\_<target mode>\_MC registers, if any of the flashes is to be put in its low-power or power-down mode, the MC\_ME requests the flash to enter the corresponding power mode and waits for the flash to acknowledge. The exact power mode status of the flashes is updated in the S\_CFLA and S\_DFLA bit fields of the ME\_GS register. This step is executed only when the Processor and System Memory Clock Disable process has completed. #### 6.4.3.17 Current Mode Update The current mode status bit field **S\_CURRENT\_MODE** of the **ME\_GS** register is updated with the target mode bit field **TARGET\_MODE** of the **ME\_MCTL** register when: - all the updated status bits in the ME\_GS register match the configuration specified in the ME\_<target mode>\_MC register - power sequences are done - clock disable/enable process is finished - processor low-power mode (halt/stop) entry and exit processes are finished Note: **SAFE** mode entry does not wait for the clock disable/enable process to finish. It only waits for the **ME\_GS.S\_IRC** bit to be set. This is to ensure that the **SAFE** mode is entered as quickly as possible. Software can monitor the mode transition status by reading the **S\_MTRANS** bit of the **ME\_GS** register. The mode transition latency can differ from one mode to another depending on the resources' availability before the new mode request and the target mode's requirements. If a mode transition is taking longer to complete than is expected, the **ME\_DMTS** register can indicate which process is still in progress. Start Write ME\_MCTL register Target Mode Request **SAFE** mode request interrupt/wakeup event **Clock Sources** Switch-On **FLASH** Pad l Switch-On Outputs On I 1 Peripheral Clocks I Disable DIGITAL CONTROL Processor & Memory Clock Enable Processor Low-Power Peripheral Clocks Entry Enable Processor System Clock Low-Power Switching Processor & Memory Exit Clock Disable Clock Sources Without Dependencies Switch-Off FLASH ANALOG OFF PAD Clock Sources With Switch-Off Outputs Off Dependencies Switch-Off I S\_MTRANS = '0' Current Mode Update End Figure 70. MC\_ME Transition Diagram ### 6.4.4 Protection of Mode Configuration Registers While programming the mode configuration registers **ME\_<mode>\_MC**, the following rules must be respected. Otherwise, the write operation is ignored and an invalid mode configuration interrupt may be generated. - If the IRC is selected as the system clock, IRC must be on. - If the XOSC clock is selected as the system clock, OSC must be on. - If the FMPLL 0 PCS clock is selected as the system clock, PLL must be on. - If FMPLL\_0 is on, XOSC must also be on. Note: Software must ensure that clock sources with dependencies other than those mentioned above are switched on as needed. There is no automatic protection mechanism to check this in the MC\_ME. - Configuration "00" for the CFLAON bit field is reserved. - Configuration "00" for the **DFLAON** bit field is reserved. - Configuration "10" for the **DFLAON** bit field is reserved. - Configuration "11" for the **DFLAON** bit field is reserved if the **CFLAON** bit field is not "11". - System clock configurations marked as 'reserved' may not be selected. - Configuration "1111" for the SYSCLK bit field is allowed only for esthete's mode, and only in this case may all system clock sources be turned off. Warning: If the system clock is stopped during TEST mode, the chip can exit only via a system reset. #### 6.4.5 Mode Transition Interrupts The MC\_ME provides interrupts for incorrectly configuring a mode, requesting an invalid mode transition, indicating a **SAFE** mode transition not due to a software request, and indicating when a mode transition has completed. #### 6.4.5.1 Invalid Mode Configuration Interrupt Whenever a write operation is attempted to the ME\_<mode>\_MC registers violating the protection rules mentioned in the Section 6.4.4: Protection of Mode Configuration Registers, the interrupt pending bit I\_ICONF of the ME\_IS register is set and an interrupt request is generated if the mask bit M ICONF of the ME IM register is '1'. In addition, during a mode transition, if a clock source has been configured in the ME\_<target mode>\_MC register to be off and a peripheral requiring this clock source to be on has been enabled via the ME\_RUN\_PC0...7/ME\_LP\_PC0...7 and ME\_PCTLn registers, the interrupt pending bit I\_ICONF\_CU of the ME\_IS register is set and an interrupt request is generated if the mask bit M\_ICONF\_CU of the ME\_IM register is '1'. #### 6.4.5.2 Invalid Mode Transition Interrupt The mode transition request is considered invalid under the following conditions: • If the system is in the **SAFE** mode and the **SAFE** mode request from MC\_RGM is active, and if the target mode requested is other than **RESET** or **SAFE**, then this new mode request is considered to be invalid, and the **S\_SEA** bit of the **ME\_IMTS** register is set - If the TARGET\_MODE bit field of the ME\_MCTL register is written with a value different from the specified mode values (i.e., a non-existing mode), an invalid mode transition event is generated. When such a non existing mode is requested, the S\_NMA bit of the ME\_IMTS register is set. This condition is detected regardless of whether the proper key mechanism is followed while writing the ME\_MCTL register. - If some of the chip modes are disabled as programmed in the ME\_ME register, their respective configurations are considered reserved, and any access to the ME\_MCTL register with those values results in an invalid mode transition request. When such a disabled mode is requested, the S\_DMA bit of the ME\_IMTS register is set. This condition is detected regardless of whether the proper key mechanism is followed while writing the ME\_MCTL register. - If the target mode is not a valid mode with respect to the current mode, the mode request illegal status bit S\_MRI of the ME\_IMTS register is set. This condition is detected only when the proper key mechanism is followed while writing the ME\_MCTL register. Otherwise, the write operation is ignored. - If further new mode requests occur while a mode transition is in progress (the S\_MTRANS bit of the ME\_GS register is '1'), the mode transition illegal status bit S\_MTI of the ME\_IMTS register is set. This condition is detected only when the proper key mechanism is followed while writing the ME\_MCTL register. Otherwise, the write operation is ignored. Note: As the causes of invalid mode transitions may overlap at the same time, the priority implemented for invalid mode transition status bits of the ME\_IMTS register in the order from highest to lowest is S SEA, S NMA, S DMA, S MRI, and S MTI. As an exception, the mode transition request is not considered as invalid under the following conditions: - A new request is allowed to enter the RESET or SAFE mode irrespective of the mode transition status. - As the exit of HALTO and STOPO modes depends on the interrupts of the system which can occur at any instant, these requests to return to RUNO...3 modes are always valid. - In order to avoid any unwanted lockup of the chip modes, software can abort a mode transition by requesting the parent mode if, for example, the mode transition has not completed after a software determined 'reasonable' amount of time for whatever reason. The parent mode is the chip mode before a valid mode request was made. - Self-transition requests (e.g., RUN0 → RUN0) are not considered as invalid even when the mode transition process is active (i.e., S\_MTRANS is '1'). During the low-power mode exit process, if the system is not able to enter the respective RUN0...3 mode properly (i.e., all status bits of the ME\_GS register match with configuration bits in the ME\_<mode>\_MC register), then software can only request the SAFE or RESET mode. It is not possible to request any other mode or to go back to the low-power mode again. Whenever an invalid mode request is detected, the interrupt pending bit **I\_IMODE** of the **ME\_IS** register is set, and an interrupt request is generated if the mask bit **M\_IMODE** of the **ME\_IM** register is '1'. #### 6.4.5.3 SAFE Mode Transition Interrupt Whenever the system enters the **SAFE** mode as a result of a **SAFE** mode request from the MC\_RGM due to a hardware failure, the interrupt pending bit **I\_SAFE** of the **ME\_IS** register is set, and an interrupt is generated if the mask bit **M\_SAFE** of **ME\_IM** register is '1'. The **SAFE** mode interrupt pending bit can be cleared only when the **SAFE** mode request is deasserted by the MC\_RGM (see the MC\_RGM chapter for details on how to clear a **SAFE** mode request). If the system is already in **SAFE** mode, any new **SAFE** mode request by the MC\_RGM also sets the interrupt pending bit **I\_SAFE**. However, the **SAFE** mode interrupt pending bit is not set when the **SAFE** mode is entered by a software request (i.e., programming of **ME\_MCTL** register). #### 6.4.5.4 Mode Transition Complete interrupt Whenever the system fully completes a mode transition (i.e., the **S\_MTRANS** bit of **ME\_GS** register transits from '1' to '0'), the interrupt pending bit **I\_MTC** of the **ME\_IS** register is set, and an interrupt request is generated if the mask bit **M\_MTC** of the **ME\_IM** register is '1'. The interrupt bit **I\_MTC** is not set when entering low-power modes **HALT0** and **STOP0** in order to avoid the same event requesting the immediate exit of these low-power modes. #### 6.4.6 Peripheral Clock Gating During all chip modes, each peripheral can be associated with a particular clock gating policy determined by two groups of peripheral configuration registers. The run peripheral configuration registers **ME\_RUN\_PCO...7** are chosen only during the software running modes **DRUN**, **TEST**, **SAFE**, and **RUNO...3**. All configurations are programmable by software according to the needs of the application. Each configuration register contains a mode bit which determines whether or not a peripheral clock is to be gated. Run configuration selection for each peripheral is done by the **RUN\_CFG** bit field of the **ME PCTL***n* registers. The low-power peripheral configuration registers **ME\_LP\_PCO...7** are chosen only during the low-power modes **HALTO** and **STOPO**. All configurations are programmable by software according to the needs of the application. Each configuration register contains a mode bit which determines whether or not a peripheral clock is to be gated. Low-power configuration selection for each peripheral is done by the **LP\_CFG** bit field of the **ME\_PCTLn** registers. Any modifications to the **ME\_RUN\_PC0...7**, **ME\_LP\_PC0...7**, and **ME\_PCTL***n* registers do not affect the clock gating behavior until a new mode transition request is generated. Whenever the processor enters a debug session during any mode, the following occurs for each peripheral: The clock is gated if the DBG\_F bit of the associated ME\_PCTLn register is set. Otherwise, the peripheral clock gating status depends on the RUN\_CFG and LP\_CFG bits. Any further modifications of the ME\_RUN\_PC0...7, ME\_LP\_PC0...7, and ME\_PCTLn registers during a debug session will take affect immediately without requiring any new mode request. #### 6.4.7 Application Example *Figure 71* shows an example application flow for requesting a mode change and then waiting until the mode transition has completed. Figure 71. MC\_ME Application Example Flow Diagram # 7 Power Control Unit (MC\_PCU) ### 7.1 Introduction #### 7.1.1 Overview The power control unit (MC\_PCU) acts as a bridge for mapping the PMU peripheral to the MC\_PCU address space. Figure 72 depicts the MC\_PCU block diagram. Figure 72. MC\_PCU Block Diagram #### 7.1.2 Features The MC\_PCU includes the following features: • maps the PMU registers to the MC\_PCU address space ### 7.2 External Signal Description The MC\_PCU has no connections to any external pins. ## 7.3 Memory Map and Register Definition ### 7.3.1 Memory Map Table 61. MC\_PCU memory map | Offset from PCU_BASE (0xC3FE_8000) | Register | Location | |------------------------------------|---------------------------------------------------|--------------| | 0x0000 | PCU_PCONF0—Power Domain #0 Configuration register | on page 200 | | 0x0004-0x003F | Reserved | | | 0x0040 | PCU_PSTAT—Power Domain Status register | on page 201 | | 0x0044-0x007F | Reserved | | | 0x0080 | VREG_CTL—Voltage Regulator Control register | on page 1044 | | 0x0084 | VREG_STATUS—Voltage Regulator Status register | on page 1045 | | 0x0044-0x7FFF | Reserved | | Note: Accesses to unused registers as well as write accesses to read-only registers do not change register content, and can cause a transfer error. Table 62. MC PCU registers | | | | | | | • | | ` | , | | | | | | | | | | |-----------------|------------|---|----|----|-------|----|----|-------|----|-------|------|------|------|------|------|------|------|-----| | Address | Name | | 0 | 1 | 2 | 3 | 27 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | 7144.000 | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | 0xC3FE_8000 | PCU_PCONF0 | R | 0 | 0 | STBY0 | 0 | 0 | STOP0 | 0 | НАСТО | RUN3 | RUNZ | RUN1 | RUNO | DRUN | SAFE | TEST | RST | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE_8004 | | | | | | | | | | | | | | | | | | | | <br>0xC3FE_803F | reserved | | | | | | | | | | | | | | | | | | | Address | Name | | 0 | 1 | 2 | 3 | 27 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-------------|--------------|-----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|------------------| | Addicas | Nume | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0xC3FE_8040 | DOLL DOTAT | W | | | | | | | | | | | | | | | | | | 0XC3FE_6040 | FCO_FSTAT | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PD0 | | | | W | | | | | | | | | | | | | | | | | | 0x044 | | | | | | | | | | | | | | | | | | | | <br>0x07F | | | | | | | | rese | rved | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0,0255 0000 | VDEC CTI (1) | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SK | | 0xC3FE_8080 | VKEG_CILV | | | | | | | | | | | | | | | | | 5V_LVD_MASK | | | | W | | | | | | | | | | | | | | | | LVD | | | | | | | | | | | | | | | | | | | | 5V_ | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TUS | | 0xC3FE_8084 | VREG_STATUS | | • | | | | | | | | | | | | | | • | STA <sup>-</sup> | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Ον | | | | | | | | | | | | | | | | | | | | 5V_LVD_STATUS | | | | W | | | | | | | | | | | | | | | | 2 | | 0xC3FE_8088 | | l . | | | | | | | | | | | | | | | | | | | reserved | | | | | | | | | | | | | | | | | | | 0xC3FE_BFFF | | | | | | | | | | | | | | | | | | | Table 62. MC\_PCU registers(Continued)(Continued) ### 7.3.2 Register Descriptions All registers may be accessed as 32-bit words, 16-bit half-words, or 8-bit bytes. The bytes are ordered according to big endian. For example, the PD0 field of the PCU\_PSTAT register may be accessed as a word at address 0xC3FE\_8040, as a half-word at address 0xC3FE\_8042, or as a byte at address 0xC3FE\_8043. <sup>1.</sup> See Section 36.1.4.1: Voltage Regulator Control Register (VREG\_CTL). <sup>2.</sup> See Section 36.1.4.2: Voltage Regulator Status register (VREG\_STATUS). #### 7.3.2.1 Power Domain #0 Configuration Register (PCU\_PCONF0) Figure 73. Power Domain #0 Configuration Register (PCU\_PCONF0) This register defines for power domain #0 whether it is on or off in each chip mode. As power domain #0 is the always-on power domain (and includes the MC\_PCU), none of its bits are programmable. This register is available for completeness reasons. **Table 63. Power Domain Configuration Register Field Descriptions** | Field | Description | |-------|--------------------------------------------------------------------------------------| | RST | Power domain control during <i>RESET</i> mode 0 Power domain off 1 Power domain on | | TEST | Power domain control during <i>TEST</i> mode 0 Power domain off 1 Power domain on | | SAFE | Power domain control during <i>SAFE</i> mode 0 Power domain off 1 Power domain on | | DRUN | Power domain control during <i>DRUN</i> mode 0 Power domain off 1 Power domain on | | RUN0 | Power domain control during <i>RUN0</i> mode 0 Power domain off 1 Power domain on | | RUN1 | Power domain control during <i>RUN1</i> mode 0 Power domain off 1 Power domain on | | RUN2 | Power domain control during <i>RUN2</i> mode 0 Power domain off 1 Power domain on | Table 63. Power Domain Configuration Register Field Descriptions(Continued) | Field | Description | |-------|----------------------------------------------------------------------------------------| | RUN3 | Power domain control during <i>RUN3</i> mode 0 Power domain off 1 Power domain on | | HALT0 | Power domain control during <i>HALT0</i> mode 0 Power domain off 1 Power domain on | | STOP0 | Power domain control during <i>STOP0</i> mode 0 Power domain off 1 Power domain on | | STBY0 | Power domain control during <i>STANDBY0</i> mode 0 Power domain off 1 Power domain on | #### 7.3.2.2 Power Domain Status Register (PCU\_PSTAT) Figure 74. Power Domain Status Register (PCU\_PSTAT) This register reflects the power status of all available power domains. Table 64. Power Domain Status Register (PCU\_PSTAT) Field Descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------| | PDn | Power status for power domain #n 0 Power domain is inoperable 1 Power domain is operable | # 8 Reset Generation Module (MC\_RGM) #### 8.1 Introduction #### 8.1.1 Overview The reset generation module (MC\_RGM) centralizes the different reset sources and manages the reset sequence of the chip. It provides a register interface and the reset sequencer. Various registers are available to monitor and control the chip reset sequence. The reset sequencer is a state machine which controls the different phases (PHASE0, PHASE1, PHASE2, PHASE3, and IDLE) of the reset sequence and controls the reset signals generated in the system. Figure 75 shows the MC\_RGM block diagram. Figure 75. MC\_RGM Block Diagram #### 8.1.2 Features The MC\_RGM contains the functionality for the following features: - 'destructive' resets management - 'functional' resets management - signalling of reset events after each reset sequence (reset status flags) - conversion of reset events to SAFE mode or interrupt request events - short reset sequence configuration - bidirectional reset behavior configuration - boot mode capture on RESET deassertion #### 8.1.3 Reset Sources The different reset sources are organized into two families: 'destructive' and 'functional'. - A 'destructive' reset source is associated with an event related to a critical usually hardware - error or dysfunction. When a 'destructive' reset event occurs, the full reset sequence is applied to the chip starting from PHASE0. This resets the full chip ensuring a safe start-up state for both digital and analog modules, and the memory content must be considered to be unknown. 'Destructive' resets are - power-on reset - 1.2V low-voltage detected - software watchdog timer 0 - software watchdog timer 1 - 2.7V low-voltage detected (VREG) - 2.7V low-voltage detected (flash) - 2.7V low-voltage detected (I/O) - A 'functional' reset source is associated with an event related to a less-critical usually non-hardware - error or dysfunction. When a 'functional' reset event occurs, a partial reset sequence is applied to the chip starting from PHASE1. In this case, most digital modules are reset normally, while the state of analog modules or specific digital modules (e.g., debug modules, flash modules) is preserved. 'Functional' resets are - external reset - JTAG initiated reset - reset of core 0 or core 1 - software reset - checkstop reset of core\_0 or core\_1 - FMPLL 0 fail - oscillator frequency lower than reference - FMPLL\_0 clock frequency higher/lower than reference - 4.5V low-voltage detected - code or data flash fatal error or ECSM ECC not correctable error - system clock frequency higher/lower than reference When a reset is triggered, the MC\_RGM state machine is activated and proceeds through the different phases (i.e., PHASEn states). Each phase is associated with a particular chip reset being provided to the system. A phase is completed when all corresponding phase completion gates from either the system or internal to the MC\_RGM are acknowledged. The chip reset associated with the phase is then released, and the state machine proceeds to the next phase up to entering the IDLE phase. During this entire process, the MC\_ME state machine is held in RESET mode. Only at the end of the reset sequence, when the IDLE phase is reached, does the MC\_ME enter the DRUN mode. Alternatively, it is possible for software to configure some reset source events to be converted from a reset to either a SAFE mode request issued to the MC\_ME or to an interrupt issued to the core (see Section 8.3.1.3: Functional Event Reset Disable Register (RGM\_FERD) and Section 8.3.1.5: Functional Event Alternate Request Register (RGM\_FEAR) for 'functional' resets). ## 8.2 External Signal Description The MC\_RGM interfaces to the bidirectional reset pin RESET and the boot mode pins PAD[4:2]. ### 8.3 Memory Map and Register Definition Access **Address** Name Description Size Location User Supervisor Test 0xC3FE read/write(1) RGM\_FES Functional Event Status half-word read read/write(1) on page 208 4000 0xC3FE Destructive Event read/write(1) read/write(1) RGM DES half-word read on page 209 \_4002 Status Functional Event Reset 0xC3FE RGM\_FERD half-word read read/write(2) read/write(2) on page 211 4004 Disable 0xC3FE Destructive Event Reset RGM DERD half-word read read read on page 212 4006 Disable 0xC3FE **Functional Event** RGM FEAR half-word read/write read/write on page 213 read \_4010 Alternate Request 0xC3FE Functional Event Short **RGM FESS** half-word read read/write read/write on page 214 \_4018 Sequence 0xC3FE **Functional Bidirectional** RGM FBRE half-word read read/write read/write on page 216 401C Reset Enable Table 65. MC\_RGM Register Description Note: Any access to unused registers as well as write accesses to read-only registers will: - not change register content - cause a transfer error <sup>1.</sup> Individual bits cleared on writing '1'. <sup>2.</sup> Write once: '0' = enable, '1' = disable. #### Table 66. MC\_RGM Memory Map | | | | | | 10 | ibic c | bb. IVI | <u></u> | , 141 | | y ivia | Ρ | | | | | | | |----------------------------------------|-------------------------------|---|-------|----|----|--------|-------------|---------|-------|---------|----------|-------------|---------------|--------------|-----------|--------|---------|---------| | Address | Name | 9 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FE<br>_4000 | RGM_<br>FES /<br>RGM_<br>DES | R | F_EXR | 0 | 0 | 0 | F_CMU1_FHL | 0 | 0 | F_FLASH | F_LVD45 | F_CMU0_FHL | F_CMU0_OLR | F_PLL0 | F_CHKSTOP | F_SOFT | F_CORE | F_JTAG | | | | W | w1c | | | | w1c | | | w1c | | | R | F_POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F_LVD27_10 | F_LVD27_FLASH | F_LVD27_VREG | F_SWT1 | F_SWT0 | | F_LVD12 | | | | W | w1c | | | | | | | | | w1c | w1c | w1c | w1c | w1c | | w1c | | 0xC3FE<br>_4004 | RGM_<br>FERD/<br>RGM_<br>DERD | R | D_EXR | 0 | 0 | | D_CMU1_FHL | 0 | 0 | 0 | D_LVD45 | D_CMU0_FHL | D_CMU0_OLR | D_PLL0 | D_CHKSTOP | D_SOFT | D_CORE | D_JTAG | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | D_LVD27_IO | D_LVD27_FLASH | D_LVD27_VREG | D_SWT1 | D_SWT0 | 0 | D_LVD12 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE<br>_4008<br><br>0xC3FE<br>_400F | | | | | | | | | reser | ved | | | | | | | | | | 0xC3FE<br>_4010 | RGM_<br>FEAR | R | 0 | 0 | 0 | 0 | AR_CMU1_FHL | 0 | 0 | 0 | AR_LVD45 | AR_CMU0_FHL | AR_CMU0_OLR | AR_PLL0 | 0 | 0 | AR_CORE | AR_JTAG | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | #### Table 66. MC\_RGM Memory Map(Continued) | | 1 | | | | | | | | | | | | | | | | | 1 | |----------------------------------------|--------------|----------|--------|----|----|----|-------------|----|----|----------|----------|-------------|-------------|---------|------------|---------|---------|---------| | Address | Name | <u> </u> | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | Addiooo | Num | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0xC3FE<br>_4014<br><br>0xC3FE<br>_4017 | | reserved | | | | | | | | | | | | | | | | | | 0xC3FE<br>_4018 | RGM_<br>FESS | R | SS_EXR | 0 | 0 | 0 | SS_CMU1_FHL | 0 | 0 | SS_FLASH | SS_LVD45 | SS_CMU0_FHL | SS_CMU0_OLR | SS_PLL0 | SS_CHKSTOP | SS_SOFT | SS_CORE | SS_JTAG | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE<br>_401C | RGM_<br>FBRE | R | BE_EXR | 0 | 0 | 0 | BE_CMU1_FHL | 0 | 0 | BE_FLASH | BE_LVD45 | BE_CMU0_FHL | BE_CMU0_OLR | BE_PLL0 | BE_CHKSTOP | BE_SOFT | BE_CORE | BE_JTAG | | | | W | | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | W | | | | | | | | | | | | | | | | | | 0xC3FE<br>_401E<br><br>0xC3FE<br>_7FFF | reserved | | | | | | | | | | | | | | | | | | ### 8.3.1 Register Descriptions Unless otherwise noted, all registers may be accessed as 32-bit words, 16-bit half-words, or 8-bit bytes. The bytes are ordered according to big endian. For example, the RGM\_DES[8:15] register bits may be accessed as a word at address 0xC3FE\_4000, as a half-word at address 0xC3FE\_4002, or as a byte at address 0xC3FE\_4003. Some fields may be read-only, and their reset value of '1' or '0' and the corresponding behavior cannot be changed. #### 8.3.1.1 Functional Event Status Register (RGM\_FES) Address 0xC3FE 4000 Access: User read, Supervisor read/write, Test read/write 5 6 10 13 15 CMU1\_FHL CHKSTOP Ī 딩 F\_FLASH F\_PLL0 CORE F\_LVD45 SOFT F\_JTAG EXR CMU0 CMUO 0 0 0 0 R 0 W w1c **POR** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Figure 76. Functional Event Status Register (RGM\_FES) This register contains the status of the last asserted functional reset sources. It can be accessed in read/write on either supervisor mode or test mode. It can be accessed in read only in user mode. Register bits are cleared on write '1' if the triggering event has already been cleared at the source. Note: If a 'functional' reset source is configured to generate a SAFE mode request or an interrupt request, software needs to clear the event in the source module at least three system clock cycles before it clears the associated RGM\_FES status bit in order to avoid multiple SAFE mode requests or interrupts for the same event. In order to avoid having to count cycles, it is good practice for software to check whether the RGM\_FES has been properly cleared, and if not, clear it again. Table 67. Functional Event Status Register (RGM\_FES) Field Descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F_EXR | Flag for External Reset 0 No external reset event has occurred since either the last clear or the last destructive reset assertion 1 An external reset event has occurred | | F_CMU1_FHL | Flag for system clock frequency higher/lower than reference 0 No system clock frequency higher/lower than reference event has occurred since either the last clear or the last destructive reset assertion 1 A system clock frequency higher/lower than reference event has occurred | | F_FLASH | Flag for code or data flash fatal error or ECSM ECC not correctable error No code or data flash fatal error or ECSM ECC not correctable error event has occurred since either the last clear or the last destructive reset assertion A code or data flash fatal error or ECSM ECC not correctable error event has occurred | | F_LVD45 | Flag for 4.5V low-voltage detected 0 No 4.5V low-voltage detected event has occurred since either the last clear or the last destructive reset assertion 1 A 4.5V low-voltage detected event has occurred | | F_CMU0_FHL | Flag for FMPLL_0 clock frequency higher/lower than reference 0 No FMPLL_0 clock frequency higher/lower than reference event has occurred since either the last clear or the last destructive reset assertion 1 A FMPLL_0 clock frequency higher/lower than reference event has occurred | Table 67. Functional Event Status Register (RGM\_FES) Field Descriptions(Continued) | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F_CMU0_OLR | Flag for oscillator frequency lower than reference 0 No oscillator frequency lower than reference event has occurred since either the last clear or the last destructive reset assertion 1 A oscillator frequency lower than reference event has occurred | | F_PLL0 | Flag for FMPLL_0 fail 0 No FMPLL_0 fail event has occurred since either the last clear or the last destructive reset assertion 1 A FMPLL_0 fail event has occurred | | F_CHKSTOP | Flag for checkstop reset of core_0 or core_1 0 No checkstop reset of core_0 or core_1 event has occurred since either the last clear or the last destructive reset assertion 1 A checkstop reset of core_0 or core_1 event has occurred | | F_SOFT | Flag for software reset 0 No software reset event has occurred since either the last clear or the last destructive reset assertion 1 A software reset event has occurred | | F_CORE | Flag for reset of core_0 or core_1 0 No reset of core_0 or core_1 event has occurred since either the last clear or the last destructive reset assertion 1 A reset of core_0 or core_1 event has occurred | | F_JTAG | Flag for JTAG initiated reset 0 No JTAG initiated reset event has occurred since either the last clear or the last destructive reset assertion 1 A JTAG initiated reset event has occurred | ### 8.3.1.2 Destructive Event Status Register (RGM\_DES) Figure 77. Destructive Event Status Register (RGM\_DES) This register contains the status of the last asserted destructive reset sources. It can be accessed in read/write on either supervisor mode or test mode. It can be accessed in read only in user mode. Register bits are cleared on write '1'. Table 68. Destructive Event Status Register (RGM\_DES) Field Descriptions | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F_POR | Flag for Power-On reset 0 No power-on event has occurred since the last clear 1 A power-on event has occurred | | F_LVD27_IO | Flag for 2.7V low-voltage detected (I/O) 0 No 2.7V low-voltage detected (I/O) event has occurred since either the last clear or the last power-on reset assertion 1 A 2.7V low-voltage detected (I/O) event has occurred | | F_LVD27_FLASH | Flag for 2.7V low-voltage detected (flash) 0 No 2.7V low-voltage detected (flash) event has occurred since either the last clear or the last power-on reset assertion 1 A 2.7V low-voltage detected (flash) event has occurred | | F_LVD27_VREG | Flag for 2.7V low-voltage detected (VREG) 0 No 2.7V low-voltage detected (VREG) event has occurred since either the last clear or the last power-on reset assertion 1 A 2.7V low-voltage detected (VREG) event has occurred | | F_SWT1 | Flag for software watchdog timer 1 0 No software watchdog timer 1 event has occurred since either the last clear or the last power- on reset assertion 1 A software watchdog timer 1 event has occurred | | F_SWT0 | Flag for software watchdog timer 0 0 No software watchdog timer 0 event has occurred since either the last clear or the last power- on reset assertion 1 A software watchdog timer 0 event has occurred | | F_LVD12 | Flag for 1.2V low-voltage detected 0 No 1.2V low-voltage detected event has occurred since either the last clear or the last power- on reset assertion 1 A 1.2V low-voltage detected event has occurred | Note: The F\_POR flag is automatically cleared on a 1.2 V low-voltage detected or a 2.7 V low-voltage detected. This means that if the power-up sequence is not monotonic (i.e., the voltage rises and then drops enough to trigger a low-voltage detection), the F\_POR flag may not be set but instead the <register>F\_LVD12 or <register>F\_LVD27\_VREG flag is set on exiting the reset sequence. Therefore, if the F\_POR, <register>F\_LVD12 or <register>F\_LVD27\_VREG flags are set on reset exit, software should interpret the reset cause as power-on. **POR** 0 0 0 0 0 0 0 #### Address 0xC3FE 4004 Access: User read, Supervisor read/write, Test read/write 5 6 10 15 CMU1\_FHL CHKSTOP Ī CMU0\_OL D\_FLASH D\_LVD45 D\_CORE D\_JTAG SOFT D\_PLL0 EXR CMU0 F R 0 0 0 0 0 ام W #### 8.3.1.3 Functional Event Reset Disable Register (RGM\_FERD) 0 Figure 78. Functional Event Reset Disable Register (RGM\_FERD) This register provides dedicated bits to disable functional reset sources. When a functional reset source is disabled, the associated functional event will trigger either a SAFE mode request or an interrupt request (see Section 8.3.1.5: Functional Event Alternate Request Register (RGM\_FEAR)). It can be accessed in read/write in either supervisor mode or test mode. It can be accessed in read only in user mode. Each byte can be written only once after power-on reset. 0 0 0 0 0 0 0 0 Warning: It is important to clear the RGM FES register before setting any of the bits in the RGM FERD register to '1'. Otherwise a redundant SAFE mode request or interrupt request may occur. Table 69. Functional Event Reset Disable Register (RGM\_FERD) Field Descriptions | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D_EXR | Disable External Reset 0 An external reset event triggers a reset sequence | | D_CMU1_FHL | Disable system clock frequency higher/lower than reference 0 A system clock frequency higher/lower than reference event triggers a reset sequence 1 A system clock frequency higher/lower than reference event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_CMU1_FHL | | D_FLASH | Disable code or data flash fatal error or ECSM ECC not correctable error 0 A code or data flash fatal error or ECSM ECC not correctable error event triggers a reset sequence | | D_LVD45 | Disable 4.5V low-voltage detected 0 A 4.5V low-voltage detected event triggers a reset sequence 1 A 4.5V low-voltage detected event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_LVD45 | | D_CMU0_FHL | Disable FMPLL_0 clock frequency higher/lower than reference 0 A FMPLL_0 clock frequency higher/lower than reference event triggers a reset sequence 1 A FMPLL_0 clock frequency higher/lower than reference event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_CMU0_FHL | Table 69. Functional Event Reset Disable Register (RGM\_FERD) Field Descriptions(Continued) | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D_CMU0_OLR | Disable oscillator frequency lower than reference 0 A oscillator frequency lower than reference event triggers a reset sequence 1 A oscillator frequency lower than reference event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_CMU0_OLR | | D_PLL0 | Disable FMPLL_0 fail 0 A FMPLL_0 fail event triggers a reset sequence 1 A FMPLL_0 fail event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_PLL0 | | D_CHKSTOP | Disable checkstop reset of core_0 or core_1 0 A checkstop reset of core_0 or core_1 event triggers a reset sequence | | D_SOFT | Disable software reset 0 A software reset event triggers a reset sequence | | D_CORE | Disable reset of core_0 or core_1 0 A reset of core_0 or core_1 event triggers a reset sequence 1 A reset of core_0 or core_1 event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_CORE | | D_JTAG | Disable JTAG initiated reset 0 A JTAG initiated reset event triggers a reset sequence 1 A JTAG initiated reset event generates either a SAFE mode or an interrupt request depending on the value of RGM_FEAR.AR_JTAG | ### 8.3.1.4 Destructive Event Reset Disable Register (RGM\_DERD) Figure 79. Destructive Event Reset Disable Register (RGM\_DERD) This register provides dedicated bits to disable particular destructive reset sources. It can be accessed in read-only in supervisor mode, test mode, and user mode. | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------| | D_LVD27_IO | Disable 2.7V low-voltage detected (I/O) 0 A 2.7V low-voltage detected (I/O) event triggers a reset sequence | | D_LVD27_FLASH | Disable 2.7V low-voltage detected (flash) 0 A 2.7V low-voltage detected (flash) event triggers a reset sequence | | D_LVD27_VREG | Disable 2.7V low-voltage detected (VREG) 0 A 2.7V low-voltage detected (VREG) event triggers a reset sequence | | D_SWT1 | Disable software watchdog timer 1 0 A software watchdog timer 1 event triggers a reset sequence | | D_SWT0 | Disable software watchdog timer 0 0 A software watchdog timer 0 event triggers a reset sequence | | D_LVD12 | Disable 1.2V low-voltage detected 0 A 1.2V low-voltage detected event triggers a reset sequence | Table 70. Destructive Event Reset Disable Register (RGM DERD) Field Descriptions #### 8.3.1.5 Functional Event Alternate Request Register (RGM\_FEAR) Figure 80. Functional Event Alternate Request Register (RGM FEAR) This register defines an alternate request to be generated when a reset on a functional event has been disabled. The alternate request can be either a SAFE mode request to MC\_ME or an interrupt request to the system. It can be accessed in read/write in either supervisor mode or test mode. It can be accessed in read only in user mode. Table 71. Functional Event Alternate Request Register (RGM\_FEAR) Field Descriptions | Field | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AR_CMU1_FHL | Alternate Request for system clock frequency higher/lower than reference O Generate a <i>SAFE</i> mode request on a system clock frequency higher/lower than reference event if the reset is disabled Generate an interrupt request on a system clock frequency higher/lower than reference event if the reset is disabled | | AR_LVD45 | Alternate Request for 4.5V low-voltage detected O Generate a <b>SAFE</b> mode request on a 4.5V low-voltage detected event if the reset is disabled Generate an interrupt request on a 4.5V low-voltage detected event if the reset is disabled | Field **Description** Alternate Request for FMPLL 0 clock frequency higher/lower than reference 0 Generate a SAFE mode request on a FMPLL 0 clock frequency higher/lower than reference AR CMU0 FHL event if the reset is disabled Generate an interrupt request on a FMPLL 0 clock frequency higher/lower than reference event if the reset is disabled Alternate Request for oscillator frequency lower than reference 0 Generate a SAFE mode request on a oscillator frequency lower than reference event if the AR CMU0 OLR reset is disabled Generate an interrupt request on a oscillator frequency lower than reference event if the reset is disabled Alternate Request for FMPLL 0 fail AR PLL0 0 Generate a SAFE mode request on a FMPLL 0 fail event if the reset is disabled 1 Generate an interrupt request on a FMPLL 0 fail event if the reset is disabled Alternate Request for reset of core 0 or core 1 AR CORE 0 Generate a SAFE mode request on a reset of core 0 or core 1 event if the reset is disabled Generate an interrupt request on a reset of core 0 or core 1 event if the reset is disabled Alternate Request for JTAG initiated reset AR\_JTAG 0 Generate a SAFE mode request on a JTAG initiated reset event if the reset is disabled Generate an interrupt request on a JTAG initiated reset event if the reset is disabled Table 71. Functional Event Alternate Request Register (RGM\_FEAR) Field #### 8.3.1.6 Functional Event Short Sequence Register (RGM\_FESS) Figure 81. Functional Event Short Sequence Register (RGM\_FESS) This register defines which reset sequence will be done when a functional reset sequence is triggered. The functional reset sequence can either start from PHASE1 or from PHASE3, skipping PHASE1 and PHASE2. Note: This could be useful for fast reset sequence, for example to skip flash reset. It can be accessed in read/write in either supervisor mode or test mode. It can be accessed in read in user mode. Table 72. Functional Event Short Sequence Register (RGM\_FESS) Field Descriptions | Field | Description | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SS_EXR | Short Sequence for External Reset 0 The reset sequence triggered by an external reset event will start from PHASE1 | | SS_CMU1_FHL | Short Sequence for system clock frequency higher/lower than reference The reset sequence triggered by a system clock frequency higher/lower than reference event will start from PHASE1 The reset sequence triggered by a system clock frequency higher/lower than reference event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_FLASH | Short Sequence for code or data flash fatal error or ECSM ECC not correctable error The reset sequence triggered by a code or data flash fatal error or ECSM ECC not correctable error event will start from PHASE1 | | SS_LVD45 | Short Sequence for 4.5V low-voltage detected The reset sequence triggered by a 4.5V low-voltage detected event will start from PHASE1 The reset sequence triggered by a 4.5V low-voltage detected event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_CMU0_FHL | Short Sequence for FMPLL_0 clock frequency higher/lower than reference The reset sequence triggered by a FMPLL_0 clock frequency higher/lower than reference event will start from PHASE1 The reset sequence triggered by a FMPLL_0 clock frequency higher/lower than reference event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_CMU0_OLR | Short Sequence for oscillator frequency lower than reference The reset sequence triggered by a oscillator frequency lower than reference event will start from PHASE1 The reset sequence triggered by a oscillator frequency lower than reference event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_PLL0 | Short Sequence for FMPLL_0 fail The reset sequence triggered by a FMPLL_0 fail event will start from PHASE1 The reset sequence triggered by a FMPLL_0 fail event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_CHKSTOP | Short Sequence for checkstop reset of core_0 or core_1 The reset sequence triggered by a checkstop reset of core_0 or core_1 event will start from PHASE1 | | SS_SOFT | Short Sequence for software reset 0 The reset sequence triggered by a software reset event will start from PHASE1 | | SS_CORE | Short Sequence for reset of core_0 or core_1 The reset sequence triggered by a reset of core_0 or core_1 event will start from PHASE1 The reset sequence triggered by a reset of core_0 or core_1 event will start from PHASE3, skipping PHASE1 and PHASE2 | | SS_JTAG | Short Sequence for JTAG initiated reset 0 The reset sequence triggered by a JTAG initiated reset event will start from PHASE1 1 The reset sequence triggered by a JTAG initiated reset event will start from PHASE3, skipping PHASE1 and PHASE2 | Note: This register is reset on any enabled 'destructive' or 'functional' reset event. #### 8.3.1.7 Functional Bidirectional Reset Enable Register (RGM\_FBRE) Figure 82. Functional Bidirectional Reset Enable Register (RGM\_FBRE) This register enables the generation of an external reset on functional reset. It can be accessed in read/write in either supervisor mode or test mode. It can be accessed in read in user mode.reset Table 73. Functional Bidirectional Reset Enable Register (RGM\_FBRE) Field Descriptions | Field | Description | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BE_EXR | Bidirectional Reset Enable for External Reset 0 RESET is asserted on an external reset event if the reset is enabled 1 RESET is not asserted on an external reset event | | BE_CMU1_FHL | Bidirectional Reset Enable for system clock frequency higher/lower than reference 0 RESET is asserted on a system clock frequency higher/lower than reference event if the reset is enabled 1 RESET is not asserted on a system clock frequency higher/lower than reference event | | BE_FLASH | Bidirectional Reset Enable for code or data flash fatal error or ECSM ECC not correctable error 0 RESET is asserted on a code or data flash fatal error or ECSM ECC not correctable error event if the reset is enabled 1 RESET is not asserted on a code or data flash fatal error or ECSM ECC not correctable error event | | BE_LVD45 | Bidirectional Reset Enable for 4.5V low-voltage detected 0 RESET is asserted on a 4.5V low-voltage detected event if the reset is enabled 1 RESET is not asserted on a 4.5V low-voltage detected event | | BE_CMU0_FHL | Bidirectional Reset Enable for FMPLL_0 clock frequency higher/lower than reference 0 RESET is asserted on a FMPLL_0 clock frequency higher/lower than reference event if the reset is enabled 1 RESET is not asserted on a FMPLL_0 clock frequency higher/lower than reference event | | BE_CMU0_OLR | Bidirectional Reset Enable for oscillator frequency lower than reference 0 RESET is asserted on a oscillator frequency lower than reference event if the reset is enabled 1 RESET is not asserted on a oscillator frequency lower than reference event | | BE_PLL0 | Bidirectional Reset Enable for FMPLL_0 fail 0 RESET is asserted on a FMPLL_0 fail event if the reset is enabled 1 RESET is not asserted on a FMPLL_0 fail event | | BE_CHKSTOP | Bidirectional Reset Enable for checkstop reset of core_0 or core_1 0 RESET is asserted on a checkstop reset of core_0 or core_1 event if the reset is enabled 1 RESET is not asserted on a checkstop reset of core_0 or core_1 event | | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BE_SOFT | Bidirectional Reset Enable for software reset 0 RESET is asserted on a software reset event if the reset is enabled 1 RESET is not asserted on a software reset event | | BE_CORE | Bidirectional Reset Enable for reset of core_0 or core_1 0 RESET is asserted on a reset of core_0 or core_1 event if the reset is enabled 1 RESET is not asserted on a reset of core_0 or core_1 event | | BE_JTAG | Bidirectional Reset Enable for JTAG initiated reset 0 RESET is asserted on a JTAG initiated reset event if the reset is enabled 1 RESET is not asserted on a JTAG initiated reset event | Table 73. Functional Bidirectional Reset Enable Register (RGM FBRE) Field # 8.4 Functional Description #### 8.4.1 Reset State Machine The main role of MC\_RGM is the generation of the reset sequence which ensures that the correct parts of the chip are reset based on the reset source event. This is summarized in *Table 74*. | Source | What Gets Reset | External Reset<br>Assertion <sup>(1)</sup> | Boot Mode<br>Capture | |----------------------------------------------|--------------------------------------------------|--------------------------------------------|-----------------------------| | power-on reset | all | yes | yes | | 'destructive' resets | all except some clock/reset management | yes | yes | | external reset | all except some clock/reset management and debug | programmable <sup>(2)</sup> | yes | | 'functional' resets | all except some clock/reset management and debug | programmable <sup>(2)</sup> | programmable <sup>(3)</sup> | | shortened 'functional' resets <sup>(4)</sup> | flip-flops except some clock/reset management | programmable <sup>(2)</sup> | programmable <sup>(3)</sup> | Table 74. MC\_RGM Reset Implications - 1. 'external reset assertion' means that the RESET pin is asserted by the MC\_RGM until the end of reset PHASE3. - 2. The assertion of the external reset is controlled via the RGM\_FBRE register. - 3. The boot mode is captured if the external reset is asserted. - 4. The short sequence is enabled via the RGM\_FESS register. Note: JTAG logic has its own independent reset control and is not controlled by the MC\_RGM in any way. The reset sequence is comprised of five phases managed by a state machine, which ensures that all phases are correctly processed through waiting for a minimum duration and until all processes that need to occur during that phase have been completed before proceeding to the next phase. The state machine used to produce the reset sequence is shown in Figure 83. power-on or enabled 'destructive' PHASE0 reset duration ≥ 3 internal RC oscillator clock cycles 16 MHz IRC stable, VREG voltage okay done enabled nonshortened external or PHASE1 'functional' reset1 duration $\geq$ 350 internal RC oscillator clock cycles PHASE2 enabled shortened duration ≥ 8 internal RC oscillator clock cycles external or code and data flash initialization done 'functional' reset PHASE3 duration ≥ 40 internal RC oscillator clock cycles **RESET** released code and data flash initialization done IDLE Figure 83. MC\_RGM State Machine #### 8.4.1.1 PHASE0 Phase This phase is entered immediately from any phase on a power-on or enabled 'destructive' reset event. The reset state machine exits PHASE0 and enters PHASE1 on verification of the following: - all enabled 'destructive' resets have been processed - all processes that need to be done in PHASE0 are completed - 16 MHz IRC stable, VREG voltage okay - a minimum of 3 internal RC oscillator clock cycles have elapsed since power-up completion and the last enabled 'destructive' reset event #### 8.4.1.2 PHASE1 Phase This phase is entered either on exit from PHASE0 or immediately from PHASE2, PHASE3, or IDLE on a non-masked external or 'functional' reset event if it has not been configured to trigger a 'short' sequence. The reset state machine exits PHASE1 and enters PHASE2 on verification of the following: - all enabled, non-shortened 'functional' resets have been processed - a minimum of 350 internal RC oscillator clock cycles have elapsed since the last enabled external or non-shortened 'functional' reset event #### 8.4.1.3 PHASE2 Phase This phase is entered on exit from PHASE1. The reset state machine exits PHASE2 and enters PHASE3 on verification of the following: - all processes that need to be done in PHASE2 are completed - code and data flash initialization - a minimum of 8 internal RC oscillator clock cycles have elapsed since entering PHASE2 # 8.4.1.4 PHASE3 Phase This phase is a entered either on exit from PHASE2 or immediately from IDLE on an enabled, shortened 'functional' reset event. The reset state machine exits PHASE3 and enters IDLE on verification of the following: - all processes that need to be done in PHASE3 are completed - code and data flash initialization - a minimum of 40 internal RC oscillator clock cycles have elapsed since the last enabled, shortened 'functional' reset event # 8.4.1.5 IDLE Phase This is the final phase and is entered on exit from PHASE3. When this phase is reached, the MC\_RGM releases control of the chip to the core and waits for new reset events that can trigger a reset sequence. # 8.4.2 Destructive Resets A 'destructive' reset indicates that an event has occurred after which critical register or memory content can no longer be guaranteed. The status flag associated with a given 'destructive' reset event (RGM\_DES.F\_<destructive reset> bit) is set when the 'destructive' reset is asserted and the power-on reset is not asserted. It is possible for multiple status bits to be set simultaneously, and it is software's responsibility to determine which reset source is the most critical for the application. The chip's low-voltage detector threshold ensures that, when 1.2V low-voltage detected is enabled, the supply is sufficient to have the destructive event correctly propagated through the digital logic. Therefore, if a given 'destructive' reset is enabled, the MC\_RGM ensures that the associated reset event will be correctly triggered to the full system. However, if the given 'destructive' reset is disabled and the voltage goes below the digital functional threshold, functionality can no longer be ensured, and the reset may or may not be asserted. An enabled 'destructive' reset will trigger a reset sequence starting from the beginning of PHASE0. # 8.4.3 External Reset The MC\_RGM manages the external reset coming from RESET. The detection of a falling edge on RESET will start the reset sequence from the beginning of PHASE1. By default RESET pin is an internal pull-down configuration. The status flag associated with the external reset falling edge event (RGM\_FES.F\_EXR bit) is set when the external reset is asserted and the power-on reset is not asserted. The external reset can optionally be disabled by writing bit RGM\_FERD.D\_EXR. Note: The RGM\_FERD register can be written only once between two power-on reset events. An enabled external reset will normally trigger a reset sequence starting from the beginning of PHASE1. Nevertheless, the RGM\_FESS register enables the further configuring of the reset sequence triggered by the external reset. When RGM\_FESS.SS\_EXR is set, the external reset will trigger a reset sequence starting directly from the beginning of PHASE3, skipping PHASE1 and PHASE2. This can be useful especially when an external reset should not reset the flash. The MC\_RGM may also assert the external reset if the reset sequence was triggered by one of the following: - a power-on reset - a 'destructive' reset event - an external reset event - a 'functional' reset event configured via the RGM\_FBRE register to assert the external reset In this case, the external reset is asserted until the end of PHASE3. # 8.4.4 Functional Resets A 'functional' reset indicates that an event has occurred after which it can be guaranteed that critical register and memory content is still intact. The status flag associated with a given 'functional' reset event (RGM\_FES.F\_<functional reset> bit) is set when the 'functional' reset is asserted and the power-on reset is not asserted. It is possible for multiple status bits to be set simultaneously, and it is software's responsibility to determine which reset source is the most critical for the application. The 'functional' reset can be optionally disabled by software writing bit RGM FERD.D <functional reset>. Note: The RGM\_FERD register can be written only once between two power-on reset events. An enabled 'functional' reset will normally trigger a reset sequence starting from the beginning of PHASE1. Nevertheless, the RGM\_FESS register enables the further configuring of the reset sequence triggered by a functional reset. When RGM\_FESS.SS\_<functional reset> is set, the associated 'functional' reset will trigger a reset sequence starting directly from the beginning of PHASE3, skipping PHASE1 and PHASE2. This can be useful especially in case a functional reset should not reset the flash module. See the MC ME chapter for details on the STANDBY0 and DRUN modes. # 8.4.5 Alternate Event Generation The MC\_RGM provides alternative events to be generated on reset source assertion. When a reset source is asserted, the MC\_RGM normally enters the reset sequence. Alternatively, it is possible for some reset source events to be converted from a reset to either a SAFE mode request issued to the MC\_ME or to an interrupt request issued to the core. Alternate event selection for a given reset source is made via the RGM\_FERD and RGM\_FEAR registers as shown in *Table 75*. | RGM_FERD<br>Bit Value | RGM_FEAR<br>Bit Value | Generated Event | |-----------------------|-----------------------|-------------------| | 0 | Х | reset | | 1 | 0 | SAFE mode request | | 1 | 1 | interrupt request | Table 75. MC RGM Alternate Event Selection The alternate event is cleared by deasserting the source of the request (i.e., at the reset source that caused the alternate request) and also clearing the appropriate RGM\_FES status bit. Note: Alternate requests (SAFE mode as well as interrupt requests) are generated regardless of whether the system clock is running. Note: If a masked 'functional' reset event which is configured to generate a SAFE mode/interrupt request occurs during PHASE1, it is ignored, and the MC\_RGM will not send any safe mode/interrupt request to the MC\_ME. # 8.4.6 Boot Mode Capturing The MC\_RGM samples PAD[4:2] whenever RESET is asserted until five internal RC oscillator clock cycles before its deassertion edge. The result of the sampling is used at the beginning of reset PHASE3 for boot mode selection and is retained after RESET has been deasserted for subsequent boots after reset sequences during which RESET is not asserted. Note: In order to ensure that the boot mode is correctly captured, the application needs to apply the valid boot mode value the entire time that RESET is asserted. Note: RESET can be asserted as a consequence of the internal reset generation. This will force re-sampling of the boot mode pins. (See Table 74 for details.) # 9 Interrupt Controller (INTC) # 9.1 Introduction The INTC provides priority-based preemptive scheduling of interrupt service requests (ISRs). This scheduling scheme is suitable for statically scheduled hard real-time systems. The INTC supports 148 interrupt requests. It is targeted to work with Power Architecture technology and automotive applications where the ISRs nest to multiple levels, but it also can be used with other processors and applications. The SPC56xP60x/54x implements INTC 0 and INTC 1. For high-priority interrupt requests in these target applications, the time from the assertion of the peripheral's interrupt request to when the processor is performing useful work to service the interrupt request needs to be minimized. The INTC supports this goal by providing a unique vector for each interrupt request source. It also provides 16 priorities so that lower priority ISRs do not delay the execution of higher priority ISRs. Because each individual application will have different priorities for each source of interrupt request, the priority of each interrupt request is configurable. When multiple tasks share a resource, coherent accesses to that resource need to be supported. The INTC supports the priority ceiling protocol for coherent accesses. By providing a modifiable priority mask, the priority can be raised temporarily so that tasks sharing the resource will not preempt each other. Multiple processors can assert interrupt requests to each other through software configurable interrupt requests. These software configurable interrupt requests can also be used to separate the work involved in servicing an interrupt request into a high-priority portion and a low-priority portion. The high-priority portion is initiated by a peripheral interrupt request, but then the ISR can assert a software configurable interrupt request to finish the servicing in a lower priority ISR. Therefore these software configurable interrupt requests can be used instead of the peripheral ISR scheduling a task through the RTOS. # 9.2 Features - Supports 140 peripheral interrupt and 8 software-configurable interrupt request sources - Unique 9-bit vector per interrupt source - Preemption - Preemptive prioritized interrupt requests to processor - ISR at a higher priority preempts ISRs or tasks at lower priorities - Automatic pushing or popping of preempted priority to or from a LIFO - Ability to modify the ISR or task priority; modifying the priority can be used to implement the priority ceiling protocol for accessing shared resources. - Low latency—3 clock cycles from receipt of interrupt request from peripheral to interrupt request to processor Table 76. Interrupt sources available | Interrupt sources (148) | Number available | |-------------------------|------------------| | Software | 8 | | ECSM | 3 | | eDMA2x | 17 | | SWT | 1 | | STM | 4 | | SIUL | 4 | | MC_ME | 4 | | MC_RGM | 1 | | XOSC | 1 | | PIT | 4 | | ADC | 2 | | FlexCAN | 16 | | FlexRay | 8 | | eTimer | 15 | | CTU | 15 | | Safety Port | 8 | | DSPI | 25 | | LINFlex | 6 | | FCCU | 4 | | Semaphore | 2 | # 9.3 Block diagram Figure 84 shows a block diagram of the interrupt controller (INTC). Figure 84. INTC block diagram # 9.4 Modes of operation # 9.4.1 Normal mode In normal mode, the INTC has two handshaking modes with the processor: software vector mode and hardware vector mode. Note: To correctly configure the interrupts in both software and hardware vector mode, the user must also configure the IVPR. The core register IVPR contains the base address for the interrupt handlers. Please refer to the core reference manual for more information. #### 9.4.1.1 Software vector mode In software vector mode, the interrupt exception handler software must read a register in the INTC to obtain the vector associated with the interrupt request to the processor. The INTC will use software vector mode for a given processor when its associated HVEN bit in INTC\_MCR is negated. The hardware vector enable signal to processor 0 or processor 1 is driven as negated when its associated HVEN bit is negated. The vector is read from INC\_IACKR. Reading the INTC\_IACKR negates the interrupt request to the associated processor. Even if a higher priority interrupt request arrived while waiting for this interrupt acknowledge, the interrupt request to the processor will negate for at least one clock. The reading also pushes the PRI value in INTC\_CPR onto the associated LIFO and updates PRI in the associated INTC\_CPR with the new priority. Furthermore, the interrupt vector to the processor is driven as all 0s. The interrupt acknowledge signal from the associated processor is ignored. #### 9.4.1.2 Hardware vector mode In hardware vector mode, the hardware signals the interrupt vector from the INTC in conjunction with a processor that can use that vector. This hardware causes the first instruction to be executed in handling the interrupt request to the processor to be specific to that vector. Therefore, the interrupt exception handler is specific to a peripheral or software configurable interrupt request rather than being common to all of them. The INTC uses hardware vector mode for a given processor when the associated HVEN bit in the INTC\_MCR is asserted. The hardware vector enable signal to the associated processor is driven as asserted. When the interrupt request to the associated processor asserts, the interrupt vector signal is updated. The value of that interrupt vector is the unique vector associated with the preempting peripheral or software configurable interrupt request. The vector value matches the value of the INTVEC field in the INTC\_IACKR, depending on which processor was assigned to handle a given interrupt source. The processor negates the interrupt request to the processor driven by the INTC by asserting the interrupt acknowledge signal for one clock. Even if a higher priority interrupt request arrived while waiting for the interrupt acknowledge, the interrupt request to the processor will negate for at least one clock. The assertion of the interrupt acknowledge signal for a given processor pushes the associated PRI value in the associated INTC\_CPR onto the associated LIFO and updates the associated PRI in the associated INTC\_CPR with the new priority. This pushing of the PRI value onto the associated LIFO and updating PRI in the associated INTC\_CPR does not occur when the associated interrupt acknowledge signal asserts and INTC\_SSCIRO\_3—INTC\_SSCIR4\_7 is written at a time such that the PRI value in the associated INTC\_CPR would need to be pushed and the previously last pushed PRI value would need to be popped simultaneously. In this case, PRI in the associated INTC\_CPR is updated with the new priority, and the associated LIFO is neither pushed or popped. #### 9.4.1.3 **Debug mode** The INTC operation in debug mode is identical to its operation in normal mode. # 9.4.1.4 Stop mode The INTC supports stop mode. The INTC can have its clock input disabled at any time by the clock driver on the device. While its clocks are disabled, the INTC registers are not accessible. The INTC requires clocking in order for a peripheral interrupt request to generate an interrupt request to the processor. # 9.5 Memory map and registers description # 9.5.1 Module memory map Table 77 shows the INTC memory map. | Offset from INTC_BASE 0xFFF4_8000 (INTC_0) 0x8FF4_8000 (INTC_1) | Register | Location | | |-----------------------------------------------------------------|---------------------------------------------------------------------------|-------------|--| | 0x0000 | INTC Module Configuration Register (INTC_MCR) | on page 227 | | | 0x0004 | Reserved | | | | 0x0008 | INTC Current Priority Register (INTC_CPR) | on page 228 | | | 0x000C | Reserved | | | | 0x0010 | INTC Interrupt Acknowledge Register (INTC_IACKR) | on page 230 | | | 0x0014 | Reserved | | | | 0x0018 | 8 INTC End-of-Interrupt Register (INTC_EOIR) | | | | 0x001C | Reserved | | | | 0x0020-0x0027 | INTC Software Set/Clear Interrupt Registers (INTC_SSCIR0_3-INTC_SSCIR4_7) | on page 231 | | | 0x0028- 0x003C | Reserved | | | | 0x0040-0x0144 | INTC Priority Select Registers (INTC_PSR0_3-INTC_PSR260) <sup>(1)</sup> | on page 233 | | | 0x0148-0x3FFF | Reserved | | | Table 77. INTC memory map # 9.5.2 Registers description With exception of the INTC\_SSCIn and INTC\_PSRn, all registers are 32 bits in width. Any combination of accessing the four bytes of a register with a single access is supported, provided that the access does not cross a register boundary. These supported accesses include types and sizes of 8 bits, aligned 16 bits, misaligned 16 bits to the middle 2 bytes, and aligned 32 bits. Although INTC\_SSCI*n* and INTC\_PSR*n* are 8 bits wide, they can be accessed with a single 16-bit or 32-bit access, provided that the access does not cross a 32-bit boundary. In software vector mode, the side effects of a read of INTC\_IACKR are the same regardless of the size of the read. In either software or hardware vector mode, the size of a write to either INTC\_SSCIR0\_3-INTC\_SSCIR4\_7 or INTC\_EOIR does not affect the operation of the write. INTC registers are accessible only when the core is in supervisor mode. # 9.5.2.1 INTC Module Configuration Register (INTC\_MCR) The module configuration register configures options of the INTC. The PRI fields are "reserved" for peripheral interrupt requests whose vectors are labeled as Reserved in Table 84. Figure 85. INTC Module Configuration Register (INTC\_MCR) Table 78. INTC\_MCR field descriptions | Field | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26<br>VTES | Vector table entry size Controls the number of 0s to the right of INTVEC in Section 9.5.2.3: INTC Interrupt Acknowledge Register (INTC_IACKR). If the contents of INTC_IACKR are used as an address of an entry in a vector table as in software vector mode, then the number of right most 0s will determine the size of each vector table entry. VTES impacts software vector mode operation but also affects INTC_IACKR[INTVEC] position in both hardware vector mode and software vector mode. 0 4 bytes 1 8 bytes | | 31<br>HVEN | Hardware vector enable Controls whether the INTC is in hardware vector mode or software vector mode. Refer to Section 9.4: Modes of operation, for the details of the handshaking with the processor in each mode. O Software vector mode Hardware vector mode | # 9.5.2.2 INTC Current Priority Register (INTC\_CPR) Figure 86. INTC Current Priority Register (INTC\_CPR) Table 79. INTC\_CPR field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 28–31<br>PRI[0:3] | Priority PRI is the priority of the currently executing ISR according to the following: 1111 Priority 15—highest priority 1110 Priority 14 1101 Priority 13 1100 Priority 12 1011 Priority 11 1010 Priority 10 1001 Priority 9 1000 Priority 8 0111 Priority 7 0110 Priority 6 0101 Priority 5 0100 Priority 4 0011 Priority 3 0010 Priority 2 0001 Priority 1 0000 Priority 0—lowest priority | The INTC\_CPR masks any peripheral or software settable interrupt request set at the same or lower priority as the current value of the INTC\_CPR[PRI] field from generating an interrupt request to the processor. When the INTC interrupt acknowledge register (INTC\_IACKR) is read in software vector mode or the interrupt acknowledge signal from the processor is asserted in hardware vector mode, the value of PRI is pushed onto the LIFO, and PRI is updated with the priority of the preempting interrupt request. When the INTC end-of-interrupt register (INTC\_EOIR) is written, the LIFO is popped into the INTC\_CPR's PRI field. The masking priority can be raised or lowered by writing to the PRI field, supporting the PCP. Refer to Section 9.7.5: Priority ceiling protocol. Note: A store to modify the PRI field that closely precedes or follows an access to a shared resource can result in a non-coherent access to the resource. Refer to Section 9.7.5.2: Ensuring coherency, for example code to ensure coherency. # 9.5.2.3 INTC Interrupt Acknowledge Register (INTC\_IACKR) | Address I | Base | + 0x00 | 10 | | | | | | | | | | Acce | ss: Use | er read | /write | |-----------|------|---------|----------|----------|----|----|--------|----------|----------|-----------|-----|----|------|---------|---------|--------| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R<br>W | | | | | | V | TBA (m | nost sig | ınifican | it 16 bii | ts) | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | VTBA | | | | | | | | 11 | NTVEC | ;1 | | | | 0 | 0 | | W | (I | east si | gnificar | nt 5 bit | s) | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | <sup>1.</sup> When the VTES bit in INTC\_MCR is asserted, INTVEC is shifted to the left one bit. Bit 29 is read as a '0'. VTBA is narrowed to 20 bits in width. Figure 87. INTC Interrupt Acknowledge Register (INTC\_IACKR) Table 80. INTC\_IACKR field descriptions | Field | Description | |--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–20<br>or<br>0–19<br>VTBA | Vector Table Base Address Can be the base address of a vector table of addresses of ISRs. The VTBA only uses the leftmost 20 bits when the VTES bit in INTC_MCR is asserted. | | 21–29<br>or<br>20–28<br>INTVEC | Interrupt Vector It is the vector of the peripheral or software configurable interrupt request that caused the interrupt request to the processor. When the interrupt request to the processor asserts, the INTVEC is updated, whether the INTC is in software or hardware vector mode. Note: If INTC_MCR[VTES] = 1, then the INTVEC field is shifted left one position to bits 20–28. VTBA is then shortened by one bit to bits 0–19. | The interrupt acknowledge register provides a value that can be used to load the address of an ISR from a vector table. The vector table can be composed of addresses of the ISRs specific to their respective interrupt vectors. In software vector mode, the INTC\_IACKR has side effects from reads. Therefore, it must not be speculatively read while in this mode. The side effects are the same regardless of the size of the read. Reading the INTC\_IACKR does not have side effects in hardware vector mode. #### Address Base + 0x0018 Access: Write-only R W Reset R Reset # 9.5.2.4 INTC End-of-Interrupt Register (INTC\_EOIR) Figure 88. INTC End-of-Interrupt Register (INTC\_EOIR) Writing to the end-of-interrupt register signals the end of the servicing of the interrupt request. When the INTC\_EOIR is written, the priority last pushed on the LIFO is popped into INTC\_CPR. An exception to this behavior is described in *Section 9.4.1.2: Hardware vector mode*. The values and size of data written to the INTC\_EOIR are ignored. The values and sizes written to this register neither update the INTC\_EOIR contents or affect whether the LIFO pops. For possible future compatibility, write four bytes of all 0s to the INTC\_EOIR. Reading the INTC\_EOIR has no effect on the LIFO. # 9.5.2.5 INTC Software Set/Clear Interrupt Registers (INTC\_SSCIR0\_3-INTC\_SSCIR4\_7) Figure 89. INTC Software Set/Clear Interrupt Register 0-3 (INTC\_SSCIR[0:3]) Figure 90. INTC Software Set/Clear Interrupt Register 4-7 (INTC\_SSCIR[4:7]) Table 81. INTC\_SSCIR[0:7] field descriptions | Field | Description | |---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6, 14, 22, 30<br>SET[0:7] | Set Flag Bits Writing a '1' sets the corresponding CLRx bit. Writing a '0' has no effect. Each SETx always will be read as a '0'. | | 7, 15, 23, 31<br>CLR[0:7] | Clear Flag Bits CLRx is the flag bit. Writing a '1' to CLRx clears it provided that a '1' is not written simultaneously to its corresponding SETx bit. Writing a '0' to CLRx has no effect. O Interrupt request not pending within INTC 1 Interrupt request pending within INTC | The software set/clear interrupt registers support the setting or clearing of software configurable interrupt request. These registers contain eight independent sets of bits to set and clear a corresponding flag bit by software. Excepting being set by software, this flag bit behaves the same as a flag bit set within a peripheral. This flag bit generates an interrupt request within the INTC like a peripheral interrupt request. Writing a '1' to SETx will leave SETx unchanged at 0 but sets CLRx. Writing a '0' to SETx has no effect. CLRx is the flag bit. Writing a '1' to CLRx clears it. Writing a '0' to CLRx has no effect. If a '1' is written simultaneously to a pair of SETx and CLRx bits, CLRx will be asserted, regardless of whether CLRx was asserted before the write. # 9.5.2.6 INTC Priority Select Registers (INTC\_PSR0\_3-INTC\_PSR260) Figure 91. INTC Priority Select Register 0-3 (INTC\_PSR[0:3]) Figure 92. INTC Priority Select Register 260 (INTC\_PSR[260]) Table 82. INTC\_PSR0\_3-INTC\_PSR260 field descriptions | Field | Description | |-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | 4-7, 12-15, 20-<br>23, 28-31<br>PRI[0:3]-<br>PRI260 | Priority Select PRIx selects the priority for interrupt requests. Refer to Section 9.6: Functional description. | Table 83. INTC Priority Select Register address offsets | INTC_PSRx_x | Offset Address | |---------------|----------------| | INTC_PSR0_3 | 0x0040 | | INTC_PSR4_7 | 0x0044 | | INTC_PSR8_11 | 0x0048 | | INTC_PSR12_15 | 0x004C | | INTC_PSR16_19 | 0x0050 | | INTC_PSR20_23 | 0x0054 | | INTC_PSR24_27 | 0x0058 | | INTC_PSRx_x | Offset Address | |-----------------|----------------| | INTC_PSR132_135 | 0x00C4 | | INTC_PSR136_139 | 0x00C8 | | INTC_PSR140_143 | 0x00CC | | INTC_PSR144_147 | 0x00D0 | | INTC_PSR148_151 | 0x00D4 | | INTC_PSR152_155 | 0x00D8 | | INTC_PSR156_159 | 0x00DC | Table 83. INTC Priority Select Register address offsets(Continued) | INTC_PSRx_x | Offset Address | INTC_PSRx_x | Offset Address | |-----------------|----------------|-----------------|----------------| | INTC_PSR28_31 | 0x005C | INTC_PSR160_163 | 0x00E0 | | INTC_PSR32_35 | 0x0060 | INTC_PSR164_167 | 0x00E4 | | INTC_PSR36_39 | 0x0064 | INTC_PSR168_171 | 0x00E8 | | INTC_PSR40_43 | 0x0068 | INTC_PSR172_175 | 0x00EC | | INTC_PSR44_47 | 0x006C | INTC_PSR176_179 | 0x00F0 | | INTC_PSR48_51 | 0x0070 | INTC_PSR180_183 | 0x00F4 | | INTC_PSR52_55 | 0x0074 | INTC_PSR184_187 | 0x00F8 | | INTC_PSR56_59 | 0x0078 | INTC_PSR188_191 | 0x00FC | | INTC_PSR60_63 | 0x007C | INTC_PSR192_195 | 0x0100 | | INTC_PSR64_67 | 0x0080 | INTC_PSR196_199 | 0x0104 | | INTC_PSR68_71 | 0x0084 | INTC_PSR200_203 | 0x0108 | | INTC_PSR72_75 | 0x0088 | INTC_PSR204_207 | 0x010C | | INTC_PSR76_79 | 0x008C | INTC_PSR208_211 | 0x0110 | | INTC_PSR80_83 | 0x0090 | INTC_PSR212_215 | 0x0114 | | INTC_PSR84_87 | 0x0094 | INTC_PSR216_219 | 0x0118 | | INTC_PSR88_91 | 0x0098 | INTC_PSR220_223 | 0x011C | | INTC_PSR92_95 | 0x009C | INTC_PSR224_227 | 0x0120 | | INTC_PSR96_99 | 0x00A0 | INTC_PSR228_231 | 0x0124 | | INTC_PSR100_103 | 0x00A4 | INTC_PSR232_235 | 0x0128 | | INTC_PSR104_107 | 0x00A8 | INTC_PSR236_239 | 0x012C | | INTC_PSR108_111 | 0x00AC | INTC_PSR240_243 | 0x0130 | | INTC_PSR112_115 | 0x00B0 | INTC_PSR244_247 | 0x0134 | | INTC_PSR116_119 | 0x00B4 | INTC_PSR248_251 | 0x0138 | | INTC_PSR120_123 | 0x00B8 | INTC_PSR252_255 | 0x013C | | INTC_PSR124_127 | 0x00BC | INTC_PSR256_259 | 0x0140 | | INTC_PSR128_131 | 0x00C0 | INTC_PSR260 | 0x0144 | # 9.6 Functional description The functional description involves the areas of interrupt request sources, priority management, and handshaking with the processor. Note: The INTC has no spurious vector support. Therefore, if an asserted peripheral or software settable interrupt request, whose PRIn value in INTC\_PSR0-INTC\_PSR260 is higher than the PRI value in INTC\_CPR, negates before the interrupt request to the processor for that peripheral or software settable interrupt request is acknowledged, the interrupt request to the processor still can assert or will remain asserted for that peripheral or software settable interrupt request. In this case, the interrupt vector will correspond to that peripheral or software settable interrupt request. Also, the PRI value in the INTC\_CPR will be updated with the corresponding PRIn value in INTC\_PSRn. Furthermore, clearing the peripheral interrupt request's enable bit in the peripheral or, alternatively, setting its mask bit has the same consequences as clearing its flag bit. Setting its enable bit or clearing its mask bit while its flag bit is asserted has the same effect on the INTC as an interrupt event setting the flag bit. Table 84. Interrupt vector table | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | |-------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------|--| | On-Platform Peripherals | | | | | | | | | Software Interr | upts | | | | 0 | 0x0800 | Software setable flag 0 | INTC_0 (Software) | INTC_1 (Software) | | | 1 | 0x0804 | Software setable flag 1 | INTC_0 (Software) | INTC_1 (Software) | | | 2 | 0x0808 | Software setable flag 2 | INTC_0 (Software) | INTC_1 (Software) | | | 3 | 0x080C | Software setable flag 3 | INTC_0 (Software) | INTC_1 (Software) | | | 4 | 0x0810 | Software setable flag 4 | INTC_0 (Software) | INTC_1 (Software) | | | 5 | 0x0814 | Software setable flag 5 | INTC_0 (Software) | INTC_1 (Software) | | | 6 | 0x0818 | Software setable flag 6 | INTC_0 (Software) | INTC_1 (Software) | | | 7 | 0x081C | Software setable flag 7 | INTC_0 (Software) | INTC_1 (Software) | | | 8 | 0x0820 | | Rese | erved | | | | | ECSM | | | | | 9 | 0x0824 | Platform Flash Bank 0 Abort Platform Flash Bank 0 Stall Platform Flash Bank 1 Abort Platform Flash Bank 1 Stall Platform Flash Bank 2 Abort Platform Flash Bank 2 Stall Platform Flash Bank 3 Abort Platform Flash Bank 3 Stall | ECSM_0 | ECSM_1 | | | | DMA2x | | | | | | 10 | 0x0828 | Combined Error | DM | A_0 | | **Table 84. Interrupt vector table(Continued)** | IRQ# | Offset | Interrupt vector t | Source Module for INTC_0 | Source Module for INTC_1 | |------|--------|---------------------------------------------|--------------------------|--------------------------| | 11 | 0x082C | Channel 0 | DM | A_0 | | 12 | 0x0830 | Channel 1 | DMA_0 | | | 13 | 0x0834 | Channel 2 | DM | A_0 | | 14 | 0x0838 | Channel 3 | DM | A_0 | | 15 | 0x083C | Channel 4 | DM | A_0 | | 16 | 0x0840 | Channel 5 | DM | A_0 | | 17 | 0x0844 | Channel 6 | DM | A_0 | | 18 | 0x0848 | Channel 7 | DM | A_0 | | 19 | 0x084C | Channel 8 | DM | A_0 | | 20 | 0x0850 | Channel 9 | DM | A_0 | | 21 | 0x0854 | Channel 10 | DM | A_0 | | 22 | 0x0858 | Channel 11 | DM | A_0 | | 23 | 0x085C | Channel 12 | DM | A_0 | | 24 | 0x0860 | Channel 13 | DM | A_0 | | 25 | 0x0864 | Channel 14 | DMA_0 | | | 26 | 0x0868 | Channel 15 | DM | A_0 | | 27 | 0x086C | F | Reserved | | | | | SWT | | | | 28 | 0x0870 | SWT Timeout | SWT_0 | SWT_1 | | 29 | 0x0874 | F | Reserved | | | | | STM | | | | 30 | 0x0878 | Match on channel 0 | STM_0 | STM_1 | | 31 | 0x087C | Match on channel 1 | STM_0 | STM_1 | | 32 | 0x0880 | Match on channel 2 | STM_0 | STM_1 | | 33 | 0x0884 | Match on channel 3 | STM_0 | STM_1 | | 34 | 0x0888 | F | Reserved | | | | | ECSM | | | | 35 | 0x088C | ECC_DBD_PlatformFlash ECC_DBD_PlatformRAM | ECSM_0 | ECSM_1 | | 36 | 0x0890 | ECC_SBC_PlatformFlash ECC_SBC_PlatformRAM | ECSM_0 ECSM_1 | | | 37 | 0x0894 | Reserved | | | | 38 | 0x0898 | Reserved | | | | 39 | 0x089C | Reserved | | | Table 84. Interrupt vector table(Continued) | Offset | Interrupt | Source wooding for | | |--------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | 0x08A0 | F | Reserved | | | | SIUL | | | | 0x08A4 | SIU External IRQ_0 | SII | UL | | 0x08A8 | SIU External IRQ_1 | SII | UL | | 0x08AC | SIU External IRQ_2 | SII | UL | | 0x08B0 | SIU External IRQ_3 | SII | UL | | 0x08B4 | F | Reserved | | | 0x08B8 | F | Reserved | | | 0x08BC | F | Reserved | | | 0x08C0 | F | Reserved | | | 0x08C4 | F | Reserved | | | 0x08C8 | F | Reserved | | | MC_ME | | | | | 0x08CC | Safe Mode Interrupt | MC_ | _ME | | 0x08D0 | Mode Transition Interrupt | MC_ | _ME | | 0x08D4 | Invalid Mode Interrupt | MC_ | _ME | | 0x08D8 | Invalid Mode Config | MC_ | _ME | | 0x08DC | F | Reserved | | | | MC_RGM | | | | 0x08E0 | Functional and destructive reset alternate event interrupt (ipi_int) | MC_I | RGM | | | xosc | | | | 0x08E4 | XOSC counter expired (ipi_int_osc) | хо | SC | | | PIT | | | | 0x08E8 | F | Reserved | | | 0x08EC | PITimer Channel 0 | P | IT | | 0x08F0 | PITimer Channel 1 | P | IT | | 0x08F4 | PITimer Channel 2 PIT | | IT | | | ADC0 | | | | 0x08F8 | ADC_EOC | ADO | C_0 | | 0x08FC | Reserved | | | | 0x0900 | ADC_WD | ADO | C_0 | | | 0x08A8 0x08BC 0x08BC 0x08BC 0x08CC 0x08CC 0x08CC 0x08D0 0x08BC | 0x08A4 SIU External IRQ_0 0x08A8 SIU External IRQ_2 0x08B0 SIU External IRQ_3 0x08B4 If 0x08B8 If 0x08C0 If 0x08C4 If 0x08CC Safe Mode Interrupt 0x08D0 Mode Transition Interrupt 0x08D4 Invalid Mode Interrupt 0x08D5 Invalid Mode Config 0x08D6 Invalid Mode Config 0x08D7 Invalid Mode Config 0x08D8 Invalid Mode Config 0x08E0 Functional and destructive reset alternate event interrupt (ipi_int) XOSC counter expired (ipi_int_osc) XOSC 0x08E4 XOSC counter expired (ipi_int_osc) PIT 0x08E8 If 0x08E0 PITimer Channel 0 0x08F0 0x08F0 PITimer Channel 1 0x08F4 0x08F8 ADC_EOC 0x08FC Invalid Mode Interrupt (ipi_int) | 0x08A4 SIU External IRQ_0 SII 0x08A8 SIU External IRQ_1 SII 0x08B0 SIU External IRQ_3 SII 0x08B4 Reserved 0x08B6 Reserved 0x08B7 Reserved 0x08C0 Reserved 0x08C4 Reserved 0x08C8 Reserved 0x08D0 Mode Transition Interrupt MC_ 0x08D1 Invalid Mode Interrupt MC_ 0x08D2 Reserved 0x08D3 Invalid Mode Config MC_ 0x08D4 Invalid Mode Config MC_ 0x08D6 Reserved MC_RGM 0x08E0 Functional and destructive reset alternate event interrupt (ipi_int) MC_ x0SC XOSC XO 0x08E4 XOSC counter expired (ipi_int_osc) XO PIT 0x08E8 Reserved 0x08F0 PITimer Channel 0 P 0x08F0 PITimer Channel 1 P 0x08F8 ADC_EOC ADC 0x08FC | **Table 84. Interrupt vector table(Continued)** | | Source Module for Source Module for | | | | | |------|-------------------------------------|-----------------------------------------------------------------------|-----------|--------|--| | IRQ# | Offset | Interrupt | INTC_0 | INTC_1 | | | | | FlexCAN0 | | | | | 65 | 0x0904 | FLEXCAN_ESR[ERR_INT] | FlexC | AN_0 | | | 66 | 0x0908 | FLEXCAN_ESR_BOFF FLEXCAN_Transmit_Warning FLEXCAN_Receive_Warning | FlexC | AN_0 | | | 67 | 0x090C | F | Reserved | | | | 68 | 0x0910 | FLEXCAN_BUF_00_03 | FlexC | :AN_0 | | | 69 | 0x0914 | FLEXCAN_BUF_04_07 | FlexC | :AN_0 | | | 70 | 0x0918 | FLEXCAN_BUF_08_11 | FlexC | AN_0 | | | 71 | 0x091C | FLEXCAN_BUF_12_15 | FlexC | AN_0 | | | 72 | 0x0920 | FLEXCAN_BUF_16_31 | FlexC | AN_0 | | | 73 | 0x0924 | ŀ | Reserved | | | | | | DSPI0 | | | | | 74 | 0x0928 | DSPI_SR[TFUF] /<br>DSPI_SR[RFOF] | DSPI_0 | | | | 75 | 0x092C | DSPI_SR[EOQF] | DSF | 기_0 | | | 76 | 0x0930 | DSPI_SR[TFFF] | DSPI_0 | | | | 77 | 0x0934 | DSPI_SR[TCF] | DSF | 기_0 | | | 78 | 0x0938 | DSPI_SR[RFDF] | DSF | 기_0 | | | | | LINFlex0 | | | | | 79 | 0x093C | LINFlex_RXI | LINF | lex_0 | | | 80 | 0x0940 | LINFlex_TXI | LINF | lex_0 | | | 81 | 0x0944 | LINFlex_ERR | LINF | lex_0 | | | 82 | 0x0948 | ŀ | Reserved | | | | 83 | 0x094C | F | Reserved | | | | 84 | 0x0950 | F | Reserved | | | | | | FlexCAN1 | | | | | 85 | 0x0954 | FLEXCAN_ESR[ERR_INT] | FlexC | AN_1 | | | 86 | 0x0958 | FLEXCAN_ESR_BOFF FLEXCAN_Transmit_Warning FLEXCAN_Receive_Warning | FlexCAN_1 | | | | 87 | 0x095C | F | Reserved | | | | 88 | 0x0960 | FLEXCAN_BUF_00_03 | FlexC | AN_1 | | | 89 | 0x0964 | FLEXCAN_BUF_04_07 | FlexC | AN_1 | | | | | | | | | Table 84. Interrupt vector table(Continued) | Note | | iable 84. interrupt vector table(Continued) | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------|-------------------|--------------------------|--------------------------|--| | 91 0x096C | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | | 92 0x0970 | 90 | 0x0968 | FLEXCAN_BUF_08_11 | FlexC | :AN_1 | | | DSPI | 91 | 0x096C | FLEXCAN_BUF_12_15 | FlexCAN_1 | | | | DSPI | 92 | 0x0970 | FLEXCAN_BUF_16_31 | FlexC | AN_1 | | | DSPI_SR[FUF] / DSPI_SR[RFOF] DSPI_1 DSPI_SRIP DSPI_SRI | 93 | 0x0974 | F | Reserved | | | | DSPI_SR[RFOF] DSPI_1 | | | DSPI1 | | | | | 96 0x0980 DSPI_SR[TFF] DSPI_1 97 0x0984 DSPI_SR[TCF] DSPI_1 LINFlex1 LINFlex_1 99 0x098C LINFlex_RXI LINFlex_1 100 0x0990 LINFlex_TXI LINFlex_1 101 0x0994 LINFlex_ERR LINFlex_1 102 0x0998 Reserved 103 0x099C Reserved 104 0x09A0 Reserved 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EQOF] DSPI_2 116 0x09Dd DSPI_SR[TFFF] | 94 | 0x0978 | | DSF | 기_1 | | | 97 0x0984 DSPI_SR[TCF] DSPI_1 98 0x0988 DSPI_SR[RFDF] DSPI_1 100 0x0990 LINFlex_TXI LINFlex_1 101 0x0994 LINFlex_ERR LINFlex_1 102 0x0998 Reserved 103 0x099C Reserved 104 0x09A0 Reserved 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved 114 0x09C0 Reserved 115 0x09C0 Reserved 116 0x09C DSPI_SR[TFUF] / DSPI_2 117 0x09DC DSPI_SR[TFFF] DSPI_2 118 0x09C0 DSPI_SR[TFFF] DSPI_2 119 0x09D0 DSPI_SR[TFFF] DSPI_2 110 0x09D0 DSPI_SR[TFFF] DSPI_2 111 0x09D0 DSPI_SR[TFFF] DSPI_2 111 0x09D1 DSPI_SR[TFFF] DSPI_2 111 0x09D1 DSPI_SR[TFFFF] DSPI_2 | 95 | 0x097C | DSPI_SR[EOQF] | DSF | 기_1 | | | DSPI_SR[RFDF] DSPI_1 | 96 | 0x0980 | DSPI_SR[TFFF] | DSF | 기_1 | | | See | 97 | 0x0984 | DSPI_SR[TCF] | DSF | 기_1 | | | 99 0x098C LINFlex_RXI LINFlex_1 100 0x0990 LINFlex_TXI LINFlex_1 101 0x0994 LINFlex_ERR LINFlex_1 102 0x0998 Reserved 103 0x099C Reserved 104 0x09A0 Reserved 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 110 0x09B4 Reserved 111 0x09B6 Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 98 | 0x0988 | DSPI_SR[RFDF] | DSF | 기_1 | | | 100 | | | LINFlex1 | | | | | 101 | 99 | 0x098C | LINFlex_RXI | LINF | lex_1 | | | 102 0x0998 | 100 | 0x0990 | LINFlex_TXI | LINF | lex_1 | | | 103 0x099C Reserved 104 0x09A0 Reserved 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[TFUF] / DSPI_SR[TFUF] DSPI_2 115 0x09CC DSPI_SR[EQQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 101 | 0x0994 | LINFlex_ERR | LINFlex_1 | | | | 104 0x09A0 Reserved 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 102 | 0x0998 | Reserved | | | | | 105 0x09A4 Reserved 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[FOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 103 | 0x099C | F | Reserved | | | | 106 0x09A8 Reserved 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 104 | 0x09A0 | F | Reserved | | | | 107 0x09AC Reserved 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 105 | 0x09A4 | F | Reserved | | | | 108 0x09B0 Reserved 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 106 | 0x09A8 | F | Reserved | | | | 109 0x09B4 Reserved 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 107 | 0x09AC | F | Reserved | | | | 110 0x09B8 Reserved 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 108 | 0x09B0 | F | Reserved | | | | 111 0x09BC Reserved 112 0x09C0 Reserved 113 0x09C4 Reserved DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 109 | 0x09B4 | F | Reserved | | | | 112 0x09C0 Reserved DSPI2 DSPI_SR[TFUF] / DSPI_SR[RFOF] 115 0x09C0 DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 110 | 0x09B8 | F | Reserved | | | | DSPI | 111 | 0x09BC | F | Reserved | | | | DSPI2 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 112 | 0x09C0 | F | Reserved | | | | 114 0x09C8 DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 113 | 0x09C4 | F | Reserved | | | | 0x09C8 DSPI_SR[RFOF] DSPI_2 115 0x09CC DSPI_SR[EOQF] DSPI_2 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | | | DSPI2 | | | | | 116 0x09D0 DSPI_SR[TFFF] DSPI_2 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 114 | 0x09C8 | | DSPI_2 | | | | 117 0x09D4 DSPI_SR[TCF] DSPI_2 | 115 | 0x09CC | DSPI_SR[EOQF] | DSPI_2 | | | | | 116 | 0x09D0 | DSPI_SR[TFFF] | DSPI_2 | | | | 118 0x09D8 DSPI_SR[RFDF] DSPI_2 | 117 | 0x09D4 | DSPI_SR[TCF] | DSPI_2 | | | | | 118 | 0x09D8 | DSPI_SR[RFDF] | DSPI_2 | | | Table 84. Interrupt vector table(Continued) | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | |------|--------|-------------------|--------------------------|--------------------------|--| | 119 | 0x09DC | | Reserved | | | | 120 | 0x09E0 | | Reserved | | | | 121 | 0x09E4 | | Reserved | | | | 122 | 0x09E8 | | Reserved | | | | 123 | 0x09EC | | Reserved | | | | 124 | 0x09F0 | | Reserved | | | | 125 | 0x09F4 | | Reserved | | | | 126 | 0x09F8 | | Reserved | | | | | | PIT | | | | | 127 | 0x09FC | PITimer Channel 3 | Р | IT | | | 128 | 0x0A00 | | Reserved | | | | 129 | 0x0A04 | | Reserved | | | | 130 | 0x0A08 | | Reserved | | | | 131 | 0x0A0C | | Reserved | | | | 132 | 0x0A10 | Reserved | | | | | | | FlexRay | | | | | 133 | 0x0A14 | CIFRR.FNEAIF | Flex | Ray | | | 134 | 0x0A18 | CIFRR.FNEBIF | Flex | Ray | | | 135 | 0x0A1C | CIFRR.WUPIF | Flex | Ray | | | 136 | 0x0A20 | CIFRR.PRIF | Flex | Ray | | | 137 | 0x0A24 | CIFRR.CHIF | Flex | Ray | | | 138 | 0x0A28 | CIFRR.TBIF | Flex | Ray | | | 139 | 0x0A2C | CIFRR.RBIF | Flex | Ray | | | 140 | 0x0A30 | CIFRR.MIF | Flex | Ray | | | 141 | 0x0A34 | | Reserved | | | | 142 | 0x0A38 | | Reserved | | | | 143 | 0x0A3C | Reserved | | | | | 144 | 0x0A40 | Reserved | | | | | 145 | 0x0A44 | Reserved | | | | | 146 | 0x0A48 | Reserved | | | | | 147 | 0x0A4C | Reserved | | | | | 148 | 0x0A50 | | Reserved | | | | 149 | 0x0A54 | | Reserved | | | | 150 | 0x0A58 | | Reserved | | | Table 84. Interrupt vector table(Continued) | - I | Table 84. Interrupt vector table(Continued) | | | | | |------|---------------------------------------------|--------------|--------------------------|--------------------------|--| | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | | 151 | 0x0A5C | | Reserved | | | | 152 | 0x0A60 | 1 | Reserved | | | | 153 | 0x0A64 | 1 | Reserved | | | | 154 | 0x0A68 | | Reserved | | | | 155 | 0x0A6C | | Reserved | | | | 156 | 0x0A70 | | Reserved | | | | | | eTimer | | | | | 157 | 0x0A74 | TC0IR | eTim | ner_0 | | | 158 | 0x0A78 | TC1IR | eTim | ner_0 | | | 159 | 0x0A7C | TC2IR | eTim | ner_0 | | | 160 | 0x0A80 | TC3IR | eTim | ner_0 | | | 161 | 0x0A84 | TC4IR | eTim | ner_0 | | | 162 | 0x0A88 | TC5IR | eTim | ner_0 | | | 163 | 0x0A8C | Reserved | | | | | 164 | 0x0A90 | Reserved | | | | | 165 | 0x0A94 | WTIF | eTim | ner_0 | | | 166 | 0x0A98 | | Reserved | | | | 167 | 0x0A9C | RCF | eTim | ner_0 | | | 168 | 0x0AA0 | TC0IR | eTim | ner_1 | | | 169 | 0x0AA4 | TC1IR | eTim | ner_1 | | | 170 | 0x0AA8 | TC2IR | eTim | ner_1 | | | 171 | 0x0AAC | TC3IR | eTim | ner_1 | | | 172 | 0x0AB0 | TC4IR | eTim | ner_1 | | | 173 | 0x0AB4 | TC5IR | eTim | ner_1 | | | 174 | 0x0AB8 | | Reserved | | | | 175 | 0x0ABC | 1 | Reserved | | | | 176 | 0x0AC0 | Reserved | | | | | 177 | 0x0AC4 | Reserved | | | | | 178 | 0x0AC8 | RCF eTimer_1 | | ner_1 | | | 179 | 0x0ACC | Reserved | | | | | 180 | 0x0AD0 | Reserved | | | | | 181 | 0x0AD4 | Reserved | | | | | 182 | 0x0AD8 | | Reserved | | | | 183 | 0x0ADC | | Reserved | | | **Table 84. Interrupt vector table(Continued)** | IRQ# | Offset | Interrupt vector | Source Module for INTC_0 | Source Module for INTC_1 | | |------|--------|--------------------------------------------------------------------------------------------|--------------------------|--------------------------|--| | 184 | 0x0AE0 | Reserved | | | | | 185 | 0x0AE4 | Reserved | | | | | 186 | 0x0AE8 | 1 | Reserved | | | | 187 | 0x0AEC | I | Reserved | | | | 188 | 0x0AF0 | 1 | Reserved | | | | 189 | 0x0AF4 | 1 | Reserved | | | | 190 | 0x0AF8 | ı | Reserved | | | | 191 | 0x0AFC | | Reserved | | | | 192 | 0x0B00 | | Reserved | | | | | | СТИ | | | | | 193 | 0x0B04 | MRS_I | СТ | J_0 | | | 194 | 0x0B08 | T0_I | СТ | J_0 | | | 195 | 0x0B0C | T1_I | T1_I CTU_0 | | | | 196 | 0x0B10 | T2_I CTU_0 | | J_0 | | | 197 | 0x0B14 | T3_I | T3_I CTU_0 | | | | 198 | 0x0B18 | T4_I CTU_0 | | | | | 199 | 0x0B1C | T5_I | T5_I CTU_0 | | | | 200 | 0x0B20 | T6_I | СТ | J_0 | | | 201 | 0x0B24 | T7_I | СТ | 0_0 | | | 202 | 0x0B28 | FIFO0_I | СТ | J_0 | | | 203 | 0x0B2C | FIFO1_I | СТ | J_0 | | | 204 | 0x0B30 | FIFO2_I | СТ | J_0 | | | 205 | 0x0B34 | FIFO3_I | СТ | J_0 | | | 206 | 0x0B38 | ADC_I | СТІ | J_0 | | | 207 | 0x0B3C | ERR_I | СТ | J_0 | | | | | SafetyPort | | | | | 208 | 0x0B40 | FLEXCAN_ESR[ERR_INT] | SafetyPort | (FlexCAN) | | | 209 | 0x0B44 | FLEXCAN_ESR_BOFF FLEXCAN_Transmit_Warning SafetyPort (FlexCAN) FLEXCAN_Receive_Warning | | (FlexCAN) | | | 210 | 0x0B48 | Reserved | | | | | 211 | 0x0B4C | FLEXCAN_BUF_0_3 | SafetyPort | (FlexCAN) | | | 212 | 0x0B50 | FLEXCAN_BUF_4_7 | SafetyPort (FlexCAN) | | | | 213 | 0x0B54 | FLEXCAN_BUF_8_11 | SafetyPort | (FlexCAN) | | Table 84. Interrupt vector table(Continued) | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | |------|--------|----------------------------------|--------------------------|--------------------------| | 214 | 0x0B58 | FLEXCAN_BUF_12_15 | SafetyPort | (FlexCAN) | | 215 | 0x0B5C | FLEXCAN_BUF_16_31 | SafetyPort | (FlexCAN) | | 216 | 0x0B60 | ŀ | Reserved | | | | | DSPI3 | | | | 217 | 0x0B64 | DSPI_SR[TFUF] /<br>DSPI_SR[RFOF] | DSF | 기_3 | | 218 | 0x0B68 | DSPI_SR[EOQF] | DSF | 기_3 | | 219 | 0x0B6C | DSPI_SR[TFFF] | DSF | 기_3 | | 220 | 0x0B70 | DSPI_SR[TCF] | DSF | 기_3 | | 221 | 0x0B74 | DSPI_SR[RFDF] | DSF | 기_3 | | 222 | 0x0B78 | ŀ | Reserved | | | 223 | 0x0B7C | ŀ | Reserved | | | 224 | 0x0B80 | ŀ | Reserved | | | 225 | 0x0B84 | Reserved | | | | 226 | 0x0B88 | Reserved | | | | 227 | 0x0B8C | Reserved | | | | 228 | 0x0B90 | Reserved | | | | 229 | 0x0B94 | Reserved | | | | 230 | 0x0B98 | F | Reserved | | | 231 | 0x0B9C | ſ | Reserved | | | 232 | 0x0BA0 | ſ | Reserved | | | 233 | 0x0BA4 | F | Reserved | | | 234 | 0x0BA8 | F | Reserved | | | 235 | 0x0BAC | I | Reserved | | | 236 | 0x0BB0 | ſ | Reserved | | | 237 | 0x0BB4 | ſ | Reserved | | | 238 | 0x0BB8 | ŀ | Reserved | | | 239 | 0x0BBC | F | Reserved | | | 240 | 0x0BC0 | Reserved | | | | 241 | 0x0BC4 | Reserved | | | | 242 | 0x0BC8 | Reserved | | | | 243 | 0x0BCC | F | Reserved | | | 244 | 0x0BD0 | F | Reserved | | | 245 | 0x0BD4 | Ī | Reserved | | Table 84. Interrupt vector table(Continued) | | | Table 64. Interrupt vector table(Continued) | | | | | |------|--------|---------------------------------------------|--------------------------|--------------------------|--|--| | IRQ# | Offset | Interrupt | Source Module for INTC_0 | Source Module for INTC_1 | | | | 246 | 0x0BD8 | F | Reserved | | | | | | SEM4 | | | | | | | 247 | 0x0BDC | cp0_semaphore_int | Semaphore<br>(SEM4_0) | | | | | | OXOBDC | cp1_semaphore_int | | Semaphore<br>(SEM4_0) | | | | 248 | 0x0BE0 | cp0_semaphore_int | Semaphore<br>(SEM4_1) | | | | | | OXOBLO | cp1_semaphore_int | | Semaphore<br>(SEM4_1) | | | | 249 | 0x0BE4 | Not used | Not | used | | | | | | FCCU | | | | | | 250 | 0x0BE8 | irq_alarm_b | FC | CU | | | | 251 | 0x0BEC | irq_misc_b | FC | CU | | | | 252 | 0x0BF0 | irq_rccs_b[0] | FC | CU | | | | 253 | 0x0BF4 | irq_rccs_b[1] | FC | CU | | | | 254 | 0x0BF8 | F | Reserved | | | | | 255 | 0x0BFC | F | Reserved | | | | | | | DSPI4 | | | | | | 256 | 0x0C00 | DSPI_SR[TFUF] / DSPI_SR[RFOF] DSPI_4 | | 기_4 | | | | 257 | 0x0C04 | DSPI_SR[EOQF] | DSPI_4 | | | | | 258 | 0x0C08 | DSPI_SR[TFFF] | DSPI_4 | | | | | 259 | 0x0C0C | DSPI_SR[TCF] | DSF | 기_4 | | | | 260 | 0x0C10 | DSPI_SR[RFDF] | DSF | 기_4 | | | # 9.6.1 Interrupt request sources The INTC has two types of interrupt requests, peripheral and software configurable. These interrupt requests can assert on any clock cycle. # 9.6.1.1 Peripheral interrupt requests An interrupt event in a peripheral's hardware sets a flag bit that resides in the peripheral. The interrupt request from the peripheral is driven by that flag bit. The time from when the peripheral starts to drive its peripheral interrupt request to the INTC to the time that the INTC starts to drive the interrupt request to the processor is three clocks. External interrupts are handled by the SIU (see Section 11.6.4: External interrupts). # 9.6.1.2 Software configurable interrupt requests An interrupt request is triggered by software by writing a '1' to a SETx bit in INTC\_SSCIR0\_3-INTC\_SSCIR4\_7. This write sets the corresponding flag bit, CLRx, resulting in the interrupt request. The interrupt request is cleared by writing a '1' to the CLRx bit. The time from the write to the SET*x* bit to the time that the INTC starts to drive the interrupt request to the processor is four clocks. # 9.6.1.3 Unique vector for each interrupt request source Each peripheral and software configurable interrupt request is assigned a hardwired unique 9-bit vector. Software configurable interrupts 0–7 are assigned vectors 0–7 respectively. The peripheral interrupt requests are assigned vectors 8 to as high as needed to include all the peripheral interrupt requests. The peripheral interrupt request input ports at the boundary of the INTC block are assigned specific hardwired vectors within the INTC (see *Table 76*). # 9.6.2 Priority management The asserted interrupt requests are compared to each other based on their PRIx values set in INTC Priority Select Registers (INTC\_PSR0\_3-INTC\_PSR260). The result is compared to PRI in the associated *INTC\_CPR*. The results of those comparisons manage the priority of the ISR executed by the associated processor. The associated LIFO also assists in managing that priority. # 9.6.2.1 Current priority and preemption The priority arbitrator, selector, encoder, and comparator subblocks shown in *Figure 84* compare the priority of the asserted interrupt requests to the current priority. If the priority of any asserted peripheral or software configurable interrupt request is higher than the current priority for a given processor, then the interrupt request to the processor is asserted. Also, a unique vector for the preempting peripheral or software settable interrupt request is generated for INTC interrupt acknowledge register (INTC\_IACKR), and if in hardware vector mode, for the interrupt vector provided to the processor. # 9.6.2.1.1 Priority arbitrator subblock The priority arbitrator subblock for each processor compares all the priorities of all of the asserted interrupt requests assigned to that processor, both peripheral and software configurable. The output of the priority arbitrator subblock is the highest of those priorities assigned to a given processor. Also, any interrupt requests that have this highest priority are output as asserted interrupt requests to the associated request selector subblock. #### 9.6.2.1.2 Request selector subblock If only one interrupt request from the associated priority arbitrator subblock is asserted, then it is passed as asserted to the associated vector encoder subblock. If multiple interrupt requests from the associated priority arbitrator subblock are asserted, only the one with the lowest vector passes as asserted to the associated vector encoder subblock. The lower vector is chosen regardless of the time order of the assertions of the peripheral or software configurable interrupt requests. #### 9.6.2.1.3 Vector encoder subblock The vector encoder subblock generates the unique 9-bit vector for the asserted interrupt request from the request selector subblock for the associated processor. ### 9.6.2.1.4 Priority comparator subblock The priority comparator submodule compares the highest priority output from the priority arbitrator submodule with PRI in INTC\_CPR. If the priority comparator submodule detects that this highest priority is higher than the current priority, then it asserts the interrupt request to the processor. This interrupt request to the processor asserts whether this highest priority is raised above the value of PRI in INTC\_CPR or the PRI value in INTC\_CPR is lowered below this highest priority. This highest priority then becomes the new priority that will be written to PRI in INTC\_CPR when the interrupt request to the processor is acknowledged. Interrupt requests whose PRIn in INTC\_PSRn are zero will not cause a preemption because their PRIn will not be higher than PRI in INTC\_CPR. # 9.6.2.2 Last-in first-out (LIFO) The LIFO stores the preempted PRI values from the INTC\_CPR. Therefore, because these priorities are stacked within the INTC, if interrupts need to be enabled during the ISR, at the beginning of the interrupt exception handler the PRI value in the INTC\_CPR does not need to be loaded from the INTC\_CPR and stored onto the context stack. Likewise at the end of the interrupt exception handler, the priority does not need to be loaded from the context stack and stored into the INTC\_CPR. The PRI value in the INTC\_CPR is pushed onto the LIFO when the INTC\_IACKR is read in software vector mode or the interrupt acknowledge signal from the processor is asserted in hardware vector mode. The priority is popped into PRI in the INTC\_CPR whenever the INTC\_EOIR is written. Although the INTC supports 16 priorities, an ISR executing with PRI in the INTC\_CPR equal to 15 will not be preempted. Therefore, the LIFO supports the stacking of 15 priorities. However, the LIFO is only 14 entries deep. An entry for a priority of 0 is not needed because of how pushing onto a full LIFO and popping an empty LIFO are treated. If the LIFO is pushed 15 or more times than it is popped, the priorities first pushed are overwritten. A priority of 0 would be an overwritten priority. However, the LIFO will pop 0s if it is popped more times than it is pushed. Therefore, although a priority of 0 was overwritten, it is regenerated with the popping of an empty LIFO. The LIFO is not memory mapped. # 9.6.3 Handshaking with processor # 9.6.3.1 Software vector mode handshaking This section describes handshaking in software vector mode. #### 9.6.3.1.1 Acknowledging interrupt request to processor A timing diagram of the interrupt request and acknowledge handshaking in software vector mode and the handshake near the end of the interrupt exception handler, is shown in *Figure 93*. The INTC examines the peripheral and software configurable interrupt requests. When it finds an asserted peripheral or software configurable interrupt request with a higher priority than PRI in the associated *INTC\_CPR*, it asserts the interrupt request to the processor. The INTVEC field in the associated *INTC\_IACKR* is updated with the preempting interrupt request's vector when the interrupt request to the processor is asserted. The INTVEC field retains that value until the next time the interrupt request to the processor is asserted. The rest of handshaking process is described in *Section 9.4.1.1: Software vector mode*. # 9.6.3.1.2 End of interrupt exception handler Before the interrupt exception handling completes, INTC end-of-interrupt register (INTC\_EOIR) must be written. When written, the associated LIFO is popped so the preempted priority is restored into PRI of the INTC\_CPR. Before it is written, the peripheral or software configurable flag bit must be cleared so that the peripheral or software configurable interrupt request is negated. Note: To ensure proper operation across all eSys MCUs, execute an MBAR or MSYNC instruction between the access to clear the flag bit and the write to the INTC\_EOIR. When returning from the preemption, the INTC does not search for the peripheral or software settable interrupt request whose ISR was preempted. Depending on how much the ISR progressed, that interrupt request may no longer even be asserted. When PRI in INTC\_CPR is lowered to the priority of the preempted ISR, the interrupt request for the preempted ISR or any other asserted peripheral or software settable interrupt request at or below that priority will not cause a preemption. Instead, after the restoration of the preempted context, the processor will return to the instruction address that it was to next execute before it was preempted. This next instruction is part of the preempted ISR or the interrupt exception handler's prolog or epilog. Figure 93. Software vector mode handshaking timing diagram # 9.6.3.2 Hardware vector mode handshaking A timing diagram of the interrupt request and acknowledge handshaking in hardware vector mode, along with the handshaking near the end of the interrupt exception handler, is shown in *Figure 94*. As in software vector mode, the INTC examines the peripheral and software settable interrupt requests, and when it finds an asserted one with a higher priority than PRI in INTC\_CPR, it asserts the interrupt request to the processor. The INTVEC field in the INTC\_IACKR is updated with the preempting peripheral or software settable interrupt request's vector when the interrupt request to the processor is asserted. The INTVEC field retains that value until the next time the interrupt request to the processor is asserted. In addition, the value of the interrupt vector to the processor matches the value of the INTVEC field in the INTC\_IACKR. The rest of the handshaking is described in *Section 9.4.1.2: Hardware vector mode*. The handshaking near the end of the interrupt exception handler, that is the writing to the INTC\_EOIR, is the same as in software vector mode. Refer to Section 9.6.3.1.2: End of interrupt exception handler. Figure 94. Hardware vector mode handshaking timing diagram # 9.7 Initialization/application information #### 9.7.1 Initialization flow After exiting reset, all of the PRI*n* fields in INTC Priority Select Registers (INTC\_PSR0\_3–INTC\_PSR260) will be zero, and PRI in INTC current priority register (INTC\_CPR) will be 15. These reset values will prevent the INTC from asserting the interrupt request to the processor. The enable or mask bits in the peripherals are reset such that the peripheral interrupt requests are negated. An initialization sequence for allowing the peripheral and software settable interrupt requests to cause an interrupt request to the processor is: interrupt request initialization: ``` interrupt_request_initialization: configure VTES and HVEN in INTC_MCR configure VTBA in INTC_IACKR raise the PRIn fields in INTC_PSRn set the enable bits or clear the mask bits for the peripheral interrupt requests lower PRI in INTC_CPR to zero enable processor recognition of interrupts ``` # 9.7.2 Interrupt exception handler These example interrupt exception handlers use Power Architecture assembly code. #### 9.7.2.1 Software vector mode ``` interrupt exception handler: code to create stack frame, save working register, and save SRRO and SRR1 lis r3,INTC_IACKR@ha # form adjusted upper half of INTC_IACKR address lwz r3,INTC IACKR@l(r3) # load INTC IACKR, which clears request to processor lwz r3,0x0(r3) # load address of ISR from vector table wrteei 1 # enable processor recognition of interrupts code to save rest of context required by e500 EABI mtlr r3 # move INTC IACKR contents into link register # branch to ISR; link register updated with epilog blrl # address epilog: code to restore most of context required by e500 EABI # Popping the LIFO after the restoration of most of the context and the disabling of processor # recognition of interrupts eases the calculation of the maximum stack depth at the cost of # postponing the servicing of the next interrupt request. # ensure store to clear flag bit has completed lis r3,INTC_EOIR@ha # form adjusted upper half of INTC_EOIR address li r4,0x0 # form 0 to write to INTC EOIR # disable processor recognition of interrupts stw r4,INTC EOIR@1(r3) # store to INTC EOIR, informing INTC to lower priority code to restore SRRO and SRR1, restore working registers, and delete stack frame ``` ``` vector_table_base_address: address of ISR for interrupt with vector 0 address of ISR for interrupt with vector 1 . . . address of ISR for interrupt with vector 510 address of ISR for interrupt with vector 511 ISRx: code to service the interrupt event code to clear flag bit that drives interrupt request to INTC ``` #### 9.7.2.2 Hardware vector mode blr # return to epilog This interrupt exception handler is useful with processor and system bus implementations that support a hardware vector. This example assumes that each interrupt\_exception\_handlerx only has space for four instructions, and therefore a branch to interrupt\_exception\_handler\_continuedx is needed. ``` interrupt_exception_handlerx: b interrupt_exception_handler_continuedx# 4 instructions available, branch to continue interrupt_exception_handler_continuedx: code to create stack frame, save working register, and save SRRO and SRR1 wrteei 1 # enable processor recognition of interrupts code to save rest of context required by e500 EABI bl ISRx # branch to ISR for interrupt with vector x epilog: code to restore most of context required by e500 EABI # Popping the LIFO after the restoration of most of the context and the disabling of processor # recognition of interrupts eases the calculation of the maximum stack depth at the cost of ``` ``` # postponing the servicing of the next interrupt request. mbar # ensure store to clear flag bit has completed lis r3,INTC_EOIR@ha # form adjusted upper half of INTC_EOIR address li r4,0x0 # form 0 to write to INTC_EOIR wrteei 0 # disable processor recognition of interrupts stw r4,INTC_EOIR@l(r3) # store to INTC_EOIR, informing INTC to lower priority code to restore SRR0 and SRR1, restore working registers, and delete stack frame rfi ISRx: code to service the interrupt event code to clear flag bit that drives interrupt request to INTC blr # branch to epilog ``` # 9.7.3 ISR, RTOS, and task hierarchy The RTOS and all of the tasks under its control typically execute with PRI in INTC current priority register (INTC\_CPR) having a value of 0. The RTOS will execute the tasks according to whatever priority scheme that it may have, but that priority scheme is independent and has a lower priority of execution than the priority scheme of the INTC. In other words, the ISRs execute above INTC\_CPR priority 0 and outside the control of the RTOS, the RTOS executes at INTC\_CPR priority 0, and while the tasks execute at different priorities under the control of the RTOS, they also execute at INTC\_CPR priority 0. If a task shares a resource with an ISR and the PCP is being used to manage that shared resource, then the task's priority can be elevated in the INTC\_CPR while the shared resource is being accessed. An ISR whose PRIn in INTC Priority Select Registers (INTC\_PSR0\_3–INTC\_PSR260) has a value of 0 will not cause an interrupt request to the processor, even if its peripheral or software settable interrupt request is asserted. For a peripheral interrupt request, not setting its enable bit or disabling the mask bit will cause it to remain negated, which consequently also will not cause an interrupt request to the processor. Since the ISRs are outside the control of the RTOS, this ISR will not run unless called by another ISR or the interrupt exception handler, perhaps after executing another ISR. #### 9.7.4 Order of execution An ISR with a higher priority can preempt an ISR with a lower priority, regardless of the unique vectors associated with each of their peripheral or software configurable interrupt requests. However, if multiple peripheral or software configurable interrupt requests are asserted, more than one has the highest priority, and that priority is high enough to cause preemption, the INTC selects the one with the lowest unique vector regardless of the order in time that they asserted. However, the ability to meet deadlines with this scheduling scheme is no less than if the ISRs execute in the time order that their peripheral or software configurable interrupt requests asserted. The example in *Table 85* shows the order of execution of both ISRs with different priorities and the same priority Table 85. Order of ISR execution example | Step<br># | Step Description | Code Executing at End of Step | | | | | | PRI in | |-----------|---------------------------------------------------------------------------------------------------------|-------------------------------|---------------|------------|------------|------------|-----------------------------------|-------------------------------| | | | RTOS | ISR108<br>(1) | ISR20<br>8 | ISR30<br>8 | ISR40<br>8 | Interrupt<br>Exception<br>Handler | INTC_CPR<br>at End of<br>Step | | 1 | RTOS at priority 0 is executing. | Х | | | | | | 0 | | 2 | Peripheral interrupt request 100 at priority 1 asserts. Interrupt taken. | | Х | | | | | 1 | | 3 | Peripheral interrupt request 400 at priority 4 is asserts. Interrupt taken. | | | | | Х | | 4 | | 4 | Peripheral interrupt request 300 at priority 3 is asserts. | | | | | Х | | 4 | | 5 | Peripheral interrupt request 200 at priority 3 is asserts. | | | | | Х | | 4 | | 6 | ISR408 completes. Interrupt exception handler writes to INTC_EOIR. | | | | | | Х | 1 | | 7 | Interrupt taken. ISR208 starts to execute, even though peripheral interrupt request 300 asserted first. | | | Х | | | | 3 | | 8 | ISR208 completes. Interrupt exception handler writes to INTC_EOIR. | | | | | | Х | 1 | | 9 | Interrupt taken. ISR308 starts to execute. | | | | Х | | | 3 | | 10 | ISR308 completes. Interrupt exception handler writes to INTC_EOIR. | | | | | | Х | 1 | | 11 | ISR108 completes. Interrupt exception handler writes to INTC_EOIR. | | | | | | Х | 0 | | 12 | RTOS continues execution. | Х | | | | | | 0 | <sup>1.</sup> ISR108 executes for peripheral interrupt request 100 because the first eight ISRs are for software configurable interrupt requests. # 9.7.5 Priority ceiling protocol # 9.7.5.1 Elevating priority The PRI field in *INTC\_CPR* is elevated in the OSEK PCP to the ceiling of all of the priorities of the ISRs that share a resource. This protocol allows coherent accesses of the ISRs to that shared resource. For example, ISR1 has a priority of 1, ISR2 has a priority of 2, and ISR3 has a priority of 3. They share the same resource. Before ISR1 or ISR2 can access that resource, they must raise the PRI value in INTC\_CPR to 3, the ceiling of all of the ISR priorities. After they release the resource, the PRI value in INTC\_CPR can be lowered. If they do not raise their priority, ISR2 can preempt ISR1, and ISR3 can preempt ISR1 or ISR2, possibly corrupting the shared resource. Another possible failure mechanism is deadlock if the higher priority ISR needs the lower priority ISR to release the resource before it can continue, but the lower priority ISR cannot release the resource until the higher priority ISR completes and execution returns to the lower priority ISR. Using the PCP instead of disabling processor recognition of all interrupts eliminates the time when accessing a shared resource that all higher priority interrupts are blocked. For example, while ISR3 cannot preempt ISR1 while it is accessing the shared resource, all of the ISRs with a priority higher than 3 can preempt ISR1. #### 9.7.5.2 Ensuring coherency A scenario can cause non-coherent accesses to the shared resource. For example, ISR1 and ISR2 are both running on the same core and both share a resource. ISR1 has a lower priority than ISR2. ISR1 is executing and writes to the INTC\_CPR. The instruction following this store is a store to a value in a shared coherent data block. Either immediately before or at the same time as the first store, the INTC asserts the interrupt request to the processor because the peripheral interrupt request for ISR2 has asserted. As the processor is responding to the interrupt request from the INTC, and as it is aborting transactions and flushing its pipeline, it is possible that both stores will be executed. ISR2 thereby thinks that it can access the data block coherently, but the data block has been corrupted. OSEK uses the GetResource and ReleaseResource system services to manage access to a shared resource. To prevent corruption of a coherent data block, modifications to PRI in INTC\_CPR can be made by those system services with the code sequence: ``` disable processor recognition of interrupts PRI modification enable processor recognition of interrupts ``` #### 9.7.6 Selecting priorities according to request rates and deadlines The selection of the priorities for the ISRs can be made using rate monotonic scheduling (RMS) or a superset of it, deadline monotonic scheduling (DMS). In RMS, the ISRs that have higher request rates have higher priorities. In DMS, if the deadline is before the next time the ISR is requested, then the ISR is assigned a priority according to the time from the request for the ISR to the deadline, not from the time of the request for the ISR to the next request for it. For example, ISR1 executes every 100 $\mu$ s, ISR2 executes every 200 $\mu$ s, and ISR3 executes every 300 $\mu$ s. ISR1 has a higher priority than ISR2, which has a higher priority than ISR3; however, if ISR3 has a deadline of 150 $\mu$ s, then it has a higher priority than ISR2. The INTC has 16 priorities, which may be less than the number of ISRs. In this case, the ISRs should be grouped with other ISRs that have similar deadlines. For example, a priority could be allocated for every time the request rate doubles. ISRs with request rates around 1 ms would share a priority, ISRs with request rates around 500 $\mu$ s would share a priority, ISRs with request rates around 250 $\mu$ s would share a priority, etc. With this approach, a range of ISR request rates of $2^{16}$ could be included, regardless of the number of ISRs. Reducing the number of priorities reduces the processor's ability to meet its deadlines. However, reducing the number of priorities can reduce the size and latency through the interrupt controller. It also allows easier management of ISRs with similar deadlines that share a resource. They do not need to use the PCP to access the shared resource. #### 9.7.7 Software configurable interrupt requests The software configurable interrupt requests can be used in two ways. They can be used to schedule a lower priority portion of an ISR and they may also be used by processors to interrupt other processors in a multiple processor system. #### 9.7.7.1 Scheduling a lower priority portion of an ISR A portion of an ISR needs to be executed at the PRIx value in INTC Priority Select Registers (INTC\_PSR0\_3-INTC\_PSR260), which becomes the PRI value in *INTC\_CPR* with the interrupt acknowledge. The ISR, however, can have a portion that does not need to be executed at this higher priority. Therefore, executing the later portion that does not need to be executed at this higher priority can prevent the execution of ISRs that do not have a higher priority than the earlier portion of the ISR but do have a higher priority than what the later portion of the ISR needs. This preemptive scheduling inefficiency reduces the processor's ability to meet its deadlines. One option is for the ISR to complete the earlier higher priority portion, but then schedule through the RTOS a task to execute the later lower priority portion. However, some RTOSs can require a large amount of time for an ISR to schedule a task. Therefore, a second option is for the ISR, after completing the higher priority portion, to set a SETx bit in INTC\_SSCIRO\_3—INTC\_SSCIR4\_7. Writing a '1' to SETx causes a software configurable interrupt request. This software configurable interrupt request will usually have a lower PRIx value in the INTC\_PSRx\_x and will not cause preemptive scheduling inefficiencies. After generating a software settable interrupt request, the higher priority ISR completes. The lower priority ISR is scheduled according to its priority. Execution of the higher priority ISR is not resumed after the completion of the lower priority ISR. #### 9.7.7.2 Scheduling an ISR on another processor Because the SETx bits in the INTC\_SSCIRx\_x are memory mapped, processors in multiple-processor systems can schedule ISRs on the other processors. One application is that one processor wants to command another processor to perform a piece of work and the initiating processor does not need to use the results of that work. If the initiating processor is concerned that the processor executing the software configurable ISR has not completed the work before asking it to again execute the ISR, it can check if the corresponding CLRx bit in INTC\_SSCIRx\_x is asserted before again writing a '1' to the SETx bit. Another application is the sharing of a block of data. For example, a first processor has completed accessing a block of data and wants a second processor to then access it. Furthermore, after the second processor has completed accessing the block of data, the first processor again wants to access it. The accesses to the block of data must be done coherently. To do this, the first processor writes a '1' to a SETx bit on the second processor. After accessing the block of data, the second processor clears the corresponding CLRx bit and then writes 1 to a SETx bit on the first processor, informing it that it can now access the block of data. ## 9.7.8 Lowering priority within an ISR A common method for avoiding preemptive scheduling inefficiencies with an ISR whose work spans multiple priorities (see *Section 9.7.7.1: Scheduling a lower priority portion of an ISR*) is to lower the current priority. However, the INTC has a LIFO whose depth is determined by the number of priorities. Note: Lowering the PRI value in INTC\_CPR within an ISR to below the ISR's corresponding PRI value in INTC Priority Select Registers (INTC\_PSR0\_3–INTC\_PSR260) allows more preemptions than the LIFO depth can support. Therefore, the INTC does not support lowering the current priority within an ISR as a way to avoid preemptive scheduling inefficiencies. #### 9.7.9 Negating an interrupt request outside of its ISR #### 9.7.9.1 Negating an interrupt request as a side effect of an ISR Some peripherals have flag bits that can be cleared as a side effect of servicing a peripheral interrupt request. For example, reading a specific register can clear the flag bits and their corresponding interrupt requests. This clearing as a side effect of servicing a peripheral interrupt request can cause the negation of other peripheral interrupt requests besides the peripheral interrupt request whose ISR presently is executing. This negating of a peripheral interrupt request outside of its ISR can be a desired effect. #### 9.7.9.2 Negating multiple interrupt requests in one ISR An ISR can clear other flag bits besides its own. One reason that an ISR clears multiple flag bits is because it serviced those flag bits, and therefore the ISRs for these flag bits do not need to be executed. #### 9.7.9.3 Proper setting of interrupt request priority Whether an interrupt request negates outside its own ISR due to the side effect of an ISR execution or the intentional clearing a flag bit, the priorities of the peripheral or software configurable interrupt requests for these other flag bits must be selected properly. Their PRIx values in INTC Priority Select Registers (INTC\_PSR0\_3-INTC\_PSR260) must be selected to be at or lower than the priority of the ISR that cleared their flag bits. Otherwise, those flag bits can cause the interrupt request to the processor to assert. Furthermore, the clearing of these other flag bits also has the same timing relationship to the writing to INTC\_SSCIR0\_3-INTC\_SSCIR4\_7 as the clearing of the flag bit that caused the present ISR to be executed (see Section 9.6.3.1.2: End of interrupt exception handler). A flag bit whose enable bit or mask bit negates its peripheral interrupt request can be cleared at any time, regardless of the peripheral interrupt request's PRIx value in INTC\_PSRx\_x. ## 9.7.10 Examining LIFO contents In normal mode, the user does not need to know the contents of the LIFO. He may not even know how deeply the LIFO is nested. However, if he wants to read the contents, such as in debug mode, they are not memory mapped. The contents can be read by popping the LIFO and reading the PRI field in either *INTC\_CPR*. The code sequence is: pop\_lifo: store to INTC EOIR load INTC\_CPR, examine PRI, and store onto stack if PRI is not zero or value when interrupts were enabled, branch to pop\_lifo When the examination is complete, the LIFO can be restored using this code sequence: push\_lifo: load stacked PRI value and store to ${\tt INTC\_CPR}$ load ${\tt INTC\_IACKR}$ if stacked PRI values are not depleted, branch to push\_lifo # 10 System Status and Configuration Module (SSCM) #### 10.1 Introduction #### 10.1.1 Overview The System Status and Configuration Module (SSCM), pictured in *Figure 95*, provides central device functionality. Figure 95. SSCM block diagram #### 10.1.2 Features The SSCM includes these features: - · System configuration and status - Memory sizes/status - Device mode and security status - Determine boot vector - Search Code Flash for bootable sector - Device identification information (MCU ID Registers) - Debug status port enable and selection - Bus and peripheral abort enable/disable #### 10.1.3 Modes of operation The SSCM operates identically in all system modes. # 10.2 Memory map and register description This section provides a detailed description of all memory-mapped registers in the SSCM. ### 10.2.1 Memory map *Table 86* shows the memory map for the SSCM. Note that all addresses are offsets; the absolute address may be calculated by adding the specified offset to the base address of the SSCM. Table 86. SSCM memory map | Offset from<br>SSCM_BASE<br>(0xC3FD_8000) | Register | Location | |-------------------------------------------|------------------------------------------------|-------------| | 0x0000 | STATUS—System Status register | on page 259 | | 0x0002 | MEMCONFIG—System Memory Configuration register | on page 260 | | 0x0004 | Reserved (Reads/Writes have no effect) | | | 0x0006 | ERROR—Error Configuration register | on page 261 | | 0x0008 | DEBUGPORT—Debug Status Port register | on page 262 | | 0x000A | Reserved (Reads/Writes have no effect) | | | 0x000C | PWCMPH—Password Comparison High Word register | on page 263 | | 0x0010 | PWCMPL—Password Comparison Low Word register | on page 263 | | 0x0014 | Reserved | | | 0x0018 | DPMBOOT—DPM Boot Register | on page 265 | | 0x001C | DPMKEY—DPM Boot Key Register | on page 265 | | 0x0020 | UOPS—User Option Status Register | on page 266 | | 0x0024 | Reserved | | | 0x0028 | PSA—Processor Start Address Register | on page 267 | | 0x002C-0x3FFF | Reserved | | All registers are accessible via 8, 16 or 32-bit accesses. However, 16-bit accesses must be aligned to 16-bit boundaries, and 32-bit accesses must be aligned to 32-bit boundaries. As an example, the MEMCONFIG register is accessible by a 16-bit read/write to address Base + 0x0002, but performing a 16-bit access to Base + 0x0003 is illegal. ### 10.2.2 Register description Each description includes a standard register diagram. Details of register bit and field function follow the register diagrams, in bit order. The numbering convention of the registers is MSB = 0, however the numbering of the internal fields is LSB = 0, for example, register $SSCM\_STATUS[8] = BMODE[2]$ . Figure 96. Key to register fields #### 10.2.2.1 System Status register (STATUS) The system status register is a read-only register that reflects the current state of the system. Figure 97. Status (STATUS) register 1. The reset value reflects the VLE bit value on RCHW, see Section 35.5.3: Reset Configuration Half Word (RCHW). Table 87. STATUS register accesses | A | | Access width | | |-------------|-------------|--------------|-----------------------| | Access type | 8-bit | 16-bit | 32-bit <sup>(1)</sup> | | Read | Allowed | Allowed | Allowed | | Write | Not allowed | Not allowed | Not allowed | <sup>1.</sup> All 32-bit accesses must be aligned to 32-bit addresses (i.e., 0x0, 0x4, 0x8, or 0xC). #### Table 88. STATUS field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CER | Configuration Error. This field indicates that the SSCM has detected a configuration error during bootup. 1 Device configuration is not correct 0 No configuration problem detected by the SSCM | | NXEN1 | Processor 1 Nexus enabled. | | NXEN | Nexus enabled | | PUB | Public Serial Access Status This bit indicates whether serial boot mode with public password is allowed. 1: Serial boot mode with public password allowed 0: Serial boot mode with private Flash password allowed, provided the key has not been swallowed | **Table 88. STATUS field descriptions(Continued)** | Field | Description | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SEC | Security Status This bit reflects the current security state of the Flash. 1: Flash secured 0: Flash not secured | | VLE | Variable Length Instruction Mode. When booting from Flash, this field indicates that the code stored there is using the VLE instruction set. The value of this field is determined by the RCHW field of the Flash boot sector. 1 Main Flash contains VLE code 0 Main Flash contains standard PPC code | | BMODE<br>[2:0] | Device Boot Mode 000: Reserved for FlexRay boot serial boot loader 001: Legacy bootstrap via CAN (no autobaud) 010: Legacy bootstrap via UART (no autobaud) 011: Single Chip 100–111: Reserved This field is updated only during reset. | | ABD | Autobaud Indicates that autobaud detection is active when in SCI or CAN serial boot loader mode. No meaning in other modes. | #### **System Memory Configuration register (MEMCONFIG)** 10.2.2.2 The system memory configuration register is a read-only register that reflects the memory configuration of the system. Figure 98. System memory configuration (MEMCONFIG) register Table 89. MEMCONFIG field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | JPIN | JTAG Part ID Number | | IVLD | CFlash Valid This bit identifies whether or not the on-chip CFlash is accessible in the system memory map. The Flash may not be accessible due to security limitations. 1: CFlash accessible 0: CFlash not accessible Note: This is a status bit only and writing to this bit does not enable the CFlash if it has been disabled due to specific mode of operation. | | MREV | Minor Mask Revision | | DVLD | DFlash Valid This bit identifies whether or not the on-chip DFlash is visible in the system memory map. The Flash may not be accessible due to security limitations. 1: DFlash visible 0: DFlash not visible Note: This is a status bit only and writing to this bit does not enable the CFlash if it has been disabled due to specific mode of operation. | Table 90. MEMCONFIG register accesses | Access type | Access width | | | |-------------|--------------|-------------|--------------------------------------------| | Access type | 8-bit | 16-bit | 32-bit | | Read | Allowed | Allowed | Allowed<br>(also reads STATUS<br>register) | | Write | Not allowed | Not allowed | Not allowed | ## 10.2.2.3 Error Configuration (ERROR) register The Error Configuration register is a read-write register that controls the error handling of the system. Figure 99. Error Configuration (ERROR) register Table 91. ERROR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PAE | Peripheral Bus Abort Enable This bit enables bus aborts on any access to a peripheral slot that is not used on the device. This feature is intended to aid in debugging when developing application code. 1: Illegal accesses to non-existing peripherals produce a Prefetch or Data Abort exception. 0: Illegal accesses to non-existing peripherals do not produce a Prefetch or Data Abort exception. | | RAE | Register Bus Abort Enable This bit enables bus aborts on illegal accesses to off-platform peripherals. Illegal accesses are defined as reads or writes to reserved addresses within the address space for a particular peripheral. This feature is intended to aid in debugging when developing application code. 1: Illegal accesses to peripherals produce a Prefetch or Data Abort exception. 0: Illegal accesses to peripherals do not produce a Prefetch or Data Abort exception. | Note: Transfers to Peripheral Bus resources may be aborted even before they reach the Peripheral Bus (i.e., at the PRIDGE level). In this case, the PAE and RAE register bits will have no effect on the abort. Table 92. ERROR register accesses | Access type | Access width | | | |-------------|-----------------------------|---------|-------------| | Access type | 8-bit | 16-bit | 32-bit | | Read | Allowed | Allowed | Allowed | | Write | Allowed Allowed Not allowed | | Not allowed | #### 10.2.2.4 Debug Status Port (DEBUGPORT) register The Debug Status Port register provides debug data on a set of pins. Figure 100. Debug Status Port (DEBUGPORT) register Table 93. DEBUGPORT field descriptions | Field | Description | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13-15<br>DEBUG_MODE[2:0] | Debug Status Port Mode This field selects the alternate debug functionality for the Debug Status Port. 000: No alternate functionality selected 001: Mode 1 selected 010: Mode 2 selected 011: Mode 3 selected 100: Mode 4 selected 101: Mode 5 selected 111: Mode 6 selected 111: Mode 7 selected Table 94 describes the functionality of the Debug Status Port in each mode. | Table 94. Debug Status Port modes | Pin<br>(1) | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Mode 5 | Mode 6 | Mode 7 | |------------|-----------|------------|--------------|---------------|----------|----------|----------| | 0 | STATUS[0] | STATUS[8] | MEMCONFIG[0] | MEMCONFIG[8] | Reserved | Reserved | Reserved | | 1 | STATUS[1] | STATUS[9] | MEMCONFIG[1] | MEMCONFIG[9] | Reserved | Reserved | Reserved | | 2 | STATUS[2] | STATUS[10] | MEMCONFIG[2] | MEMCONFIG[10] | Reserved | Reserved | Reserved | | 3 | STATUS[3] | STATUS[11] | MEMCONFIG[3] | MEMCONFIG[11] | Reserved | Reserved | Reserved | | 4 | STATUS[4] | STATUS[12] | MEMCONFIG[4] | MEMCONFIG[12] | Reserved | Reserved | Reserved | | 5 | STATUS[5] | STATUS[13] | MEMCONFIG[5] | MEMCONFIG[13] | Reserved | Reserved | Reserved | | 6 | STATUS[6] | STATUS[14] | MEMCONFIG[6] | MEMCONFIG[14] | Reserved | Reserved | Reserved | | 7 | STATUS[7] | STATUS[15] | MEMCONFIG[7] | MEMCONFIG[15] | Reserved | Reserved | Reserved | <sup>1.</sup> All signals are active high, unless otherwise noted. Table 95. DEBUGPORT register accesses | A 4 | | Access width | | | |-------------|---------|--------------|-----------------------|--| | Access type | 8-bit | 16-bit | 32-bit <sup>(1)</sup> | | | Read | Allowed | Allowed | Not allowed | | | Write | Allowed | Allowed | Not allowed | | <sup>1.</sup> All 32-bit accesses must be aligned to 32-bit addresses (i.e., 0x0, 0x4, 0x8 or 0xC). #### 10.2.2.5 Password comparison registers These registers allow to unsecure the device, if the correct password is known. Figure 101. Password Comparison Register High Word (PWCMPH) register Figure 102. Password Comparison Register Low Word (PWCMPL) register #### Table 96. PWCMPH/L field descriptions | Field | Description | | |--------------|-------------------------------|--| | PWD_HI[31:0] | Upper 32 bits of the password | | | PWD_LO[31:0] | Lower 32 bits of the password | | Table 97. PWCMPH/L register accesses | Access towns | Access width | | | |--------------|--------------|-------------|-----------------------| | Access type | 8-bit | 16-bit | 32-bit <sup>(1)</sup> | | Read | Allowed | Allowed | Allowed | | Write | Not allowed | Not allowed | Allowed | 1. All 32-bit accesses must be aligned to 32-bit addresses (i.e., 0x0, 0x4, 0x8 or 0xC). #### 10.2.2.6 DPM Boot Register Figure 103. DPM Boot (DPMBOOT) Register **Table 98. DPMBOOT Field Descriptions** | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Determines the location from which the 2nd processor will boot, once the main processor releases it from reset. This field is only used if the device is operating in DPM mode. | #### 10.2.2.7 Boot Key Register Figure 104. Boot Key Register (DPMKEY) Register **Table 99. DPMKEY Field Descriptions** | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | KEY | Control key. This field is used to activate the second core in DP Mode. The sequence following sequence is required: - write to the DPMBOOT register - write the value 0101101011110000 (0x5AF0) to the key field - write the value 1010010100001111 (0xA50F) to the key field After this the second core will start executing from the address specified in the DPMBOOT register. | #### 10.2.2.8 User Option Status Register Figure 105. User Option Status (UOPS) Register Table 100. UOPS Field Descriptions | Field | Description | |-------|------------------------------------------------------------------------| | UOPT | Shows the values read from the User Option Bits location in the Flash. | #### 10.2.2.9 Processor Start Address Register Figure 106. Processor Start Address (PSA) Register # 10.3 Functional description **Table 101. PSA Field Descriptions** | Field | Description | |-------|--------------------------------------------------------------------------------------------| | SADR | Start Address - the boot processor will start executing application code from this address | The primary purpose of the SSCM is to provide information about the current state and configuration of the system that may be useful for configuring application software and for debug of the system. # 10.4 Initialization/application information #### 10.4.1 Reset The reset state of each individual bit is shown in Section 10.2.2: Register description. #### **System Integration Unit Lite (SIUL)** 11 #### 11.1 Introduction This chapter describes the System Integration Unit Lite (SIUL), which is used for the management of the pads and their configuration. It controls the multiplexing of the alternate functions used on all pads and is responsible for managing the external interrupts to the device. #### 11.2 Overview The System Integration Unit Lite (SIUL) controls the MCU pad configuration, ports, generalpurpose input and output (GPIO) signals and external interrupts with trigger event configuration. Figure 107 is a block diagram of the SIUL and its interfaces to other system components. The module provides dedicated general-purpose pads that can be configured as either inputs or outputs. When configured as an output, you can write to an internal register to control the state driven on the associated output pad. When configured as an input, you can detect the state of the associated pad by reading the value from an internal register. When configured as an input and output, the pad value can be read back, which can be used a method of checking if the written value appeared on the pad. Figure 107. System Integration Unit Lite block diagram ## 11.3 Features The System Integration Unit Lite provides these features: - GPIO - GPIO function on up to 106 I/O pins - Dedicated input and output registers for each GPIO pin - External interrupts - 4 system interrupt vectors for up to 32 interrupt sources - 32 programmable digital glitch filters - Independent interrupt mask - Edge detection - System configuration - Pad configuration control #### 11.3.1 Register protection Most of the configuration registers of the System Integration Unit Lite are protected from accidental writes, see *Appendix A: Registers Under Protection*. # 11.4 External signal description The pad configuration allows flexible, centralized control of the pin electrical characteristics of the MCU with the GPIO control providing centralized general purpose I/O for an MCU that multiplexes GPIO with other signals at the I/O pads. These other signals, or alternate functions, will normally be the peripherals functions. The internal multiplexing allows user selection of the input to chip-level signal multiplexers. Each GPIO port communicates via 16 I/O channels. In order to use the pad as a GPIO, the corresponding Pad Configuration Registers (PCR[0:108]) for all pads used in the port must be configured as GPIO rather than as the alternate pad function. Table 102 lists the external pins used by the SIUL. | 142.5 102. 0.02 0.9.14. p. opo. 1.00 | | | | |--------------------------------------|---------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------| | GPIO category | Name | I/O direction | Function | | System configuration | GPIO[0:19],<br>GPIO[22],<br>GPIO[35:62]<br>GPIO[77:107] | Input/Output | General-purpose input/output | | | GPIO[23:34],<br>GPIO[63:76] | Input | Analog precise channel pins | | External interrupt | EIRQ[0:31] | Input | Pins with External Interrupt Request functionality. Please refer to the signal description chapter of this reference manual for details. | Table 102. SIUL signal properties ## 11.4.1 Detailed signal descriptions #### 11.4.1.1 General-purpose I/O pins (GPIO[0:107]) The GPIO pins provide general-purpose input and output function. The GPIO pins are generally multiplexed with other I/O pin functions. Each GPIO input and output is separately controlled by an input (GPDIn n) or output (GPDOn n) register. See Section 11.5.2.10: GPIO Pad Data Output registers 0\_3–104\_107 (GPDO[0\_3:104\_107]) and Section 11.5.2.11: GPIO Pad Data Input registers 0\_3–104\_107 (GPDI[0\_3:104\_107]). #### 11.4.1.2 External interrupt request input pins (EIRQ[0:31]) The EIRQ[0:31] are connected to the SIUL inputs. Rising or falling edge events are enabled by setting the corresponding bits in the "n" SIUL\_IREER or the SIUL\_IFEER. See Section 11.5.2.5: Interrupt Rising-Edge Event Enable Register (IREER) and Section 11.5.2.6: Interrupt Falling-Edge Event Enable Register (IFEER). # 11.5 Memory map and register description This section provides a detailed description of all registers accessible in the SIUL module. # 11.5.1 SIUL memory map Table 103 lists the SIUL registers. Table 103. SIUL memory map | Offset from<br>SIUL_BASE<br>(0xC3F9_0000) | Register | Location | |-------------------------------------------|-------------------------------------------------------------------------|-------------| | 0x0000-0x0003 | Reserved | | | 0x0004 | MCU ID Register #1 (MIDR1) | on page 272 | | 0x0008 | MCU ID Register #2 (MIDR2) | on page 273 | | 0x000C-0x0013 | Reserved | | | 0x0014 | Interrupt Status Flag Register (ISR) | on page 274 | | 0x0018 | Interrupt Request Enable Register (IRER) | on page 274 | | 0x001C-0x0027 | Reserved | | | 0x0028 | Interrupt Rising-Edge Event Enable Register (IREER) | on page 275 | | 0x002C | Interrupt Falling-Edge Event Enable Register (IFEER) | on page 275 | | 0x0030 | Interrupt Filter Enable Register (IFER) | on page 276 | | 0x0034-0x003F | Reserved | | | 0x0040-0x0118 | Pad Configuration Registers (PCR[0:108]) | on page 276 | | 0x0118-0x04FF | Reserved | | | 0x0500-0x0524 | Pad Selection for Multiplexed Inputs registers (PSMI[0_3:36_39]) | on page 278 | | 0x0528-0x05FF | Reserved | | | 0x0600-0x0668 | GPIO Pad Data Output registers 0_3-104_107 (GPDO[0_3:104_107]) | on page 282 | | 0x066C-0x07FF | Reserved | | | 0x0800-0x0868 | GPIO Pad Data Input registers 0_3–104_107 (GPDI[0_3:104_107]) | on page 282 | | 0x086C-0x0BFF | Reserved | | | 0x0C00-0x0C0C | Parallel GPIO Pad Data Out register 0–3 (PGPDO[0:3]) | on page 283 | | 0x0C10-0x0C3F | Reserved | | | 0x0C40-0x0C4C | Parallel GPIO Pad Data In register 0–3 (PGPDI[0:3]) | on page 283 | | 0x0C50-0x0C7F | Reserved | | | 0x0C80-0x0C98 | Masked Parallel GPIO Pad Data Out register 0–6 (MPGPDO[0:6]) on page 28 | | | 0x0C9C-0x0FFF | Reserved | | | 0x1000-0x107C | Interrupt Filter Maximum Counter registers 0–31 (IFMC[0:31]) | on page 285 | | 0x1080 | Interrupt Filter Clock Prescaler Register (IFCPR) | on page 285 | | 0x1084-0x3FFF | Reserved | | Note: A transfer error will be issued when trying to access completely reserved register space. ## 11.5.2 Register description This section describes in address order all the SIUL registers. Each description includes a standard register diagram. Details of register bit and field function follow the register diagrams, in bit order. The numbering convention of register is MSB = 0, however the numbering of internal field is LSB = 0, for example PARTNUM[5] = MIDR1[10]. Figure 108. Key to register fields ### 11.5.2.1 MCU ID Register #1 (MIDR1) This register contains the part number and the package ID of the device. Figure 109. MCU ID Register #1 (MIDR1) 1. See Table 104. Table 104. MIDR1 field descriptions | Field | Description | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | PARTNUM[15:0] | MCU Part Number Device part number of the MCU. 0101_0110_0000_0101: 768 KB, single core 0101_0110_0000_0110: 1 MB, single core 0101_0110_1010_0101: 768 KB, dual core 0101_0110_1010_0110: 1 MB, dual core For the full part number this field needs to be combined with MIDR2.PARTNUM[23:16] | | | | CSP | Always reads back 0 | | | | PKG[4:0] PKG[4:0] Package Settings Can by read by software to determine the package type that is used for the particular 01001: 100-pin LQFP 01101: 144-pin LQFP | | | | Table 104. MIDR1 field descriptions(Continued) | Field | Description | | | |-----------------|-------------------------------------------------------------------------------------------|--|--| | MAJOR_MASK[3:0] | Major Mask Revision Counter starting at 0x0. Incremented each time a resynthesis is done. | | | | MINOR_MASK[3:0] | Minor Mask Revision Counter starting at 0x0. Incremented each time a mask change is done. | | | #### 11.5.2.2 MCU ID Register #2 (MIDR2) This register contains additional configuration information about the device. Figure 110. MCU ID Register #2 (MIDR2) Table 105. MIDR2 field descriptions | Field | Description | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | SF | Manufacturer 0: Reserved 1: ST | | | | FLASH_SIZE_1[3:0] | Coarse granularity for Flash memory size Needs to be combined with FLASH_SIZE_2 to calculate the actual memory size. 0101: 512 KB 0110: 1 MB Other values are reserved. | | | | Fine granularity for Flash memory size Needs to be combined with FLASH_SIZE_1 to calculate the actual memory size. 0000: 0 x (FLASH_SIZE_1 / 8) 0010: 2 x (FLASH_SIZE_1 / 8) 0100: 4 x (FLASH_SIZE_1 / 8) Other values are reserved. | | | | | PARTNUM[23:16] ASCII character in MCU Part Number 0x50: P family (Steering) | | | | | Data Flash present EE 0: No Data Flash present 1: Data Flash present | | | | ### 11.5.2.3 Interrupt Status Flag Register (ISR) This register holds the interrupt flags. Figure 111. Interrupt Status Flag Register (ISR) Table 106. ISR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EIFn | External Interrupt Status Flag <i>n</i> This flag can be cleared only by writing a 1. Writing a 0 has no effect. If enabled (IRER <i>n</i> ), EIF <i>n</i> causes an interrupt request. 0: No interrupt event has occurred on the pad. 1: An interrupt event as defined by IREER <i>n</i> and IFEER <i>n</i> has occurred. | ## 11.5.2.4 Interrupt Request Enable Register (IRER) This register enables the interrupt messaging to the interrupt controller. Figure 112. Interrupt Request Enable Register (IRER) Table 107. IRER field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | External Interrupt Request Enable <i>n</i> 0: Interrupt requests from the corresponding EIF <i>n</i> bit are disabled. 1: A set EIF <i>n</i> bit causes an interrupt request. | #### 11.5.2.5 Interrupt Rising-Edge Event Enable Register (IREER) This register allows rising-edge triggered events to be enabled on the corresponding interrupt pads. Figure 113. Interrupt Rising-Edge Event Enable Register (IREER) Table 108. IREER field descriptions | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------| | IREE <i>n</i> | Enable rising-edge events to cause the EIF <i>n</i> bit to be set. 0: Rising-edge event disabled 1: Rising-edge event enabled | #### 11.5.2.6 Interrupt Falling-Edge Event Enable Register (IFEER) This register allows falling-edge triggered events to be enabled on the corresponding interrupt pads. Figure 114. Interrupt Falling-Edge Event Enable Register (IFEER) Table 109. IFEER field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------| | IFEEn | Enable falling-edge events to cause the EIF <i>n</i> bit to be set. 0: Falling-edge event disabled 1: Falling-edge event enabled | Note: If both the IREER.IREE and IFEER.IFEE bits are cleared for the same interrupt source, the interrupt status flag for the corresponding external interrupt will never be set. #### 11.5.2.7 Interrupt Filter Enable Register (IFER) This register enables a digital filter counter on the corresponding interrupt pads to filter out glitches on the inputs. Figure 115. Interrupt Filter Enable Register (IFER) Table 110. IFER field descriptions | Field Description | | | | | |-------------------|------------------------------------------------------------------------------------------------|--|--|--| | IFE <i>n</i> | Enable digital glitch filter on the interrupt pad input. 0: Filter disabled 1:Filter enabled | | | | #### 11.5.2.8 Pad Configuration Registers (PCR[0:108]) The Pad Configuration Registers allow configuration of the static electrical and functional characteristics associated with I/O pads. Each PCR controls the characteristics of a single pad. Base + 0x0040 (PCR0) Address: ... Base + 0x0118 (PCR108) 109 registers Figure 116. Pad Configuration Registers 0–108 (PCR[0:108]) 1. See Table 112. Note: 16/32-bit access is supported for the PCR[0:108] registers. Access: User read/write Table 111. PCR[0:108] field descriptions | Field | Description | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SMC | Safe Mode Control This bit supports the overriding of the automatic deactivation of the output buffer of the associated pad upon entering Safe mode of the device. 0: In Safe mode, output buffer of the pad disabled 1: In Safe mode, output buffer remains functional | | APC | Analog Pad Control This bit enables the usage of the pad as analog input. 0: Analog input path from the pad is gated and cannot be used. 1: Analog input path switch can be enabled by the ADC. | | PA[1:0] | Pad Output Assignment This field selects the function that is allowed to drive the output of a multiplexed pad. The PA field size can vary from 0 to 2 bits, depending on the number of output functions associated with this pad. 00: Alternative mode 0: GPIO 01: Alternative mode 1 (see Chapter 3: Signal Description) 10: Alternative mode 2 (see Chapter 3: Signal Description) 11: Alternative mode 3 (see Chapter 3: Signal Description) Note: The number of bits in the PA bitfield depends of the number of actual alternate functions provided for each pad. Please see the SPC56xP60x/54x Datasheet (SPC56xP60x/54x). | | OBE | Output Buffer Enable This bit enables the output buffer of the pad in case the pad is in GPIO mode. 0: Output buffer of the pad disabled when PA = 00 1: Output buffer of the pad enabled when PA = 00 | | IBE | Input Buffer Enable This bit enables the input buffer of the pad. 0: Input buffer of the pad disabled 1: Input buffer of the pad enabled | | ODE | Open Drain Output Enable This bit controls output driver configuration for the pads connected to this signal. Either open drain or push/pull driver configurations can be selected. This feature applies to output pads only. 0: Open drain enable signal negated for the pad 1: Open drain enable signal asserted for the pad | | SRC | Slew Rate Control 0: Slowest configuration 1: Fastest configuration | | WPE | Weak Pull Up/Down Enable This bit controls whether the weak pull up/down devices are enabled/disabled for the pad connected to this signal. 0: Weak pull device enable signal negated for the pad 1: Weak pull device enable signal asserted for the pad | | WPS | Weak Pull Up/Down Select This bit controls whether weak pull up or weak pull down devices are used for the pads connected to this signal when weak pull up/down devices are enabled. 0: Pull down enabled 1: Pull up enabled | Table 112. PCR[n] reset value exceptions | Field | Description | |----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | PCR[2]<br>PCR[3]<br>PCR[4] | These registers correspond to the ABS[0], ABS[1], and FAB boot pins, respectively. Their default state is input, pull enabled. Their reset value is 0x0102. | | PCR[20] | This register corresponds to the TDO pin. Its default state is ALT1, slew rate = 1. Its reset value is 0x0604. | | PCR[21] | This register corresponds to the TDI pin. Its default state is input, pull enabled, pull selected, slew enabled. So its reset value is 0x0107. | | PCR[108] | This register corresponds to the RESET pin. Its reset value is 0x0102. | | PCR[n] | For other PCR[n] registers, the reset value is 0x0000. | In addition to the bit map above, the following *Table 113: PCR bit implementation by pad type* describes the PCR depending on the pad type (refer to *Section 3.4.3: Pin muxing* for pad types description). The bits in shaded fields are not implemented for the particular I/O type. The PA field selecting the number of alternate functions may or may not be present depending on the number of alternate functions actually mapped on the pad. Table 113. PCR bit implementation by pad type | Pad type | | PCR bit No. | | | | | | | | | | | | | | | |-------------------------------------------------------------------------|---|-------------|-----|---|----|-------|-----|-----|---|---|-----|----|----|-----|-----|-----| | rau type | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | S, M, F (Pad<br>with GPIO<br>and digital<br>alternate<br>functionality) | | SMC | APC | | PA | [1:0] | OBE | IBE | | | ODE | | | SRC | WPE | WPS | | I (Pad with<br>GPIO and<br>analog<br>functionality) | | SMC | APC | | PA | [1:0] | OBE | IBE | | | ODE | | | SRC | WPE | WPS | <sup>1.</sup> Only OBE, IBE, ODE, SRC, WPE, and WPS fields are implemented in PCR[108]. #### 11.5.2.9 Pad Selection for Multiplexed Inputs registers (PSMI[0\_3:36\_39]) The purpose of the PSMI[0\_3:36\_39] registers is to allow connecting a single input pad to one of several peripheral inputs. Thus, it is possible to define different pads to be possible inputs for a certain peripheral function. Figure 117. Pad Selection for Multiplexed Inputs registers (PSMI[0\_3:36\_39]) Table 114. PSMI[0\_3:36\_39] field descriptions | Field | Description | |-------------|-------------------------------------------------------------------------------------------------------| | PADSEL0-3 | Pad Selection Bits | | PADSEL32-35 | Each PADSEL field selects the pad currently used for a certain input function. See <i>Table 115</i> . | Table 115. Pad selection | Posistor | PADSEL | Module | Port | PADSEL | Port name | LQFP pin | | | | |-----------|---------|---------|---------|----------------------|-------------|----------|---------|---------|--| | Register | PADSEL | Wiodule | | field <sup>(1)</sup> | Fortilalile | 176-pin | 144-pin | 100-pin | | | | PADSEL0 | ctu0 | EXT IN | 0b | C[13] | 125 | 101 | 71 | | | | PADSELU | Cluo | EVI_IIN | 1b | C[15] | 148 | 124 | 85 | | | | PADSEL1 | dspi2 | SCK | 0b | A[0] | 89 | 73 | 51 | | | PSMI0 3 | | | | 1b | A[11] | 144 | 120 | 82 | | | PSIVIIU_3 | PADSEL2 | dspi2 | SIN | 0b | A[2] | 102 | 84 | 57 | | | | | | | 1b | A[13] | 160 | 136 | 95 | | | | PADSEL3 | dspi2 | CS0 | 0b | A[3] | 116 | 92 | 64 | | | | FADSELS | | | 1b | A[10] | 142 | 118 | 81 | | Table 115. Pad selection(Continued) | D. wieten | DAROEL | | | PADSEL | | LQFP pin | | | | |-----------|---------|-------------|--------|----------------------|-----------|----------|----------|---------|--| | Register | PADSEL | Module | Port | field <sup>(1)</sup> | Port name | 176-pin | 144-pin | 100-pin | | | | | | | 00b | D[6] | 42 | 34 | 23 | | | | PADSEL0 | dspi3 | SCK | 01b | D[11] | 94 | 78 | 54 | | | | | | | 10b | E[13] | 141 | 117 | _ | | | | | | | 00b | D[7] | 45 | 37 | 26 | | | | PADSEL1 | dspi3 | SIN | 01b | D[14] | 129 | 105 | 73 | | | DCMI4 7 | | | | 10b | E[15] | 145 | 121 | | | | PSMI4_7 | | | | 00b | C[11] | 96 | 80 | 55 | | | | PADSEL2 | dspi3 | CS0 | 01b | D[10] | 92 | 76 | 53 | | | | | | | 10b | F[3] | 176 | 139 | _ | | | | | | | 00b | A[4] | 132 | 108 | 75 | | | | PADSEL3 | eTimer0 | ETC[4] | 01b | C[11] | 96 | 80 | 55 | | | | | | | 10b | B[14] | 76 | 54 | 44 | | | | PADSEL0 | eTimer0 | ETC[5] | 0b | C[12] | 100 | 82 | 56 | | | | | | | 1b | B[8] | 55 | 47 | 31 | | | | PADSEL1 | eTimer1 | ETC[0] | 0b | A[4] | 132 | 108 | 75 | | | | | | | 1b | C[15] | 148 | 124 | 85 | | | PSMI8_11 | PADSEL2 | eTimer1 | ETC[1] | 0b | C[13] | 125 | 101 | 71 | | | | | | | 1b | D[0] | 149 | 125 | 86 | | | | | eTimer1 | ETC[2] | 00b | B[0] | 133 | 109 | 76 | | | | PADSEL3 | | | 01b | C[14] | 127 | 103 | 72 | | | | | | | 10b | D[1] | 3 | 3 | 3 | | | | | | ETC[3] | 0b | B[1] | 134 | 110 | 77 | | | | PADSEL0 | eTimer1 | | 1b | D[2] | 168 | 140 | 97 | | | | | | | 10b | F[12] | 130 | 106 | _ | | | | | | | 0b | A[14] | 175 | 143 | 99 | | | | DADOELA | - Time - m4 | ETO(4) | 1b | C[3] | 24 | 16 | 10 | | | PSMI12_15 | PADSEL1 | eTimer1 | ETC[4] | 10b | D[3] | 152 | 128 | 89 | | | | | | | 11b | F[13] | 136 | 112 | _ | | | | | | | 0b | A[5] | 22 | 14 | 8 | | | | PADSEL2 | eTimer1 | ETC[5] | 1b | A[15] | 176 | 144 | 100 | | | | | | - | 10b | D[4] | 153 | 129 | 90 | | | | PADSEL3 | | | | | | | | | | PSMI16-19 | | <u> </u> | | UNIMPLEME | NTED | 1 | <u> </u> | 1 | | Table 115. Pad selection(Continued) | De viete v | DADOEL | Madala | Dowt | PADSEL | D | LQFP pin | | | | | | | |---------------|---------|----------------------|---------------|----------------------|-----------|----------|---------|---------|--|--|--|--| | Register | PADSEL | Module | Port | field <sup>(1)</sup> | Port name | 176-pin | 144-pin | 100-pin | | | | | | PSMI20-23 | | UNIMPLEMENTED | | | | | | | | | | | | PSMI24-27 | | | UNIMPLEMENTED | | | | | | | | | | | | PADSEL0 | ADSEL0 UNIMPLEMENTED | | | | | | | | | | | | | PADSEL1 | | | UNIMPL | EMENTED | | | | | | | | | PSMI28-31 | PADSEL2 | | | UNIMPL | EMENTED | | | | | | | | | | PADSEL3 | Lin0 | RX | 0b | B[3] | 140 | 116 | 80 | | | | | | | PADSELS | LIIIO | KA | 1b | B[7] | 51 | 43 | 29 | | | | | | | | | | 0b | B[13] | 68 | 60 | 42 | | | | | | | PADSEL0 | Lin1 | RX | 1b | D[12] | 123 | 99 | 70 | | | | | | | | | | 10b | F[15] | 137 | 113 | _ | | | | | | | PADSEL1 | Can1 | RX | 0b | C[13] | 125 | 110 | 71 | | | | | | | | | | 1b | G[9] | 95 | 79 | _ | | | | | | PSMI32-35 | PADSEL2 | Dspi4 | SCK | 0b | B[3] | 140 | 116 | 80 | | | | | | | | | | 1b | C[5] | 21 | 13 | 7 | | | | | | | | | | 10b | G[4] | 124 | 100 | _ | | | | | | | | | SIN | 0b | A[9] | 158 | 134 | 94 | | | | | | | PADSEL3 | Dspi4 | | 1b | C[7] | 23 | 15 | 9 | | | | | | | | | | 10b | G[2] | 126 | 102 | _ | | | | | | | | | | 0b | A[8] | 20 | 12 | 6 | | | | | | | PADSEL0 | Dspi4 | CS0 | 1b | C[9] | 147 | 123 | 84 | | | | | | PSMI36-39 | | | | 10b | G[5] | 103 | 85 | _ | | | | | | 1- SIVII30-39 | PADSEL1 | | | UNIMPL | EMENTED | | | | | | | | | | PADSEL2 | | | UNIMPL | EMENTED | | | | | | | | | | PADSEL3 | | | UNIMPL | EMENTED | | | | | | | | <sup>1.</sup> Values not listed are reserved. Reset ### 11.5.2.10 GPIO Pad Data Output registers 0\_3-104\_107 (GPDO[0\_3:104\_107]) These registers can be used to set or clear a single GPIO pad with a byte access. Base + 0x0600 (GPDO0\_3) Address: ... Access: User read/write Base + 0x0668 (GPDO104\_107) 27 registers R PDO PDO [0] [1] W Reset R PDO **PDO** [2] [3] W Figure 118. Port GPIO Pad Data Output registers 0\_3-104\_107 (GPDO[0\_3:104\_107]) # Table 116. GPDO[0\_3:104\_107] field descriptions | Field | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PDO[ <i>n</i> ] | Pad Data Out This bit stores the data to be driven out on the external GPIO pad controlled by this register. 0: Logic low value is driven on the corresponding GPIO pad when the pad is configured as an output. 1: Logic high value is driven on the corresponding GPIO pad when the pad is configured as an output. | #### 11.5.2.11 GPIO Pad Data Input registers 0\_3-104\_107 (GPDI[0\_3:104\_107]) These registers can be used to read the GPIO pad data with a byte access. Base + 0x0800 (GPDI0\_3) Address: ... Access: User read-only Base + 0x0868 (GPDI104\_107) 27 registers PDI PDI R [0] [1] W Reset PDI PDI R [2] [3] W Reset Figure 119. GPIO Pad Data Input registers 0\_3-104\_107 (GPDI[0\_3:104\_107]) gare 110. 31 10 1 da Bata inpat registers o\_5 10+\_10/ (31 Bi[o\_6:10+\_10/] Table 117. GPDI[0\_3:104\_107] field descriptions | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PDI[x] | Pad Data In This bit stores the value of the external GPIO pad associated with this register. 0: The value of the data in signal for the corresponding GPIO pad is logic low. 1: The value of the data in signal for the corresponding GPIO pad is logic high. | #### 11.5.2.12 Parallel GPIO Pad Data Out register 0-3 (PGPDO[0:3]) These registers set or clear the respective pads of the device. Figure 120. Parallel GPIO Pad Data Out register 0-3(PGPDO[0:3]) Table 118. PGPDO0\_3 field descriptions | Field | Description | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PPDO[x] | Parallel Pad Data Out Write or read the data register that stores the value to be driven on the pad in output mode. Accesses to this register location are coherent with accesses to the bit-wise GPIO Pad Data Output registers $0_3-104_107$ (GPDO[ $0_3:104_107$ ]). The $x$ and bit index define which PPDO register bit is equivalent to which PDO register bit according to the following equation: $PPDO[x][y] = PDO[(x*16) + y]$ | Note: The PGPDO registers access the same physical resource as the PDO and MPGPDO address locations. Some examples of the mapping: PPDO[0][0] = PDO[0]PPDO[2][0] = PDO[32] #### 11.5.2.13 Parallel GPIO Pad Data In register 0-3 (PGPDI[0:3]) These registers hold the synchronized input value from the pads. Figure 121. Parallel GPIO Pad Data In register 0-3 (PGPDI[0:3]) Table 119. PGPDI[0:3] field descriptions | Field | Description | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PPDI[x] | Parallel Pad Data In Read the current pad value. Accesses to this register location are coherent with accesses to the bit-wise GPIO Pad Data Input registers $0_3$ -104_107 (GPDI[ $0_3$ :104_107]). The $x$ and bit index define which PPDI register bit is equivalent to which PDI register bit according to the following equation: $PPDI[x][y] = PDI[(x * 16) + y]$ | #### 11.5.2.14 Masked Parallel GPIO Pad Data Out register 0–6 (MPGPDO[0:6]) This register can be used to selectively modify the pad values associated to PPDO[x][15:0]. The MPGPDO[x] register may only be accessed with 32-bit writes. 8-bit or 16-bit writes will not modify any bits in the register and cause a transfer error response by the module. Read accesses will return 0. Figure 122. Masked Parallel GPIO Pad Data Out register 0-6 (MPGPDO[0:6]) | Field | Description | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MASK[x]<br>[15:0] | Mask Field Each bit corresponds to one data bit in the MPPDO[x] field at the same bit location. 0: The associated bit value in the MPPDO[x] field is ignored. 1: The associated bit value in the MPPDO[x] field is written. | | MPPDO[x]<br>[15:0] | Masked Parallel Pad Data Out Write the data register that stores the value to be driven on the pad in output mode. Accesses to this register location are coherent with accesses to the bit-wise GPIO Pad Data Output registers 0_3–104_107 (GPDO[0_3:104_107]). The x and bit index define which MPPDO register bit is equivalent to which PDO register bit according to the following equation: MPPDO[x][y] = PDO[(x * 16) + y] | Table 120. MPGPDO[0:6] field descriptions #### 11.5.2.15 Interrupt Filter Maximum Counter registers 0–31 (IFMC[0:31]) These registers configure the filter counter associated with each digital glitch filter. Figure 123. Interrupt Filter Maximum Counter registers 0-31 (IFMC[0:31]) | Field | Description | |--------------------------|---------------------------------------------------------------------------------------------| | MAXCNT <i>x</i><br>[3:0] | Maximum Interrupt Filter Counter setting. | | | Filter Period = $(T_{CK} \times MAXCNTx) + (n \times T_{CK})$ | | | Where <i>n</i> can be –2 to 3 | | | MAXCNTx can be 0 to 15 | | | T <sub>CK</sub> : Prescaled Filter Clock Period, which is IRC clock prescaled to IFCP value | | | T <sub>IRC</sub> : Basic Filter Clock Period: 62.5 ns (f <sub>IRC</sub> = 16 MHz) | Table 121. IFMC[0:31] field descriptions ### 11.5.2.16 Interrupt Filter Clock Prescaler Register (IFCPR) This register configures a clock prescaler that selects the clock for all digital filter counters in the SIUL. Figure 124. Interrupt Filter Clock Prescaler Register (IFCPR) Table 122. IFCPR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------| | | Interrupt Filter Clock Prescaler setting | | IFCP | Prescaled Filter Clock Period = T <sub>IRC</sub> × (IFCP + 1) | | [3:0] | T <sub>IRC</sub> is the internal oscillator period. IFCP can be 0 to 15. | # 11.6 Functional description #### 11.6.1 **General** This section provides a functional description of the System Integration Unit Lite. #### 11.6.2 Pad control The SIUL controls the configuration and electrical characteristic of the device pads. It provides a consistent interface for all pads, both on a by-port and a by-bit basis. The SIUL allows each pad to be configured as either a General Purpose Input Output pad (GPIO), and as one or more alternate functions (input or output). The pad configuration registers (PCRn, see Section 11.5.2.8: Pad Configuration Registers (PCR[0:108])) allow software control of the static electrical characteristics of external pins with a single write. These configure the following pad features: - Open drain output enable - Slew rate control - Pull control - Pad assignment - Control of analog path switches - Safe mode behavior configuration #### 11.6.3 General purpose input and output pads (GPIO) The SIUL allows each pad to be configured as either a General Purpose Input Output pad (GPIO), and as one or more alternate functions (input or output), the function of which is normally determined by the peripheral that uses the pad. The SIUL manages up to 106 GPIO pads organized as ports that can be accessed for data reads and writes as 32-bit, 16-bit or 8-bit. As shown in *Figure 125*, all port accesses are identical with each read or write being performed only at a different location to access a different port width. Figure 125. Data port example arrangement showing configuration for different port width accesses This implementation requires that the registers are arranged in such a way as to support this range of port widths without having to split reads or writes into multiple accesses. The SIUL has separate data input (GPDIn\_n, see Section 11.5.2.11: GPIO Pad Data Input registers 0\_3-104\_107 (GPDI[0\_3:104\_107])) and data output (GPDOn\_n, see Section 11.5.2.10: GPIO Pad Data Output registers 0\_3-104\_107 (GPDO[0\_3:104\_107])) registers for all pads, allowing the possibility of reading back an input or output value of a pad directly. This supports the ability to validate what is present on the pad rather than merely confirming the value that was written to the data register by accessing the data input registers. The data output registers support both read and write operations to be performed. The data input registers support read access only. When the pad is configured to use one of its alternate functions, the data input value reflect the respective value of the pad. If a write operation is performed to the data output register for a pad configured as an alternate function (non GPIO), this write will not be reflected by the pad value until reconfigured to GPIO. The allocation of what input function is connected to the pin is defined by the PSMI registers (see Section 11.5.2.9: Pad Selection for Multiplexed Inputs registers (PSMI[0\_3:36\_39])). #### 11.6.4 External interrupts The SIUL supports 32 external interrupts, EIRQ[0:31]. The signal description chapter of this reference manual provides a map of the external interrupts. The SIUL supports four interrupt vectors to the interrupt controller. Each vector interrupt has eight external interrupts combined together with the presence of flag generating an interrupt for that vector if enabled. All of the external interrupt pads within a single group have equal priority. Refer to *Figure 126* for an overview of the external interrupt implementation. Figure 126. External interrupt pad diagram #### 11.6.4.1 **External interrupt management** Each interrupt can be enabled or disabled independently. This can be performed using the IRER (see Section 11.5.2.4: Interrupt Request Enable Register (IRER)). A pad defined as an external interrupt can be configured to recognize interrupts with an active rising edge, an active falling edge or both edges being active. A setting of having both edge events disabled is reserved and should not be configured. The active EIRQ edge is controlled through the configuration of the registers IREER and IFEER. Each external interrupt supports an individual flag that is held in the ISR (see Section 11.5.2.3: Interrupt Status Flag Register (ISR)). This register is a write-1-to-clear register type, preventing inadvertent overwriting of other flags in the same register. #### 11.7 Pin muxing For pin muxing, please refer to Chapter 3: Signal Description of this reference manual. DocID018714 Rev 5 288/1102 ### 12 e200z0 and e200z0h Core #### 12.1 Overview The SPC56xP60x/54x microcontroller implements the e200z0h core. The e200 processor family is a set of CPU cores built on the Power Architecture technology. e200 processors are designed for deeply embedded control applications that require low cost solutions rather than maximum performance. The e200z0 and e200z0h processors integrate an integer execution unit, branch control unit, instruction fetch and load/store units, and a multi-ported register file capable of sustaining three read and two write operations per clock. Most integer instructions execute in a single clock cycle. Branch target prefetching is performed by the branch unit to allow single-cycle branches in some cases. The e200z0 core is a single-issue, 32-bit Power Architecture technology VLE-only design with 32-bit general purpose registers (GPRs). Implementing only the VLE (variable-length encoding) APU provides improved code density. All arithmetic instructions that execute in the core operate on data in the GPRs. e200z0 and e200z0h Core RM0083 ### 12.2 Features The following is a list of some of the key features of the e200z0 and e200z0h cores: - 32-bit Power Architecture technology VLE-only programmer's model - Single issue, 32-bit CPU - Implements the VLE APU for reduced code footprint - In-order execution and retirement - Precise exception handling - Branch processing unit - Dedicated branch address calculation adder - Branch acceleration using Branch Target Buffer (e200z0h only) - Supports independent instruction and data accesses to different memory subsystems, such as SRAM and Flash memory via independent Instruction and Data bus interface units (BIUs) (e200z0h only) - Supports instruction and data access via a unified 32-bit Instruction/Data BIU (e200z0 only) - Load/store unit - 1 cycle load latency - Fully pipelined - Big-endian support only - Misaligned access support - Zero load-to-use pipeline bubbles for aligned transfers - Power management - Low power design - Dynamic power management of execution units - Testability - Synthesizeable, full MuxD scan design - ABIST/MBIST for optional memory arrays ### 12.2.1 Microarchitecture summary The e200z0 processor utilizes a four stage pipeline for instruction execution. The Instruction Fetch (stage 1), Instruction Decode/Register file Read/Effective Address Calculation (stage 2), Execute/Memory Access (stage 3), and Register Writeback (stage 4) stages operate in an overlapped fashion, allowing single clock instruction execution for most instructions. The integer execution unit consists of a 32-bit Arithmetic Unit (AU), a Logic Unit (LU), a 32-bit Barrel shifter (Shifter), a Mask-Insertion Unit (MIU), a Condition Register manipulation Unit (CRU), a Count-Leading-Zeros unit (CLZ), an 8 × 32 Hardware Multiplier array, result feed-forward hardware, and a hardware divider. Arithmetic and logical operations are executed in a single cycle with the exception of the divide and multiply instructions. A Count-Leading-Zeros unit operates in a single clock cycle. The Instruction Unit contains a PC incrementer and a dedicated Branch Address adder to minimize delays during change of flow operations. Sequential prefetching is performed to ensure a supply of instructions into the execution pipeline. Branch target prefetching from the BTB is performed to accelerate certain taken branches in the e200z0. Prefetched instructions are placed into an instruction buffer with 4 entries (2 entries in e200z0), each capable of holding a single 32-bit instruction or a pair of 16-bit instructions. Conditional branches that are not taken execute in a single clock. Branches with successful target prefetching have an effective execution time of one clock on e200z0h. All other taken branches have an execution time of two clocks. Memory load and store operations are provided for byte, halfword, and word (32-bit) data with automatic zero or sign extension of byte and halfword load data as well as optional byte reversal of data. These instructions can be pipelined to allow effective single cycle throughput. Load and store multiple word instructions allow low overhead context save and restore operations. The load/store unit contains a dedicated effective address adder to allow effective address generation to be optimized. Also, a load-to-use dependency does not incur any pipeline bubbles for most cases. The Condition Register unit supports the condition register (CR) and condition register operations defined by the Power Architecture architecture. The condition register consists of eight 4-bit fields that reflect the results of certain operations, such as move, integer and floating-point compare, arithmetic, and logical instructions, and provide a mechanism for testing and branching. Vectored and autovectored interrupts are supported by the CPU. Vectored interrupt support is provided to allow multiple interrupt sources to have unique interrupt handlers invoked with no software overhead. e200z0 and e200z0h Core RM0083 ### 12.2.1.1 Block diagram Figure 127. e200z0 block diagram OnCE/NEXUS CPU **CONTROL LOGIC CONTROL LOGIC NEXUS DEBUG** INTEGER EXECUTION UNIT CR CTR UNIT SPR **GPR** XER MULTIPLY UNIT ADDRESS **INSTRUCTION UNIT** INSTRUCTION BUS INTERFACE UNIT INSTRUCTION BUFFER CONTROL **EXTERNAL** SPR DATA **INTERFACE** (MTSPR/MFSPR CONTROL PC **BRANCH** UNIT UNIT LOAD/STORE UNIT DATA BUS INTERFACE UNIT **ADDRESS** DATA CONTROL Figure 128. e200z0h block diagram e200z0 and e200z0h Core RM0083 #### 12.2.1.2 Instruction unit features The features of the e200 Instruction unit are: • 32-bit instruction fetch path supports fetching of one 32-bit instruction per clock, or as many as two 16-bit VLE instructions per clock - Instruction buffer with 4 entries in e200z0h, each holding a single 32-bit instruction, or a pair of 16-bit instructions - Instruction buffer with 2 entries in e200z0, each holding a single 32-bit instruction, or a pair of 16-bit instructions - Dedicated PC incrementer supporting instruction prefetches - Branch unit with dedicated branch address adder supporting single cycle of execution of certain branches, two cycles for all others ### 12.2.1.3 Integer unit features The e200 integer unit supports single cycle execution of most integer instructions: - 32-bit AU for arithmetic and comparison operations - 32-bit LU for logical operations - 32-bit priority encoder for count leading zero's function - 32-bit single cycle barrel shifter for shifts and rotates - 32-bit mask unit for data masking and insertion - Divider logic for signed and unsigned divide in 5 to 34 clocks with minimized execution timing - 8 × 32 hardware multiplier array supports 1 to 4 cycle 32 × 32 $\rightarrow$ 32 multiply (early out) #### 12.2.1.4 Load/Store unit features The e200 load/store unit supports load, store, and the load multiple / store multiple instructions: - 32-bit effective address adder for data memory address calculations - Pipelined operation supports throughput of one load or store operation per cycle - 32-bit interface to memory (dedicated memory interface on e200z0h) ### 12.2.1.5 e200z0h system bus features The features of the e200z0h System Bus interface are as follows: - Independent Instruction and Data Buses - AMBA AHB Lite Rev 2.0 Specification with support for ARM v6 AMBA Extensions - Exclusive Access Monitor - Byte Lane Strobes - Cache Allocate Support - 32-bit address bus plus attributes and control on each bus - 32-bit read data bus for Instruction Interface - Separate uni-directional 32-bit read data bus and 32-bit write data bus for Data Interface - Overlapped, in-order accesses #### 12.2.1.6 Nexus 2+ features The Nexus 2+ module is compliant with Class 2 of the IEEE-ISTO 5001-2003 standard, with additional Class 3 and Class 4 features available. The following features are implemented: - Program Trace via Branch Trace Messaging (BTM). Branch trace messaging displays program flow discontinuities (direct and indirect branches, exceptions, etc.), allowing the development tool to interpolate what transpires between the discontinuities. Thus, static code may be traced. - Ownership Trace via Ownership Trace Messaging (OTM). OTM facilitates ownership trace by providing visibility of which process ID or operating system task is activated. An Ownership Trace Message is transmitted when a new process/task is activated, allowing the development tool to trace ownership flow. - Run-time access to the processor memory map via the JTAG port. This allows for enhanced download/upload capabilities. - Watchpoint Messaging via the auxiliary interface - Watchpoint Trigger enable of Program Trace Messaging - Auxiliary interface for higher data input/output - Configurable (min/max) Message Data Out pins (nex\_mdo[n:0]) - One (1) or two (2) Message Start/End Out pins (nex\_mseo\_b[1:0]) - One (1) Read/Write Ready pin (nex\_rdy\_b) pin - One (1) Watchpoint Event pin (nex\_evto\_b) - One (1) Event In pin (nex\_evti\_b) - One (1) MCKO (Message Clock Out) pin - Registers for Program Trace, Ownership Trace and Watchpoint Trigger control - All features controllable and configurable via the JTAG port # 12.3 Core registers and programmer's model This section describes the registers implemented in the e200z0 and e200z0h cores. It includes an overview of registers defined by the Power Architecture technology, highlighting differences in how these registers are implemented in the e200 core, and provides a detailed description of e200-specific registers. Full descriptions of the architecture-defined register set are provided in Power Architecture Specification. The Power Architecture defines register-to-register operations for all computational instructions. Source data for these instructions are accessed from the on-chip registers or are provided as immediate values embedded in the opcode. The three-register instruction format allows specification of a target register distinct from the two source registers, thus preserving the original data for use by other instructions. Data is transferred between memory and registers with explicit load and store instructions only. Figure 129 and Figure 130: e200z0h Supervisor mode programmer's model show the e200 register set, including the registers that are accessible while in supervisor mode and the registers that are accessible in user mode. The number to the right of the special-purpose registers (SPRs) is the decimal number used in the instruction syntax to access the register (for example, the integer exception register (XER) is SPR 1). Note: e200z0 and e200z0h is a 32-bit implementation of the Power Architecture specification. e200z0 and e200z0h Core RM0083 **Exception Handling/Control Registers General Registers** Interrupt Vector Prefix SPR General Save and Restore General-Purpose Registers **Condition Register** SRR0 SPR 26 SPRG0 SPR 272 IVPR SPR 63 SRR1 SPR 27 SPR 273 SPRG1 CR GPR0 CSRR1 SPR 58 Count Register GPR1 DSRR0 **SPR 59** CTR SPR 9 DSRR1 SPR 574 CSRR0 SPR 575 Link Register GPR31 LR SPR 8 **Exception Syndrome Register** XER FSR SPR 62 XER SPR 1 Machine Check Syndrome Register MCSR SPR 572 **Processor Control Registers Data Exception Address** Hardware Implementation Dependent 1 **Machine State** SPR 61 DEAR MSR HID0 **SPR 1008** Processor Version HID1 SPR 1009 **PVR** SPR 287 **Memory Management Registers** Processor ID Process ID PIR **SPR 286** Debug Registers<sup>2</sup> PID0 SPR 48 System Version<sup>1</sup> Instruction Address Compare SVR SPR 1023 **Debug Control** Configuration (Read-only **SPR 308** DBCR0 **SPR 312** IAC1 MMUCFG SPR 1015 DBCR1 **SPR 309** SPR 313 IAC2 DBCR2 **SPR 310 SPR 314** IAC3 SPR 315 IAC4 **Cache Registers** Debug Status **Data Address Compare SPR 304** DBSR Cache Configuration (Read-only) DAC1 **SPR 316** DAC2 **SPR 317** SPR 515 L1CFG0 1 - These e200-specific registers may not be supported by other Power Architecture processors 2 - Optional registers defined by the Power Architecture technology Figure 129. e200z0 Supervisor mode programmer's model Figure 130. e200z0h Supervisor mode programmer's model ## 12.4 Instruction summary The e200z0 core supports Power Architecture technology VLE instructions. # 13 Peripheral Bridge (PBRIDGE) ### 13.1 Introduction The peripheral bridge (PBRIDGE) is the interface between the system bus and on-chip peripherals. Accesses that fall within the address space of the PBRIDGE are decoded to provide individual module selects for peripheral devices on the slave bus interface. The PBRIDGE will automatically manage peripheral access requests from software. In other words, you can access a peripheral using its memory-mapped interface without having to configure the PBRIDGE. However, the PBRIDGE also supports special peripheral access, such as memory protection, that is available for you to use if you need it. This device includes two instantiations of the PBRIDGE. These are called PBRIDGE\_0 and PBRIDGE\_1. ### 13.2 Block interface Figure 131. PBRIDGE interface 4 ### 13.3 Features The following list summarizes the key features of the PBRIDGE: - Includes a 32-bit address bus and 32-bit data bus - Supports 32-bit slave peripherals (byte, halfword, and word reads and writes are supported by the bridge) - Provides configurable per-master access protections - Provides configurable per-peripheral access protections for both on-platform and offplatform peripherals ### 13.4 Memory map and register description ### 13.4.1 Register access All registers are 32-bit registers and can only be accessed in supervisor mode by trusted bus masters. Additionally, these registers must only be read from or written to by a 32-bit aligned access. Two system clock cycles are required for read accesses and three system clock cycles are required for write accesses to the PBRIDGE registers. ### 13.4.2 Memory map Each register in the PBRIDGE module has a size of 32 bits. The registers are listed in *Table 123*. The memory map organization is shown in *Table 124*. The organizational hierarchy is as follows: - The module has multiple registers with the same register name (MPROT, PACR, OPACR), each at a different address offset. - Each register has multiple similarly-named fields, each with a different number. - Each field has subfields as defined elsewhere in this section. Accesses to registers or register fields marked as reserved will return undefined data on reads, and will be ignored on writes. Offset from PBRIDGE BASE Location Register PBRIDGE 0 = 0xFFF0 0000 **PBRIDGE 1 = 0x8FF0 0000** 0x0000-0x0007 (1) Master Protection Registers (MPROT) on page 300 0x0008-0x001F Reserved 0x0020-0x003F (1) Peripheral Access Control Registers (PACR) on page 301 Off-Platform Peripheral Access Control 0x0040-0x006F (1) on page 302 Registers (OPACR) 0x0070-0x3FFF Reserved Table 123. PBRIDGE registers <sup>1.</sup> This memory range contains reserved areas. See *Table 124*. | Address | Register | gister Bit numbers | | | | | | | | |---------|----------|-----------------------|------------------------|---------|----------|------------------------|----------|----------|----------| | offset | name | 0–3 | 4–7 | 8–11 | 12–15 | 16–19 | 20–23 | 24–27 | 28–31 | | 0x0000 | MPROT | MPROT0 | MPROT1 | MPROT2 | MPROT3 | Reserved | Reserved | Reserved | Reserved | | 0x0004 | WIFKOI | Reserved | Reserved | | | Reser | ved | | | | 0x0020 | | PACR0 | PACR1 <sup>(1)</sup> | Res | erved | PACR4 | | Reserved | | | 0x0024 | PACR | Reserved | PACR9 | | Rese | erved | | PACR14 | PACR15 | | 0x0028 | PACK | PACR16 | PACR17 <sup>(1)</sup> | PACR18 | | | Reserved | | | | 0x002C | | | | | Rese | rved | | | | | 0x0030 | | Reserved | | | | | | | | | 0x0034 | | Reserved | | | | | | | | | 0x0038 | | Reserved | | | | | | | | | 0x003C | | Reserved | | | | | | | | | 0x0040 | | | Rese | rved | | OPACR4 | OPACR5 | OPACR6 | OPACR7 | | 0x0044 | | OPACR8 <sup>(2)</sup> | | | | Reserved | | | | | 0x0048 | | OPACR16 | OPACR17 <sup>(2)</sup> | | | Reserved | | | OPACR23 | | 0x004C | | OPACR24 | Reserved | OPACR26 | | Reser | ved | | OPACR31 | | 0x0050 | | OPACR32 | Rese | rved | OPACR35 | Resei | rved | OPACR38 | OPACR39 | | 0x0054 | | | | | Rese | rved | | | | | 0x0058 | OPACR | OPACR48 | OPACR49 | | | Reser | ved | | | | 0x005C | | Res | erved | OPACR58 | OPACR59 | OPACR60 <sup>(2)</sup> | Reserved | OPACR62 | Reserved | | 0x0060 | | Res | erved | OPACR66 | OPACR67 | OPACR68 | OPACR69 | Rese | erved | | 0x0064 | | | | | Rese | rved | | | | | 0x0068 | | | | Rese | erved | | | OPACR86 | OPACR87 | | 0x006C | | OPACR88 | OPACR89 | OPACR90 | Reserved | OPACR92 | | Reserved | | Table 124. PBRIDGE memory map ### 13.4.3 Register descriptions ### 13.4.3.1 Master Protection Registers (MPROT) Each MPROT register contains one or more 4-bit fields, called MPROT*n*, as shown in *Table 124*. Each of these fields defines the access privilege level associated with bus master *n* in the platform. The registers provide one field per bus master. See *Section 14.1.4*: *Logical master IDs*, for a list of master numbers and names. Each MPROT*n* field has the structure described in *Figure 132* and *Table 126*. <sup>1.</sup> Not present in PBRIDGE\_1. <sup>2.</sup> Not present in PBRIDGE\_0. Figure 132. MPROTn field structure Table 125. MPROTn field reset values | n | MTR | MTW | MPL | |------------|-----|-----|-----| | 0 | 1 | 1 | 1 | | 1 | 1 | 1 | 1 | | 2 | 0 | 0 | 1 | | 8 | 1 | 1 | 1 | | 9 | 1 | 1 | 1 | | All others | 0 | 0 | 0 | Table 126. MPROTn field structure descriptions | Subfield | Description | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MTR | Master Trusted for Reads. This bit determines whether the master is trusted for read accesses. O This master is not trusted for read accesses. This master is trusted for read accesses. | | MTW | Master Trusted for Writes. This bit determines whether the master is trusted for write accesses. O This master is not trusted for write accesses. 1 This master is trusted for write accesses. | | MPL | Master Privilege Level. This bit determines how the privilege level of the master is determined. 0 Accesses from this master are forced to user-mode. 1 Accesses from this master are not forced to user-mode. | #### 13.4.3.2 Peripheral access control registers (PACR) Each PACR contains one or more 4-bit fields, called PACR*n*, as shown in *Table 124*. Each of these fields defines the access levels supported by the associated module. The lists of modules and their corresponding numbers are shown in *Table 128*. Each PACRn field has the structure described in Figure 133 and Table 127. The reset state of PACR0[TP] is 1, not 0. PACR0[SP] and PACR0[TP] are hard wired to 1 and cannot be changed. Therefore, untrusted masters or user-mode accesses are always denied. Figure 133. PACRn field structure Table 127. PACRn field structure descriptions | Subfield | Description | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SP | Supervisor Protect. This bit determines whether the peripheral requires supervisor privilege level for access. O This peripheral does not require supervisor privilege level for accesses. This peripheral requires supervisor privilege level for accesses. The MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. | | WP | Write Protect. This bit determines whether the peripheral allows write accesses. O This peripheral allows write accesses. This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. | | TP | Trusted Protect. This bit determines whether the peripheral allows accesses from an untrusted master. O Accesses from an untrusted master are allowed. Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. | Table 128. On-platform peripherals and PACR numbers | Peripheral | PACR number | |------------|-------------------| | PBRIDGE | 0 | | XBAR | 1 <sup>(1)</sup> | | MPU | 4 | | SEMA4 | 9 | | SWT | 14 | | STM | 15 | | ECSM | 16 | | eDMA | 17 <sup>(1)</sup> | | INTC | 18 | <sup>1.</sup> Not present in PBRIDGE\_1. ### 13.4.3.3 Off-platform peripheral access control registers (OPACR) The OPACR defines the access levels supported by the associated module. Each OPACR has a format identical to the PACR described in *Section 13.4.3.2: Peripheral access control registers (PACR)*. The lists of off-platform modules and their corresponding numbers are listed in *Table 129*. Table 129. Off-platform peripherals and OPACR numbers | Peripheral <sup>(1)</sup> | OPACR number | |---------------------------|--------------| | DSPI 0 | 4 | | DSPI 1 | 5 | Table 129. Off-platform peripherals and OPACR numbers(Continued) | Peripheral <sup>(1)</sup> | OPACR number | |---------------------------|--------------| | DSPI 2 | 6 | | DSPI 3 | 7 | | DSPI 4 | 8 | | FlexCAN 0 | 16 | | FlexCAN 1 | 17 | | DMA_MUX | 23 | | FlexRay controller | 24 | | Safety_port | 26 | | ВАМ | 31 | | ADC0 | 32 | | СТИ | 35 | | eTimer 0 | 38 | | eTimer 1 | 39 | | LINFlex 0 | 48 | | LINFlex 1 | 49 | | CRC | 58 | | FCCU | 59 | | CRC1 | 60 | | CFLASH0 | 66 | | DFLASH0 | 67 | | SIUL | 68 | | WKPU | 69 | | SSCM | 86 | | MC_ME | 87 | | MC_CGM | 88 | | MC_RGM | 89 | | MC_PCU | 90 | | PIT | 92 | All these peripherals are mapped on PBRIDGE\_0 except DSPI4, CRC1, FCCU, and FLEXCAN1 which are mapped on PBRIDGE\_1. # 13.5 Functional description The PBRIDGE serves as an interface between a system bus and the peripheral (slave) bus. It functions as a protocol translator. Accesses that fall within the address space of the PBRIDGE are decoded to provide individual module selects for peripheral devices on the slave bus interface. There is no need to configure the PBRIDGE registers unless the default master and/or peripheral access privileges need to be changed. ### 13.5.1 Access support Aligned 32-bit word accesses, halfword accesses, and byte accesses are supported for the peripherals. Peripheral registers must not be misaligned, although no explicit checking is performed by the PBRIDGE. Note: Data accesses that cross a 32-bit boundary are not supported. #### 13.5.1.1 Peripheral write buffering Buffered writes are not supported by the PBRIDGE. ### 13.5.1.2 Read cycles Two-clock read accesses are possible with the PBRIDGE when the requested access size is 32-bits or smaller, and is not misaligned across a 32-bit boundary. ### 13.5.1.3 Write cycles Three clock write accesses are possible with the PBRIDGE when the requested access size is 32-bits or smaller. Misaligned writes that cross a 32-bit boundary are not supported. ### 13.5.2 General operation Slave peripherals are modules that contain readable/writable control and status registers. The system bus master reads and writes these registers through the PBRIDGE. The PBRIDGE generates module enables, the module address, transfer attributes, byte enables, and write data as inputs to the slave peripherals. The PBRIDGE captures read data from the slave interface and drives it on the system bus. The PBRIDGE occupies a 64 MB portion of the address space. The register maps of the slave peripherals are located on 16-KB boundaries. Each slave peripheral is allocated one 16-KB block of the memory map, and is activated by one of the module enables from the PBRIDGE. The PBRIDGE is responsible for indicating to slave peripherals if an access is in supervisor or user mode. All eDMA and FlexRay transfers are done in supervisor mode. # 14 Crossbar Switch (XBAR) ### 14.1 Information specific to this device This section presents device-specific parameterization, customization, and feature availability information not specifically referenced in the remainder of this chapter. ### 14.1.1 Register availability Not all registers listed in *Table 133* are available on this device. Specifically, this device includes only registers for: - Slaves 0, 1, 2, 3, 6, and 7 - Masters 0, 1, 2, 3, 5, and 6 #### 14.1.2 MPR reset value The reset value of the MPR on this device is 0x0540\_3210. ### 14.1.3 max\_halt\_request signal value The max\_halt\_request signal is hardwired to '0' on this device. Halt mode feature is not supported. ### 14.1.4 Logical master IDs Table 130 defines the logical master ID used for the chip masters. Table 130. Logical master IDs | Master | Logical Master ID | | | |------------------------------------------------|-------------------|--|--| | Core_0 Instruction port Core_0 Load/Store port | 0 | | | | Core_1 Instruction port Core_1 Load/Store port | 1 | | | | eDMA_0 | 2 | | | | Core_0 Nexus | 8 <sup>(1)</sup> | | | | Core_1 Nexus | 9 <sup>(1)</sup> | | | | FlexRay | 3 | | | <sup>1.</sup> The MPU cannot differentiate between core and Nexus accesses to slave ports. #### 14.1.5 Master port allocation Table 131 defines the XBAR master port allocation for this device. Table 131. XBAR master port allocation | XBAR master port | XBAR module | |------------------|-----------------------------------------------------| | MO | Core 0 e200z0h complex Instruction port | | M1 | Core 0 e200z0h complex Load/Store port + Nexus port | | M2 | DMA_0 | | M3 | FlexRay | | M4 | _ | | M5 | Core 1 e200z0h complex Instruction port | | M6 | Core 1 e200z0h complex Load/Store port + Nexus port | | M7 | _ | ### 14.1.6 Slave port allocation Table 132 defines the XBAR slave port allocation for this device. Table 132. XBAR slave port allocation | XBAR slave port | XBAR module | | |-----------------|-------------------------|--| | S0 | Flash Controller Port 0 | | | S1 | Flash Controller Port 1 | | | S2 | SRAM Controller 0 | | | S3 | SRAM Controller 1 | | | S4 | _ | | | S5 | <del>-</del> | | | S6 | PBRIDGE_1 | | | S7 | PBRIDGE_0 | | ### 14.2 Introduction ### 14.2.1 Overview This section provides an overview of the generic multi-layer AHB crossbar switch (XBAR<sup>(h)</sup>). The purpose of the XBAR is to concurrently support up to eight simultaneous connections between master ports and slave ports. The XBAR supports a 32-bit address bus width and a 32-bit data bus width at all master and slave ports. h. An alternate abbreviation for this module is MAX. #### 14.2.2 Features The XBAR has the ability to gain control of all the slave ports and prevent any masters from making accesses to the slave ports. This feature is useful when the user wishes to turn off the clocks to the system and needs to ensure that no bus activity will be interrupted. The XBAR can put each slave port into a low power park mode so that slave port will not dissipate any power transitioning address, control or data signals when not being actively accessed by a master port. Each slave port can also support multiple master priority schemes. Each slave port has a hardware input which selects the master priority scheme so the user can dynamically change master priority levels on a slave port by slave port basis. The XBAR will allow for concurrent transactions to occur from any master port to any slave port. It is possible for all master ports and slave ports to be in use at the same time as a result of independent master requests. If a slave port is simultaneously requested by more than one master port, arbitration logic will select the higher priority master and grant it ownership of the slave port. All other masters requesting that slave port will stalled until the higher priority master completes its transactions. #### 14.2.3 Limitations The XBAR routes bus transactions initiated on the master ports to the appropriate slave ports. There is no provision included to route transactions initiated on the slave ports to other slave ports or to master ports. Simply put, the slave ports do not support the bus request/bus grant protocol, the XBAR assumes it is the sole master of each slave port. Since the XBAR does not support the bus request/bus grant protocol, if multiple masters are to be connected to a single master port an external arbiter will need to be used. In the case of a single master connecting to a master port the single master's bus grant signal must be tied off in the asserted state. Each master and slave port is fully AHB-Lite + AMBA V6 extensions compliant. The ports are not fully AHB compliant because the XBAR does not support SPLITs or RETRYs. #### 14.2.4 General Operation When a master makes an access to the XBAR the access will be immediately taken by the XBAR. If the targeted slave port of the access is available then the access will be immediately presented on the slave port. It is possible to make single clock (zero wait state) accesses through the XBAR. If the targeted slave port of the access is busy or parked on a different master port the requesting master will simply see wait states inserted (**hready** held negated) until the targeted slave port can service the master's request. The latency in servicing the request will depend on each master's priority level and the responding peripheral's access time. Since the XBAR appears to be just another slave to the master device, the master device will have no knowledge of whether or not it actually owns the slave port it is targeting. While the master does not have control of the slave port it is targeting it will simply be wait stated. A master will be given control of the targeted slave port only after a previous access to a different slave port has completed, regardless of its priority on the newly targeted slave port. This prevents deadlock from occurring when a master has an outstanding request to one slave port that has a long response time, has a pending access to a different slave port, and a lower priority master is also making a request to the same slave port as the pending access of the higher priority master. Once the master has control of the slave port it is targeting the master will remain in control of that slave port until it gives up the slave port by running an IDLE cycle or by leaving that slave port for its next access. The master could also lose control of the slave port if another higher priority master makes a request to the slave port; however, if the master is running a locked or fixed length burst transfer it will retain control of the slave port until that transfer is completed. Based on the AULB bit in the MGPCR (Master General Purpose Control Register) the master will either retain control of the slave port when doing undefined length incrementing burst transfers or will lose the bus to a higher priority master. The XBAR will terminate all master IDLE transfers (as opposed to allowing the termination to come from one of the slave busses). Additionally, when no master is requesting access to a slave port the XBAR will drive IDLE transfers onto the slave bus, even though a default master may be granted access to the slave port. When the XBAR is controlling the slave bus (that is, during low power park) the **hmaster** field will indicate 4'b0000. When a slave bus is being IDLEd by the XBAR it can park the slave port on the master port indicated by the PARK bits in the SGPCR (Slave General Purpose Control Register). This can be done in an attempt to save the initial clock of arbitration delay that would otherwise be seen if the master had to arbitrate to gain control of the slave port. The slave port can also be put into low power park mode in attempt to save power. ## 14.3 XBAR registers This section provides information on XBAR registers. ### 14.3.1 Register summary There are two registers that reside in each slave port of the XBAR and one register that resides in each master port of the XBAR. These registers are IP bus compliant registers. Read and write transfers both require two IP bus clock cycles. The registers can only be read from and written to in supervisor mode. Additionally, these registers can only be read from or written to by 32-bit accesses. The registers are fully decoded and an error response is returned if an unimplemented location is accessed within the XBAR. The slave registers also feature a bit, which when written with a 1, will prevent the registers from being written to again. The registers will still be readable, but future write attempts will have no effect on the registers and will be terminated with an error response. The memory map for the XBAR program-visible registers is shown in *Table 133*. *Table 134* shows the XBAR register summary. | · · · · · · · · · · · · · · · · · · · | | | | | | |-------------------------------------------|----------|---------------------------------------------------|--|--|--| | Offset from<br>XBAR_BASE<br>(0xFFF0_4000) | Register | Use | | | | | 0x000 | MPR0 | Master Priority Register for Slave port 0 | | | | | 0x010 | SGPCR0 | General Purpose Control Register for Slave port 0 | | | | Table 133. XBAR register configuration summary Table 133. XBAR register configuration summary(Continued) | Offset from<br>XBAR_BASE<br>(0xFFF0_4000) | Register | Use | |-------------------------------------------|----------|----------------------------------------------------| | 0x100 | MPR1 | Master Priority Register for Slave port 1 | | 0x110 | SGPCR1 | General Purpose Control Register for Slave port 1 | | 0x200 | MPR2 | Master Priority Register for Slave port 2 | | 0x210 | SGPCR2 | General Purpose Control Register for Slave port 2 | | 0x300 | MPR3 | Master Priority Register for Slave port 3 | | 0x310 | SGPCR3 | General Purpose Control Register for Slave port 3 | | 0x400 | MPR4 | Master Priority Register for Slave port 4 | | 0x410 | SGPCR4 | General Purpose Control Register for Slave port 4 | | 0x500 | MPR5 | Master Priority Register for Slave port 5 | | 0x510 | SGPCR5 | General Purpose Control Register for Slave port 5 | | 0x600 | MPR6 | Master Priority Register for Slave port 6 | | 0x610 | SGPCR6 | General Purpose Control Register for Slave port 6 | | 0x700 | MPR7 | Master Priority Register for Slave port 7 | | 0x710 | SGPCR7 | General Purpose Control Register for Slave port 7 | | 0x800 | MGPCR0 | General Purpose Control Register for Master port 0 | | 0x900 | MGPCR1 | General Purpose Control Register for Master port 1 | | 0xA00 | MGPCR2 | General Purpose Control Register for Master port 2 | | 0xB00 | MGPCR3 | General Purpose Control Register for Master port 3 | | 0xC00 | MGPCR4 | General Purpose Control Register for Master port 4 | | 0xD00 | MGPCR5 | General Purpose Control Register for Master port 5 | | 0xE00 | MGPCR6 | General Purpose Control Register for Master port 6 | | 0xF00 | MGPCR7 | General Purpose Control Register for Master port 7 | #### Figure 134. Key to Register Fields BIT BIT Always R/W Read-Write-Write 1 Self-clear Always BIT reads 1 reads 0 bit only bit only bit to clear BIT w1c BIT ### Table 134. XBAR register summary | Name | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |----------------------------------|---|----|----|-------|----|----|----|-------|-----------------|----|----|-------|----|----|----|----|----| | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | MPRn | R | 0 | | | | 0 | 0 | | | | | | | 0 | | | | | (\$BASE +<br>0x000 +<br>n*0x100) | W | | N | ISTR_ | _7 | | M | ISTR_ | STR_6 MSTR_5 MS | | | ISTR_ | 4 | | | | | 47/ DocID018714 Rev 5 Name R MSTR\_3 MSTR\_2 MSTR\_1 MSTR\_0 W R **SGPCRn** (\$BASE + HP HP HP HP HP HP HP HP 0x010 +W RO HLP E5 E2 E7 E6 E4 E3 E1 E0 n\*0x100) R W **ARB PCTL PARK MGPCRn** R (\$BASE + 0x800 + W n\*0x100 R W **AULB** Table 134. XBAR register summary(Continued) **Note:** for n = 0 to 7. ### 14.3.2 XBAR register descriptions The following paragraphs provide detailed descriptions of the various XBAR registers. Table 135 provides a key to the terms found in XBAR registers. Table 135. Register terms | Term | Description | |----------|------------------------------------------------------------------------------------------------| | Gray bit | Unimplemented bit; always reads as zero; writing has no effect | | Access | | | S | Supervisor mode only | | - | Supervisor or user mode | | Туре | | | r | Read only; writing to this bit has no effect | | w | Write only | | rw | Standard read/write bit. Only software can change a bit's value (other than a hardware reset). | | rwm | A read/write bit that may be modified by hardware in some fashion other than reset. | | w1c | A status bit that can be read and cleared by writing a logic 1 | | slfclr | Self-clearing bit. Writing a 1 has some effect on module, but it always reads as a 0. | Table 135. Register terms(Continued) | Term | Description | | | | | | | |-------|-------------------------|--|--|--|--|--|--| | Reset | | | | | | | | | 0 | Resets to a logic 0 | | | | | | | | 1 | Resets to a logic 1 | | | | | | | | u | Unaffected by reset | | | | | | | | ? | Reset state is unknown. | | | | | | | ### 14.3.2.1 Master Priority Register The Master Priority Register (MPR) sets the priority of each master port on a per slave port basis and resides in each slave port. | | MPR | <b>t</b> n | | | | Master Priority Register n | | | | | | Addr<br>\$BASE + 0x000 + n*10<br>Wait State: 0<br>Access: S | | | | | |--------|-----|------------|--------|----|----|----------------------------|--------|----|----|----|-------|-------------------------------------------------------------|----|----|-------|----| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | N | ISTR_ | 7 | | N | /ISTR_ | 6 | | N | ISTR_ | 5 | | N | ISTR_ | 4 | | RESET: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | N | /ISTR_ | 3 | | N | /ISTR_ | 2 | | N | ISTR_ | 1 | | N | ISTR_ | 0 | | RESET: | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Note: for n = 0 to 7 Figure 135. Master Priority Register n Table 136. Master Priority Register descriptions | Name | Description | Settings | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | Bit 0 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | MSTR 7 | <b>Master 7 Priority -</b> These bits set the arbitration priority for master port 7 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | These bits are initialized by hardware reset. The reset value is 000 | 111This master has the lowest priority when accessing the slave port. | | Bit 4 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | Table 136. Master Priority Register descriptions(Continued) | Name | Description | Settings | | | | | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|--|--| | MSTR 6 | <b>Master 6 Priority -</b> These bits set the arbitration priority for master port 6 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | | These bits are initialized by hardware reset. The reset value is 101 | 111This master has the lowest priority when accessing the slave port. | | | | | | Bit 8 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | | | | | MSTR_5 | <b>Master 5 Priority -</b> These bits set the arbitration priority for master port 5 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | | These bits are initialized by hardware reset. The reset value is 100 | 111This master has the lowest priority when accessing the slave port. | | | | | | Bit 12 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | | | | | MSTR 4 | <b>Master 4 Priority -</b> These bits set the arbitration priority for master port 4 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | WIO11\_+ | These bits are initialized by hardware reset. The reset value is 000 | 111This master has the lowest priority when accessing the slave port. | | | | | | Bit 16 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | | | | | MSTR_3 | <b>Master 3 Priority -</b> These bits set the arbitration priority for master port 3 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | WOTT | These bits are initialized by hardware reset. The reset value is 011 | 111This master has the lowest priority when accessing the slave port. | | | | | | Bit 20 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | | | | | MCTD 2 | <b>Master 2 Priority -</b> These bits set the arbitration priority for master port 2 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | MSTR_2 | These bits are initialized by hardware reset. The reset value is 010 | 111This master has the lowest priority when accessing the slave port. | | | | | | Bit 24 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | | | | | MSTR_1 | <b>Master 1 Priority -</b> These bits set the arbitration priority for master port 1 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | | | | INISTR_T | These bits are initialized by hardware reset. The reset value is 001 | 111This master has the lowest priority when accessing the slave port. | | | | | | Name | Description | Settings | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | Bit 28 | Master Priority Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | MSTR 0 | <b>Master 0 Priority -</b> These bits set the arbitration priority for master port 0 on the associated slave port. | 000 This master has the highest priority when accessing the slave port. | | | These bits are initialized by hardware reset. The reset value is 000 | 111This master has the lowest priority when accessing the slave port. | Table 136. Master Priority Register descriptions(Continued) The Master Priority Register can only be accessed in supervisor mode with 32-bit accesses. Once the RO (Read Only) bit has been set in the slave General Purpose Control Register the Master Priority Register can only be read from, attempts to write to it will have no effect on the MPR and result in an error response. Note: No two available master ports may be programmed with the same priority level. Attempts to program two or more available masters with the same priority level will result in an error response and the MPR will not be updated. #### 14.3.2.2 Slave General Purpose Control Register The Slave General Purpose Control Register (SGPCR) controls several features of each slave port. The Read Only (RO) bit will prevent any registers associated with this slave port from being written to once set. This bit may be written with 0 as many times as the user desires, but once it is written to a 1 only a reset condition will allow it to be written again. The Halt Low Priority (HLP) bit has no effect since max\_halt\_request input is hard wired to zero for SPC56xP60x/54x. The PCTL bits determine how the slave port will park when no master is actively making a request. The available options are to park on the master defined by the PARK bits, park on the last master to use the slave port, or go into a low power park mode which will force all the outputs of the slave port to inactive states when no master is requesting an access. The low power park feature can result in an overall power savings if a the slave port is not saturated; however, it will force an extra clock of latency whenever any master tries to access it when it is not in use because it will not be parked on any master. The PARK bits determine which master the slave will park on when no master is making an active request. Please use caution to only select master ports that are actually present in the design. If the user programs the PARK bits to a master not present in the current design implementation undefined behavior will result. Figure 136. Slave General Purpose Control Register n **Table 137. Slave General Purpose Control Register Descriptions** | Name | Description | Setting | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RO | Read Only - This bit is used to force all of a slave port's registers to be read only. Once written to 1 it can only be cleared by hardware reset. This bit is initialized by hardware reset. The reset value is 0 | <ul> <li>O All this slave port's registers can be written.</li> <li>1 All this slave port's registers are read only and cannot be written (attempted writes have no effect and result in an error response).</li> </ul> | | HLP | Halt Low Priority - This bit is used to set the initial arbitration priority of the max_halt_request input. This bit is initialized by hardware reset. The reset value is 0 | <ul> <li>The max_halt_request input has the highest priority for arbitration on this slave port</li> <li>The max_halt_request input has the lowest initial priority for arbitration on this slave port.</li> </ul> | | Bits 2–7 | Slave General Purpose Control Register Reserved - These bits are reserved for future expansion. They read as zero and should be written with zero for upward compatibility. | NA | | HPEx | High Priority Enable - These bits are used to enable the mX_high_priority inputs for the respective master. These bits are initialized by hardware reset. The reset value is 0 | <ul> <li>0 The mX_high_priority input is disabled on this slave port</li> <li>1 The mX_high_priority input is enabled on this slave port.</li> </ul> | | Bits 16–<br>21 | Slave General Purpose Control Register Reserved - These bits are reserved for future expansion. They are read as zero and should be written with zero for upward compatibility. | NA | Table 137. Slave General Purpose Control Register Descriptions(Continued) | Name | Description | Setting | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ARB | Arbitration Mode - These bits are used to select the arbitration policy for the slave port. These bits are initialized by hardware reset. The reset value is 00 | 00 Fixed Priority. 01 Round Robin (rotating) Priority. 10 Reserved 11 Reserved | | Bits 24–<br>25 | Slave General Purpose Control Register Reserved - These bits are reserved for future expansion. They are read as zero and should be written with zero for upward compatibility. | NA | | PCTL | Parking Control - These bits determine the parking control used by this slave port. These bits are initialized by hardware reset. The reset value is 00. | <ul> <li>00 When no master is making a request the arbiter will park the slave port on the master port defined by the PARK bit field.</li> <li>01 When no master is making a request the arbiter will park the slave port on the last master to be in control of the slave port.</li> <li>10 When no master is making a request the arbiter will park the slave port on no master and will drive all outputs to a constant safe state.</li> <li>11 Reserved</li> </ul> | | Bit 28 | Slave General Purpose Control Register Reserved - This bit is reserved for future expansion. It is read as zero and should be written with zero for upward compatibility. | NA | | PARK | <b>PARK</b> - These bits are used to determine which master port this slave port parks on when no masters are actively making requests and the PCTL bits are set to 00. | 000 Park on Master Port 0 001 Park on Master Port 1 010 Park on Master Port 2 011 Park on Master Port 3 100 Park on Master Port 4 | | | These bits are initialized by hardware reset. The reset value is 000 | <ul><li>101 Park on Master Port 5</li><li>110 Park on Master Port 6</li><li>111 Park on Master Port 7</li></ul> | The SGPCR can only be accessed in supervisor mode with 32-bit accesses. Once the RO (Read Only) bit has been set in the SGPCR the SGPCR can only be read, attempts to write to it will have no effect on the SGPCR and result in an error response. #### 14.3.2.3 Master General Purpose Control Register The Master General Purpose Control Register (MGPCR) presently controls only whether or not the master's undefined length burst accesses will be allowed to complete uninterrupted or whether they can be broken by requests from higher priority masters. The AULB (Arbitrate on Undefined Length Bursts) bit field determines whether (and when) or not the XBAR will arbitrate away the slave port the master owns when the master is performing undefined length burst accesses. If the user has configured the XBAR to have less than eight master ports only the registers associated with the remaining master ports will be present, all other registers will become reserved locations in memory. | | MGPC | CRn | | | Maste | r Gene | eral Pu | rpose | Contro | ol Reg | ister n | | • | E + 0x<br>Wait S | ldr<br>:800 +<br>:tate: 0<br>:ss: S | | |--------|------|-----|----|----|-------|--------|---------|-------|--------|--------|---------|----|----|------------------|-------------------------------------|----| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | | | | | | | | | | | | | | | | RESET: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | | | | | | | | | | | | | | AULB | | | RESET: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Note: for n = 0 to 7 Figure 137. Master General Purpose Control Register n **Table 138. Master General Purpose Control Register Descriptions** | Name | Description | Setting | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bits 0–28 | Master General Purpose Control Register Reserved - These bits are reserved for future expansion. They read as zero and should be written with zero for upward compatibility. | NA | | AULB | Arbitrate on Undefined Length Bursts - These bits are used to select the arbitration policy during undefined length bursts by this master. These bits are initialized by hardware reset. The reset value is 000 | <ul> <li>No arbitration will be allowed during an undefined length burst.</li> <li>Arbitration will be allowed at any time during an undefined length burst.</li> <li>Arbitration will be allowed after four beats of an undefined length burst.</li> <li>Arbitration will be allowed after eight beats of an undefined length burst.</li> <li>Arbitration will be allowed after 16 beats of an undefined length burst.</li> <li>Reserved</li> <li>Reserved</li> <li>Reserved</li> <li>Reserved</li> </ul> | The MGPCR can only be accessed in supervisor mode with 32-bit accesses. ### 14.3.3 Coherency Since the content of the registers has a real time effect on the operation of the XBAR it is important for the user to understand that any register modifications take effect as soon as the register is written. The values of the registers do not track with slave port related AHB accesses but instead track only with IP bus accesses. The exception to this rule are the AULB bits in the MGPCR. These update of these bits is only recognized when the master on that master port runs an IDLE cycle, even though the IP bus cycle to write them will have long since terminated successfully. If the AULB bits in the MGPCR are written in between two burst accesses the new AULB encodings will not take effect until an IDLE cycle has been initiated by the master on that master port. #### 14.4 Function This section describes in more detail the functionality of the XBAR. #### 14.4.1 Arbitration The XBAR supports two arbitration schemes; a simple fixed-priority comparison algorithm, and a simple round-robin fairness algorithm. The arbitration scheme is independently programmable for each slave port. #### 14.4.1.1 Arbitration During Undefined Length Bursts Arbitration points during an undefined length burst are defined by the current master's MGPCR[AULB] field configuration. When a defined length is imposed on the burst via the AULB bits the undefined length burst will be treated as a single or series of single back to back fixed length burst accesses. Example: A master runs an undefined length burst and the AULB bits in the MGPCR indicate arbitration will occur after the fourth beat of the burst. The master runs two sequential beats and then starts what will be a 12-beat undefined length burst access to a new address within the same slave port region as the previous access. The XBAR will not allow an arbitration point until the fourth overall access (second beat of the second burst). At that point all remaining accesses will be open for arbitration until the master loses control of the slave port. Assume the master loses control of the slave port after the fifth beat of the second burst. Once the master regains control of the slave port no arbitration point will be available until after the master has run four more beats of its burst. After the fourth beat of the (now continued) burst (ninth beat of the second burst from the master's perspective) is taken all beats of the burst will once again be open for arbitration until the master loses control of the slave port. Assume the master again loses control of the slave port on the fifth beat of the third (now continued) burst (10th beat of the second burst from the master's perspective). Once the master regains control of the slave port it will be allowed to complete its final two beats of its burst without facing arbitration. Note that fixed length burst accesses are not affected by the AULB bits. All fixed length burst accesses lock out arbitration until the last beat of the fixed length burst. #### 14.4.1.2 Fixed Priority Operation When operating in fixed-priority mode, each master is assigned a unique priority level in the MPR (Master Priority Register). If two masters both request access to a slave port the master with the highest priority in the selected priority register will gain control over the slave port. Any time a master makes a request to a slave port the slave port checks to see if the new requesting master's priority level is higher than that of the master that currently has control over the slave port (unless the slave port is in a parked state). The slave port does an arbitration check at every clock edge to ensure that the proper master (if any) has control of the slave port. If the new requesting master's priority level is higher than that of the master that currently has control of the slave port the new requesting master will be granted control over the slave port at the next clock edge. The exception to this rule is if the master that currently has control over the slave port is running a fixed length burst transfer or a locked transfer. In this case the new requesting master will have to wait until the end of the burst transfer or locked transfer before it will be granted control of the slave port. If the master is running an undefined length burst transfer the new requesting master must wait until an arbitration point for the undefined length burst transfer before it will be granted control of the slave port. Arbitration points for an undefined length burst are defined in the MGPCR for each master. If the new requesting master's priority level is lower than that of the master that currently has control of the slave port the new requesting master will be forced to wait until the master that currently has control of the slave port either runs an IDLE cycle or runs a non IDLE cycle to a location other than the current slave port. ### 14.4.1.3 Round-Robin Priority Operation When operating in round-robin mode, each master is assigned a relative priority based on the master number. This relative priority is compared to the ID of the last master to perform a transfer on the slave bus. The highest priority requesting master will become owner of the slave bus as the next transfer boundary (accounting for locked and fixed-length burst transfers). Priority is based on how far ahead the ID of the requesting master is to the ID of the last master (ID is defined by master port number, not the **hmaster** field). Once granted access to a slave port, a master may perform as many transfers as desired to that port until another master makes a request to the same slave port. The next master in line will be granted access to the slave port at the next assertion of **sX\_hready**, or possibly on the next clock cycle if the current master has no pending access request. As an example of arbitration in round-robin mode, assume the XBAR is implemented with master ports 0, 1, 4 and 5. If the last master of the slave port was master 1, and master 0, 4 and 5 make simultaneous requests, they will be serviced in the order 4, 5 and then 0. Parking may still be used in a round-robin mode, but will not affect the round-robin pointer unless the parked master actually performs a transfer. Handoff will occur to the next master in line after one cycle of arbitration. If the slave port is put into low power park mode the round-robin pointer will be reset to point at master port 0, giving it the highest priority. Each master port has an **mX\_high\_priority** input which can be enabled by writing the correct data to the SGPCR. If a master's **mX\_high\_priority** input is enabled for a slave port programmed for round-robin mode, that master can force the slave port into fixed priority mode by asserting its **mX\_high\_priority** input while making a request to that particular slave port. While that (or any enabled) master's **mX\_high\_priority** input is asserted while making an access attempt to that particular slave port, the slave port will remain in fixed priority mode. Once that (or any enabled) master's **mX\_high\_priority** input is negated, or the master no longer attempts to make accesses to that particular slave port, the slave port will revert back to round-robin priority mode and the pointer will be set on the last master to access the slave port. ### 14.4.2 Priority Assignment Each master port needs to be assigned a unique 3-bit priority level. If an attempt is made to program multiple master ports with the same priority level within a register (MPR) the XBAR will respond with an error and the registers will not be updated. ### 14.4.2.1 Priority Elevation The XBAR has a hardware input per master port (mX\_high\_priority) which is used to temporarily elevate the master's priority level on all slave ports. When the master's mX\_high\_priority input is asserted the master port will automatically have higher priority than all other master ports that do not have their mX\_high\_priority input asserted regardless of the priority levels programmed in the MPR and AMPR. If multiple master ports have their mX\_high\_priority input asserted they will have higher priority than all master ports which do not have their mX\_high\_priority inputs asserted. The MPR priority level will determine which master port that has its mX\_high\_priority input asserted has the highest priority on a slave port by slave port basis. This functionality is useful because it allows the user to automatically elevate a master port's priority level throughout the XBAR in order to quickly perform temporary tasks such as servicing interrupts. Please note that the HPEx bits must be set in the SGPCR in the slave port in order for the **mX\_high\_priority** inputs to be received by the slave port. ### 14.4.3 Master Port Functionality #### 14.4.3.1 General Each master port consists of two decoders, a capture unit, a register slice, a mux and a small state machine. The first decoder is used to decode the **mX\_hsel\_slv** and control signals coming directly from the master, telling the state machine where the master's next access will be and if it is in fact a legal access. The second decoder receives its input from the capture unit, so it may be looking directly at the signals coming from the master or it may be looking at captured signals coming from the master, depending entirely on the state of the targeted slave port. The second decoder is then used to generate the access requests that go to the slave ports. The capture unit is used to capture the address and control information coming from the master in the event that the targeted slave port cannot immediately service the master. The capture unit is controlled by outputs from the state machine which tell it to either pass through the original master signals or the captured signals. The register slice contains the registers associated with the specific master port. The registers have a quasi-IP bus interface at this level for reads and writes and the outputs feed directly into the state machine. The mux is used simply to select which slave's read data is sent back to the master. The mux is controlled by the state machine. The state machine controls all aspects of the master port. It knows which slave port the master wants to make a request to and controls when that request is made. It also has knowledge of each slave port, knowing whether or not the slave port is ready to accept an access from the master port. This will determine whether or not the master may immediately have its request taken by the slave port or whether the master port will have to capture the master's request and queue it at the slave port boundary. #### 14.4.3.2 Master Port Decoders The decoders are very simple as they ensure an access request is allowed to be made and that the slave port targeted is actually present in the design. The decoders feeding the state machine are always enabled. The decoders that select the slave are enabled only when the master port controlling state machine wants to make a request to a slave port. This is necessary so that if a master port is making an access to a slave port and is being wait stated, and its next access is to a different slave port, the request to the second slave port can be held off until the access to the first slave port is terminated. The decoders also output a "hole decode" or illegal access signal which tells the state machine that the master is trying to access a slave port that does not exist. #### 14.4.3.3 Master Port Capture Unit The capture unit simply captures the state of the master's address and control signals if the XBAR cannot immediately pass the master's request through to the proper slave port. The capture unit consists of a set of flops and a mux which selects either the asynchronous path from address and control or the flopped (captured) address and control information. ### 14.4.3.4 Master Port Registers The registers in the master port are only those registers associated with this particular master port. The read and write interface for the registers is a quasi-IP bus interface. It is not a full IP bus interface at this level because not all the IP bus signals are routed this deep in the design. There is a register control block at the same level of the master port and slave port instantiations in the XBAR. This control block ensures that all accesses are 32-bit supervisor accesses before passing them on to the master ports. The register outputs are connected directly to the state machine. #### 14.4.3.5 Master Port State Machine #### 14.4.3.5.1 Master Port State Machine States The master side state machine's main function is to monitor the activities of the master port. The state machine has six states: busy, idle, waiting, stalled, steady state, first cycle error response and second cycle error response. The **busy** state is used when the master runs a BUSY cycle to the master port. The master port maintains its request to the slave port if it currently owns the slave port; however, if it loses control of the slave port it will no longer maintain its request. If the master port loses control of the slave port it will not be allowed to make another request to the slave port until it runs a NSEQ or SEQ cycle. The **idle** state is used when the master runs a valid IDLE cycle to the master port. The master port makes no requests to the slave ports (disables the slave port decoder) and terminates the IDLE cycle. The **waiting** state is used when the **hsel** signal is negated to the master port, indicating the master is running valid cycles to a local slave other than the XBAR. In this case the max disables the slave port decoder and holds **hresp** and **hready** negated. The **stalled** state is used when the master makes a request to a slave port that is not immediately ready to receive the request. In this case the state machine will direct the capture unit to send out the captured address and control signals and will enable the slave port decoder to indicate a pending request to the appropriate slave port. The **steady state** state is used when the master port and slave port are in fully asynchronous mode, making the XBAR completely transparent in the access. The state machine selects the appropriate slave's **hresp**, **hready** and **hrdata** to pass back to the master. The **first cycle error response** and **second cycle error response** states are self explanatory. The XBAR will respond with an error response to the master if the master tries to access an unimplemented memory location through the XBAR (that is, a slave port that does not exist). ### 14.4.3.5.2 Master Port State Machine Slave Swapping The design of the master side state machine is fairly straightforward. The one real decision to be made is how to handle the master moving from one slave port access to another slave port access. The approach that was taken is to minimize or eliminate when possible any "bubbles" that would be inserted into the access due to switching slave ports. The state machine will not allow the master to request access to another slave port until the current access being made is terminated. This prevents a single master from owning two slave ports at the same time (the slave port it is currently accessing and the slave port it wishes to access next). The state machine also maintains watch on the slave port the master is accessing as well as the slave port the master wishes to switch to. If the new slave port is parked on the master then the master will be able to make the switch without incurring any delays. The termination of the current access will also act as the launch of the new access on the new slave port. If the new slave port is not parked on the master then the master will incur a minimum one clock delay before it can launch its access on the new slave port. This is the same for switching from the **busy**, **idle** or **waiting** state to actively accessing a slave port. If the slave port is parked on the master the state machine will go to the **steady state** state and the access will begin immediately. If the slave port is not parked on the master (serving another master, parked on another master or in low power park mode) then the state machine will transition to the **stalled** state and at least a one clock penalty will be paid. #### 14.4.4 Slave Port Functionality #### 14.4.4.1 General Each slave port consists of a register slice, a bank of muxes and a state machine. The register slice contains the registers associated with the specific slave port. The registers have a quasi-IP bus interface at this level for reads and writes and the outputs feed directly into the state machine. The muxes are a series of 8 to 1 muxes that take in all the address, control and write data information from each of the master ports and then pass the correct master's signals to the slave port. The state machine controls all the muxes. The state machine is where the main slave port arbitration occurs, it decides which master is in control of the slave port and which master will be in control of the slave port in the next bus cycle. #### 14.4.4.2 Slave Port Muxes The XBAR instantiates many 8 to 1 muxes, one for each master-to-slave signal in fact. All the muxes are designed in an AND - OR fashion, so that if no master is selected the output of the muxes will be zero. (This is an important feature for low power park mode.) The muxes also have an override signal which is used by the slave port to asynchronously force IDLE cycles onto the slave bus. When the state machine forces an IDLE cycle it zeros out **htrans** and **hmastlock**, making sure the slave bus sees a valid IDLE cycle being run by the XBAR. The enable to the mux controlling **htrans** also contains an additional control signal from the state machine so that a NSEQ transaction can be forced. This is done any time the slave port switches masters to ensure that no IDLE-SEQ, BUSY-SEQ or NSEQ-SEQ transactions are seen on the slave port when they shouldn't be. If the state machine indicates to run both an IDLE and an NSEQ cycle, the IDLE directive will have priority. Note: IDLE-SEQ is in fact an illegal access, but a possible scenario given the multi-master environment in the XBAR unless corrected by the XBAR. #### 14.4.4.3 Slave Port Registers There is a register control block at the same level of the master port and slave port instantiations in the XBAR. This control block ensures that all accesses are 32-bit supervisor accesses before passing them on to the master and slave ports. The registers in the slave port are only those registers associated with this particular slave port. The read and write interface for the registers is a quasi-IP bus interface. It is not a full IP bus interface at this level because not all the IP bus signals are routed this deep in the design. The register outputs are connected directly to the slave state machine. The registers can be read from an unlimited number of times. The registers can only be written to as long as the RO bit is written to 0 in the SGPCR, once it is written to a 1 only a hardware reset will allow the registers to be written again. #### 14.4.4.4 Slave port state machine #### 14.4.4.4.1 Slave Port State Machine States At the heart of the slave port is the state machine. The state machine is simplicity itself, requiring only four states - **steady state**, **transition state**, **transition hold state** and **hold state**. Either the slave port is owned by the same master it was in the last clock cycle (either by active use or by parking), it is transitioning to a new master (either for active use or parking), it is transitioning to a new master during wait states or it is being held on the same master pending a transition to a new master. #### 14.4.4.4.2 Slave Port State Machine Arbitration The real work in the state machine is determining which master port will be in control of the slave port in the next clock cycle, the arbitration. Each master is programmed with a fixed 3-bit priority level. A fourth priority bit is derived from the **mX\_high\_priority** inputs on the master ports, effectively making each master's priority level a 4-bit field with **mX\_high\_priority** being the MSB. The XBAR uses these bits in determining priority levels when programmed for fixed priority mode of operation or when one of the enabled **mX\_high\_priority** inputs is asserted. Arbitration always occurs on a clock edge, but only occurs on edges when a change in mastership will not violate AHB-Lite protocols. Valid arbitrations points include any clock cycle in which **sX\_hready** is asserted (provide the master is not performing a burst or locked cycle) and any wait state in which the master owning the bus indicates a transfer type of IDLE (provided the master is not performing a locked cycle). Since arbitration can occur on every clock cycle the slave port masks off all master requests if the current master is performing a locked transfer or a protected burst transfer, guaranteeing that no matter how low its priority level it will be allowed to finish its locked or protected portion of a burst sequence. #### 14.4.4.4.3 Slave Port State Machine Master Handoff The only times the slave port will switch masters when programmed for fixed priority mode of operation is when a higher priority master makes a request or when the current master is the highest priority and it gives up the slave port by either running and IDLE cycle to the slave port or running a valid access to a location other than the slave port. If the current master loses control of the slave port because a higher priority master takes it away, the slave port will not incur any wasted cycles. The current master has its current cycle terminated by the slave port at the same time the new master's address and control information are recognized by the slave port. This appears as a seamless transition on the slave port. If the current master is being wait-stated when the higher priority master makes its request, then the current master will be allowed to make one more transaction on the slave bus before giving it up to the new master. *Figure 138* illustrates the effect of a higher priority master taking control of the bus when the slave port is programmed for a fixed priority mode of operation. Figure 138. Low to high priority mastership change If the current master is the highest priority master and it gives up the slave port by running an IDLE cycle or by running a valid cycle to another location other than the slave port the next highest priority master will gain control of the slave port. If the current access incurs any wait states then the transition will be seamless and no bandwidth will be lost; however, if the current transaction is terminated without wait states then one IDLE cycle will be forced onto the slave bus by the XBAR before the new master will be able to take control of the slave port. If no other master is requesting the bus then IDLE cycles will be run by the XBAR but no bandwidth will truly be lost since no master is making a request. *Figure 139* illustrates the effect of a higher priority master giving up control of the bus. Figure 139. High to low priority mastership change When the slave port is programmed for round-robin mode of arbitration then the slave port will switch masters any time there is more than one master actively making a request to the slave port. This will happen because any master other than the one which presently owns the bus will be considered to have higher priority. *Figure 140* shows an example of round-robin mode of operation. Figure 140. Round-robin mastership change ### 14.4.4.4.4 Slave port state machine parking If no master is currently making a request to the slave port then the slave port will be parked. It will park in one of four places, dictated by the PCTL and PARK bits in the GPCR and the locked state of the last master to access it. If the last master to access the slave port ran a locked cycle and continues to run locked cycles even after leaving the slave port the slave port will park on that master without regard to the bit settings in the GPCR and without regard to pending requests from other masters. This is done so a master can run a locked transfer to the slave port, leave it, and return to it and be guaranteed that no other master has had access to it (provided the master maintains all transfers are locked transfers). If locking is not an issue for parking the GPCR bits will dictate the parking method. If the PCTL bits are set for "low power park" mode then the slave port will enter low power park mode. It will not recognize any master as being in control of it and it will not select any master's signals to pass through to the slave bus. In this case all slave bus activity will effectively halt because all slave bus signals being driven from the XBAR will be 0. This of course can save quite a bit of power if the slave port will not be in use for some time. The down side is that when a master does make a request to the slave port it will be delayed by one clock since it will have to arbitrate to acquire ownership of the slave port. If the PCTL bits are set to "park on last" mode then the slave port will park on the last master to access it, passing all that masters signals through to the slave bus. The XBAR will asynchronously force htrans[1:0], hmaster[3:0], hburst[2:0] and hmastlock to 0 for all access that the master does not run to the slave port. When that master access the slave port again it will not pay any arbitration penalty; however, if any other master wishes to access the slave port a one clock arbitration penalty will be imposed. If the PCTL bits are set to "use PARK/APARK" mode then the slave port will park on the master designated by the PARK bits. The behavior here is the same as for the "park on last" mode with the exception that a specific master will be parked on instead of the last master to access the slave port. If the master designated by the PARK bits tries to access the slave port it will not pay an arbitration penalty while any other master will pay a one clock penalty. Figure 141 illustrates parking on a specific master. Figure 141. Parking on a specific master Figure 142 illustrates parking on the last master. Note that in cycle 6 simultaneous requests are made by master 2 and master 4. Although master 2 has higher priority, the slave bus is parked on master 4 so master 4's access will be taken first. The slave port parks on master 2 once it has given control to master 2. This same situation can occur when parking on a specific master as well. Figure 142. Parking on last master # 14.5 Initialization/Application Information No initialization is required by or for the XBAR. Hardware reset ensures all the register bits used by the XBAR are properly initialized. ### 14.6 Interface This section provides information on the XBAR interface. #### 14.6.1 Overview The main goal of the XBAR is to increase overall system performance by allowing multiple masters to communicate in parallel with multiple slaves. In order to maximize data throughput it is essential to keep arbitration delays to a minimum. This section examines data throughput from the point of view of masters and slaves, detailing when the XBAR will stall the masters or insert bubbles on the slave side. #### 14.6.2 Master Ports Master accesses will receive one of four responses from the XBAR. They will either be ignored, terminated, taken, stalled or responded to with an error. #### 14.6.2.1 Ignored Accesses A master access will be ignored if the **hsel** input of the XBAR is not asserted. The XBAR will respond to IDLE transfers when the **hsel** input is asserted but will not allow the access to pass through the XBAR. #### 14.6.2.2 Terminated Accesses A master access will be terminated if the **hsel** input of the XBAR is asserted and the transfer type is IDLE. The XBAR will terminated the access and it will not be allowed to pass through the XBAR. #### 14.6.2.3 Taken Accesses A master access will be taken if the **hsel** input of the XBAR is asserted and the transfer type is non IDLE and the slave port to which the access decodes is either currently servicing the master or is parked on the master. In this case the XBAR will be completely transparent and the master's access will be immediately seen on the slave bus and no arbitration delays will be incurred. #### 14.6.2.4 Stalled Accesses A master access will be stalled if the **hsel** input of the XBAR is asserted and the transfer type is non IDLE and the access decodes to a slave port that is busy serving another master, parked on another master or is in low power park mode. The XBAR will indicate to the master that the address phase of the access has been taken but will then queue the access to the appropriate slave port to enter into arbitration for access to that slave port. If the slave port is currently parked on another master or is in low power park mode and no other master is requesting access to the slave port then only one clock of arbitration will be incurred. If the slave port is currently serving another master of a lower priority and the master has a higher priority than all other requesting masters then the master will gain control over the slave port as soon as the data phase of the current access is completed (burst and locked transfers excluded). If the slave port is currently servicing another master of a higher priority then the master will gain control of the slave port once the other master releases control of the slave port if no other higher priority master is also waiting for the slave port. #### 14.6.2.5 Error Response Terminated Accesses A master access will be responded to with an error if the **hsel** input of the XBAR is asserted and the transfer type is non IDLE and the access decodes to a location not occupied by a slave port. This is the only time the XBAR will respond with an error response. All other error responses received by the master are the result of error responses on the slave ports being passed through the XBAR. #### 14.6.3 Slave Ports The goal of the XBAR with respect to the slave ports is to keep them 100% saturated when masters are actively making requests. In order to do this the XBAR must not insert any bubbles onto the slave bus unless absolutely necessary. There is only one instance when the XBAR will force a bubble onto the slave bus when a master is actively making a request. This occurs when a higher priority master has control of the slave port and is running single clock (zero wait state) accesses while a lower priority master is stalled waiting for control of the slave port. When the higher priority master either leaves the slave port or runs an IDLE cycle to the slave port the XBAR will take control of the slave bus and run a single IDLE cycle before giving the slave port to the lower priority master that was waiting for control of the slave port. The only other times the XBAR will have control of the slave port is when the XBAR is halting or when no masters are making access requests to the slave port and the XBAR is forced to either park the slave port on a specific master or put the slave port into low power park mode. In most instances when the XBAR has control of the slave port it will indicate IDLE for the transfer type, negate all control signals and indicate ownership of the slave bus via the **hmaster** encoding of 4'b0000. One exception to this rule is when a master running locked cycles has left the slave port but continues to run locked cycles. In this case the XBAR will control the slave port and will indicate IDLE for the transfer type but it will not affect any other signals. Note: When a master runs a locked cycle through the XBAR, the master will be guaranteed ownership of all slave ports it accesses while running locked cycles for one cycle beyond when the master finishes running locked cycles. # 15 Error Correction Status Module (ECSM) ### 15.1 Introduction The Error Correction Status Module (ECSM) provides control functions for the device Standard Product Platform (SPP) including program-visible information about the platform configuration and revision levels, a reset status register, a software watchdog timer, and wakeup control for exiting sleep modes, and optional features such as an address map for the device's crossbar switch, information on memory errors reported by error-correcting codes and/or generic access error information for certain processor cores. #### 15.2 Overview The Error Correction Status Module is mapped into the IPS space and supports a number of control functions for the platform device. #### 15.3 Features The ECSM includes these features: - Program-visible information on the platform device configuration and revision - Reset status register (MRSR) - Registers for capturing information on platform memory errors if error-correcting codes (ECC) are implemented - Registers to specify the generation of single- and double-bit memory data inversions for test purposes if error-correcting codes are implemented - Access address information for faulted memory accesses for certain processor core micro-architectures - XBAR priority functions, including forcing round robin and high priority enabling # 15.4 Memory map and registers description This section details the programming model for the ECSM. This is an on-platform 128-byte space mapped to the region serviced by an IPS bus controller. Some of the control registers have a 64-bit width. These 64-bit registers are implemented as two 32-bit registers, and include an "H" and "L" suffixes, indicating the "high" and "low" portions of the control function. The Error Correction Status Module does not include any logic that provides access control. Rather, this function is supported using the standard access control logic provided by the IPS controller. ECSM registers are accessible only when the core is in supervisor mode. #### **15.4.1 Memory map** Table 139 lists the registers in the ECSM. Table 139. ECSM registers | Offset from<br>ECSM_BASE<br>0xFFF4_0000 (ECSM_0)<br>0x8FF4_0000 (ECSM_1) | Register | Location | Size (bits) | |--------------------------------------------------------------------------|---------------------------------------------------|-------------|-------------| | 0x0000 | PCT—Processor Core Type register | on page 332 | 16 | | 0x0002 | REV—Revision register | on page 332 | 16 | | 0x0004 | PLAMC — Platform XBAR Master Configuration | on page 333 | 16 | | 0x0006 | PLASC — Platform XBAR Slave Configuration | on page 333 | 16 | | 0x0008 | IMC—IPS Module Configuration register | on page 334 | 16 | | 0x000C-0x000E | Reserved | | | | 0x000F | MRSR—Miscellaneous Reset Status register | on page 334 | 8 | | 0x0010-0x001E | Reserved | | | | 0x001F | MIR—Miscellaneous Interrupt register | on page 335 | 8 | | 0x0020-0x0023 | Reserved | | | | 0x0024 | MUDCR—Miscellaneous User-Defined Control Register | on page 336 | 32 | | 0x0028-0x0042 | Reserved | | | | 0x0043 | ECR—ECC Configuration register | on page 337 | 8 | | 0x0044-0x0046 | Reserved | | | | 0x0047 | ESR—ECC Status register | on page 338 | 8 | | 0x0048-0x0049 | Reserved | | | | 0x004A | EEGR—ECC Error Generation register | on page 340 | 16 | | 0x004C-0x004F | Reserved | | | | 0x0050 | FEAR—Flash ECC Address register | on page 342 | 32 | | 0x0054-0x0055 | Reserved | | | | 0x0056 | FEMR—Flash ECC Master Number Register | on page 343 | 8 | | 0x0057 | FEAT—Flash ECC Attributes register | on page 343 | 8 | | 0x0058-0x005B | Reserved | | | | 0x005C | FEDR—Flash ECC Data register | on page 344 | 32 | | 0x0060 | REAR—RAM ECC Address register | on page 345 | 32 | | 0x0064 | Reserved | | | | 0x0065 | RESR—RAM ECC Syndrome register | on page 346 | 8 | | 0x0066 | REMR—RAM ECC Master register | on page 348 | 8 | | 0x0067 | REAT—RAM ECC Attributes register | on page 348 | 8 | | 0x0068-0x006B | Reserved | | | | 0x006C | REDR—RAM ECC Data register | on page 349 | 32 | | 0x0070-0x3FFF | Reserved | | | # 15.4.2 Registers description Attempted accesses to reserved addresses result in an error termination, while attempted writes to read-only registers are ignored and do not terminate with an error. Unless noted otherwise, writes to the programming model must match the size of the register, e.g., an n-bit register only supports n-bit writes, etc. Attempted writes of a different size than the register width produce an error termination of the bus cycle and no change to the targeted register. # 15.4.2.1 Processor core type (PCT) register The PCT is a 16-bit read-only register that specifies the architecture of the processor core in the device. The state of this register is defined by a module input signal; it can only be read from the IPS programming model. Any attempted write is ignored. Figure 143. Processor core type (PCT) register Table 140. PCT field descriptions | Name | Description | |-----------|-----------------------------------------------| | 0-15 | Processor Core Type | | PCT[15:0] | 0xE012 identifies the z0H Power Architecture. | # 15.4.2.2 Revision (REV) register The REV is a 16-bit read-only register specifying a revision number. The state of this register is defined by an input signal; it can only be read from the IPS programming model. Any attempted write is ignored. Table 141. REV field descriptions | Name | Description | |-----------|---------------------------------------------------------------------------------------------------| | 0-15 | Revision | | REV[15:0] | The REV[15:0] field is specified by an input signal to define a software-visible revision number. | ### 15.4.2.3 Platform XBAR Master Configuration (PLAMC) The PLAMC is a 16-bit read-only register identifying the presence/absence of bus master connections to the device's AMBA-AHB Crossbar Switch (XBAR). The state of this register is defined by a module input signal; it can only be read from the IPS programming model. Any attempted write is ignored. Figure 145. Platform XBAR Master Configuration (PLAMC) register Table 142. PLAMC field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | | XBAR Master Configuration 0 Bus master connection to XBAR input port <i>n</i> is not present. 1 Bus master connection to XBAR input port <i>n</i> is present. | #### 15.4.2.4 Platform XBAR Slave Configuration (PLASC) The PLASC is a 16-bit read-only register identifying the presence/absence of bus slave connections to the device's AMBA-AHB Crossbar Switch (XBAR), plus a 1-bit flag defining the internal platform datapath width (DP64). The state of this register is defined by a module input signal; it can only be read from the IPS programming model. Any attempted write is ignored. Figure 146. Platform XBAR Slave Configuration (PLASC) register Table 143. PLASC field descriptions | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | DP64 | 64-bit Datapath 0 Datapath width is 32 bits. 1 Datapath width is 64 bits. | | ASC[7:0] | XBAR Slave Configuration 0 Bus slave connection to XBAR output port <i>n</i> is not present. 1 Bus slave connection to XBAR output port <i>n</i> is present. | # 15.4.2.5 IPS Module Configuration (IMC) register The IMC is a 32-bit read-only register identifying the presence/absence of the 32 low-order IPS peripheral modules connected to the primary slave bus controller. The state of this register is defined by a module input signal; it can only be read from the IPS programming model. Any attempted write is ignored. Figure 147. IPS Module Configuration (IMC) register Table 144. IMC field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 0-31 | IPS Module Configuration 0 IPS module connection to decoded slot <i>n</i> not present 1 IPS module connection to decoded slot <i>n</i> present | #### 15.4.2.6 Miscellaneous Reset Status Register (MRSR) The MRSR contains a bit for each of the reset sources to the device. An asserted bit indicates the last type of reset that occurred. Only one bit is set at any time in the MRSR, reflecting the cause of the most recent reset as signaled by device reset input signals. The MRSR can only be read from the IPS programming model. Any attempted write is ignored. Figure 148. Miscellaneous Reset Status Register (MRSR) | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>POR | Power-On Reset 0 Last recorded event was not caused by a power-on reset (based on a device input signal). 1 Last recorded event was caused by a power-on reset (based on a device input signal). | | 1<br>DIR | Device Input Reset 0 Last recorded event was not caused by a device input reset. 1 Last recorded event was a reset caused by a device input reset. | # 15.4.2.7 Miscellaneous Interrupt Register (MIR) All interrupt requests associated with ECSM are collected in the MIR. This includes the processor core system bus fault interrupt. During the appropriate interrupt service routine handling these requests, the interrupt source contained in the ECSMIR must be explicitly cleared. Figure 149. Miscellaneous Interrupt Register (MIR) Table 146. MIR field descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>FB0AI | Flash Bank 0 Abort Interrupt 0 A flash bank 0 abort has not occurred. 1 A flash bank 0 abort has occurred. The interrupt request is negated by writing a 1 to this bit. Writing a 0 has no effect. | | 1<br>FB0SI | Flash Bank 0 Stall Interrupt 0 A flash bank 0 stall has not occurred. 1 A flash bank 0 stall has occurred. The interrupt request is negated by writing a 1 to this bit. Writing a 0 has no effect. | | 2<br>FB1AI | Flash Bank 1 Abort Interrupt 0 A flash bank 1 abort has not occurred. 1 A flash bank 1 abort has occurred. The interrupt request is negated by writing a 1 to this bit. Writing a 0 has no effect. | | 3<br>FB1SI | Flash Bank 1 Stall Interrupt 0 A flash bank 1 stall has not occurred. 1 A flash bank 1 stall has occurred. The interrupt request is negated by writing a 1 to this bit. Writing a 0 has no effect. | # 15.4.2.8 Miscellaneous User-Defined Control Register (MUDCR) The MUDCR provides a program-visible register for user-defined control functions. It provides configuration control for assorted modules on the device. The contents of this register is output from the ECSM to other modules where these user-defined control functions are implemented. Figure 150. Miscellaneous User-Defined Control register (MUDCR) Table 147. MUDCR field descriptions | Name | Description | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Pram Wait State Control (MUDCR[30]) When the programmable wait-state pram controller is included on the platform, this bit is used to select whether the pram controller will insert 1-wait state into every read access made to the ram arrays. By setting the hardware define 1 = spp_pram_ecc32 controller is a 1-wait state controller 0 = spp_pram_ecc32 controller is a 0-wait state controller | #### 15.4.2.9 ECC registers There are a number of program-visible registers for the sole purpose of reporting and logging of memory failures. These registers include the following: - ECC Configuration Register (ECR) - ECC Status Register (ESR) - ECC Error Generation Register (EEGR) - Flash ECC Address Register (FEAR) - Flash ECC Master Number Register (FEMR) - Flash ECC Attributes Register (FEAT) - Flash ECC Data Register (FEDR) - RAM ECC Address Register (REAR) - RAM ECC Syndrome Register (RESR) - RAM ECC Master Number Register (REMR) - RAM ECC Attributes Register (REAT) - RAM ECC Data Register (REDR) The details on the ECC registers are provided in the subsequent sections. If the design does not include ECC on the memories, these addresses are reserved locations within the ECSM's programming model. ### 15.4.2.10 ECC Configuration Register (ECR) The ECC Configuration Register is an 8-bit control register for specifying which types of memory errors are reported. In all systems with ECC, the occurrence of a non-correctable error causes the current access to be terminated with an error condition. In many cases, this error termination is reported directly by the initiating bus master. However, there are certain situations where the occurrence of this type of non-correctable error is not reported by the master. Examples include speculative instruction fetches, which are discarded due to a change-of-flow operation, and buffered operand writes. The ECC reporting logic in the ECSM provides an optional error interrupt mechanism to signal all non-correctable memory errors. In addition to the interrupt generation, the ECSM captures specific information (memory address, attributes and data, bus master number, etc.) that may be useful for subsequent failure analysis. The reporting of single-bit memory corrections can only be enabled via an SoC-configurable module input signal. While not directly accessible to a user, this capability is viewed as important for error logging and failure analysis. Figure 151. ECC Configuration register (ECR) Table 148. ECR field descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2<br>ER1BR | Enable RAM 1-bit Reporting This bit can only be set if the input enable signal is asserted. The occurrence of a single-bit RAM correction generates a ECSM ECC interrupt request as signaled by the assertion of ESR[R1BC]. The address, attributes and data are also captured in the REAR, RESR, REMR, REAT and REDR registers. 0 Reporting of single-bit RAM corrections disabled 1 Reporting of single-bit RAM corrections enabled | | 3<br>EF1BR | Enable Flash 1-bit Reporting This bit can only be set if the input enable signal is asserted. The occurrence of a single-bit flash correction generates a ECSM ECC interrupt request as signaled by the assertion of ESR[F1BC]. The address, attributes and data are also captured in the FEAR, FEMR, FEAT and FEDR registers. OReporting of single-bit flash corrections disabled 1Reporting of single-bit flash corrections enabled | Table 148. ECR field descriptions(Continued) | Field | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6<br>ERNCR | Enable RAM Non-Correctable Reporting The occurrence of a non-correctable multi-bit RAM error generates a ECSM ECC interrupt request as signaled by the assertion of ESR[RNCE]. The faulting address, attributes and data are also captured in the REAR, RESR, REMR, REAT and REDR registers. OReporting of non-correctable RAM errors disabled 1Reporting of non-correctable RAM errors enabled | | 7<br>EFNCR | Enable Flash Non-Correctable Reporting The occurrence of a non-correctable multi-bit flash error generates a ECSM ECC interrupt request as signaled by the assertion of ESR[FNCE]. The faulting address, attributes and data are also captured in the FEAR, FEMR, FEAT and FEDR registers. O Reporting of non-correctable flash errors disabled 1 Reporting of non-correctable flash errors enabled | ### 15.4.2.11 ECC Status Register (ESR) The ECC Status Register is an 8-bit control register for signaling which types of properly enabled ECC events have been detected. The ESR signals the last properly enabled memory event to be detected. ECC interrupt generation is separated into single-bit error detection/correction, uncorrectable error detection, and the combination of the two as defined by the following boolean equations: where the combination of a properly enabled category in the ECR and the detection of the corresponding condition in the ESR produces the interrupt request. The ECSM allows a maximum of one bit of the ESR to be asserted at any given time. This preserves the association between the ESR and the corresponding address and attribute registers, which are loaded on each occurrence of an properly enabled ECC event. If there is a pending ECC interrupt and another properly enabled ECC event occurs, the ECSM hardware automatically handles the ESR reporting, clearing the previous data and loading the new state and thus guaranteeing that only a single flag is asserted. To maintain the coherent software view of the reported event, the following sequence in the ECSM error interrupt service routine is suggested: - Read the ESR and save it. - 2. Read and save all the address and attribute reporting registers. - 3. Re-read the ESR and verify the current contents matches the original contents. If the two values are different, go back to step 1 and repeat. - 4. When the values are identical, write a 1 to the asserted ESR flag to negate the interrupt request. Figure 152. ECC Status register (ESR) Table 149. ESR field descriptions | Field | Description | | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 2<br>R1BC | RAM 1-bit Correction This bit can only be set if ECR[ER1BR] is asserted. The occurrence of a properly enabled single-bit RAM correction generates a ECSM ECC interrupt request. The address, attributes and data are also captured in the REAR, RESR, REMR, REAT and REDR registers. To clear this interrupt flag, write a 1 to this bit. Writing a 0 has no effect. O No reportable single-bit RAM correction detected Reportable single-bit RAM correction detected | | | 3<br>F1BC | Flash 1-bit Correction This bit can only be set if ECR[EF1BR] is asserted. The occurrence of a properly enabled single-bit flash correction generates a ECSM ECC interrupt request. The address, attributes and data are also captured in the FEAR, FEMR, FEAT and FEDR registers. To clear this interrupt flag, write a 1 to this bit. Writing a 0 has no effect. O No reportable single-bit flash correction detected Reportable single-bit flash correction detected | | | 6<br>RNCE | RAM Non-Correctable Error The occurrence of a properly enabled non-correctable RAM error generates a ECSM ECC interrupt request. The faulting address, attributes and data are also captured in the REAR, RESR, REMR, REAT and REDR registers. To clear this interrupt flag, write a 1 to this bit. Writing a 0 has no effect. This bit can only be set if ECR[ERNCR] is asserted. O No reportable non-correctable RAM error detected Reportable non-correctable RAM error detected | | | 7<br>FNCE | Flash Non-Correctable Error The occurrence of a properly enabled non-correctable flash error generates a ECSM ECC interrupt request. The faulting address, attributes and data are also captured in the FEAR, FEMR, FEAT and FEDR registers. To clear this interrupt flag, write a 1 to this bit. Writing a 0 has no effect. This bit can only be set if ECR[ERNCR] is asserted. 0 No reportable non-correctable flash error detected 1 Reportable non-correctable flash error detected | | In the event that multiple status flags are signaled simultaneously, ECSM records the event with the R1BC as highest priority, then F1BC, then RNCE, and finally FNCE. #### 15.4.2.12 ECC Error Generation Register (EEGR) The ECC error generation register is a 16-bit control register used to force the generation of single- and double-bit data inversions in the memories with ECC, most notably the RAM. This capability is provided for two purposes: - It provides a software-controlled mechanism for injecting errors into the memories during data writes to verify the integrity of the ECC logic. - It provides a mechanism to allow testing of the software service routines associated with memory error logging. It should be noted that while the EEGR is associated with the RAM, similar capabilities exist for the flash, that is, the ability to program the non-volatile memory with single- or double-bit errors is supported for the same two reasons previously identified. For both types of memories (RAM and flash), the intent is to generate errors during data write cycles, such that subsequent reads of the corrupted address locations generate ECC events, either single-bit corrections or double-bit non-correctable errors that are terminated with an error response. The enabling of these error generation modes requires the same input enable signal (as that used to enable single-bit correction reporting) be asserted. This signal is tied to 1 at SoC level and hence reporting of single-bit memory corrections is always enabled. Figure 153. ECC Error Generation register (EEGR) # Table 150. EEGR field descriptions | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2<br>FRC1BI | Force RAM Continuous 1-Bit Data Inversions 0 No RAM continuous 1-bit data inversions generated 1 1-bit data inversions in the RAM continuously generated The assertion of this bit forces the RAM controller to create 1-bit data inversions, as defined by the bit position specified in ERRBIT[6:0], continuously on every write operation. The normal ECC generation takes place in the RAM controller, but then the polarity of the bit position defined by ERRBIT is inverted to introduce a 1-bit ECC event in the RAM. After this bit has been enabled to generate another continuous 1-bit data inversion, it must be cleared before being set again to properly re-enable the error generation logic. This bit can only be set if the same input enable signal (as that used to enable single-bit correction reporting) is asserted. | | 3<br>FR11BI | Force RAM One 1-bit Data Inversion 0 No RAM single 1-bit data inversion generated 1 One 1-bit data inversion in the RAM generated The assertion of this bit forces the RAM controller to create one 1-bit data inversion, as defined by the bit position specified in ERRBIT[6:0], on the first write operation after this bit is set. The normal ECC generation takes place in the RAM controller, but then the polarity of the bit position defined by ERRBIT is inverted to introduce a 1-bit ECC event in the RAM. After this bit has been enabled to generate a single 1-bit data inversion, it must be cleared before being set again to properly re-enable the error generation logic. This bit can only be set if the same input enable signal (as that used to enable single-bit correction reporting) is asserted. | | 6<br>FRCNCI | Force RAM Continuous Non-Correctable Data Inversions 0 No RAM continuous 2-bit data inversions generated 1 2-bit data inversions in the RAM continuously generated The assertion of this bit forces the RAM controller to create 2-bit data inversions, as defined by the bit position specified in ERRBIT[6:0] and the overall odd parity bit, continuously on every write operation. After this bit has been enabled to generate another continuous non-correctable data inversion, it must be cleared before being set again to properly re-enable the error generation logic. The normal ECC generation takes place in the RAM controller, but then the polarity of the bit position defined by ERRBIT and the overall odd parity bit are inverted to introduce a 2-bit ECC error in the RAM. | Table 150. EEGR field descriptions(Continued) | Field | Description | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Force RAM One Non-Correctable Data Inversions | | | No RAM single 2-bit data inversions generated One 2-bit data inversion in the RAM generated | | 7<br>FR1NCI | The assertion of this bit forces the RAM controller to create one 2-bit data inversion, as defined by the bit position specified in ERRBIT[6:0] and the overall odd parity bit, on the first write operation after this bit is set. | | | The normal ECC generation takes place in the RAM controller, but then the polarity of the bit position defined by ERRBIT and the overall odd parity bit are inverted to introduce a 2-bit ECC error in the RAM. | | | After this bit has been enabled to generate a single 2-bit error, it must be cleared before being set again to properly re-enable the error generation logic. | | | Error Bit Position | | | The vector defines the bit position that is complemented to create the data inversion on the write operation. For the creation of 2-bit data inversions, the bit specified by this field plus the odd parity bit of the ECC code are inverted. | | | The RAM controller follows a vector bit ordering scheme where LSB=0. Errors in the ECC syndrome bits can be generated by setting this field to a value greater than the RAM width. For example, consider a 32-bit RAM implementation. | | 9-15 | The 32-bit ECC approach requires 7 code bits for a 32-bit word. For PRAM data width of 32 bits, the actual SRAM (32 bits data + 7 bits for ECC) = 39 bits. The following association between the ERRBIT field and the corrupted memory bit is defined: | | ERRBIT | | | [6:0] | if ERRBIT = 0, then RAM[0] of the odd bank is inverted. | | | if ERRBIT = 1, then RAM[1] of the odd bank is inverted. | | | if ERRBIT = 31, then RAM[31] of the odd bank is inverted. | | | if ERRBIT = 64, then ECC Parity[0] of the odd bank is inverted. | | | if ERRBIT = 65, then ECC Parity[1] of the odd bank is inverted. | | | | | | if ERRBIT = 70, then ECC Parity[6] of the odd bank is inverted. | | | For ERRBIT values of 32 to 63 and greater than 70, no bit position is inverted. | If an attempt to force a non-correctable inversion (by asserting EEGR[FRCNCI] or EEGR[FRC1NCI]) and EEGR[ERRBIT] equals 64, then no data inversion will be generated. The only allowable values for the 4 control bit enables $\{FR11BI, FRC1BI, FRCNCI, FR1NCI\}$ are $\{0,0,0,0\}, \{1,0,0,0\}, \{0,1,0,0\}, \{0,0,1,0\}$ and $\{0,0,0,1\}$ . All other values result in undefined behavior. #### 15.4.2.13 Flash ECC Address Register (FEAR) The FEAR is a 32-bit register for capturing the address of the last properly enabled ECC event in the flash memory. Depending on the state of the ECC Configuration Register, an ECC event in the flash causes the address, attributes and data associated with the access to be loaded into the FEAR, FEMR, FEAT and FEDR registers, and the appropriate flag (F1BC or FNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 154. Flash ECC Address register (FEAR) Table 151. FEAR field descriptions | Field | Description | |--------------------|------------------------------------------------------------------------------------------------------------------------------------| | 0-31<br>FEAR[31:0] | Flash ECC Address Register This 32-bit register contains the faulting access address of the last properly enabled flash ECC event. | #### 15.4.2.14 Flash ECC Master Number Register (FEMR) The FEMR is a 4-bit register for capturing the XBAR bus master number of the last properly enabled ECC event in the flash memory. Depending on the state of the ECC Configuration Register, an ECC event in the flash causes the address, attributes and data associated with the access to be loaded into the FEAR, FEMR, FEAT and FEDR registers, and the appropriate flag (F1BC or FNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 155. Flash ECC Master Number Register (FEMR) Table 152. FEMR field descriptions | Name | Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4-7<br>FEMR[3:0] | Flash ECC Master Number Register This 4-bit register contains the XBAR bus master number of the faulting access of the last properly enabled flash ECC event. | ### 15.4.2.15 Flash ECC Attributes (FEAT) register The FEAT is an 8-bit register for capturing the XBAR bus master attributes of the last properly enabled ECC event in the flash memory. Depending on the state of the ECC Configuration Register, an ECC event in the flash causes the address, attributes and data associated with the access to be loaded into the FEAR, FEMR, FEAT and FEDR registers, and the appropriate flag (F1BC or FNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 156. Flash ECC Attributes (FEAT) Register Table 153. FEAT field descriptions | Name | Description | |--------------------|----------------------------------------------------------------------------------------------------------------------| | 0<br>WRITE | AMBA-AHB HWRITE 0 AMBA-AHB read access 1 AMBA-AHB write access | | 1-3<br>SIZE[2:0] | AMBA-AHB HSIZE[2:0] 000 8-bit AMBA-AHB access 001 16-bit AMBA-AHB access 010 32-bit AMBA-AHB access 1xx Reserved | | 4<br>PROTECTION[3] | AMBA-AHB HPROT[3] Protection[0]: Type 0 I-Fetch 1 Data | | 5<br>PROTECTION[2] | AMBA-AHB HPROT[2] Protection[1]: Mode 0 User mode 1 Supervisor mode | | 6<br>PROTECTION[1] | AMBA-AHB HPROT[1] Protection[2]: Bufferable 0 Non-bufferable 1 Bufferable | | 7<br>PROTECTION[0] | AMBA-AHB HPROT[0] Protection[3]: Cacheable 0 Non-cacheable 1 Cacheable | #### 15.4.2.16 Flash ECC Data Register (FEDR) The FEDR is a 32-bit register for capturing the data associated with the last properly enabled ECC event in the flash memory. Depending on the state of the ECC Configuration Register, an ECC event in the flash causes the address, attributes and data associated with the access to be loaded into the FEAR, FEMR, FEAT and FEDR registers, and the appropriate flag (F1BC or FNCE) in the ECC Status Register to be asserted. The data captured on a multi-bit non-correctable ECC error is undefined. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 157. Flash ECC Data register (FEDR) Table 154. FEDR field descriptions | Name | Description | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-31<br>FEDR[31:0] | Flash ECC Data Register This 32-bit register contains the data associated with the faulting access of the last properly enabled flash ECC event. The register contains the data value taken directly from the data bus. | #### 15.4.2.17 RAM ECC Address Register (REAR) The REAR is a 32-bit register for capturing the address of the last properly enabled ECC event in the RAM memory. Depending on the state of the ECC Configuration Register, an ECC event in the RAM causes the address, attributes and data associated with the access to be loaded into the REAR, RESR, REMR, REAT and REDR registers, and the appropriate flag (R1BC or RNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 158. RAM ECC Address register (REAR) Table 155. REAR field descriptions | Name | Description | | |------------|-------------------------------------------------------------------------------------------------------|--| | 0-31 | RAM ECC Address Register | | | REAR[31:0] | This 32-bit register contains the faulting access address of the last properly enabled RAM ECC event. | | #### 15.4.2.18 RAM ECC Syndrome Register (RESR) The RESR is an 8-bit register for capturing the error syndrome of the last properly enabled ECC event in the RAM memory. Depending on the state of the ECC Configuration Register, an ECC event in the RAM causes the address, attributes and data associated with the access to be loaded into the REAR, RESR, REMR, REAT and REDR registers, and the appropriate flag (R1BC or RNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 159. RAM ECC Syndrome Register (RESR) Table 156. RESR field descriptions | Name | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-7<br>RESR[7:0] | RAM ECC Syndrome Register This 8-bit syndrome field includes 6 bits of Hamming decoded parity plus an odd-parity bit for the entire 39-bit (32-bit data + 7 ECC) code word. The upper 7 bits of the syndrome specify the exact bit position in error for single-bit correctable codewords, and the combination of a non-zero 7-bit syndrome plus overall incorrect parity bit signal a multi-bit, non-correctable error. For correctable single-bit errors, the mapping shown in <i>Table 157</i> associates the upper 7 bits of the syndrome with the data bit in error. | Note: Table 157 associates the upper 7 bits of the ECC syndrome with the exact data bit in error for single-bit correctable codewords. This table follows the bit vectoring notation where the LSB=0. Note that the syndrome value of 0x0001 implies no error condition but this value is not readable when the PRESR is read for the no error case. Table 157. RAM syndrome mapping for single-bit correctable errors | RESR[7:0] | Data Bit in Error | |-----------|-------------------| | 0x00 | ECC ODD[0] | | 0x01 | No Error | | 0x02 | ECC ODD[1] | | 0x04 | ECC ODD[2] | Table 157. RAM syndrome mapping for single-bit correctable errors(Continued) | RESR[7:0] | Data Bit in Error | |-----------|-------------------| | 0x06 | DATA ODD BANK[31] | | 0x08 | ECC ODD[3] | | 0x01 | ECC ODD[0] | | 0x02 | ECC ODD[1] | | 0x04 | ECC ODD[2] | | 0x07 | DATA ODD BANK[31] | | 0x08 | ECC ODD[3] | | 0x10 | ECC ODD[4] | | 0x20 | ECC ODD[5] | | 0x40 | ECC ODD[6] | | 0x43 | DATA ODD BANK[0] | | 0x45 | DATA ODD BANK[1] | | 0x46 | DATA ODD BANK[2] | | 0x49 | DATA ODD BANK[3] | | 0x4a | DATA ODD BANK[4] | | 0x4c | DATA ODD BANK[5] | | 0x4f | DATA ODD BANK[21] | | 0x51 | DATA ODD BANK[6] | | 0x52 | DATA ODD BANK[7] | | 0x54 | DATA ODD BANK[8] | | 0x57 | DATA ODD BANK[22] | | 0x58 | DATA ODD BANK[9] | | 0x5b | DATA ODD BANK[23] | | 0x5d | DATA ODD BANK[24] | | 0x5e | DATA ODD BANK[25] | | 0x61 | DATA ODD BANK[10] | | 0x62 | DATA ODD BANK[11] | | 0x64 | DATA ODD BANK[12] | | 0x67 | DATA ODD BANK[26] | | 0x68 | DATA ODD BANK[13] | | 0x6b | DATA ODD BANK[27] | | 0x6d | DATA ODD BANK[28] | | 0x6e | DATA ODD BANK[29] | | 0x70 | DATA ODD BANK[14] | | 0x73 | DATA ODD BANK[15] | | RESR[7:0] | Data Bit in Error | |---------------|--------------------| | 0x75 | DATA ODD BANK[16] | | 0x76 | DATA ODD BANK[17] | | 0x79 | DATA ODD BANK[18] | | 0x7a | DATA ODD BANK[19] | | 0x7c | DATA ODD BANK[20] | | 0x7f | DATA ODD BANK[30] | | 0x03,0x050x4D | Multiple bit error | | > 0x4D | Multiple bit error | Table 157. RAM syndrome mapping for single-bit correctable errors(Continued) #### 15.4.2.19 RAM ECC Master Number Register (REMR) The REMR is an 8-bit register in which the 4-bit field REMR[0:3] is used for capturing the XBAR bus master number of the last properly enabled ECC event in the RAM memory. Depending on the state of the ECC Configuration Register, an ECC event in the RAM causes the address, attributes and data associated with the access to be loaded into the REAR, RESR, REMR, REAT and REDR registers, and the appropriate flag (R1BC or RNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 160. RAM ECC Master Number register (REMR) Table 158. REMR field descriptions | Name | Description | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 4-7<br>REMR[3:0] | RAM ECC Master Number Register This 4-bit field contains the XBAR bus master number of the faulting access of the last properly enabled RAM ECC event. | #### 15.4.2.20 RAM ECC Attributes (REAT) register The REAT is an 8-bit register for capturing the XBAR bus master attributes of the last properly enabled ECC event in the RAM memory. Depending on the state of the ECC Configuration Register, an ECC event in the RAM causes the address, attributes and data associated with the access to be loaded into the REAR, RESR, REMR, REAT and REDR registers, and the appropriate flag (R1BC or RNCE) in the ECC Status Register to be asserted. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 161. RAM ECC Attributes (REAT) register Table 159. REAT field descriptions | Namo | Name Description | | | |--------------------|------------------------------------------------------------------------------------------------------------------|--|--| | INAIIIC | ρεοσιβίου | | | | 0<br>WRITE | AMBA-AHB HWRITE 0 AMBA-AHB read access 1 AMBA-AHB write access | | | | 1-3<br>SIZE[2:0] | AMBA-AHB HSIZE[2:0] 000 8-bit AMBA-AHB access 001 16-bit AMBA-AHB access 010 32-bit AMBA-AHB access 1xx Reserved | | | | 4<br>PROTECTION[3] | AMBA-AHB HPROT[3] Protection[0]: Type 0 I-Fetch 1 Data | | | | 5<br>PROTECTION[2] | AMBA-AHB HPROT[2] Protection[1]: Mode 0 User mode 1 Supervisor mode | | | | 6<br>PROTECTION[1] | AMBA-AHB HPROT[1] Protection[2]: Bufferable 0 Non-bufferable 1 Bufferable | | | | 7<br>PROTECTION[0] | AMBA-AHB HPROT[0] Protection[3]: Cacheable 0 Non-cacheable 1 Cacheable | | | #### 15.4.2.21 RAM ECC Data Register (REDR) The REDR is a 32-bit register for capturing the data associated with the last properly enabled ECC event in the RAM memory. Depending on the state of the ECC Configuration Register, an ECC event in the RAM causes the address, attributes and data associated with the access to be loaded into the REAR, RESR, REMR, REAT and REDR registers, and the appropriate flag (R1BC or RNCE) in the ECC Status Register to be asserted. The data captured on a multi-bit non-correctable ECC error is undefined. This register can only be read from the IPS programming model; any attempted write is ignored. Figure 162. RAM ECC Data Register (REDR) Table 160. REDR field descriptions | Name | Description | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-31<br>REDR[31:0] | RAM ECC Data Register This 32-bit register contains the data associated with the faulting access of the last properly enabled RAM ECC event. The register contains the data value taken directly from the data bus. | # 16 Internal Static RAM (SRAM) ### 16.1 Introduction The general-purpose SRAM has a size of 80 KB. The first SRAM block (48 KB) is connected to SRAMC\_0 (SRAM controller 0) and the second SRAM block (32 KB) is connected to SRAMC\_1 (SRAM controller 1). The SRAM provides the following features: - SRAM can be read/written from any bus master - Byte, halfword, word and doubleword addressable - Single-bit correction and double-bit error detection # 16.2 SRAM operating mode The SRAM has only one operating mode. No standby mode is available. Table 161. SRAM operating modes | Mode | Configuration | |---------------------|---------------------------------| | Normal (functional) | Allows reads and writes of SRAM | # 16.3 Module memory map The SRAM occupies up to 80 KB of address space. Table 162 shows the SRAM memory map. Table 162. SRAM memory map | Address | SPC56xP60x | SPC56xP54x | |--------------------|------------|------------| | 0x4000_0000 (Base) | 48 KB RAM | 40 KB RAM | | 0x5000_0000 (Base) | 32 KB RAM | 24 KB RAM | # 16.4 Register descriptions The SRAM has no registers. Registers associated with the ECC are located in the ECSM. See *Section 15.4.2.9: ECC registers*. ### 16.5 SRAM ECC mechanism The SRAM ECC detects the following conditions and produces the following results: - Detects and corrects all 1-bit errors - Detects and flags all 2-bit errors as non-correctable errors - Detects 39-bit reads (32-bit data bus plus the 7-bit ECC) that return all zeros or all ones, asserts an error indicator on the bus cycle, and sets the error flag SRAM does not detect all errors greater than 2 bits. Internal SRAM write operations are performed on the following byte boundaries: - 1 byte (0:7 bits) - 2 bytes (0:15 bits) - 4 bytes or 1 word (0:31 bits) If the entire 32 data bits are written to SRAM, no read operation is performed and the ECC is calculated across the 32-bit data bus. The 8-bit ECC is appended to the data segment and written to SRAM. If the write operation is less than the entire 32-bit data width (1 or 2-byte segment), the following occurs: - 1. The ECC mechanism checks the entire 32-bit data bus for errors, detecting and either correcting or flagging errors. - 2. The write data bytes (1 or 2-byte segment) are merged with the corrected 32 bits on the data bus. - 3. The ECC is then calculated on the resulting 32 bits formed in the previous step. - 4. The 7-bit ECC result is appended to the 32 bits from the data bus, and the 39-bit value is then written to SRAM. # 16.5.1 Access timing The system bus is a two-stage pipelined bus that makes the timing of any access dependent on the access during the previous clock. *Table 163* lists the various combinations of read and write operations to SRAM and the number of wait states used for the each operation. The table columns contain the following information: - Current operation—Lists the type of SRAM operation currently executing - Previous operation—Lists the valid types of SRAM operations that can precede the current SRAM operation (valid operation during the preceding clock) - Wait states—Lists the number of wait states (bus clocks) the operation requires, which depends on the combination of the current and previous operation | Operation type | Current operation | Previous operation | Number of wait states required | | |----------------|-------------------|---------------------|-----------------------------------|--| | Operation type | Current operation | Previous operation | Number of wait states required | | | | Read | Idle | 1 | | | | | Pipelined read | | | | Read | | 816 or 32-bit write | 0 (read from the same address) | | | | | | 1 (read from a different address) | | | | Pinelined read | Read | 0 | | Table 163. Number of wait states required for SRAM operations | Operation type | Current operation | Previous operation | Number of wait states required | | |----------------|---------------------------------|------------------------------|--------------------------------|--| | | 8 or 16-bit write | Idle | 1 | | | | | Read | | | | | | Pipelined 8- or 16-bit write | 2 | | | Write | | 32-bit write | 2 | | | | | 8 or 16-bit write | 0 (write to the same address) | | | | Pipelined 8, 16 or 32-bit write | 816 or 32-bit write | 0 | | | | | Idle | | | | | 32-bit write | 32-bit write | 0 | | | | | Read | | | Table 163. Number of wait states required for SRAM operations(Continued) #### 16.5.2 Reset effects on SRAM accesses Asynchronous reset will possibly corrupt RAM if it asserts during a read or write operation to SRAM. The completion of that access depends on the cycle at which the reset occurs. If no access is occurring when reset occurs, RAM corruption does not happen. Instead synchronous reset (SW reset) should be used in controlled function (without RAM accesses) in case initialization procedure is needed without RAM initialization. # 16.6 Functional description ECC checks are performed during the read portion of an SRAM ECC read/write (R/W) operation, and ECC calculations are performed during the write portion of a R/W operation. Because the ECC bits can contain random data after the device is powered on, the SRAM must be initialized by executing 32-bit write operations prior any read accesses. This is also true for implicit read accesses caused by any write accesses smaller than 32 bits as discussed in Section 16.5: SRAM ECC mechanism. # 16.7 Initialization and application information To use the SRAM, the ECC must check all bits that require initialization after power on. All writes must specify an even number of registers performed on 32-bit word-aligned boundaries. If the write is not the entire 32-bits (8 or 16 bits), a read/modify/write operation is generated that checks the ECC value upon the read. Refer to Section 16.5: SRAM ECC mechanism. Note: You must initialize SRAM, even if the application does not use ECC reporting. Flash Memory RM0083 # 17 Flash Memory # 17.1 Introduction The Flash memory comprises a platform Flash controller interface and two Flash memory arrays: two arrays of 512 KB for code (code Flash) and one array of 64 KB for data (data Flash). The Flash architecture of the SPC56xP60x/54x device is illustrated in *Figure 163*. RM0083 Flash Memory Figure 163. SPC56xP60x/54x Flash memory architecture # 17.2 Platform Flash controller #### 17.2.1 Introduction This section provides an introduction of the platform Flash controller, which acts as the interface between the system bus and as many as three banks of Flash memory arrays RM0083 Flash Memory > (program and data). It intelligently converts the protocols between the system bus and the dedicated Flash array interfaces. Several important terms are used to describe the platform Flash controller module and its connections. These terms are defined here. - Port—This term describes the AMBA-AHB connection(s) into the platform Flash controller. From an architectural and programming model viewpoint, the definition supports as many as two AHB ports, even though this specific controller only supports a dual AHB connections. - Bank—This term describes the attached Flash memories. From the platform Flash controller's perspective, there may be one or two attached banks of Flash memory. The code Flash bank is required and always attached to bank0. Additionally, there is a data Flash attached to bank1. The platform Flash controller interface supports two separate connections, one to each memory bank. On the SPC56xP60x/54x device, bank0 and bank1 are internal to the device. - **Array**—Each memory bank has one Flash array instantiation. - Page—This value defines the number of bits read from the Flash array in a single access. For this controller and memory, the page size is 128 bits (16 bytes). The nomenclature "page buffers" and "line buffers" are used interchangeably. #### 17.2.1.1 Overview The platform Flash controller supports a 32-bit data bus width at the two AHB port and connections to 128-bit read data interfaces from two memory banks, where each bank contains one instantiation of the Flash memory array. One Flash bank is connected to the code Flash memory and the other bank is connected to the data Flash memory. The memory controller capabilities vary between the two banks with each bank's functionality optimized with the typical use cases associated with the attached Flash memory. As an example, the platform Flash controller logic associated with the code Flash bank contains 2 four-entry "page" buffer, one for each AHB input port, each buffer entry containing 128 bits of data (1 Flash page) plus an associated controller that prefetches sequential lines of data from the Flash array into the buffer, while the controller logic associated with the data Flash bank only supports two 128-bit register (again, one for each AHB port) that serves as a temporary page holding register and does not support any prefetching. Prefetch buffer hits from the code Flash bank support 0-wait AHB data phase responses. AHB read requests that miss the buffers generate the needed Flash array access and are forwarded to the AHB upon completion, typically incurring two wait states at an operating frequency of 60 to 64 MHz. This memory controller is optimized for applications where a cacheless processor core, for example the Power e200z0h, is connected through the platform to on-chip memories, for example Flash and RAM, where the processor and platform operate at the same frequency. For these applications, the 2-stage pipeline AMBA-AHB system bus is effectively mapped directly into stages of the processor's pipeline and 0 wait state responses for most memory accesses are critical for providing the required level of system performance. RM0083 Flash Memory #### 17.2.1.2 Features The following list summarizes the key features of the platform Flash controller: Dual AHB port interfaces support a 32-bit data bus. All AHB aligned and unaligned reads within the 32-bit container are supported. Only aligned word writes are supported. - Array interfaces support a 128-bit read data bus and a 64-bit write data bus for each bank. - Each AHB input port provides configurable read buffering and page prefetch support for code Flash (bank0). Each AHB input port includes four page read buffers (each 128 bits wide) and a prefetch controller support single-cycle read responses (0 AHB data phase wait states) for hits in the buffers. The buffers implement a least-recently-used replacement algorithm to maximize performance. - Each AHB input port interfaces with data Flash (bank1) includes a 128-bit register to temporarily hold a single Flash page. This logic supports single-cycle read responses (0 AHB data phase wait states) for accesses that hit in the holding register. There is no support for prefetching associated with bank1. - Programmable response for read-while-write sequences including support for stallwhile-write, optional stall notification interrupt, optional Flash operation termination, and optional termination notification interrupt - Separate and independent configurable access timing (on a per bank basis) to support use across a wide range of platforms and frequencies - Support of address-based read access timing for emulation of other memory types - Support for reporting of single- and multi-bit Flash ECC events - Typical operating configuration loaded into programming model by system reset # 17.2.2 Modes of operation The platform Flash controller module does not support any special modes of operation. Its operation is driven from the AMBA-AHB memory references it receives from the platform's bus masters. Its configuration is defined by the setting of the programming model registers, physically located as part of the Flash array modules. # 17.2.3 External signal descriptions The platform Flash controller does not directly interface with any external signals. Its primary internal interfaces include a connection to an AMBA-AHB crossbar (or memory protection unit) slave port and connections with as many as two banks (code and data) of Flash memory, each containing one instantiation of the Flash array. Additionally, the operating configuration for the platform Flash controller is defined by the contents of certain code Flash array0 registers that are inputs to the module. # 17.2.4 Memory map and registers description Two memory maps are associated with the platform Flash controller: one for the Flash memory space and another for the program-visible control and configuration registers. The Flash memory space is accessed via the AMBA-AHB port. The program-visible registers are accessed via the slave peripheral bus. Details on both memory spaces are provided in Section 17.2.4.1: Memory map. Flash Memory RM0083 There are no program-visible registers that physically reside inside the platform Flash controller. Rather, the platform Flash controller receives control and configuration information from the Flash array controller(s) to determine the operating configuration. These are part of the Flash array's configuration registers mapped into its slave peripheral (IPS) address space but are described here. Note: Updating the configuration fields that control the platform flash controller behavior should only occur while the flash controller is idle. Changing configuration settings while a flash access is in progress can lead to non-deterministic behavior. # 17.2.4.1 Memory map First, consider the Flash memory space accessed via transactions from the platform Flash controller's AHB port. To support the two separate Flash memory banks, the platform Flash controller uses address bit 23 (haddr[23]) to steer the access to the appropriate memory bank. In addition to the actual Flash memory regions, there are shadow and test sectors included in the system memory map. The program-visible control and configuration registers associated with each memory array are included in the slave peripheral address region. The system memory map defines one code Flash array and one data Flash array. See *Table 164*. Caution: Software executing from flash memory must not write to registers that control flash behavior (such as wait state settings or prefetch enable/disable). Doing so can cause data corruption. On this chip, these registers include PFCR0 and PFAPR. Note: Flash memory configuration registers should be written only with 32-bit write operations to avoid any issues associated with register incoherency caused by bit fields spanning smaller size (8-, 16-bit) boundaries. Table 164. Flash-related regions in the system memory map | Start address | End address | Size<br>(KB) | Region | |---------------|-------------|--------------|-------------------------------------------------| | 0x0000_0000 | 0x0007_FFFF | 512 | Code Flash array 0 | | 0x0008_0000 | 0x000F_FFFF | 512 | Code Flash array 1 | | 0x0010_0000 | 0x001F_FFFF | 1024 | Reserved | | 0x0020_0000 | 0x0020_3FFF | 16 | Code Flash array 0: shadow sector | | 0x0020_4000 | 0x003F_FFFF | 2032 | Reserved | | 0x0040_0000 | 0x0040_3FFF | 16 | Code Flash array 0: test sector | | 0x0040_4000 | 0x007F_FFFF | 4080 | Reserved | | 0x0080_0000 | 0x0080_FFFF | 64 | Data Flash array 0 | | 0x0081_0000 | 0x00C0_1FFF | 4040 | Reserved | | 0x00C0_2000 | 0x00C0_3FFF | 8 | Data Flash array 0: test sector | | 0x00C0_4000 | 0x00FF_FFFF | 4080 | Reserved | | 0x0100_0000 | 0x1FFF_FFFF | 507904 | Emulation Mapping | | 0xFFE8_8000 | 0xFFE8_BFFF | 16 | Code Flash array 0 configuration <sup>(1)</sup> | | 0xFFE8_C000 | 0xFFE8_FFFF | 16 | Data Flash array 0 configuration <sup>(1)</sup> | | 0xFFEB_0000 | 0xFFEB_BFFF | 48 | Reserved | <sup>1.</sup> This region is also aliased to address 0xC3F8\_nnnn. RM0083 Flash Memory For additional information on the address-based read access timing for emulation of other memory types, see *Section 17.2.17: Wait state emulation*. Next, consider the memory map associated with the control and configuration registers. There are multiple registers that control operation of the platform Flash controller. Note the first two Flash array registers (PFCR0, PFCR1) are reset to a device-defined value, while the remaining register (PFAPR) is loaded at reset from specific locations in the array's shadow region. Regardless of the number of populated banks or the number of Flash arrays included in a given bank, the configuration of the platform Flash controller is wholly specified by the platform Flash controller control registers associated with code Flash array0. The code array0 register settings define the operating behavior of **both** Flash banks. It is recommended to set the platform Flash controller control registers for both arrays to the array0 values. Note: To perform program and erase operations, the control registers in the actual referenced Flash array must both be programmed, but the configuration of the platform Flash controller module is defined by the platform Flash controller control registers of code array0. The 32-bit memory map for the platform Flash controller control registers is shown in *Table 165*. | Offset from PFlash_BASE (0xFFE8_8000) | Register | Location | |---------------------------------------|---------------------------------------------------|-------------| | 0x001C | Platform Flash Configuration Register 0 (PFCR0) | on page 402 | | 0x0020 | Platform Flash Configuration Register 1 (PFCR1) | on page 407 | | 0x0024 | Platform Flash Access Protection Register (PFAPR) | on page 410 | Table 165. Platform Flash controller 32-bit memory map # 17.2.5 Functional description The platform Flash controller interfaces between the AHB-Lite 2.v6 system bus and the Flash memory arrays. The platform Flash controller generates read and write enables, the Flash array address, write size, and write data as inputs to the Flash array. The platform Flash controller captures read data from the Flash array interface and drives it onto the AHB. As much as four pages of data (128-bit width) from bank0 are buffered by the platform Flash controller. Lines may be prefetched in advance of being requested by the AHB interface, allowing single-cycle (0 AHB wait states) read data responses on buffer hits. Several prefetch control algorithms are available for controlling page read buffer fills. Prefetch triggering may be restricted to instruction accesses only, data accesses only, or may be unrestricted. Prefetch triggering may also be controlled on a per-master basis. Buffers may also be selectively enabled or disabled for allocation by instruction and data prefetch. Access protections may be applied on a per-master basis for both reads and writes to support security and privilege mechanisms. Flash Memory RM0083 Throughout this discussion, $bkn_i$ is used as a prefix to refer to two signals, each for each bank: $bk0_i$ and $bk1_i$ . Also, the nomenclature $Bx_i Py_i$ RegName is used to reference a program-visible register field associated with bank "x" and port "y". ### 17.2.6 Basic interface protocol The platform Flash controller interfaces to the Flash array by driving addresses (bkn\_fl\_addr[23:0]) and read or write enable signals (bkn\_fl\_rd\_en, bkn\_fl\_wr\_en). The read or write enable signal (bkn\_fl\_rd\_en, bkn\_fl\_wr\_en) is asserted in conjunction with the reference address for a single rising clock when a new access request is made. Addresses are driven to the Flash array in a flow-through fashion to minimize array access time. When no outstanding access is in progress, the platform Flash controller drives addresses and asserts bk*n*\_fl\_rd\_en or bk*n*\_fl\_wr\_en and then may change to the next outstanding address in the next cycle. Accesses are terminated under control of the appropriate read/write wait state control setting. Thus, the access time of the operation is determined by the settings of the wait state control fields. Access timing can be varied to account for the operating conditions of the device (frequency, voltage, temperature) by appropriately setting the fields in the programming model for either bank. The platform Flash controller also has the capability of extending the normal AHB access time by inserting additional wait states for reads and writes. This capability is provided to allow emulation of other memories that have different access time characteristics. The added wait state specifications are provided by bit 28 to bit 24 of Flash address (haddr[28:24], see *Table 167* and *Table 168*). These wait states are applied in addition to the normal wait states incurred for Flash accesses. Refer to *Section 17.2.17: Wait state emulation* for more details. Prefetching of next sequential page is blocked when haddr[28:24] is non-zero. Buffer hits are also blocked as well, regardless of whether the access corresponds to valid data in one of the page read buffers. These steps are taken to ensure that timing emulation is correct and that excessive prefetching is avoided. In addition, to prevent erroneous operation in certain rare cases, the buffers are invalidated on any non-sequential AHB access with a non-zero value on haddr[28:24]. # 17.2.7 Access protections The platform Flash controller provides programmable configurable access protections for both read and write cycles from masters via the Platform Flash Access Protection Register (PFAPR). It allows restriction of read and write requests on a per-master basis. This functionality is described in *Section 17.3.7.10.3: Platform Flash Access Protection Register (PFAPR)*. Detection of a protection violation results in an error response from the platform Flash controller on the AHB transfer. # 17.2.8 Read cycles — buffer miss Read cycles from the Flash array are initiated by driving a valid access address on $bkn_fl_addr[23:0]$ and asserting $bkn_fl_rd_en$ for the required setup (and hold) time before (and after) the rising edge of hclk. The platform Flash controller then waits for the programmed number of read wait states before sampling the read data on $bkn_fl_rdata[127:0]$ . This data is normally stored in the least-recently updated page read buffer for bank0 in parallel with the requested data being forwarded to the AHB. For bank1, the data is captured in the page-wide temporary holding register as the requested data is forwarded to the AHB bus. Timing diagrams of basic read accesses from the Flash array are shown in *Figure 164* through *Figure 167*. If the Flash access was the direct result of an AHB transaction, the page buffer is marked as most-recently-used as it is being loaded. If the Flash access was the result of a speculative prefetch to the next sequential line, it is first loaded into the least-recently-used buffer. The status of this buffer is not changed to most-recently-used until a subsequent buffer hit occurs. # 17.2.9 Read cycles — buffer hit Single cycle read responses to the AHB are possible with the platform Flash controller when the requested read access was previously loaded into one of the bank0 page buffers. In these "buffer hit" cases, read data is returned to the AHB data phase with a 0 wait state response. Likewise, the bank1 logic includes a single 128-bit temporary holding register and sequential accesses that "hit" in this register are also serviced with a 0 wait state response. # 17.2.10 Write cycles In a write cycle, address, write data, and control signals are launched off the same edge of hclk at the completion of the first AHB data phase cycle. Write cycles to the Flash array are initiated by driving a valid access address on $bkn_fl_addr[23:0]$ , driving write data on $bkn_fl_wdata[63:0]$ , and asserting $bkn_fl_wr_en$ . Again, the controller drives the address and control information for the required setup time before the rising edge of hclk, and provides the required amount of hold time. The platform Flash controller then waits for the appropriate number of write wait states before terminating the write operation. On the cycle following the programmed wait state value, the platform Flash controller asserts hready\_out to indicate to the AHB port that the cycle has terminated. #### 17.2.11 Error termination The platform Flash controller follows the standard procedure when an AHB bus cycle is terminated with an ERROR response. First, the platform Flash controller asserts hresp[0] and negates hready\_out to signal an error has occurred. On the following clock cycle, the platform Flash controller asserts hready\_out and holds both hresp[0] and hready\_out asserted until hready\_in is asserted. The first case that can cause an error response to the AHB is when an access is attempted by an AHB master whose corresponding Read Access Control or Write Access Control settings do not allow the access, thus causing a protection violation. In this case, the platform Flash controller does not initiate a Flash array access. The second case that can cause an error response to the AHB is when an access is performed to the Flash array and is terminated with a Flash error response. See Section 17.2.13: Flash error response operation. This may occur for either a read or a write operation. The third case that can cause an error response to the AHB is when a write access is attempted to the Flash array and is disallowed by the state of the bkn\_fl\_ary\_access control input. This case is similar to case 1. A fourth case involves an attempted read access while the Flash array is busy doing a write (program) or erase operation if the appropriate read-while-write control field is programmed for this response. The 3-bit read-while-write control allows for immediate termination of an attempted read, or various stall-while-write/erase operations are occurring. The platform Flash controller can also terminate the current AHB access if hready\_in is asserted before the end of the current bus access. While this circumstance should not occur, this does not result in an error condition being reported, as this behavior is initiated by the AHB. In this circumstance, the platform Flash controller control state machine completes any Flash array access in progress (without signaling the AHB) before handling a new access request. # 17.2.12 Access pipelining The platform Flash controller does not support access pipelining since this capability is not supported by the Flash array. As a result, the APC (Address Pipelining Control) field should typically be the same value as the RWSC (Read Wait State Control) field for best performance, that is, BKn APC = BKn RWSC. It cannot be less than the RWSC. ## 17.2.13 Flash error response operation The Flash array may signal an error response by asserting bkn\_fl\_xfr\_err to terminate a requested access with an error. This may occur due to an uncorrectable ECC error, or because of improper sequencing during program/erase operations. When an error response is received, the platform Flash controller does not update or validate a bank0 page read buffer nor the bank1 temporary holding register. An error response may be signaled on read or write operations. For more information on the specifics related to signaling of errors, including Flash ECC, refer to subsequent sections in this chapter. For additional information on the system registers that capture the faulting address, attributes, data and ECC information, see *Chapter 15: Error Correction Status Module (ECSM)*. # 17.2.14 Bank0 page read buffers and prefetch operation The logic associated with bank0 of the platform Flash controller contains four 128-bit page read buffers that hold data read from the Flash array. Each buffer operates independently, and is filled using a single array access. The buffers are used for both prefetch and normal demand fetches. The organization of each page buffer is described as follows in a pseudo-code representation. The hardware structure includes the buffer address and valid bit, along with 128 bits of page read data and several error flags. ``` struct {// bk0_page_buffer regaddr[23:4];// page address regvalid;// valid bit regrdata[127:0];// page read data regxfr_error;// transfer error indicator from Flash array regmulti_ecc_error;// multi-bit ECC error indicator from Flash array regsingle_ecc_error;// single-bit correctable ECC indicator from Flash array } bk0_page_buffer[4]; ``` For the general case, a page buffer is written at the completion of an error-free Flash access and the valid bit asserted. Subsequent Flash accesses that "hit" the buffer, that is, the current access address matches the address stored in the buffer, can be serviced in 0 AHB wait states as the stored read data is routed from the given page buffer back to the requesting bus master. As noted in Section 17.2.13: Flash error response operation a page buffer is not marked as valid if the Flash array access terminated with any type of transfer error. However, the result is that Flash array accesses that are tagged with a single-bit correctable ECC event are loaded into the page buffer and validated. For additional comments on this topic, see Section 17.2.14.4: Buffer invalidation. Prefetch triggering is controllable on a per-master and access-type basis. Bus masters may be enabled or disabled from triggering prefetches, and triggering may be further restricted based on whether a read access is for instruction or data. A read access to the platform Flash controller may trigger a prefetch to the next sequential page of array data on the first idle cycle following the request. The access address is incremented to the next-higher 16-byte boundary, and a Flash array prefetch is initiated if the data is not already resident in a page buffer. Prefetched data is always loaded into the least-recently-used buffer. Buffers may be in one of six states, listed here in prioritized order: - Invalid—the buffer contains no valid data. - 2. Used—the buffer contains valid data that has been provided to satisfy an AHB burst type read. - 3. Valid—the buffer contains valid data that has been provided to satisfy an AHB single type read. - Prefetched—the buffer contains valid data that has been prefetched to satisfy a potential future AHB access. - 5. Busy AHB—the buffer is currently being used to satisfy an AHB burst read. - 6. Busy Fill—the buffer has been allocated to receive data from the Flash array, and the array access is still in progress. Selection of a buffer to be loaded on a miss is based on the following replacement algorithm: - First, the buffers are examined to determine if there are any invalid buffers. If there are multiple invalid buffers, the one to be used is selected using a simple numeric priority, where buffer 0 is selected first, then buffer 1, etc. - 2. If there are no invalid buffers, the least-recently-used buffer is selected for replacement. Once the candidate page buffer has been selected, the Flash array is accessed and read data loaded into the buffer. If the buffer load was in response to a miss, the just-loaded buffer is immediately marked as most-recently-used. If the buffer load was in response to a speculative fetch to the next-sequential line address after a buffer hit, the recently-used status is not changed. Rather, it is marked as most-recently-used only after a subsequent buffer hit. This policy maximizes performance based on reference patterns of Flash accesses and allows for prefetched data to remain valid when non-prefetch enabled bus masters are granted Flash access. Several algorithms are available for prefetch control that trade off performance versus power. They are defined by the Bx\_Py\_PFLM (prefetch limit) register field. More aggressive prefetching increases power slightly due to the number of wasted (discarded) prefetches, but may increase performance by lowering average read latency. > In order for prefetching to occur, a number of control bits must be enabled. Specifically, the global buffer enable (Bx\_Py\_BFE) must be set, the prefetch limit (Bx\_Py\_PFLM) must be non-zero and either instruction prefetching (Bx\_Py\_IPFE) or data prefetching (Bx Py DPFE) enabled. Refer to Section 17.3.6: Registers description for a description of these control fields. ### 17.2.14.1 Instruction/data prefetch triggering Prefetch triggering may be enabled for instruction reads via the Bx Py IPFE control field, while prefetching for data reads is enabled via the Bx\_Py\_DPFE control field. Additionally, the Bx\_Py\_PFLIM field must also be set to enable prefetching. Prefetches are never triggered by write cycles. #### 17.2.14.2 Per-master prefetch triggering Prefetch triggering may be also controlled for individual bus masters. AHB accesses indicate the requesting master via the hmaster[3:0] inputs. Refer to Section 17.3.7.10.3: Platform Flash Access Protection Register (PFAPR) for details on these controls. #### 17.2.14.3 **Buffer allocation** Allocation of the line read buffers is controlled via page buffer configuration (Bx Py BCFG) field. This field defines the operating organization of the four page buffers. The buffers can be organized as a "pool" of available resources (with all four buffers in the pool) or with a fixed partition between buffers allocated to instruction or data accesses. For the fixed partition, two configurations are supported. In one configuration, buffers 0 and 1 are allocated for instruction fetches and buffers 2 and 3 for data accesses. In the second configuration, buffers 0, 1, and 2 are allocated for instruction fetches and buffer 3 reserved for data accesses. #### 17.2.14.4 Buffer invalidation The page read buffers may be invalidated under hardware or software control. Any falling edge transition of the array's $bkn_fl_o$ done signal causes the page read buffers to be marked as invalid. This input is negated by the Flash array at the beginning of all program/erase operations as well as in certain other cases. Buffer invalidation occurs at the next AHB non-sequential access boundary, but does not affect a burst from a page read buffer in progress. Software may invalidate the buffers by clearing the Bx Py BFE bit, which also disables the buffers. Software may then re-assert the Bx\_Py\_BFE bit to its previous state, and the buffers will have been invalidated. One special case needing software invalidation relates to page buffer "hits" on Flash data that was tagged with a single-bit ECC event on the original array access. Recall that the page buffer structure includes an status bit signaling the array access detected and corrected a single-bit ECC error. On all subsequent buffer hits to this type of page data, a single-bit ECC event is signaled by the platform Flash controller. Depending on the specific hardware configuration, this reporting of a single-bit ECC event may generate an ECC alert interrupt. In order to prevent repeated ECC alert interrupts, the page buffers need to be invalidated by software after the first notification of the single-bit ECC event. Finally, the buffers are invalidated by hardware on any non-sequential access with a nonzero value on haddr[28:24] to support wait state emulation. ## 17.2.15 Bank1 temporary holding register Recall the bank1 logic within the Flash includes a single 128-bit data register, used for capturing read data. Since this bank does not support prefetching, the read data for the referenced address is bypassed directly back to the AHB data bus. The page is also loaded into the temporary data register and subsequent accesses to this page can hit from this register, if it is enabled (B1 Py BFE). The organization of the temporary holding register is described as follows, in a pseudo-code representation. The hardware structure includes the buffer address and valid bit, along with 128 bits of page read data and several error flags and is the same as an individual bank0 page buffer. ``` struct {// bk1_page_buffer regaddr[23:4];// page address regvalid;// valid bit regrdata[127:0];// page read data regxfr_error;// transfer error indicator from Flash array regmulti_ecc_error;// multi-bit ECC error indicator from Flash array regsingle_ecc_error;// single-bit correctable ECC indicator from Flash array } bk1 page buffer; ``` For the general case, a temporary holding register is written at the completion of an error-free Flash access and the valid bit asserted. Subsequent Flash accesses that "hit" the buffer, that is, the current access address matches the address stored in the temporary holding register, can be serviced in 0 AHB wait states as the stored read data is routed from the temporary register back to the requesting bus master. The contents of the holding register are invalidated by the falling edge transition of bk1\_fl\_done and on any non-sequential access with a non-zero value on haddr[28:24] (to support wait state emulation) in the same manner as the bank0 page buffers. Additionally, the B1\_Py\_BFE register bit can be cleared by software to invalidate the contents of the holding register. As noted in Section 17.2.13: Flash error response operation the temporary holding register is not marked as valid if the Flash array access terminated with any type of transfer error. However, the result is that Flash array accesses that are tagged with a single-bit correctable ECC event are loaded into the temporary holding register and validated. Accordingly, one special case needing software invalidation relates to holding register "hits" on Flash data that was tagged with a single-bit ECC event. Depending on the specific hardware configuration, the reporting of a single-bit ECC event may generate an ECC alert interrupt. In order to prevent repeated ECC alert interrupts, the page buffers need to be invalidated by software after the first notification of the single-bit ECC event. The bank1 temporary holding register effectively operates like a single page buffer. ### 17.2.16 Read-While-Write functionality The platform Flash controller supports various programmable responses for read accesses while the Flash is busy performing a write (program) or erase operation. For all situations, the platform Flash controller uses the state of the Flash array's $bkn_fl_done$ output to determine if it is busy performing some type of high-voltage operation, namely, if $bkn_fl_done = 0$ , the array is busy. Specifically, there are two 3-bit read-while-write (BKn\_RWWC) control register fields that define the platform Flash controller's response to these types of access sequences. There are five unique responses that are defined by the BKn\_RWWC setting: one immediately reports an error on an attempted read, and four settings that support various stall-while-write capabilities. Consider the details of these settings. - BKn\_RWWC = 0b0xx - For this mode, any attempted Flash read to a busy array is immediately terminated with an AHB error response and the read is blocked in the controller and not seen by the Flash array. - BKn RWWC = 0b111 - This defines the basic stall-while-write capability and represents the default reset setting. For this mode, the platform Flash controller module stalls any read reference until the Flash has completed its program/erase operation. If a read access arrives while the array is busy or if a falling-edge on bkn\_fl\_done occurs while a read is still in progress, the AHB data phase is stalled by negating hready\_out and saving the address and attributes into holding registers. Once the array has completed its program/erase operation, the platform Flash controller uses the saved address and attribute information to create a pseudo address phase cycle to "retry" the read reference and sends the registered information to the array as bkn\_fl\_rd\_en is asserted. Once the retried address phase is complete, the read is processed normally and once the data is valid, it is forwarded to the AHB bus and hready\_out negated to terminate the system bus transfer. - BKn RWWC = 0b110 - This setting is similar to the basic stall-while-write capability provided when BKn\_RWWC = 0b111 with the added ability to generate a notification interrupt if a read arrives while the array is busy with a program/erase operation. There are two notification interrupts, one for each bank. - BKn RWWC = 0b101 - Again, this setting provides the basic stall-while-write capability with the added ability to terminate any program/erase operation if a read access is initiated. For this setting, the read request is captured and retried as described for the basic stall-while-write, plus the program/erase operation is terminated by the platform Flash controller's assertion of the bkc\_fl\_abort signal. The bkn\_fl\_abort signal remains asserted until bkn\_fl\_done is driven high. For this setting, there are no notification interrupts generated. - BK*n*\_RWWC = 0b100 - This setting provides the basic stall-while-write capability with the ability to terminate any program/erase operation if a read access is initiated plus the generation of a termination notification interrupt. For this setting, the read request is captured and retried as described for the basic stall-while-write, the program/erase operation is terminated by the platform Flash controller's assertion of the bkn\_fl\_abort signal and a termination notification interrupt generated. There are two termination notification interrupts, one for each bank. As detailed above, there are a total of four interrupt requests associated with the stall-while-write functionality. These interrupt requests are captured as part of ECSM's Interrupt Register and logically summed together to form a single request to the interrupt controller. | MIR[n] | Interrupt description | |-------------|-----------------------------------------------------------| | ECSM.MIR[7] | Platform Flash bank0 termination notification, MIR[FB0Al] | | ECSM.MIR[6] | Platform Flash bank0 stall notification, MIR[FB0SI] | | ECSM.MIR[5] | Platform Flash bank1 termination notification, MIR[FB1AI] | | ECSM.MIR[4] | Platform Flash bank1 stall notification, MIR[FB1S1] | Table 166. Platform Flash controller stall-while-write interrupts For example timing diagrams of the stall-while-write and terminate-while-write operations, see *Figure 168* and *Figure 169* respectively. #### 17.2.17 Wait state emulation Emulation of other memory array timings are supported by the platform Flash controller on read cycles to the Flash. This functionality may be useful to maintain the access timing for blocks of memory that were used to overlay Flash blocks for the purpose of system calibration or tuning during code development. The platform Flash controller inserts additional wait states according to the values of haddr[28:24], where haddr represents the Flash address. When these inputs are non-zero, additional cycles are added to AHB read cycles. Write cycles are not affected. In addition, no page read buffer prefetches are initiated, and buffer hits are ignored. Table 167 and Table 168 show the relationship of haddr[28:24] to the number of additional primary wait states. These wait states are applied to the initial access of a burst fetch or to single-beat read accesses on the AHB system bus. Note that the wait state specification consists of two components: haddr[28:26] and haddr[25:24] and effectively extends the Flash read by $(8 \times \text{haddr}[25:24] + \text{haddr}[28:26])$ cycles. **Memory address** Additional wait states haddr[28:26] 000 0 1 001 010 2 3 011 4 100 101 5 6 110 111 7 Table 167. Additional wait state encoding *Table 168* shows the relationship of haddr[25:24] to the number of additional wait states. These are applied in addition to those specified by haddr[28:26] and thus extend the total wait state specification capability. | Memory address<br>haddr[25:24] | Additional wait states (added to those specified by haddr[28:26]) | |--------------------------------|-------------------------------------------------------------------| | 00 | 0 | | 01 | 8 | | 10 | 16 | | 11 | 24 | Table 168. Extended additional wait state encoding # 17.2.18 Timing diagrams Since the platform Flash controller is typically used in platform configurations with a cacheless core, the operation of the processor accesses to the platform memories, for example Flash and SRAM, plays a major role in the overall system performance. Given the core/platform pipeline structure, the platform's memory controllers (PFlash, PRAM) are designed to provide a 0 wait state data phase response to maximize processor performance. The following diagrams illustrate operation of various cycle types and responses referenced earlier in this chapter including stall-while-read (*Figure 168*) and terminate-while-read (*Figure 169*) diagrams. Figure 164. 1-cycle access, no buffering, no prefetch Figure 165. 3-cycle access, no prefetch, buffering disabled Figure 166. 3-cycle access, no prefetch, buffering enabled Figure 167. 3-cycle access, prefetch and buffering enabled Figure 168. 3-cycle access, stall-and-retry with $BKn_RWWC = 11x$ As shown in *Figure 168*, the 3-cycle access to address y is interrupted when an operation causes the bkn\_done signal to be negated, signaling that the array bank is busy with a high-voltage program or erase event. Eventually, this array operation completes (at the end of cycle 4) and bkn\_done returns to a logical 1. In cycle 6, the platform Flash controller module retries the read to address y that was interrupted by the negation of bkn\_done in cycle 3. Note that throughout cycles 2–9, the AHB bus pipeline is stalled with a read to address y in the AHB data phase and a read to address y + 4 in the address phase. Depending on the state of the least-significant-bit of the Bkn\_RWWC control field, the hardware may also signal a stall notification interrupt (if Bkn\_RWWC = 110). The stall notification interrupt is shown as the optional assertion of ECSM's MIR[FBnSI] (Flash bank n stall interrupt). Figure 169. 3-cycle access, terminate-and-retry with $BKn_RWWC = 10x$ Figure 169 shows the terminate-while-write timing diagram. In this example, the 3-cycle access to address y is interrupted when an operation causes the bkn\_done signal to be negated, signaling that the array bank is busy with a high-voltage program or erase event. Based on the setting of BKn\_RWWC, once the bkn\_done signal is detected as negated, the platform Flash controller asserts bkn\_abort, which forces the Flash array to cancel the high-voltage program or erase event. The array operation completes (at the end of cycle 4) and bkn\_done returns to a logical 1. It should be noted that the time spent in cycle 4 for Figure 169 is considerably less than the time in the same cycle in Figure 168 (because of the terminate operation). In cycle 6, the platform Flash controller module retries the read to address y that was interrupted by the negation of bkn\_done in cycle 3. Note that throughout cycles 2–9, the AHB bus pipeline is stalled with a read to address y in the AHB data phase and a read to address y+4 in the address phase. Depending on the state of the least-significant-bit of the BKn\_RWWC control field, the hardware may also signal an termination notification interrupt (if BKn\_RWWC = 100). The stall notification interrupt is shown as the optional assertion of ECSM's MIR[FBnAI] (Flash bank n termination interrupt). # 17.3 Flash memory ### 17.3.1 Introduction The Flash module provides electrically programmable and erasable non-volatile memory (NVM), which may be used for instruction and/or data storage. The Flash module is arranged as two functional units: the Flash core and the memory interface. The Flash core is composed of arrayed non-volatile storage elements, sense amplifiers, row decoders, column decoders and charge pumps. The arrayed storage elements in the Flash core are sub-divided into physically separate units referred to as blocks (or sectors). The memory interface contains the registers and logic which control the operation of the Flash core. The memory interface is also the interface between the Flash module and a bus interface unit (BIU), and may contain the ECC logic and redundancy logic. The BIU connects the Flash module to a system bus. The SPC56xP60x/54x provides three Flash modules: two 512 KB code Flash modules, and one 64 KB data module. #### 17.3.2 Main features - High read parallelism (128 bits) - Error Correction Code (SEC-DED) to enhance data retention - Double word program (64 bits) - Sector erase - Single bank architecture - Read-While-Modify not available within an individual module - Read-While-Modify can be performed between the two Flash modules - Erase suspend available (program suspend not available) - Software programmable program/erase protection to avoid unwanted writes - Censored mode against piracy - Shadow Sector available on code Flash module ## 17.3.3 Block diagram #### 17.3.3.1 Data Flash The data Flash module contains one module, composed of a Single Bank: Bank 0, normally used for code storage. No Read-While-Modify operations are possible. The Modify operations are managed by an embedded Flash Program/Erase Controller (FPEC). Commands to the FPEC are given through a user registers interface. The read data bus is 32 bits wide, while the data Flash registers are on a separate 32-bit wide bus. The high voltages needed for Program/Erase operations are internally generated. *Figure 170* shows the data Flash module structure. Figure 170. Data Flash module structure #### 17.3.3.2 Code Flash The code Flash module contains the matrix modules normally used for Code storage. No Read-While-Modify operations are possible. The Modify operations are managed by an embedded Flash Program/Erase Controller (FPEC). Commands to the FPEC are given through a User Registers Interface. The read data bus is $2 \times 128$ bits wide, while the Flash registers are on a separate 32-bit wide bus. The high voltages needed for Program/Erase operations are internally generated. *Figure 171* shows the code Flash module structure. Figure 171. Code Flash module structure # 17.3.4 Functional description #### 17.3.4.1 Macrocell structure The Flash macrocell provides high density non-volatile memories with high-speed read access. The Flash module is addressable by word (32 bits) or double-word (64 bits) for programming, and by page (128 bits) for reads. Reads done to the Flash always return 128 bits, although read page buffering may be done in the platform BIU. Each read of the Flash module retrieves a page, or 4 consecutive words (128 bits) of information. The address for each word retrieved within a page differ from the other addresses in the page only by address bits (3:2). The Flash page read architecture supports both cache and burst mode at the BIU level for high-speed read application. The Flash module supports fault tolerance through Error Correction Code (ECC) and/or error detection. The ECC implemented within the Flash module will correct single bit failures and detect double bit failures. The Flash module uses an embedded hardware algorithm implemented in the memory interface to program and erase the Flash core. Control logic that works with the software block enables, and software lock mechanisms, is included in the embedded hardware algorithm to guard against accidental program/erase. The hardware algorithm perform the steps necessary to ensure that the storage elements are programmed and erased with sufficient margin to guarantee data integrity and reliability. A programmed bit in the Flash module reads as logic level 0 (or low). An erased bit in the Flash module reads as logic level 1 (or high). Program and erase of the Flash module requires multiple system clock cycles to complete. The erase sequence may be suspended. The program and erase sequences may be terminated. #### 17.3.4.2 Flash module sectorization The code Flash module supports 1024 KB of user memory, plus 16 KB of test memory (a portion of which is one-time programmable by the user). An extra 16 KB sector is available as Shadow space usable for user option bits or censorship. The Flash Multi-module is composed of three modules (0 and 1): Read-While-Write is not supported. The code Flash Bank 0 is divided in 16 sectors including a reserved sector named TestFlash, in which One Time Programmable (OTP) user data are stored, and a Shadow Sector in which user erasable configuration values can be stored (see *Table 169*). 768 KB devices use only the first 256 KB of Module0 plus the shadow block. The data Flash Bank 1 is divided in five sectors including a reserved sector named TestFlash (see *Table 170*). Table 169. Code Flash memory storage address map | Address | Use | Sector <sup>(1),</sup> | Size | SPC56AP54x<br>768 KB | SPC56AP60x<br>1 MB | Module | | |-------------|-----------------------------------------------------|------------------------|--------|----------------------|--------------------|--------|--| | 0x0000_0000 | | B0F0 | 16 KB | Available | Available | | | | 0x0000_4000 | | B0F1 | 16 KB | Available | Available | | | | 0x0000_8000 | | B0F2 | 32 KB | Available | Available | | | | 0x0001_0000 | Low Address Space | B0F3 | 32 KB | Available | Available | | | | 0x0001_8000 | 256 KB | B0F4 | 16 KB | Available | Available | | | | 0x0001_C000 | | B0F5 | 16 KB | Available | Available | 0 | | | 0x0002_0000 | | B0F6 | 64 KB | Available | Available | | | | 0x0003_0000 | | B0F7 | 64 KB | Available | Available | | | | 0x0004_0000 | Mid Address Space | B0F8 | 128 KB | Not available | Available | | | | 0x0006_0000 | 256 KB | B0F9 | 128 KB | Not available | Available | | | | 0x0008_0000 | | B0FA | 128 KB | Available | Available | | | | 0x000A_0000 | High Address Space | B0FB | 128 KB | Available | Available | | | | 0x000C_0000 | 512 KB | B0FC | 128 KB | Available | Available | 1 | | | 0x000E_0000 | | B0FD | 128 KB | Available | Available | | | | 0x0010_0000 | Reserved | | | | | | | | 0x0020_0000 | Shadow Address Space B0SH 16 KB Available Available | | | | | | | | 0x0020_4000 | Reserved | | | | | | | | | | | | • • | | | |-------------|--------------------|----------------------------|-------|----------------------|--------------------|--------| | Address | Use | Sector <sup>(1),</sup> (2) | Size | SPC56AP54x<br>768 KB | SPC56AP60x<br>1 MB | Module | | 0x0040_0000 | Test Address Space | B0TF | 16 KB | Available | Available | 0 | | 0x0040_4000 | Reserved | | | | | | Table 169. Code Flash memory storage address map(Continued) - 1. The boot can be performed from any of the six locations B0F0 to BF0F5 in lower address space. - 2. Each block can be "Locked" against modification or "Selected" for erase. Table 170. 64 KB data Flash module sectorization | Bank | Sector | Addresses | Size (KB) | Address space | |------|----------|----------------------------|-----------|--------------------| | B1 | B1F0 | 0x0080_0000 to 0x0080_3FFF | 16 | Low Address Space | | B1 | B1F1 | 0x0080_4000 to 0x0080_7FFF | 16 | Low Address Space | | B1 | B1F2 | 0x0080_8000 to 0x0080_BFFF | 16 | Low Address Space | | B1 | B1F3 | 0x0080_C000 to 0x0080_FFFF | 16 | Low Address Space | | B1 | Reserved | 0x0081_0000 to 0x00C0_1FFF | 4040 | Reserved | | B1 | B1TF | 0x00C0_2000 to 0x00C0_3FFF | 8 | Test Address Space | | B1 | Reserved | 0x00C0_4000 to 0x00FF_FFFF | 4080 | Reserved | Each Flash module is divided into blocks to implement independent program/erase protection. A software mechanism is provided to independently lock/unlock each block in address space against program and erase. #### 17.3.4.2.1 TestFlash block The TestFlash block exists outside the normal address space and is programmed and read independently of the other blocks. The independent TestFlash block is included also to support systems that require non-volatile memory for security and/or to store system initialization information. A section of the TestFlash is reserved to store the non-volatile information related to redundancy, configuration, and protection. ECC is also applied to TestFlash. The usage of reserved TestFlash sectors is detailed in *Table 171*. Table 171. TestFlash structure | Name | Description | Addresses | | | | | | | |-------|-----------------------------------------------------------|-------------------------|--------------------------|---------|--|--|--|--| | Name | Description | Code TestFlash | Data TestFlash | (bytes) | | | | | | _ | Reserved | 0x0040_0000-0x0040_1FFF | 0x00C0_0000- 0x00C0_1FFF | 8192 | | | | | | _ | Reserved | 0x0040_2000-0x0040_3CFF | 0x00C0_2000- 0x00C0_3CFF | 7424 | | | | | | _ | User Reserved | 0x0040_3D00-0x0040_3DE7 | 0x00C0_3D00-0x00C0_3DE7 | 232 | | | | | | NVLML | Non-volatile Low/Mid address space block Locking register | 0x0040_3DE8-0x0040_3DEF | 0x00C0_3DE8-0x00C0_3DEF | 8 | | | | | | Description | | Addresses | | | | | | | | |-------------|--------------------------------------------------------|-------------------------|-------------------------|---------|--|--|--|--|--| | | | Code TestFlash | Data TestFlash | (bytes) | | | | | | | | Non-volatile High address space Block Locking register | 0x0040_3DF0-0x0040_3DF7 | 0x00C0_3DF0-0x00C0_3DF7 | 8 | | | | | | | | Non-volatile Secondary | | | | | | | | | 0x00C0 3DF8-0x00C0 3DFF 0x00C0\_3E00-0x00C0\_3EFF 0x00C0 3F00-0x00C0 3FFF 8 256 256 Table 171. TestFlash structure(Continued) 0x0040 3DF8-0x0040 3DFF 0x0040\_3E00-0x0040\_3EFF 0x0040 3F00-0x0040 3FFF Erase of the TestFlash block is always locked. TestFlash block programming restrictions, in terms of how ECC is calculated, are similar to array programming restrictions. Only one program is allowed per 64-bit ECC segment. Locations of the Code TestFlash block marked as reserved cannot be programmed by the user application. Locations of the Data TestFlash block marked as reserved cannot be programmed by the user application. #### 17.3.4.2.1.1 Unique Serial Number Low/mid add space block Lock Name NVHBL **NVSLL** register Reserved User Reserved For tracking purposes by the customer, a Unique Serial Number is included in the Test Block to allow identification of a particular device. The Unique Serial Number is defined to be 128 bits and is based on the manufacturing lot identifier and additional information specific to each device in a manufacturing lot. **Table 172. Unique Serial Number** | Address | Use | Default value | Number of word used (32-bit) | |----------|-----------------------------|------------------|------------------------------| | 0x403C10 | Device Unique Serial Number | x <sup>(1)</sup> | 4 words (128 bits) | <sup>1.</sup> This value is different on every device. #### 17.3.4.2.2 Shadow block A Shadow block is present in each Code flash module, but not in the Data flash module. The Shadow block can be enabled by the BIU. When the Shadow space is enabled, all the operations are mapped to the Shadow block. User mode program and erase of the shadow block are enabled only when MCR[PEAS] is set. The Shadow block may be locked/unlocked against program or erase by using the LML[TSLK] and SLL[STSLK] bitfields. Program of the Shadow block has similar restriction as the array in terms of how ECC is calculated. Only one program is allowed per 64-bit ECC segment between erases. Erase of the Shadow block is done similarly as an sectors erase. The Shadow block contains specified data that are needed for user features. The user area of Shadow block may be used for user-defined functions (possibly to store boot code, other configuration words, or factory process codes). The usage of the Shadow sector is detailed in *Table 173*. Table 173. Shadow sector structure | Name | Description | Addresses | Size<br>(bytes) | |----------|----------------------------------------------------------|-------------------------|-----------------| | _ | User Area | 0x0020_0000-0x0020_3DCF | 15824 | | _ | Reserved | 0x0020_3DD0-0x0020_3DD7 | 8 | | NVPWD0-1 | Non-volatile private censorship password 0–1 registers | 0x0020_3DD8-0x0020_3DDF | 8 | | NVSCI0-1 | Non-volatile system censorship information 0–1 registers | 0x0020_3DE0-0x0020_3DE7 | 8 | | _ | Reserved | 0x0020_3DE8-0x0020_3DFF | 24 | | NVBIU2-3 | Non-volatile bus interface unit 2–3 registers | 0x0020_3E00-0x0020_3E0F | 16 | | _ | Reserved | 0x0020_3E10-0x0020_3E17 | 8 | | NVUSRO | Non-volatile user options register | 0x0020_3E18-0x0020_3E1F | 8 | | _ | Reserved | 0x0020_3E20-0x0020_3FFF | 480 | # 17.3.5 Operating modes The following operating modes are available in the Flash module: - Reset - User mode - Low-power mode - Power-down mode #### 17.3.5.1 Reset A reset is the highest priority operation for the Flash module and terminates all other operations. The Flash module uses reset to initialize registers and status bits to their default reset values. If the Flash module is executing a program or erase operation (MCR[PGM] = 1 or MCR[ERS] = 1) and a reset is issued, the operation is suddenly terminated and the module disables the high voltage logic without damage to the high voltage circuits. Reset terminates all operations and forces the Flash module into User mode ready to receive accesses. Reset and power-down must not be used as a systematic way to terminate a program or erase operation. After reset is deasserted, read register access may be done, although it should be noted that registers that require updating from shadow information or other inputs may not read updated values until MCR[DONE] transitions. MCR[DONE] may be polled to determine if the Flash module has transitioned out of reset. Notice that the registers cannot be written until MCR[DONE] is high. #### 17.3.5.2 User mode In User mode, the Flash module may be read, written (register writes and interlock writes), programmed, or erased. The default state of the Flash module is the read state. The main, shadow, and test address space can be read only in the read state. The Flash registers are always available for reads. When the module is in power-down mode, most (but not all) registers are available for reads. The exceptions are documented. The Flash module enters the read state on reset. The module is in the read state under two sets of conditions: - The read state is active when the module is enabled (User mode read). - The read state is active when MCR[ERS] and MCR[ESUS] are set and MCR[PGM] is cleared (Erase Suspend). No Read-While-Modify is available within an individual module, although one module can be read while the other is being written or otherwise modified. Flash core reads return 128 bits (1 page = 2 double words). Register reads return 32 bits (1 word). Flash core reads are done through the BIU. Register reads to unmapped register address space return all 0s. Register writes to unmapped register address space have no effect. Array reads attempted to invalid locations will result in indeterminate data. Invalid locations occur when addressing is done to blocks that do not exist in non $2^n$ array sizes. Interlock writes attempted to invalid locations, will result in an interlock occurring, but attempts to program these blocks will not occur since they are forced to be locked. Erase will occur to selected and unlocked blocks even if the interlock write is to an invalid location. Simultaneous read cycles on the code Flash block and read/write cycles on the data Flash block are possible. However, simultaneous read/write accesses within a single block are not permitted. Chip Select, Write Enable, addresses, and data input of registers are not internally latched and must be kept stable by the CPU for all the read/write access that lasts two clock cycles. ### 17.3.5.3 Low-power mode The Low-power mode turns off most of the DC current sources within the Flash module. The module (Flash core and registers) is not accessible for read or write operations once it has entered Low-power mode. Wake-up time from Low-power mode is faster than wake-up time from Power-down mode. The user may not read some registers (UMISR0–4, UT1–2 and part of UT0) until the Low-power mode is exited. Write access is locked on all the registers in Low-power mode. When exiting from Low-power mode, the Flash module returns to its previous state in all cases, unless it was in the process of executing an erase high voltage operation at the time of entering Low-power mode. If the Flash module is put into Low-power mode during an erase operation, the MCR[ESUS] bit is set to 1. The user may resume the erase operation when the Flash module exits from Low-power mode by clearing MCR[ESUS]. MCR[EHV] must be set to resume the erase operation. If the Flash module is put in Low-power mode during a program operation, the operation is completed in all cases. Low-power mode is entered only after the programming ends. Power-down mode cannot be entered when Low-power mode is active. The module must first be set to User mode (or reset) when cycling between Low-power mode and Power-down mode. #### 17.3.5.4 Power-down mode The Power-down mode allows turning off all Flash DC current sources so that power dissipation is limited only to leakage in this mode. In Power-down mode, no reads from or writes to the Flash are possible. When enabled, the Flash module returns to its previous state in all cases, unless in the process of executing an erase high voltage operation at the time of entering Power-down mode. If the Flash module is put into Power-down mode during an erase operation, the MCR[ESUS] bit is set to 1. The user may resume the erase operation when the Flash module exits Power-down mode by clearing the MCR[ESUS] bit. MCR[EHV] must be set to resume the erase operation. If the Flash module is placed in Power-down mode during a program operation, the operation will be completed in any case and the Power-down mode is entered only after the programming is completed. If the Flash module is put in Power-down mode and the vector table remains mapped in the Flash address space, the user must observe than the Flash module will require a longer interrupt response time. This should be accomplished by adding several wait states. Low-power mode cannot be entered when Power-down mode is active. The module must first be set to User mode (or reset) when cycling between Low-power mode and Power-down mode. # 17.3.6 Registers description The Flash user registers mapping is shown in *Table 174*. Except as noted, registers and offsets are identical for the code Flash and data Flash blocks. Table 174. Flash registers | Offset from xxxx_BASE (0xC3F8_8000) | Register | Location | |-------------------------------------|------------------------------------------------------------------|-------------| | 0x0000 | Module Configuration Register (MCR) | on page 387 | | 0x0004 | Low/mid Address Space Block Locking Register (LML) | on page 392 | | 0x0008 | High Address Space Block Locking Register (HBL) | on page 394 | | 0x000C | Secondary Low/mid Address Space Block Lock Register (SLL) | on page 396 | | 0x0010 | Low/mid Address Space Block Select Register (LMS) | on page 399 | | 0x0014 | High Address Space Block Select Register (HBS) | on page 400 | | 0x0018 | Address Register (ADR) | on page 401 | | 0x001C | Platform Flash Configuration Register 0 (PFCR0) <sup>(1)</sup> | on page 402 | | 0x0020 | Platform Flash Configuration Register 1 (PFCR1) <sup>(1)</sup> | on page 407 | | 0x0024 | Platform Flash Access Protection Register (PFAPR) <sup>(1)</sup> | on page 410 | | 0x0028 | Reserved | | | 0x003C | User Test Register 0 (UT0) | on page 412 | | 0x0040 | User Test Register 1 (UT1) | on page 414 | | 0x0044 | User Test Register 2 (UT2) <sup>(1)</sup> | on page 414 | | 0x0048 | User Multiple Input Signature Register 0 (UMISR0) | on page 415 | | 0x004C | User Multiple Input Signature Register 1 (UMISR1) | on page 416 | | 0x0050 | User Multiple Input Signature Register 2 (UMISR2) <sup>(1)</sup> | on page 416 | | 0x0054 | User Multiple Input Signature Register 3 (UMISR3) <sup>(1)</sup> | on page 417 | | 0x0058 | User Multiple Input Signature Register 4 (UMISR4) <sup>(1)</sup> | on page 418 | | 0x005C-0x3FFF | Reserved | | <sup>1.</sup> This register is not implemented on the data Flash block. # 17.3.7 Register map Table 175. Flash 1056 KB multi-module register map | Addre<br>ss<br>offset | Regist<br>er<br>name | 0<br>16 | 1 | 2<br>18 | 3<br>19 | 4<br>20 | 5<br>21 | 6<br>22 | 7 23 | 8<br>24 | 9<br>25 | 10<br>26 | 11<br>27 | 12<br>28 | 13<br>29 | 14<br>30 | 15<br>31 | |-----------------------|----------------------|---------|-----|---------|---------|----------|-----------|-----------|-----------|---------|---------|----------|----------|----------|----------|----------|----------| | 0x00 | MCR | EDC | 0 | 0 | 0 | 0 | SIZE<br>2 | SIZE<br>1 | SIZE<br>0 | 0 | LAS2 | LAS1 | LAS0 | 0 | 0 | 0 | MAS | | | | EER | RWE | 0 | 0 | PEA<br>S | DON<br>E | PEG | 0 | 0 | 0 | 0 | PGM | PSU<br>S | ERS | ESU<br>S | EHV | Table 175. Flash 1056 KB multi-module register map(Continued) | Addre | Regist | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |--------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | ss<br>offset | er<br>name | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0x04 | LML | LME | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSLK | 0 | 0 | MLK1 | MLK0 | | | | LLK1<br>5 | LLK1<br>4 | LLK1<br>3 | LLK1<br>2 | LLK1<br>1 | LLK1<br>0 | LLK9 | LLK8 | LLK7 | LLK6 | LLK5 | LLK4 | LLK3 | LLK2 | LLK1 | LLK0 | | 0x08 | HBL | HBE | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | HLK3 | HLK2 | HLK1 | HLK0 | | 0x0C | SLL | SLE | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | STSL<br>K | 0 | 0 | SMK<br>1 | SMK<br>0 | | | | SLK1<br>5 | SLK1<br>4 | SLK<br>13 | SLK1<br>2 | SLK1<br>1 | SLK1<br>0 | SLK9 | SLK8 | SLK7 | SLK6 | SLK5 | SLK4 | SLK3 | SLK2 | SLK1 | SLK0 | | 0x10 | LMS | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | MSL1 | MSL0 | | | | LSL1<br>5 | LSL1<br>4 | LSL1 | LSL1<br>2 | LSL1 | LSL1<br>0 | LSL9 | LSL8 | LSL7 | LSL6 | LSL5 | LSL4 | LSL3 | LSL2 | LSL1 | LSL0 | | 0x14 | HBS | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | HSL3 | HSL2 | HSL1 | HSL0 | | 0x18 | ADR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | AD22 | AD21 | AD20 | AD19 | AD18 | AD17 | AD16 | | | | AD15 | AD14 | AD1<br>3 | AD12 | AD11 | AD10 | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | 0 | 0 | 0 | | 0x1C | PFCR0 | BI031 | BI030 | BI02<br>9 | BI028 | BI027 | BI026 | BI025 | BI024 | BI023 | BI022 | BI021 | BI020 | BI019 | BI018 | BI017 | BI016 | | | | BI015 | BI014 | BI01<br>3 | BI012 | BI011 | BI010 | BI009 | BI008 | BI007 | BI006 | BI005 | BI004 | BI003 | BI002 | BI001 | BI000 | | 0x20 | PFCR1 | BI131 | BI130 | BI12<br>9 | BI128 | BI127 | BI126 | BI125 | BI124 | BI123 | BI122 | BI121 | BI120 | BI119 | BI118 | BI117 | BI116 | | | | BI115 | BI114 | BI11<br>3 | BI112 | BI111 | BI110 | BI109 | BI108 | BI107 | BI106 | BI105 | BI104 | BI103 | BI102 | BI101 | BI100 | | 0x24 | PFAPR | BI231 | BI230 | BI22<br>9 | BI228 | BI227 | BI226 | BI225 | BI224 | BI223 | BI222 | BI221 | BI220 | BI219 | BI218 | BI217 | BI216 | | | | BI215 | BI214 | BI21<br>3 | BI212 | BI211 | BI210 | BI209 | BI208 | BI207 | BI206 | BI205 | BI204 | BI203 | BI202 | BI201 | BI200 | | 0x28 | | | | | | | | R | eserved | <u> </u> | | | | | | | | | 0x3C | UT0 | UTE | SBCE | 0 | 0 | 0 | 0 | 0 | 0 | DSI7 | DSI6 | DSI5 | DSI4 | DSI3 | DSI2 | DSI1 | DSI0 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Х | MRE | MRV | EIE | AIS | AIE | AID | | 0x40 | UT1 | DAI3<br>1 | DAI30 | DAI2<br>9 | DAI2<br>8 | DAI2<br>7 | DAI2<br>6 | DAI2<br>5 | DAI2<br>4 | DAI2<br>3 | DAI2<br>2 | DAI2<br>1 | DAI2<br>0 | DAI1<br>9 | DAI1<br>8 | DAI1<br>7 | DAI1<br>6 | | | | DAI1<br>5 | DAI14 | DAI1 | DAI1<br>2 | DAI1<br>1 | DAI1<br>0 | DAI0<br>9 | DAI0<br>8 | DAI0<br>7 | DAI0<br>6 | DAI0<br>5 | DAI0<br>4 | DAI0<br>3 | DAI0<br>2 | DAI0<br>1 | DAI0<br>0 | Table 175. Flash 1056 KB multi-module register map(Continued) | Addre | Regist | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |--------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | ss<br>offset | er<br>name | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0x44 | UT2 | DAI6 | DAI62 | DAI6<br>1 | DAI6<br>0 | DAI5 | DAI5<br>8 | DAI5<br>7 | DAI5<br>6 | DAI5<br>5 | DAI5<br>4 | DAI5 | DAI5<br>2 | DAI5 | DAI5<br>0 | DAI4<br>9 | DAI4<br>8 | | | | DAI4<br>7 | DAI46 | DAI4<br>5 | DAI4<br>4 | DAI4 | DAI4<br>2 | DAI4<br>1 | DAI4<br>0 | DAI3 | DAI3<br>8 | DAI3<br>7 | DAI3<br>6 | DAI3<br>5 | DAI3<br>4 | DAI3 | DAI3<br>2 | | 0x48 | UMISR<br>0 | MS03 | MS03<br>0 | MS0<br>29 | MS02<br>8 | MS02<br>7 | MS02<br>6 | MS02<br>5 | MS02<br>4 | MS02<br>3 | MS02<br>2 | MS02 | MS02<br>0 | MS01 | MS01<br>8 | MS01 | MS01<br>6 | | | | MS01<br>5 | MS01<br>4 | MS0<br>13 | MS01 | MS01 | MS01<br>0 | MS00<br>9 | MS00<br>8 | MS00<br>7 | MS00<br>6 | MS00<br>5 | MS00<br>4 | MS00<br>3 | MS00<br>2 | MS00<br>1 | MS00<br>0 | | 0x4C | UMISR<br>1 | MS06<br>3 | MS06<br>2 | MS0<br>61 | MS06<br>0 | MS05<br>9 | MS05<br>8 | MS05<br>7 | MS05<br>6 | MS05<br>5 | MS05<br>4 | MS05<br>3 | MS05<br>2 | MS05 | MS05<br>0 | MS04<br>9 | MS04<br>8 | | | | MS04<br>7 | MS04<br>6 | MS0<br>45 | MS04<br>4 | MS04<br>3 | MS04<br>2 | MS04<br>1 | MS04<br>0 | MS03<br>9 | MS03<br>8 | MS03<br>7 | MS03<br>6 | MS03<br>5 | MS03<br>4 | MS03 | MS03<br>2 | | 0x50 | UMISR<br>2 | MS09<br>5 | MS09<br>4 | MS0<br>93 | MS09<br>2 | MS09 | MS09<br>0 | MS08<br>9 | MS08<br>8 | MS08<br>7 | MS08<br>6 | MS08<br>5 | MS08<br>4 | MS08<br>3 | MS08<br>2 | MS08 | MS08<br>0 | | | | MS07<br>9 | MS07<br>8 | MS0<br>77 | MS07<br>6 | MS07<br>5 | MS07<br>4 | MS07 | MS07<br>2 | MS07 | MS07<br>0 | MS06<br>9 | MS06<br>8 | MS06<br>7 | MS06<br>6 | MS06<br>5 | MS06<br>4 | | 0x54 | UMISR<br>3 | MS12<br>7 | MS12<br>6 | MS1<br>25 | MS12<br>4 | MS12<br>3 | MS12<br>2 | MS12<br>1 | MS12<br>0 | MS11<br>9 | MS11<br>8 | MS11<br>7 | MS11<br>6 | MS11<br>5 | MS11<br>4 | MS11<br>3 | MS11<br>2 | | | | MS11 | MS11<br>0 | MS1<br>09 | MS10<br>8 | MS10<br>7 | MS10<br>6 | MS10<br>5 | MS10<br>4 | MS10<br>3 | MS10<br>2 | MS10<br>1 | MS10<br>0 | MS09<br>9 | MS09<br>8 | MS09<br>7 | MS09<br>6 | | 0x58 | UMISR<br>4 | MS15<br>9 | MS15<br>8 | MS1<br>57 | MS15<br>6 | MS15<br>5 | MS15<br>4 | MS15<br>3 | MS15<br>2 | MS15 | MS15<br>0 | MS14<br>9 | MS14<br>8 | MS14<br>7 | MS14<br>6 | MS14<br>5 | MS14<br>4 | | | | MS14<br>3 | MS14<br>2 | MS1<br>41 | MS14<br>0 | MS13<br>9 | MS13<br>8 | MS13<br>7 | MS13<br>6 | MS13<br>5 | MS13<br>4 | MS13<br>3 | MS13<br>2 | MS13<br>1 | MS13<br>0 | MS12<br>9 | MS12<br>8 | # Table 176. Flash 64 KB bank1 register map | Addre | Regist | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |--------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|------|------|------|------|----------|------|----------|------| | ss<br>offset | er<br>name | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0x00 | MCR | EDC | 0 | 0 | 0 | 0 | SIZE<br>2 | SIZE<br>1 | SIZE<br>0 | 0 | LAS2 | LAS1 | LAS0 | 0 | 0 | 0 | MAS | | | | EER | RWE | 0 | 0 | PEA<br>S | DON<br>E | PEG | 0 | 0 | 0 | 0 | PGM | PSU<br>S | ERS | ESU<br>S | EHV | | 0x04 | LML | LME | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSLK | 0 | 0 | MLK1 | MLK0 | | | | LLK1<br>5 | LLK1<br>4 | LLK1<br>3 | LLK1<br>2 | LLK1<br>1 | LLK1<br>0 | LLK9 | LLK8 | LLK7 | LLK6 | LLK5 | LLK4 | LLK3 | LLK2 | LLK1 | LLK0 | | 0x08 | Reserved | | | | | | | | | | | | | | | | | Table 176. Flash 64 KB bank1 register map(Continued) | Addre | Regist | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | ss<br>offset | er<br>name | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | 0x0C | SLL | SLE | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | STSL<br>K | 0 | 0 | SMK<br>1 | SMK<br>0 | | | | SLK1<br>5 | SLK1<br>4 | SLK<br>13 | SLK1<br>2 | SLK1<br>1 | SLK1<br>0 | SLK9 | SLK8 | SLK7 | SLK6 | SLK5 | SLK4 | SLK3 | SLK2 | SLK1 | SLK0 | | 0x10 | LMS | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | MSL1 | MSL0 | | | | LSL1<br>5 | LSL1<br>4 | LSL1 | LSL1<br>2 | LSL1 | LSL1<br>0 | LSL9 | LSL8 | LSL7 | LSL6 | LSL5 | LSL4 | LSL3 | LSL2 | LSL1 | LSL0 | | 0x14 | | | | | | | | R | eserved | | | | | | | | | | 0x18 | ADR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | AD22 | AD21 | AD20 | AD19 | AD18 | AD17 | AD16 | | | | AD15 | AD14 | AD1 | AD12 | AD11 | AD10 | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | 0 | 0 | 0 | | 0x1C-<br>0x3B | | | | | | | | R | eserved | | | | | | | | | | 0x3C | UT0 | UTE | SBCE | 0 | 0 | 0 | 0 | 0 | 0 | DSI7 | DSI6 | DSI5 | DSI4 | DSI3 | DSI2 | DSI1 | DSI0 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Х | MRE | MRV | EIE | AIS | AIE | AID | | 0x40 | UT1 | DAI3<br>1 | DAI30 | DAI2<br>9 | DAI2<br>8 | DAI2<br>7 | DAI2<br>6 | DAI2<br>5 | DAI2<br>4 | DAI2<br>3 | DAI2<br>2 | DAI2<br>1 | DAI2<br>0 | DAI1<br>9 | DAI1<br>8 | DAI1<br>7 | DAI1<br>6 | | | | DAI1<br>5 | DAI14 | DAI1 | DAI1<br>2 | DAI1<br>1 | DAI1<br>0 | DAI0<br>9 | DAI0<br>8 | DAI0<br>7 | DAI0<br>6 | DAI0<br>5 | DAI0<br>4 | DAI0<br>3 | DAI0<br>2 | DAI0<br>1 | DAI0<br>0 | | 0x44-<br>0x47 | | | | | | | | R | eserved | | | | | | | | | | 0x48 | UMISR<br>0 | MS03 | MS03<br>0 | MS0<br>29 | MS02<br>8 | MS02<br>7 | MS02<br>6 | MS02<br>5 | MS02<br>4 | MS02<br>3 | MS02<br>2 | MS02 | MS02<br>0 | MS01 | MS01<br>8 | MS01 | MS01<br>6 | | | | MS01<br>5 | MS01<br>4 | MS0<br>13 | MS01<br>2 | MS01 | MS01<br>0 | MS00<br>9 | MS00<br>8 | MS00<br>7 | MS00<br>6 | MS00<br>5 | MS00<br>4 | MS00<br>3 | MS00<br>2 | MS00 | MS00<br>0 | | 0x4C | UMISR<br>1 | MS06<br>3 | MS06<br>2 | MS0<br>61 | MS06<br>0 | MS05<br>9 | MS05<br>8 | MS05<br>7 | MS05<br>6 | MS05<br>5 | MS05<br>4 | MS05 | MS05<br>2 | MS05 | MS05<br>0 | MS04<br>9 | MS04<br>8 | | | | MS04<br>7 | MS04<br>6 | MS0<br>45 | MS04<br>4 | MS04<br>3 | MS04<br>2 | MS04<br>1 | MS04<br>0 | MS03<br>9 | MS03<br>8 | MS03<br>7 | MS03<br>6 | MS03<br>5 | MS03<br>4 | MS03 | MS03 | | 0x50-<br>0x5B | | | | | | | | R | eserved | | | | | | | • | | In the following sections, some non-volatile registers are described. Please notice that such entities are not Flip-Flops, but locations of TestFlash or Shadow sectors with a special meaning. During the Flash initialization phase, the FPEC reads these non-volatile registers and updates their related volatile registers. When the FPEC detects ECC double errors in these special locations, it behaves in the following way: - In case of a failing system locations (configurations, device options, redundancy, EmbAlgo firmware), the initialization phase is interrupted and a Fatal Error is flagged. - In case of failing user locations (protections, censorship, BIU,...), the volatile registers are filled with all 1s and the Flash initialization ends by clearing the MCR[PEG] bit. ### 17.3.7.1 Module Configuration Register (MCR) The Module Configuration Register enables and monitors all the modify operations of each Flash module. Identical MCRs are provided in the code Flash and the data Flash blocks. | Address: | Base · | + 0x00 | 00 | | | | | | | | | | Aco | cess: U | ser rea | d/write | |----------|--------|--------|----|----|----------|-----------|-----------|-----------|----|------|------|------|----------|---------|----------|---------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | EDC | 0 | 0 | 0 | 0 | SIZE<br>2 | SIZE<br>1 | SIZE<br>0 | 0 | LAS2 | LAS1 | LAS0 | 0 | 0 | 0 | MAS | | W | r1c | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | (1) | (1) | (1) | 0 | (1) | 1 | 0 | 0 | 0 | 0 | 0 | | | | | | | '<br>I | | | | | | | | | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | EER | RWE | 0 | 0 | PEA<br>S | DON<br>E | PEG | 0 | 0 | 0 | 0 | PGM | PSU<br>S | ERS | ESU<br>S | EHV | | W | r1c | r1c | | | | | | | | | | | 5 | | 3 | | | Reset | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 172. Module Configuration Register (MCR) Table 177. MCR field descriptions | | - · · | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Field | Description | | EDC<br>0 | ECC Data Correction EDC provides information on previous reads. If a ECC Single Error detection and correction occurs, the EDC bit is set to 1. This bit must then be cleared, or a reset must occur before this bit will return to a 0 state. This bit may not be set to 1 by the user. In the event of a ECC Double Error detection, this bit is not set. If EDC is not set, or remains 0, this indicates that all previous reads (from the last reset, or clearing of EDC) were not corrected through ECC. Since this bit is an error flag, it must be cleared to 0 by writing 1 to the register location. A write of 0 will have no effect. The function of this bit is SoC dependent and it can be configured to be disabled (through UT0.SBCE). O Reads are occurring normally. | | | An ECC Single Error occurred and was corrected during a previous read. | | 1:4 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | <sup>1.</sup> The value for this bit is different between the code and data Flash modules. See the bitfield description. Table 177. MCR field descriptions(Continued) | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SIZE[2:0]<br>5:7 | Array space SIZE 2–0 The value of SIZE field depends on the size of the Flash module: 000 128 KB 001 256 KB 010 512 KB 011 1056 KB (the value for the SPC56xP60x/54x device in the code Flash module) 100 Reserved (1536 KB) 101 Reserved (2048 KB) 110 64 KB (the value for the device in the data Flash module) 111 Reserved Note: The value for this bitfield is different between the code and data Flash modules. | | 8 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | LAS[2:0]<br>9:11 | Low Address Space 2–0 The value of the LAS field corresponds to the configuration of the Low Address Space: 000 Reserved 001 2 × 128 KB 010 32 KB + (2 × 16 KB) + (2 × 32 KB) + 128 KB (the value for the SPC56xP60x/54xdevice in the code Flash module) 011 Reserved 100 Reserved 101 Reserved 101 Reserved 101 Reserved 110 4 × 16 KB (the value for the SPC56xP60x/54xdevice in the data Flash module) 111 (2 × 16 KB) + (2 × 32 KB) + (2 × 16 KB) + (2 × 64 KB) Note: The value for this bitfield is different between the code and data Flash modules. | | 12:14 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | MAS<br>15 | Mid Address Space The value of the MAS field corresponds to the configuration of the Mid Address Space: 0 0 KB or 2 × 128 KB 1 Reserved | | EER<br>16 | ECC Event Error EER provides information on previous reads. When an ECC Double Error detection occurs, the EER bit is set to 1. This bit must then be cleared, or a reset must occur before this bit will return to a 0 state. This bit may not be set to 1 by the user. In the event of a ECC Single Error detection and correction, this bit will not be set. If EER is not set, or remains 0, this indicates that all previous reads (from the last reset, or clearing of EER) were correct. Since this bit is an error flag, it must be cleared to 0 by writing 1 to the register location. A write of 0 will have no effect. O Reads are occurring normally. 1 An ECC Double Error occurred during a previous read. | Table 177. MCR field descriptions(Continued) | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RWE<br>17 | Read-while-Write event Error RWE provides information on previous reads when a Modify operation is on going. If a RWW Error occurs, the RWE bit is set to 1. Read-While-Write Error means that a read access to the Flash module has occurred while the FPEC was performing a program or Erase operation or an Array Integrity Check. This bit must then be cleared, or a reset must occur before this bit will return to a 0 state. This bit may not be set to 1 by the user. If RWE is not set, or remains 0, this indicates that all previous RWW reads (from the last reset, or clearing of RWE) were correct. Since this bit is an error flag, it must be cleared to 0 by writing 1 to the register location. A write of 0 will have no effect. | | | <ul> <li>Reads are occurring normally.</li> <li>A RWW Error occurred during a previous read.</li> <li>Note: If stall/terminate-while-write is used, the software should ignore the setting of the RWE flag and should clear this flag after each erase operation. If stall/terminate-while-write is not used, software can handle the RWE error normally.</li> </ul> | | 18:19 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | PEAS<br>20 | Program/Erase Access Space PEAS indicates which space is valid for program and Erase operations: main array space or shadow/test space. PEAS = 0 indicates that the main address space is active for all Flash module program and erase operations. PEAS = 1 indicates that the test or shadow address space is active for program and erase. The value in PEAS is captured and held with the first interlock write done for Modify operations. The value of PEAS is retained between sampling events (that is, subsequent first interlock writes). 0 Shadow/Test address space is disabled for program/erase and main address space enabled. 1 Shadow/Test address space is enabled for program/erase and main address space disabled. | | DONE<br>21 | Modify Operation Done DONE indicates if the Flash module is performing a high voltage operation. DONE is set to 1 on termination of the Flash module reset. DONE is cleared to 0 just after a 0-to-1 transition of EHV, which initiates a high voltage operation, or after resuming a suspended operation. DONE is set to 1 at the end of program and erase high voltage sequences. DONE is set to 1 (within t <sub>PABT</sub> or t <sub>EABT</sub> , equal to P/E Abort Latency) after a 1-to-0 transition of EHV, which terminates a high voltage program/erase operation. DONE is set to 1 (within t <sub>ESUS</sub> , time equal to Erase Suspend Latency) after a 0-to-1 transition of ESUS, which suspends an erase operation. 0 Flash is executing a high voltage operation. 1 Flash is not executing a high voltage operation. | Table 177. MCR field descriptions(Continued) | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PEG<br>22 | Program/Erase Good The PEG bit indicates the completion status of the last Flash program or erase sequence for which high voltage operations were initiated. The value of PEG is updated automatically during the program and erase high voltage operations. Aborting a program/erase high voltage operation causes PEG to be cleared to 0, indicating the sequence failed. PEG is set to 1 when the Flash module is reset, unless a Flash initialization error has been detected. The value of PEG is valid only when PGM = 1 and/or ERS = 1 and after DONE transitions from 0 to 1 due to a termination or the completion of a program/erase operation. PEG is valid until PGM/ERS makes a 1-to-0 transition or EHV makes a 0-to-1 transition. The value in PEG is not valid after a 0-to-1 transition of DONE caused by ESUS being set to logic 1. If program or erase are attempted on blocks that are locked, the response is PEG = 1, indicating that the operation was successful, and the content of the block were properly protected from the program or erase operation. If a program operation tries to program at 1 bits that are at 0, the program operation is correctly executed on the new bits to be programmed at 0, but PEG is cleared, indicating that the requested operation has failed. In Array Integrity Check or Margin Mode, PEG is set to 1 when the operation is completed, regardless the occurrence of any error. The presence of errors can be detected only comparing checksum value stored in UMIRS[0:1]. O Program or erase operation failed; or program, erase, Array Integrity Check, or Margin Mode was terminated. Program or erase operation successful; or Array Integrity Check or Margin Mode completed successfully. | | 23:26 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | PGM<br>27 | Program PGM sets up the Flash module for a program operation. A 0-to-1 transition of PGM initiates a program sequence. A 1-to-0 transition of PGM ends the program sequence. PGM can be set only under User mode Read (ERS is low and UT0[AIE] is low). PGM can be cleared by the user only when EHV is low and DONE is high. PGM is cleared on reset. O Flash is not executing a program sequence. 1 Flash is executing a program sequence. | | PSUS<br>28 | Program Suspend Writing to this bit has no effect, but the written data can be read back. | | ERS<br>29 | Erase ERS sets up the Flash module for an Erase operation. A 0-to-1 transition of ERS initiates an Erase sequence. A 1-to-0 transition of ERS ends the Erase sequence. ERS can be set only under User mode Read (PGM is low and UT0[AIE] is low). ERS can be cleared by the user only when ESUS and EHV are low and DONE is high. ERS is cleared on reset. O Flash is not executing an Erase sequence. 1 Flash is executing an Erase sequence. | Table 177. MCR field descriptions(Continued) | Field | Description | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ESUS<br>30 | Erase Suspend ESUS indicates that the Flash module is in Erase Suspend or in the process of entering a Suspend state. The Flash module is in Erase Suspend when ESUS = 1 and DONE = 1. ESUS can be set high only when ERS = 1 and EHV = 1, and PGM = 0. A 0-to-1 transition of ESUS starts the sequence that sets DONE and places the Flash in erase suspend. The Flash module enters Suspend within t <sub>ESUS</sub> of this transition. ESUS can be cleared only when DONE = 1 and EHV = 1, and PGM = 0. A 1-to-0 transition of ESUS with EHV = 1 starts the sequence that clears DONE and returns the Module to Erase. The Flash module cannot exit Erase Suspend and clear DONE while EHV is low. ESUS is cleared on reset. 0 Erase sequence is not suspended. 1 Erase sequence is suspended. | | EHV<br>31 | Enable High Voltage The EHV bit enables the Flash module for a high voltage program/Erase operation. EHV is cleared on reset. EHV must be set after an interlock write to start a program/Erase sequence. EHV may be set under one of the following conditions: - Erase (ERS = 1, ESUS = 0, UT0[AIE] = 0) - Program (ERS = 0, ESUS = 0, PGM = 1, UT0[AIE] = 0) In normal operation, a 1-to-0 transition of EHV with DONE high and ESUS low terminates the current program/Erase high voltage operation. When an operation is terminated, there is a 1-to-0 transition of EHV with DONE low and the eventual Suspend bit low. A termination causes the value of PEG to be cleared, indicating a failing program/Erase; address locations being operated on by the terminated operation contain indeterminate data after a termination. A suspended operation cannot be terminated. Terminating a high voltage operation leaves the Flash module addresses in an indeterminate data state. This may be recovered by executing an Erase on the affected blocks. EHV may be written during Suspend. EHV must be high to exit Suspend. EHV may not be written after ESUS is set and before DONE transitions high. EHV may not be cleared after ESUS is cleared and before DONE transitions low. 0 Flash is not enabled to perform an high voltage operation. 1 Flash is enabled to perform an high voltage operation. | A number of MCR bits are protected against write when another bit, or set of bits, is in a specific state. These write locks are covered on a bit by bit basis in the preceding description, but those locks do not consider the effects of trying to write two or more bits simultaneously. The Flash module does not allow the user to write bits simultaneously which would put the device into an illegal state. This is implemented through a priority mechanism among the bits. *Table 178* shows the bit changing priorities. Table 178. MCR bits set/clear priority levels | Priority level | MCR bits | |----------------|----------| | 1 | ERS | | 2 | PGM | | Priority level | MCR bits | |----------------|----------| | 3 | EHV | | 4 | ESUS | Table 178. MCR bits set/clear priority levels(Continued) If the user attempts to write two or more MCR bits simultaneously, only the bit with the lowest priority level is written. #### 17.3.7.2 Low/Mid Address Space Block Locking register (LML) The Low/Mid Address Space Block Locking register provides a means to protect blocks from being modified. These bits, along with bits in the SLL register, determine if the block is locked from program or erase. An "OR" of LML and SLL determine the final lock status. Identical LML registers are provided in the code Flash and the data Flash blocks. In the code Flash module, the LML register has a related Non-Volatile Low/Mid Address Space Block Locking register (NVLML) located in TestFlash that contains the default reset value for LML. The NVLML register is read during the reset phase of the Flash module and loaded into the LML. The reset value is 0x00XX\_XXXX, initially determined by the NVLML value from test sector. Figure 173. Low/Mid Address Space Block Locking register (LML) ### 17.3.7.3 Non-Volatile Low/Mid Address Space Block Locking register (NVLML) | Address: Base + 0x40_3DE8 Access: User read/writ | | | | | | | | | | | | | d/write | | | | |--------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-------|-----|-----|-------|---------|-----|-----|-----| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSLK | 0 | 0 | MLK | MLK | | W | | | | | | | | | | | | IOLIX | | | 1 | 0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Х | 0 | 0 | Х | Х | | | | | | | I | | | | ·<br> | | | | | | | | | _ | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | LLK | W | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reset | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Figure 174. Non-Volatile Low/Mid Address Space Block Locking register (NVLML) The NVLML register is a 64-bit register, the 32 most significant bits of which (bits 63:32) are "don't care" bits that are eventually used to manage ECC codes. Identical NVLML registers are provided in the code Flash and the data Flash blocks. Table 179. LML and NVLML field descriptions | Field | Description | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LME <sup>(1)</sup><br>0 | Low/Mid Address Space Block Enable This bit enables the Lock registers (TSLK, MLK[1:0], and LLK[15:0]) to be set or cleared by registers writes. This bit is a status bit only. The method to set this bit is to write a password, and if the password matches, the LME bit is set to reflect the status of enabled, and is enabled until a reset operation | | | occurs. For LME the password 0xA1A11111 must be written to the LML register. 0 Low Address Locks are disabled: TSLK, MLK[1:0], and LLK[15:0] cannot be written. 1 Low Address Locks are enabled: TSLK, MLK[1:0], and LLK[15:0] can be written. | | 1:10 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | | Test/Shadow Address Space Block Lock This bit locks the block of Test and Shadow Address Space from program and Erase (Erase is any case forbidden for Test block). A value of 1 in the TSLK register signifies that the Test/Shadow block is locked for program and Erase. A value of 0 in the TSLK register signifies that the Test/Shadow block is available to | | TSLK<br>11 | receive program and Erase pulses. The TSLK register is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the TSLK register is not writable if a high voltage operation is suspended. | | | Upon reset, information from the TestFlash block is loaded into the TSLK register. The TSLK bit may be written as a register. Reset will cause the bit to go back to its TestFlash block value. The default value of the TSLK bit (assuming erased fuses) would be locked. | | | TSLK is not writable unless LME is high. 0 Test/Shadow Address Space Block is unlocked and can be modified (if also SLL[STSLK] = 0). 1 Test/Shadow Address Space Block is locked and cannot be modified. | | 12:13 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | Table 179. LML and NVLML field descriptions(Continued) | Field | Description | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MLK[1:0]<br>14:15 | Mid Address Space Block Lock 1-0 These bits lock the blocks of Mid Address Space from program and Erase. MLK[1:0] are related to sectors B0F[9:8], respectively. See <i>Table 169</i> for more information. A value of 1 in a bit of the MLK bitfield signifies that the corresponding block is locked for program and Erase. A value of 0 in a bit of the MLK bitfield signifies that the corresponding block is available to receive program and Erase pulses. The MLK bitfield is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the MLK bitfield is not writable if a high voltage operation is suspended. Upon reset, information from the TestFlash block is loaded into the MLK bitfields. The MLK bits may be written as a register. Reset causes the bits to revert to their TestFlash block value. The default value of the MLK bits (assuming erased fuses) would be locked. In the event that blocks are not present (due to configuration or total memory size), the MLK bits default to locked, and are not writable. The reset value will always be 1 (independent of the TestFlash block), and register writes will have no effect. MLK is not writable unless LME is high. O Mid Address Space Block is unlocked and can be modified (if also SLLISMLK1 = 0) | | LLK[15:0]<br>16:31 | 0 Mid Address Space Block is unlocked and can be modified (if also SLL[SMLK] = 0). 1 Mid Address Space Block is locked and cannot be modified. Low Address Space Block Lock 15-0 These bits lock the blocks of Low Address Space from program and Erase. For code Flash, LLK[5:0] are related to sectors B0F[7:0], respectively. See <i>Table 169</i> for more information. For data Flash, LLK[3:0] are related to sectors B1F[3:0], respectively. See <i>Table 170</i> for more information. A value of 1 in a bit of the LLK bitfield signifies that the corresponding block is locked for program and Erase. A value of 0 in a bit of the LLK bitfield signifies that the corresponding block is available to receive program and Erase pulses. The LLK bitfield is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the LLK bitfield is not writable if a high voltage operation is suspended. Upon reset, information from the TestFlash block is loaded into the LLK bitfields. The LLK bits may be written as a register. Reset will cause the bits to go back to their TestFlash block value. The default value of the LLK bits (assuming erased fuses) would be locked. In the event that blocks are not present (due to configuration or total memory size), the LLK bits will default to locked, and will not be writable. The reset value is always 1 (independent of the TestFlash block), and register writes have no effect. In the code Flash macrocell, bits LLK[15:8] are read-only and locked at 0. In the data Flash macrocell, bits LLK[15:4] are read-only and locked at 1. LLK is not writable unless LME is high. 0 Low Address Space Block is unlocked and cannot be modified. | <sup>1.</sup> This field is present only in LML. # 17.3.7.4 High Address Space Block Locking register (HBL) The High Address Space Block Locking register provides a means to protect blocks from being modified. The HBL register has a related Non- Volatile High Address Space Block Locking register (NVHBL) located in TestFlash that contains the default reset value for HBL. The reset value is 0x0000\_000X, initially determined by NVHBL. The NVHBL register is read during the reset phase of the Flash module and loaded into the HBL. Figure 175. Non-Volatile High Address Space Block Locking register (NVHBL) ### 17.3.7.5 Non-Volatile High Address Space Block Locking register (NVHBL) The NVHBL register is a 64-bit register, the 32 most significant bits of which (bits 63–32) "don't-care" bits that are eventually used to manage ECC codes. Figure 176. Non-Volatile High Address Space Block Locking register (NVHBL) | Table 100. Tibe and terribe field descriptions | | | | |------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Field | Description | | | | HBE<br>0 | High address space Block Enable This bit enables the Lock bits (HLK[3:0]) to be set or cleared by registers writes. HLK[3:0] are related to sectors B0F[D:A], respectively. See <i>Figure 169</i> for more information. This bit is a status bit only. The method to set this bit is to write a password, and if the password matches, the HBE bit is set to reflect the status of enabled, and is enabled until a reset operation occurs. For HBE the password 0xB2B2_2222 must be written to the HBL register. 0 High Address Locks are disabled: HLK[3:0] cannot be written. 1 High Address Locks are enabled: HLK[3:0] can be written. | | | | 1:25 | Reserved (Read Only). A write to these bits has no effect. A read of these bits always outputs 0. | | | Table 180. HBL and NVHBL field descriptions Table 180. HBL and NVHBL field descriptions(Continued) | Field | Description | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HLK[3:0]<br>28:31 | High Address Space Block Lock 3–0 These bits lock the blocks of High Address Space from program and Erase. Not all the HLK[3:0] are used for this memory cut that is all mapped in mid and low address space. A value of 1 in a bit of the HLK register signifies that the corresponding block is locked for program and Erase. A value of 0 in a bit of the HLK register signifies that the corresponding block is available to receive program and Erase pulses. The HLK register is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the HLK register is not writable if a high voltage operation is suspended. Upon reset, information from the TestFlash block is loaded into the HLK registers. The HLK bits may be written as a register. Reset will cause the bits to go back to their TestFlash block value. The default value of the HLK bits (assuming erased fuses) would be locked. In the event that blocks are not present (due to configuration or total memory size), the HLK bits will default to locked, and will not be writable. The reset value will always be 1 (independent of the TestFlash block), and register writes will have no effect. In the 512 KB Flash macrocell, bits HLK[3:0] are read-only and locked at 1. HLK is not writable unless HBE is high. 0 High Address Space Block is unlocked and can be modified. 1 High Address Space Block is locked and cannot be modified. | ### 17.3.7.6 Secondary Low/Mid Address Space Block Locking register (SLL) The Secondary Low/Mid Address Space Block Locking register provides an alternative means to protect blocks from being modified. These bits, along with bits in the LML register, determine if the block is locked from program or Erase. An "OR" of LML and SLL determine the final lock status. Identical SLL registers are provided in the code Flash and the data Flash blocks. In the code Flash module, the SLL register has a related Non-Volatile Secondary Low/Mid Address Space Block Locking register (NVSLL) located in TestFlash that contains the default reset value for SLL. The reset value is 0x00XX\_XXXX, initially determined by NVSLL. The NVSLL register is read during the reset phase of the Flash module and loaded into the SLL. Figure 177. Secondary Low/mid address space block Locking reg (SLL) # 17.3.7.7 Non-Volatile Secondary Low/Mid Address Space Block Locking register (NVSLL) The NVSLL register is a 64-bit register, the 32 most significant bits of which (bits 63:32) are "don't care" bits that are eventually used to manage ECC codes. Identical NVSLL registers are provided in the code Flash and the data Flash blocks. Figure 178. Non-Volatile Secondary Low/Mid Address Space Block Locking register (NVSLL) Table 181. SLL and NVSLL field descriptions | Field | Description | | | |-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | SLE <sup>(1)</sup><br>0 | Secondary Low/Mid Address Space Block Enable This bit enables the Lock registers (STSLK, SMK[1:0], and SLK[15:0]) to be set or cleared by registers writes. This bit is a status bit only. The method to set this bit is to write a password, and if the password matches, the SLE bit is set to reflect the status of enabled, and is enabled until a reset operation occurs. For SLE the password 0xC3C3_3333 must be written to the SLL register. 0 Secondary Low/Mid Address Locks are disabled: STSLK, SMK[1:0], and SLK[15:0] cannot be written. 1 Secondary Low/Mid Address Locks are enabled: STSLK, SMK[1:0], and SLK[15:0] can be written. | | | | 1:10 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | | | STSLK<br>11 | Secondary Test/Shadow address space block Lock This bit is used as an alternate means to lock the block of Test and Shadow Address Space from program and Erase (Erase is any case forbidden for Test block). A value of 1 in the STSLK bitfield signifies that the Test/Shadow block is locked for program and Erase. A value of 0 in the STSLK register signifies that the Test/Shadow block is available to receive program and Erase pulses. The STSLK register is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the STSLK register is not writable if a high voltage operation is suspended. Upon reset, information from the TestFlash block is loaded into the STSLK register. The STSLK bit may be written as a register. Reset will cause the bit to go back to its TestFlash block value. The default value of the STSLK bit (assuming erased fuses) would be locked. STSLK is not writable unless SLE is high. O Test/Shadow Address Space Block is unlocked and can be modified (if also LML[TSLK] = 0). Test/Shadow Address Space Block is locked and cannot be modified. | | | Table 181. SLL and NVSLL field descriptions(Continued) | Field | Description | | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | Reserved (Read Only) | | | 12:13 | A write to these bits has no effect. A read of these bits always outputs 0. | | | | Secondary Mid Address Space Block Lock 1–0 | | | | These bits are used as an alternate means to lock the blocks of Mid Address Space from program and Erase. | | | | SMK[1:0] are related to sectors B0F[7:6], respectively. See <i>Table 169</i> for more information. | | | | A value of 1 in a bit of the SMK register signifies that the corresponding block is locked for program and Erase. | | | | A value of 0 in a bit of the SMK register signifies that the corresponding block is available to receive program and Erase pulses. | | | SMK[1:0]<br>14:15 | The SMK register is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the SMK register is not writable if a high voltage operation is suspended. | | | | Upon reset, information from the TestFlash block is loaded into the SMK registers. The SMK bits may be written as a register. Reset will cause the bits to go back to their TestFlash block value. The default value of the SMK bits (assuming erased fuses) would be locked. | | | | In the event that blocks are not present (due to configuration or total memory size), the SMK bits will default to locked, and will not be writable. The reset value will always be 1 (independent of the TestFlash block), and register writes have no effect. SMK is not writable unless SLE is high. | | | | Mid Address Space Block is unlocked and can be modified (if also LML[MLK] = 0). Mid Address Space Block is locked and cannot be modified. | | | | Secondary Low Address Space Block Lock 15–0 | | | | These bits are used as an alternate means to lock the blocks of Low Address Space from program and Erase. | | | | For code Flash, SLK[5:0] are related to sectors B0F[5:0], respectively. See <i>Table 169</i> for more information. | | | | For data Flash, SLK[3:0] are related to sectors B1F[3:0], respectively. See <i>Table 170</i> for more information. | | | | A value of 1 in a bit of the SLK register signifies that the corresponding block is locked for program and Erase. | | | | A value of 0 in a bit of the SLK register signifies that the corresponding block is available to receive program and Erase pulses. | | | SLK[15:0]<br>16:31 | The SLK register is not writable once an interlock write is completed until MCR[DONE] is set at the completion of the requested operation. Likewise, the SLK register is not writable if a high voltage operation is suspended. | | | | Upon reset, information from the TestFlash block is loaded into the SLK registers. The SLK bits may be written as a register. Reset causes the bits to go back to their TestFlash block value. The default value of the SLK bits (assuming erased fuses) would be locked. | | | | In the event that blocks are not present (due to configuration or total memory size), the SLK bits default to locked, and are not writable. The reset value will always be 1 (independent of the TestFlash block), and register writes will have no effect. | | | | In the code Flash macrocell, bits SLK[15:8] are read-only and locked at 0. | | | | In the data Flash macrocell, bits SLK[15:4] are read-only and locked at 1. | | | | SLK is not writable unless SLE is high. | | | | O Low Address Space Block is unlocked and can be modified (if also LML[LLK] = 0). Low Address Space Block is locked and cannot be modified. | | <sup>1.</sup> This field is present only in SLL. ## 17.3.7.8 Low/Mid Address Space Block Select register (LMS) The Low/Mid Address Space Block Select register provides a means to select blocks to be operated on during erase. Identical LMS registers are provided in the code Flash and the data Flash blocks. Figure 179. Low/Mid Address Space Block Select register (LMS) Table 182. LMS field descriptions | Field | Description | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0:13 | Reserved (Read Only) | | | 0.10 | A write to these bits has no effect. A read of these bits always outputs 0. | | | | Mid Address Space Block Select 1–0 | | | | A value of 1 in the select register signifies that the block is selected for erase. See <i>Table 169</i> for more information. | | | | A value of 0 in the select register signifies that the block is not selected for erase. The reset value for the select register is 0, or unselected. | | | 140174.01 | MSL[1:0] are related to sectors B0F[7:6], respectively. | | | MSL[1:0]<br>14:15 | The blocks must be selected (or unselected) before doing an erase interlock write as part of the Erase sequence. The select register is not writable once an interlock write is completed or if a high voltage operation is suspended. | | | | In the event that blocks are not present (due to configuration or total memory size), the corresponding MSL bits default to unselected, and are not writable. The reset value will always be 0, and register writes have no effect. | | | | <ul><li>0 Mid Address Space Block is unselected for Erase.</li><li>1 Mid Address Space Block is selected for Erase.</li></ul> | | Table 182. LMS field descriptions(Continued) | Field | Description | | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | LSL[15:0]<br>16:31 | Low Address Space Block Select 15–0 A value of 1 in the select register signifies that the block is selected for erase. A value of 0 in the select register signifies that the block is not selected for erase. The reset value for the select register is 0, or unselected. For code Flash, LSL[5:0] are related to sectors B0F[5:0], respectively. See <i>Table 169</i> for more information. For data Flash, LSL[3:0] are related to sectors B1F[3:0], respectively. See <i>Table 170</i> for more information. The blocks must be selected (or unselected) before doing an erase interlock write as part of the Erase sequence. The select register is not writable once an interlock write is completed or if a high voltage operation is suspended. In the event that blocks are not present (due to configuration or total memory size), the corresponding LSL bits will default to unselected, and will not be writable. The reset value will always be 0, and register writes will have no effect. In the code Flash macrocell, bits LSL[15:6] are read-only and locked at 0. In the data Flash macrocell, bits LSL[15:4] are read-only and locked at 0. Low Address Space Block is unselected for Erase. Low Address Space Block is selected for Erase. | | ## 17.3.7.9 High Address Space Block Select register (HBS) The High Address Space Block Select register provides a means to select blocks to be operated on during erase. Figure 180. High Address Space Block Select register (HBS) Table 183. HBS field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------| | 0:25 | Reserved (Read Only). A write to these bits has no effect. A read of these bits always outputs 0. | Table 183. HBS field descriptions(Continued) | Field | Description | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | HSL[3:0]<br>26:31 | High Address Space Block Select 3–0 A value of 1 in the select register signifies that the block is selected for erase. A value of 0 in the select register signifies that the block is not selected for erase. The reset value for the select register is 0, or unselected. All the HSL[3:0] are not used for this memory cut that is all mapped in mid and low address space. The blocks must be selected (or unselected) before doing an erase interlock write as part of the Erase sequence. The select register is not writable once an interlock write is completed or if a high voltage operation is suspended. In the event that blocks are not present (due to configuration or total memory size), the corresponding HSL bits will default to unselected, and will not be writable. The reset value will always be 0, and register writes will have no effect. In the 1056 KB Flash macrocell, bits HSL[3:0] are read-only and locked at 0. 0 High Address Space Block is unselected for Erase. 1 High Address Space Block is selected for Erase. | | ## 17.3.7.10 Address Register (ADR) The Address Register provides the first failing address in the event module failures (ECC, RWW, or FPEC) or the first address at which a ECC single error correction occurs. Figure 181. Address Register (ADR) Table 184. ADR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------| | 0:8 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | Table 184. ADR field descriptions(Continued) | Field | Description | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | AD[22:3]<br>9:28 | Address 22–3 ADR provides the first failing address in the event of ECC error (MCR[EER] set) or the first failing address in the event of RWW error (MCR[RWE] set), or the address of a failure that may have occurred in a FPEC operation (MCR[PEG] cleared). The ECC double error detection takes the highest priority, followed by the RWW error, the FPEC error, and the ECC single error correction. When accessed ADR will provide the address related to the first event occurred with the highest priority. The priorities between these four possible events is summarized in <i>Table 185</i> . This address is always a double word address that selects 64 bits. In case of a simultaneous ECC double error detection on both double words of the same page, bit AD3 will output 0. The same is valid for a simultaneous ECC single error correction on both double words of the same page. In User mode, ADR is read only. | | | 29:31 | Reserved Write these bits has no effect and read these bits always outputs 0. | | Table 185. ADR content: priority list | Priority level | Error flag | ADR content | |----------------|--------------|----------------------------------------------| | 1 | MCR[EER] = 1 | Address of first ECC Double Error | | 2 | MCR[RWE] = 1 | Address of first RWW Error | | 3 | MCR[PEG] = 0 | Address of first FPEC Error | | 4 | MCR[EDC] = 1 | Address of first ECC Single Error Correction | ## 17.3.7.10.1 Platform Flash Configuration Register 0 (PFCR0) The Platform Flash Configuration Register 0 (PFCR0) defines the configuration associated with Flash memory bank0, which corresponds to the code Flash. The register is described in Figure 182 and Table 186. This register is not implemented on the data Flash block. Note: DocID018714 Rev 5 402/1102 Figure 182. Platform Flash Configuration Register 0 (PFCR0) Table 186. PFCR0 field descriptions | Field | Description | | | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0-4<br>BK0_APC | Bank0 Address Pipelining Control This field controls the number of cycles between Flash array access requests. This field must be set to a value appropriate to the operating frequency of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. This field is set to 0b00011 by hardware reset. | | | | | 00000 Accesses may be initiated on consecutive (back-to-back) cycles. 00001 Access requests require one additional hold cycle. 00010 Access requests require two additional hold cycles 11110 Access requests require 30 additional hold cycles. 11111 Access requests require 31 additional hold cycles. | | | | 5-9<br>BK0_WWSC | Bank0 Write Wait State Control This field controls the number of wait states to be added to the Flash array access time for writes. This field must be set to a value appropriate to the operating frequency of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. This field is set to an appropriate value by hardware reset. This field is set to 0b00011 by hardware reset. 00000 No additional wait states are added. 00001 1 additional wait state is added. 00010 2 additional wait states are added. | | | | | 111111 31 additional wait states are added. | | | Table 186. PFCR0 field descriptions(Continued) | Field | Description | | | |----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 10-14<br>BK0_RWSC | Bank0 Read Wait State Control This field controls the number of wait states to be added to the Flash array access time for reads. This field must be set to a value corresponding to the operating frequency of the PFlash and the actual read access time of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. 0 MHz, < 22 MHz APC = RWSC = 0. 22 MHz, < 44 MHz APC = RWSC = 1. 44 MHz, < 66 MHz APC = RWSC = 2. This field is set to 0b00011 by hardware reset. 00000 No additional wait states are added. 00001 1 additional wait state is added. 00010 2 additional wait states are added 111111 31 additional wait states are added. | | | | 15-16,24<br>BK0_RWWC | <ul> <li>Bank0 Read-While-Write Control</li> <li>This 3-bit field defines the controller response to Flash reads while the array is busy with a program (write) or erase operation.</li> <li>0xx Terminate any attempted read while write/erase with an error response.</li> <li>100 Generate a bus stall for a read while write/erase, enable the operation termination and the abort notification interrupt.</li> <li>101 Generate a bus stall for a read while write/erase, enable the operation abort, disable the abort notification interrupt.</li> <li>110 Generate a bus stall for a read while write/erase, enable the stall notification interrupt, disable the abort + abort notification interrupt.</li> <li>111 Generate a bus stall for a read while write/erase, disable the stall notification interrupt, disable the abort + abort notification interrupt.</li> <li>This field is set to 0b111 by hardware reset enabling the stall-while-write/erase and disabling the abort and notification interrupts.</li> </ul> | | | Table 186. PFCR0 field descriptions(Continued) | Field | Description | | | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Bank0, Port 1 Page Buffer Configuration This field controls the configuration of the four page buffers in the PFlash controller. The buffers can be organized as a "pool" of available resources, or with a fixed partition between instruction and data buffers. | | | | 17-18 | If enabled, when a buffer miss occurs, it is allocated to the least-recently-used buffer within the group and the just-fetched entry then marked as most-recently-used. If the Flash access is for the next-sequential line, the buffer is not marked as most-recently-used until the given address produces a buffer hit. | | | | B0_P1_BCFG | <ul> <li>O0 All four buffers are available for any Flash access, that is, there is no partitioning of the buffers based on the access type.</li> <li>O1 Reserved.</li> <li>10 The buffers are partitioned into two groups with buffers 0 and 1 allocated for instruction fetches</li> </ul> | | | | | <ul> <li>and buffers 2 and 3 for data accesses.</li> <li>The buffers are partitioned into two groups with buffers 0,1,2 allocated for instruction fetches and buffer 3 for data accesses.</li> </ul> | | | | | This field is set to 2b11 by hardware reset. | | | | 19<br>B0_P1_DPFE | Bank0, Port 1 Data Prefetch Enable This field enables or disables prefetching initiated by a data read access. This field is cleared by hardware reset. | | | | | O No prefetching is triggered by a data read access. I fpage buffers are enabled (B0_P0_BFE = 1), prefetching is triggered by any data read access. | | | | 20<br>B0_P1_IPFE | Bank0, Port 1 Instruction Prefetch Enable This field enables or disables prefetching initiated by an instruction fetch read access. This field is set by hardware reset. | | | | | <ul> <li>No prefetching is triggered by an instruction fetch read access.</li> <li>If page buffers are enabled (B0_P0_BFE = 1), prefetching is triggered by any instruction fetch read access.</li> </ul> | | | | 21-22<br>B0_P1_PFLM | Bank0, Port 1 Prefetch Limit This field controls the prefetch algorithm used by the PFlash controller. This field defines the prefetch behavior. In all situations when enabled, only a single prefetch is initiated on each buffer miss or hit. This field is set to 2b10 by hardware reset. | | | | | <ul> <li>00 No prefetching is performed.</li> <li>01 The referenced line is prefetched on a buffer miss, that is, <i>prefetch on miss</i>.</li> <li>1x The referenced line is prefetched on a buffer miss, or the next sequential page is prefetched on a buffer hit (if not already present), that is, <i>prefetch on miss or hit</i>.</li> </ul> | | | Table 186. PFCR0 field descriptions(Continued) | Field | Description | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23 | Bank0, Port 1 Buffer Enable This bit enables or disables page buffer read hits. It is also used to invalidate the buffers. This bit is set by hardware reset. | | B0_P1_BFE | <ul> <li>The page buffers are disabled from satisfying read requests, and all buffer valid bits are cleared.</li> <li>The page buffers are enabled to satisfy read requests on hits. Buffer valid bits may be set when the buffers are successfully filled.</li> </ul> | | | Bank0, Port 0 Page Buffer Configuration This field controls the configuration of the four page buffers in the PFlash controller. The buffers can be organized as a "pool" of available resources, or with a fixed partition between instruction and data buffers. If enabled, when a buffer miss occurs, it is allocated to the least-recently-used buffer within the | | 25-26<br>B0 P0 BCFG | group and the just-fetched entry then marked as most-recently-used. If the Flash access is for the next-sequential line, the buffer is not marked as most-recently-used until the given address produces a buffer hit. | | 50_1 0_501 0 | <ul> <li>O0 All four buffers are available for any Flash access, that is, there is no partitioning of the buffers based on the access type.</li> <li>O1 Reserved.</li> <li>The buffers are partitioned into two groups with buffers 0 and 1 allocated for instruction fetches and buffers 2 and 3 for data accesses.</li> <li>The buffers are partitioned into two groups with buffers 0,1,2 allocated for instruction fetches and buffer 3 for data accesses.</li> </ul> | | | This field is set to 2b11 by hardware reset. | | 27<br>B0_P0_DPFE | Bank0, Port 0 Data Prefetch Enable This field enables or disables prefetching initiated by a data read access. This field is cleared by hardware reset. | | | O No prefetching is triggered by a data read access. I If page buffers are enabled (B0_P0_BFE = 1), prefetching is triggered by any data read access. | | 28 | Bank0, Port 0 Instruction Prefetch Enable This field enables or disables prefetching initiated by an instruction fetch read access. This field is set by hardware reset. | | B0_P0_IPFE | <ul> <li>0 No prefetching is triggered by an instruction fetch read access.</li> <li>1 If page buffers are enabled (B0_P0_BFE = 1), prefetching is triggered by any instruction fetch read access.</li> </ul> | Table 186. PFCR0 field descriptions(Continued) | Field | Description | | | | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 29-30 | Bank0, Port 0 Prefetch Limit This field controls the prefetch algorithm used by the PFlash controller. This field defines the prefetch behavior. In all situations when enabled, only a single prefetch is initiated on each buffer miss or hit. This field is set to 2b10 by hardware reset. | | | | | B0_P0_PFLM | <ul> <li>00 No prefetching is performed.</li> <li>01 The referenced line is prefetched on a buffer miss, that is, <i>prefetch on miss</i>.</li> <li>1x The referenced line is prefetched on a buffer miss, or the next sequential page is prefetched on a buffer hit (if not already present), that is, <i>prefetch on miss or hit</i>.</li> </ul> | | | | | 31 | Bank0, Port 0 Buffer Enable This bit enables or disables page buffer read hits. It is also used to invalidate the buffers. This bit is set by hardware reset. | | | | | B0_P0_BFE | <ul> <li>The page buffers are disabled from satisfying read requests, and all buffer valid bits are cleared.</li> <li>The page buffers are enabled to satisfy read requests on hits. Buffer valid bits may be set when the buffers are successfully filled.</li> </ul> | | | | ## 17.3.7.10.2 Platform Flash Configuration Register 1 (PFCR1) The Platform Flash Configuration Register 1 (PFCR1) defines the configuration associated with Flash memory bank1. This corresponds to the data Flash. The register is described in *Figure 183* and *Table 187*. Note: This register is not implemented on the data Flash block. Figure 183. Platform Flash Configuration Register 1 (PFCR1) ## Table 187. PFCR1 field descriptions | Field | Description | | | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0-4 | Bank1 Address Pipelining Control This field controls the number of cycles between Flash array access requests. This field must be set to a value appropriate to the operating frequency of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. This field is set to 0b01000 by hardware reset. | | | | BK1_APC | 00000 Accesses may be initiated on consecutive (back-to-back) cycles. 00001 Access requests require one additional hold cycle. 00010 Access requests require two additional hold cycles 11110 Access requests require 30 additional hold cycles. 11111 Access requests require 31 additional hold cycles. | | | | 5-9 | Bank1 Write Wait State Control This field controls the number of wait states to be added to the Flash array access time for writes. This field must be set to a value appropriate to the operating frequency of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. This field is set to an appropriate value by hardware reset. This field is set to 0b01000 by hardware reset. | | | | BK1_WWSC | 00000 No additional wait states are added. 00001 1 additional wait state is added. 00010 2 additional wait states are added 111111 31 additional wait states are added. | | | Table 187. PFCR1 field descriptions(Continued) | | Table 187. PFCR1 field descriptions(Continued) | | | | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Field | Description | | | | | | Bank1 Read Wait State Control This field controls the number of wait states to be added to the Flash array access time for reads. This field must be set to a value corresponding to the operating frequency of the PFlash and the actual read access time of the PFlash. Higher operating frequencies require non-zero settings for this field for proper Flash operation. | | | | | 10-14<br>BK1_RWSC | 0 MHz | | | | | | This field is set to 0b01000 by hardware reset. 00000 No additional wait states are added. 00001 1 additional wait state is added. 00010 2 additional wait states are added 111111 31 additional wait states are added. | | | | | 15-16,24<br>BK1_RWWC | | | | | | | <ul> <li>Generate a bus stall for a read while write/erase, enable the stall notification interrupt, disable the abort + abort notification interrupt.</li> <li>Generate a bus stall for a read while write/erase, disable the stall notification interrupt, disable the abort + abort notification interrupt.</li> <li>This field is set to 0b111 by hardware reset enabling the stall-while-write/erase and disabling the abort and notification interrupts.</li> </ul> | | | | | 17-22 | Reserved, should be cleared. | | | | | <b>Table 187.</b> | PFCR1 | field | descriptions | (Continued) | |-------------------|-------|-------|--------------|-------------| |-------------------|-------|-------|--------------|-------------| | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23<br>B1_P1_BFE | Bank1, Port 1 Buffer Enable This bit enables or disables read hits from the 128-bit holding register. It is also used to invalidate the contents of the holding register. This bit is cleared by hardware reset, enabling the use of the holding register. | | | <ul><li>The holding register is disabled from satisfying read requests.</li><li>The holding register is enabled to satisfy read requests on hits.</li></ul> | | 25-30 | Reserved, should be cleared. | | 31<br>B1_P0_PFE | Bank1, Port 0 Buffer Enable This bit enables or disables read hits from the 128-bit holding register. It is also used to invalidate the contents of the holding register. This bit is set by hardware reset, enabling the use of the holding register. 0 The holding register is disabled from satisfying read requests. 1 The holding register is enabled to satisfy read requests on hits. | #### 17.3.7.10.3 Platform Flash Access Protection Register (PFAPR) The Platform Flash Access Protection Register (PFAPR) controls read and write accesses to the Flash based on system master number. Prefetching capabilities are defined on a per master basis. This register also defines the arbitration mode for controllers supporting two AHB ports. The register is described in *Figure 184* and *Table 188*. The contents of the register are loaded from location 0x20\_3E00 of the shadow region in the code Flash (bank0) array at reset. To temporarily change the values of any of the fields in the PFAPR, a write to the IPS-mapped register is performed. To change the values loaded into the PFAPR *at reset*, the word location at address 0x20\_3E00 of the shadow region in the Flash array must be programmed using the normal sequence of operations. The reset value shown in *Table 184* reflects an erased or unprogrammed value from the shadow region. Note: This register is not implemented on the data Flash block. Figure 184. Platform Flash Access Protection Register (PFAPR) Table 188. PFAPR field descriptions | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-5 | Reserved, should be cleared. | | 6-7<br>ARBM | Arbitration Mode This 2-bit field controls the arbitration for PFlash controllers supporting 2 AHB ports. 00 Fixed priority arbitration with AHB p0 > p1. 01 Fixed priority arbitration with AHB p1 > p0. 1x Round-robin arbitration. | | 8-15<br>MxPFD | Master <i>x</i> Prefetch Disable ( <i>x</i> = 0,1,2,,7) These bits control whether prefetching may be triggered based on the master number of the requesting AHB master. This field is further qualified by the PFCR0[B0_Px_DPFE, B0_Px_IPFE, Bx_Py_BFE] bits. 0 Prefetching may be triggered by this master. 1 No prefetching may be triggered by this master. | | 16-31<br>MxAP | Master <i>x</i> Access Protection ( <i>x</i> = 0,1,2,,7) These fields control whether read and write accesses to the Flash are allowed based on the master number of the initiating module. On No accesses may be performed by this master. Only read accesses may be performed by this master. Only write accesses may be performed by this master. Both read and write accesses may be performed by this master. | ## 17.3.7.11 Non-Volatile Bus Interface Unit 2 register (NVBIU2) The NVBIU2 register is a 64-bit register, the 32 most significant bits of which (bits 63–32) are "don't care" bits that are eventually used to manage ECC codes. Figure 185. Non-Volatile Bus Interface Unit 2 register (NVBIU2) | Table 189. | BIU2 and | <b>NVBIU2</b> field | descriptions | |------------|----------|---------------------|--------------| |------------|----------|---------------------|--------------| | Field | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bi2[31:0]<br>0:31 | Bus Interface unit 2 31–0 (Read/Write) The BI2[31:00] generic registers are reset based on the information stored in NVBIU2. Write access to the bits in this register can be locked. | ## 17.3.7.12 User Test 0 register (UT0) The User Test feature gives the user of the Flash module the ability to perform test features on the Flash. The User Test 0 register allows controlling the way in which the Flash content check is done. The UT0[MRE], UT0[MRV], UT0[AIS], UT0[EIE], and DSI[7:0] bits are not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Figure 186. User Test 0 register (UT0) Table 190. UT0 field descriptions | Field | Description | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | UTE<br>0 | User Test Enable This status bit indicates when User Test is enabled. All bits in UT0–2 and UMISR0–4 are locked when this bit is 0. This bit is not writeable to a 1, but may be cleared. The reset value is 0. The method to set this bit is to provide a password, and if the password matches, the UTE bit is set to reflect the status of enabled, and is enabled until it is cleared by a register write. For UTE the password 0xF9F9_9999 must be written to the UT0 register. | | SBCE<br>1 | Single Bit Correction Enable (Read/Clear) This bit, when high, enables to flag the information about any eventual ECC Single Bit Correction in the Flash array (MCR.EDC and ADR) Note: For correct 1-bit ECC reporting it is necessary to enable user test mode (UT0[UTE] = 1) and to set SBCE bit. | | 2:7 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | Table 190. UT0 field descriptions(Continued) | | Table 190. UT0 field descriptions(Continued) | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Field | Description | | DSI7-0<br>8:15 | Data Syndrome Input 7–0 These bits represent the input of Syndrome bits of ECC logic used in the ECC Logic Check. The DSI7–0 bits correspond to the 8 syndrome bits on a double word. These bits are not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. 0 The syndrome bit is forced at 0. 1 The syndrome bit is forced at 1. | | 16:24 | Reserved (Read Only) A write to these bits has no effect. A read of these bits always outputs 0. | | 25 | Reserved (Read/Write) This bit can be written and its value can be read back, but there is no function associated. This bit is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. | | MRE<br>26 | Margin Read Enable MRE enables margin reads to be done. This bit, combined with MRV, enables regular user mode reads to be replaced by margin reads. Margin reads are only active during Array Integrity Checks; Normal user reads are not affected by MRE. This bit is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. Margin reads are disabled. All reads are User mode reads. Margin reads are enabled. | | MRV<br>27 | Margin Read Value If MRE is high, MRV selects the margin level that is being checked. Margin can be checked to an erased level (MRV = 1) or to a programmed level (MRV = 0). This bit is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. O Zero's (programmed) margin reads are requested (if MRE = 1). 1 One's (erased) margin reads are requested (if MRE = 1). | | EIE<br>28 | ECC data Input Enable EIE enables the ECC Logic Check operation to be done. This bit is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. 0 ECC Logic Check is disabled. 1 ECC Logic Check is enabled. | | AIS<br>29 | Array Integrity Sequence AIS determines the address sequence to be used during array integrity checks or Margin Mode. The default sequence (AIS = 0) is meant to replicate sequences normal user code follows, and thoroughly checks the read propagation paths. This sequence is proprietary. The alternative sequence (AIS = 1) is just logically sequential. It should be noted that the time to run a sequential sequence is significantly shorter than the time to run the proprietary sequence. This bit is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data, and writes have no effect. In Margin Mode only the linear sequence (AIS = 1) is allowed, while the proprietary sequence (AIS = 0) is forbidden. O Array Integrity sequence is a proprietary sequence. 1 Array Integrity or Margin Mode sequence is sequential. | | Table 190. UT0 field descriptions(Continued) | Table 190. | UT0 field | descriptions | (Continued) | |----------------------------------------------|------------|-----------|--------------|-------------| |----------------------------------------------|------------|-----------|--------------|-------------| | Field | Description | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AIE<br>31 | Array Integrity Enable AIE set to 1 starts the Array Integrity Check done on all selected and unlocked blocks. The pattern is selected by AIS, and the MISR (UMISR0–4) can be checked after the operation is complete, to determine if a correct signature is obtained. AIE can be set only if MCR[ERS], MCR[PGM], and MCR[EHV] are all low. O Array Integrity Checks are disabled. Array Integrity Checks are enabled. | | AID<br>31 | Array Integrity Done AID is cleared upon an Array Integrity Check being enabled (to signify the operation is on-going). Once completed, AID is set to indicate that the Array Integrity Check is complete. At this time, the MISR (UMISR0–4) can be checked. 0 Array Integrity Check is on-going. 1 Array Integrity Check is done. | #### 17.3.7.13 User Test 1 register (UT1) The User Test 1 register allows to enable the checks on the ECC logic related to the 32 LSB of the Double Word. The User Test 1 register is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Figure 187. User Test 1 register (UT1) Table 191. UT1 field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Data Array Input 31–0 | | DAI[31:0]<br>0:31 | These bits represent the input of the even word of ECC logic used in the ECC Logic Check. The DAI[31:0] bits correspond to the 32 array bits representing Word 0 within the double word. | | 0.51 | <ul><li>0 The array bit is forced at 0.</li><li>1 The array bit is forced at 1.</li></ul> | ## 17.3.7.14 User Test 2 register (UT2) The User Test 2 register allows to enable the checks on the ECC logic related to the 32 MSB of the Double Word. The User Test 2 register is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Note: This register is not implemented on the data Flash block. Figure 188. User Test 2 register (UT2) Table 192. UT2 field descriptions | Field | Description | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DAI[63:32]<br>0:31 | Data Array Input [63:32] These bits represent the input of the odd word of ECC logic used in the ECC Logic Check. The DAI[63:32] bits correspond to the 32 array bits representing Word 1 within the double word. 0 The array bit is forced at 0. 1 The array bit is forced at 1. | #### 17.3.7.15 User Multiple Input Signature Register 0 (UMISR0) The Multiple Input Signature Register 0 (UMISR0) provides a mean to evaluate the array integrity. UMISR0 represents the bits 31:0 of the whole 144-bit word (2 double words including ECC). UMISR0 is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. | Address: Base + 0x0048 Access: User read/write | | | | | | | d/write | | | | | | | | | | |------------------------------------------------|-----|-----|-----|-----|-----|-----|---------|-----|-----|-----|-----|-----|-------|-----|-----|-----| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | MS | W | 031 | 030 | 029 | 028 | 027 | 026 | 025 | 024 | 023 | 022 | 021 | 020 | 019 | 018 | 017 | 016 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | ·<br> | | | | | · | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | MS | W | 015 | 014 | 013 | 012 | 011 | 010 | 009 | 800 | 007 | 006 | 005 | 004 | 003 | 002 | 001 | 000 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 189. User Multiple Input Signature Register 0 (UMISR0) | Table 193. UMSIR0 field descript | |----------------------------------| |----------------------------------| | Field | Description | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MS[031:000]<br>0:31 | Multiple input Signature 031–000 These bits represent the MISR value obtained by accumulating the bits 31:0 of all the pages read from the Flash memory. The MS can be seeded to any value by writing the UMISR0 register. | #### 17.3.7.16 User Multiple Input Signature Register 1 (UMISR1) The Multiple Input Signature Register 1 (UMISR1) provides a means to evaluate the array integrity. UMISR1 represents bits 63:32 of the whole 144-bit word (2 double words including ECC). UMISR1 is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Figure 190. User Multiple Input Signature Register 1 (UMISR1) Table 194. UMISR1 field descriptions | Field | Description | |---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MS[063:032]<br>0:31 | Multiple input Signature 063–032 These bits represent the MISR value obtained accumulating the bits 63:32 of all the pages read from the Flash memory. The MS can be seeded to any value by writing the UMISR1 register. | #### 17.3.7.17 User Multiple Input Signature Register 2 (UMISR2) The Multiple Input Signature Register (UMISR2) provides a mean to evaluate the array integrity. UMISR2 represents the bits 95-64 of the whole 144-bit word (2 double words including ECC). UMISR2 is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Note: This register is not implemented on the data Flash block. Figure 191. User Multiple Input Signature Register 2 (UMISR2) Table 195. UMISR2 field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:31 | Multiple input Signature 095–064 These bits represent the MISR value obtained by accumulating the bits 95:64 of all the pages read from the Flash memory. The MS can be seeded to any value by writing the UMISR2 register. | #### 17.3.7.18 User Multiple Input Signature Register 3 (UMISR3) The Multiple Input Signature Register 3 (UMISR3) provides a means to evaluate the array integrity. UMISR3 represents bits 127:96 of the whole 144-bit word (2 double words including ECC). UMISR3 is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Note: This register is not implemented on the data Flash block. Figure 192. User Multiple Input Signature Register 3 (UMISR3) | Table 196. UMISR3 field | descriptions | |-------------------------|--------------| |-------------------------|--------------| | Field | Description | |---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MS[127:096]<br>0:31 | Multiple Input Signature 127–096 These bits represent the MISR value obtained accumulating bits 127:96 of all the pages read from the Flash memory. The MS can be seeded to any value by writing the UMISR3 register. | #### 17.3.7.19 User Multiple Input Signature Register 4 (UMISR4) The Multiple Input Signature Register 4 (UMISR4) provides a means to evaluate the array integrity. The UMISR4 represents the ECC bits of the whole 144-bit word (2 double words including ECC). Bits 8:15 are ECC bits for the odd double word and bits 24:31 are the ECC bits for the even double word. Bits 4:5 and 20:21 of UMISR4 are the double and single ECC error detection for odd and even double words, respectively. UMISR4 is not accessible whenever MCR[DONE] or UT0[AID] are low. Reads return indeterminate data. Writes have no effect. Note: This register is not implemented on the data Flash block. Figure 193. User Multiple Input Signature Register 4 (UMISR4) Table 197. UMISR4 field descriptions | Field | Description | | | | | |---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | MS[159:128]<br>0:31 | Multiple Input Signature 159:128 These bits represent the MISR value obtained accumulating: - MS[135:128]—8 ECC bits for the even double word - MS138—Single ECC error detection for even double word - MS139—Double ECC error detection for even double word - MS[151:144]—8 ECC bits for the odd double word - MS154—Single ECC error detection for odd double word - MS155—Double ECC error detection for odd double word The MS can be seeded to any value by writing the UMISR4 register. | | | | | #### 17.3.7.20 Non-Volatile Private Censorship Password 0 register (NVPWD0) The Non-Volatile Private Censorship Password 0 register (NVPWD0) contains the 32 LSB of the password used to validate the Censorship information contained in NVSCI0–1 registers. Note: This register is not implemented on the data Flash block. Figure 194. Non-Volatile private Censorship Password 0 register (NVPWD0) Table 198. NVPWD0 field descriptions | Field | Description | | | | | |-----------|-----------------------------------------------------------------------------|--|--|--|--| | PWD[31:0] | Password 31–0 | | | | | | 0:31 | The PWD[31:0] bits represent the 32 LSB of the private censorship password. | | | | | #### 17.3.7.21 Non-Volatile Private Censorship Password 1 register (NVPWD1) The Non-Volatile Private Censorship Password 1 Register (NVPWD1) contains the 32 MSB of the password used to validate the Censorship information contained in NVSCI0–1 registers. Note: This register is not implemented on the data Flash block. Figure 195. Non-Volatile Private Censorship Password 1 register (NVPWD1) #### Table 199. NVPWD1 field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------| | 0:31 | <b>PWD63–32</b> : PassWorD 63–32 | | | The PWD63–32 registers represent the 32 MSB of the Private Censorship Password. | #### 17.3.7.22 Non-Volatile System Censoring Information 0 register (NVSCI0) The Non-Volatile System Censoring Information 0 register (NVSCI0) stores the 32 LSB of the Censorship Control Word of the device. NVSCI0 is a non-volatile register located in Shadow sector. It is read during the reset phase of the Flash module and the protection mechanisms are activated consequently. The parts are delivered uncensored to the user. Delivery value: 0x55AA 55AA. Note: This register is not implemented on the data Flash block. Figure 196. Non-Volatile System Censoring Information 0 register (NVSCI0) #### Table 200. NVSCI0 field descriptions | Field | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SC[15:0]<br>0:15 | Serial Censorship control word 15–0 These bits represent the 16 LSB of the Serial Censorship Control Word (SCCW). If SC[15:0] = 0x55AA and NVSCI1 = NVSCI0, the Public Access is disabled. If SC[15:0] ≠ 0x55AA or NVSCI1 ≠ NVSCI0, the Public Access is enabled. | | CW[15:0]<br>16:31 | Censorship control Word 15–0 These bits represent the 16 LSB of the Censorship Control Word (CCW). If CW[15:0] = 0x55AA and NVSCI1 = NVSCI0, the Censored mode is disabled. If CW[15:0] ≠ 0x55AA or NVSCI1 ≠ NVSCI0, the Censored mode is enabled. | ## 17.3.7.23 Non-Volatile System Censoring Information 1 register (NVSCI1) The Non-Volatile System Censoring Information 1 register (NVSCI1) stores the 32 MSB of the Censorship Control Word of the device. NVSCI1 is a non-volatile register located in Shadow sector. It is read during the reset phase of the Flash module and the protection mechanisms are activated consequently. The parts are delivered uncensored to the user. Delivery value: 0x55AA\_55AA. Note: This register is not implemented on the data Flash block. Address: 0x20\_3DE4 Access: User read/write 0 2 3 4 5 6 8 9 10 11 12 13 14 15 SC 31 30 29 28 27 26 25 24 23 22 21 20 19 18 16 17 0 0 1 0 0 1 0 0 0 0 1 1 1 1 1 1 Reset 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 R CW 31 30 29 28 27 26 25 24 23 22 21 20 19 17 16 18 0 0 0 0 0 1 1 0 0 0 Reset Figure 197. Non-Volatile System Censoring Information 1 register (NVSCI1) ## Table 201. NVSCI1 field descriptions | Field | Description | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SC[32:16]<br>0:15 | Serial Censorship control word 32–16 These bits represent the 16 MSB of the Serial Censorship Control Word (SCCW). If SC[32:16] = 0x55AA and NVSCI1 = NVSCI0, the Public Access is disabled. If SC[32:16] ≠ 0x55AA or NVSCI1≠ NVSCI0, the Public Access is enabled. | | CW[32:16]<br>16:31 | Censorship control Word 32–16 These bits represent the 16 MSB of the Censorship Control Word (CCW). CW[32:16] = 0x55AA and NVSCI1 = NVSCI0, the Censored mode is disabled. CW[32:16]≠ 0x55AA or NVSCI1≠ NVSCI0, the Censored mode is enabled. | #### 17.3.7.24 Non-Volatile User Options register (NVUSRO) The Non-Volatile User Options Register (NVUSRO) contains configuration information for the user application. NVUSRO is a 64-bit register, the 32 most significant bits of which (bits 63:32) are "don't care" bits that are eventually used to manage ECC codes. Note: This register is not implemented on the data Flash block. Address: 0x20 3E18 Access: User read/write 2 3 7 8 9 10 11 12 13 14 15 WATCH JOG\_EN UO3 PAD UO1 UO1 UO1 UO1 UO28 UO27 UO26 UO25 UO24 UO23 UO22 UO21 **UO20** DOG 0 3V5V 9 8 7 6 Reset Х Х Х х Х Х Х Х Х Х Х Х Х Х Х Х 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 R UO1 UO1 UO1 UO1 UO1 UO1 UO9 UO7 UO6 UO5 UO4 UO3 UO2 UO1 UO0 UO8 5 3 2 0 Reset Х Χ Х х Х Х Figure 198. Non-Volatile User Options register (NVUSRO) The Non-Volatile User Options Register (NVUSRO) contains configuration information for the user application. NVUSRO is a 64-bit register, the 32 most significant bits of which (bits 63:32) are "don't care" bits that are eventually used to manage ECC codes. Table 202. NVUSRO field descriptions | Field | Description | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | UO[28:0] | User Options 28–0 | | | | 3:31 | The UO[28:0] bits are reset based on the information stored in NVUSRO. | | | | PAD3V5V<br>2 | PAD3V5V 0 High Voltage supply is 5.0 V. 1 High Voltage supply is 3.3 V. Default manufacturing value before Flash initialization is '1' (3.3 V), which should ensure correct minimum slope for boundary scan. | | | | UO[30]<br>1 | User Option 30 The UO[30] bit is reset based on the information stored in NVUSRO. | | | | WATCHDOG_EN<br>0 | Watchdog Enable 0 Disable after reset. 1 Enable after reset. Default manufacturing value before Flash initialization is '1' Note: The WATCHDOG_EN bit is available only for SWT_0. | | | #### 17.3.8 Code Flash programming considerations ## 17.3.8.1 Modify operation All the modify operations of the Flash module are managed through the Flash user registers interface. All the sectors of the Flash module belong to the same partition (Bank), therefore when a Modify operation is active on some sectors, no read access is possible on any other sector (Read-While-Modify is not supported). During a Flash modify operation, any attempt to read any Flash location will output invalid data and the MCR[RWE] bit will be automatically set. This means that the Flash block is not fetchable when a modify operation is active and these commands must be executed from another memory (internal RAM or another Flash block). If a reset occurs during a modify operation, the operation is interrupted and the block is reset to read mode. The data integrity of the Flash section where the modify operation has been terminated is not guaranteed. The interrupted Flash modify operation must be repeated. In general, each modify operation is started through a sequence of three steps: - 1. The first instruction selects the desired operation by setting its corresponding selection bit in MCR (MCR[PGM] or MCR[ERS]) or UT0 (UT0[MRE] or UT0[EIE]). - 2. The second step defines the operands: the address and the data for programming or the sectors for erase or margin read. - 3. The third instruction starts the modify operation by setting MCR[EHV] or UT0[AIE]. Once selected, but not yet started, one operation can be canceled by resetting the operation selection bit. A summary of the available Flash modify operations are shown in *Table 203*. Start bit Operation Select bit Operands MCR[PGM] Address and data by interlock writes MCR[EHV] Double word program MCR[ERS] **LMS** MCR[EHV] Sector erase **LMS** UT0[AIE] Array integrity check None UT0[MRE] UT0[MRV] + LMS UT0[AIE] Margin read ECC logic check UT0[EIE] UT0[DSI], UT1, UT2 UT0[AIE] Table 203. Flash modify operations Once MCR[EHV] (or UT0[AIE]) is set, the operands cannot be modified until MCR[DONE] (or UT0[AID]) is high. In general, each modify operation is completed through a sequence of four steps: - 1. Wait for operation completion: wait for bit MCR[DONE] (or UT0[AID]) to go high. - 2. Check operation result: check bit MCR[PEG] (or compare UMISR0–4 with expected value). - 3. Switch off FPEC by resetting MCR[EHV] (or UT0[AIE]). - 4. Deselect current operation by clearing MCR[PGM] and MCR[ERS] (or UT0[MRE] and UT0[EIE]). If a modify operation is on-going in one of the Flash blocks, it is forbidden to start any other modify operation on the other Flash block. In the following sections, all the possible modify operations are described and some examples of the sequences needed to activate them are presented. #### 17.3.8.1.1 Double word program A Flash program sequence operates on any double word within the Flash core. One or both words within a double word may be altered in a single program operation. Whenever the Flash is programmed, ECC bits are also programmed (unless the selected address belongs to a sector in which the ECC has been disabled in order to allow bit manipulation). ECC is handled on a 64-bit boundary. Thus, if only one word in any given 64-bit ECC segment is programmed, the adjoining word (in that segment) should not be programmed since ECC calculation has already completed for that 64-bit segment. Attempts to program the adjoining word will probably result in an operation failure. It is recommended that all programming operations be of 64 bits. The programming operation should completely fill selected ECC segments within the double word. Programming changes the value stored in an array bit from logic 1 to logic 0 only. Programming cannot change a stored logic 0 to a logic 1. Addresses in locked/disabled blocks cannot be programmed. The user may program the values in any or all of 2 words of a double word with a single program sequence. Double word-bound words have addresses that differ only in address bit 2. The program operation consists of the following sequence of events: - 1. Change the value in the MCR[PGM] bit from 0 to 1. - 2. Ensure the block that contains the address to be programmed is unlocked. - a) Write the first address to be programmed with the program data. - b) The Flash module latches address bits (22:3) at this time. - c) The Flash module latches data written as well. - d) This write is referred to as a program data interlock write. An interlock write may be as large as 64 bits, and as small as 32 bits (depending on the CPU bus). - 3. If more than 1 word is to be programmed, write the additional address in the double word with data to be programmed. This is referred to as a program data write. The Flash module ignores address bits (22:3) for program data writes. The eventual unwritten data word defaults to 0xFFFF FFFF. - 4. Set MCR[EHV] to 1 to start the internal program sequence, or skip to step 9 to terminate. - 5. Wait until the MCR[DONE] bit goes high. - 6. Confirm MCR[PEG] = 1. - 7. Write a logic 0 to the MCR[EHV] bit. - 8. If more addresses are to be programmed, return to step 2. - 9. Write a logic 0 to the MCR[PGM] bit to terminate the program operation. A program operation may be initiated with the 0-to-1 transition of the MCR[PGM] bit or by clearing the MCR[EHV] bit at the end of a previous program. The first write after a program is initiated determines the page address to be programmed. This first write is referred to as an interlock write. The interlock write determines whether the shadow, test, or normal array space will be programmed by causing MCR[PEAS] to be set/cleared. An interlock write must be performed before setting MCR[EHV]. The user may terminate a program sequence by clearing MCR[PGM] prior to setting MCR[EHV]. After the interlock write, additional writes only affect the data to be programmed at the word location determined by address bit 2. Unwritten locations default to a data value of 0xFFFF\_FFF. If multiple writes are done to the same location, the data for the last write is used in programming. While MCR[DONE] is low and MCR[EHV] is high, the user may clear MCR[EHV], resulting in a program terminate. A program termination forces the module to step 8 of the program sequence. A terminated program results in MCR[PEG] being cleared, indicating a failed operation. MCR[DONE] must be checked to know when the terminating command has completed. The data space being operated on before the termination will contain indeterminate data. This may be recovered by repeating the same program instruction or executing an erase of the affected blocks. **Example 1** Double word program of data 0x55AA\_55AA at address 0x00\_AAA8 and data 0xAA55\_AA55 at address 0x00\_AAAC ``` MCR = 0 \times 00000010;/* Set PGM in MCR: Select Operation */ (0 \times 00 \text{AAA8}) = 0 \times 55 \text{AA55AA};/* Latch Address and 32 LSB data */ ``` #### 17.3.8.1.2 Sector erase Erase changes the value stored in all bits of the selected block(s) to logic 1. An erase sequence operates on any combination of blocks (sectors) in the low, mid or high address space, or the shadow block (if available). The test block cannot be erased. The erase sequence is fully automated within the Flash. The user only needs to select the blocks to be erased and initiate the erase sequence. Locked/disabled blocks cannot be erased. If multiple blocks are selected for erase during an erase sequence, no specific operation order must be assumed. The Erase operation consists of the following sequence of events: - 1. Change the value in the MCR[ERS] bit from 0 to 1. - 2. Select the block(s) to be erased by writing 1s to the LMS register. If the shadow block is to be erased, this step may be skipped, and LMS is ignored. Note: Lock and Select are independent. If a block is selected and locked, no erase will occur. - 3. Write to any address in Flash. This is referred to as an erase interlock write. - 4. Set MCR[EHV] to start the internal erase sequence, or skip to step 9 to terminate. - 5. Wait until the MCR[DONE] bit goes high. - 6. Confirm MCR[PEG] = 1. - 7. Clear the MCR[EHV] bit. - 8. If more blocks are to be erased, return to step 2. - Write a logic 0 to the MCR[ERS] bit to terminate the erase operation. After setting MCR[ERS], one write, referred to as an interlock write, must be performed before MCR[EHV] can be set to 1. Data words written during erase sequence interlock writes are ignored. The user may terminate the erase sequence by clearing MCR[ERS] before setting MCR[EHV]. An erase operation may be terminated by clearing MCR[EHV], assuming MCR[DONE] is low, MCR[EHV] is high, and MCR[ESUS] is low. An erase termination forces the Module to step 8 of the erase sequence. A terminated erase results in MCR[PEG] being cleared, indicating a failed operation. MCR[DONE] must be checked to know when the terminating command has completed. The block(s) being operated on before the termination contain indeterminate data. This may be recovered by executing an erase on the affected blocks. The user may not terminate an erase sequence while in erase suspend. #### **Example 2** Erase of sectors B0F1 and B0F2 The erase sequence may be suspended to allow read access to the Flash core. It is not possible to program or to erase during an erase suspend. During erase suspend, all reads to blocks targeted for erase return indeterminate data. An erase suspend can be initiated by changing the value of the MCR[ESUS] bit from 0 to 1. MCR[ESUS] can be set to 1 at any time when MCR[ERS] and MCR[EHV] are high and MCR[PGM] is low. A 0-to-1 transition of MCR[ESUS] causes the module to start the sequence that places it in erase suspend. The user must wait until MCR[DONE] = 1 before the Module is suspended and further actions are attempted. MCR[DONE] will go high no more than $t_{\rm ESUS}$ after MCR[ESUS] is set to 1. Once suspended, the array may be read. Flash core reads while MCR[ESUS] = 1 from the block(s) being erased return indeterminate data. #### **Example 3** Sector Erase Suspend Notice that there is no need to clear MCR[EHV] and MCR[ERS] in order to perform reads during erase suspend. The Erase sequence is resumed by writing a logic 0 to MCR[ESUS]. MCR[EHV] must be set to 1 before MCR[ESUS] can be cleared to resume the operation. The Module continues the erase sequence from one of a set of predefined points. This may extend the time required for the erase operation. ``` Example 4 Sector Erase Resume ``` ``` MCR = 0 \times 000000005; /* Reset ESUS in MCR: Erase Resume */ ``` #### 17.3.8.1.3 User Test mode User Test mode is a customer-accessible mode that can be used to perform specific tests to check the integrity of the Flash module. Three kinds of test can be performed: - Array integrity self-check - Margin mode read - ECC logic check The User Test mode is equivalent to a Modify operation. Read accesses attempted by the user during User Test mode generate a Read-While-Write Error (the MCR[RWE] bit is set). User Test operations are not allowed on the Test and Shadow blocks. #### 17.3.8.1.3.1 Array integrity self check Array integrity is checked using a predefined address sequence (proprietary), and this operation is executed on selected and unlocked blocks. Once the operation is completed, the results of the reads can be checked by reading the MISR value (stored in UMISR0–4), to determine if an incorrect read, or ECC detection was noted. The internal MISR calculator is a 32-bit register. The 128-bit data, the 16-bit ECC data, and the single and double ECC errors of the two double words are therefore captured by the MISR through five different read accesses at the same location. The whole check is done through five complete scans of the memory address space: - The first pass scans only bits 31:0 of each page. - 2. The second pass scans only bits 63:32 of each page. - 3. The third pass scans only bits 95:64 of each page. - The fourth pass scans only bits 127:96 of each page. - 5. The fifth pass scans only the ECC bits (8 + 8) and the single and double ECC errors (2 + 2) of both double words of each page. The 128-bit data and the 16-bit ECC data are sampled before the eventual ECC correction, while the single and double error flags are sampled after the ECC evaluation. Only data from existing and unlocked locations are captured by the MISR. The MISR can be seeded to any value by writing the UMISR0-4 registers. The Array Integrity Self Check consists of the following sequence of events: - 1. Set UT0[UTE] by writing the related password in UT0. - Select the block(s) to be checked by writing 1s to the LMS register. Note that Lock and Select are independent. If a block is selected and locked, no Array Integrity Check will occur. - 3. Set eventually UT0[AIS] bit for a sequential addressing only. - 4. Write a logic 1 to the UT0[AIE] bit to start the Array Integrity Check. - Wait until the UT0[AID] bit is set. - 6. Compare the contents of the UMISR0–4 registers with the expected results. - 7. Write a logic 0 to the UT0[AIE] bit. - 8. If more blocks are to be checked, return to step 2. It is recommended to leave UT0[AIS] at 0 and use the proprietary address sequence that checks the read path more fully, although this sequence takes more time. Note: During the execution of the Array Integrity Check operation it is forbidden to modify the content of Block Select (LMS) and Lock (LML, SLL) registers, otherwise the MISR value can vary in an unpredictable way. While UT0[AID] is low and UT0[AIE] is high, the user may clear UT0[AIE], resulting in an Array Integrity Check termination. UT0[AID] must be checked to know when the terminating command has completed. #### **Example 5** Array Integrity Check of sectors B0F1 and B0F2 ``` = 0xF9F99999;/* Set UTE in UTO: Enable User Test */ LMS = 0 \times 000000006;/* Set LSL2-1 in LMS: Select Sectors */ UT0 = 0x80000002;/* Set AIE in UTO: Operation Start */ /* Loop to wait for AID=1 */ do { tmp = UT0; /* Read UT0 */ } while ( !(tmp & 0x00000001) ); data0 = UMISR0;/* Read UMISR0 content*/ data1 = UMISR1;/* Read UMISR1 content*/ data2 = UMISR2;/* Read UMISR2 content*/ data3 = UMISR3;/* Read UMISR3 content*/ data4 = UMISR4;/* Read UMISR4 content*/ = 0 \times 000000000; /* Reset UTE and AIE in UTO: Operation End */ ``` ## 17.3.8.1.3.2 Margin read The Margin read procedure (either Margin 0 or Margin 1) can be run on unlocked blocks in order to unbalance the Sense Amplifiers with respect to standard read conditions so that all the read accesses reduce the margin vs. 0 (UT0[MRV] = 0) or vs. 1 (UT0[MRV] = 1). Locked sectors are ignored by MISR calculation and ECC flagging. The results of the margin reads can be checked by comparing the checksum value in UMISR[0:4]. Since Margin reads are done at voltages that differ than the normal read voltage, the lifetime expectancy of the Flash macrocell is impacted by the execution of Margin reads. Repeated Margin reads will result in degradation of the Flash array, and will shorten the expected lifetime experienced at normal read levels. For these reasons, Margin reads are allowed only at the factory. Margin reads are forbidden for use by user applications. In any case the charge losses detected through the Margin mode cannot be considered failures of the device and no failure analysis will be opened on them. The Margin Read Setup operation consists of the following sequence of events: - Set UTE in UT0 by writing the related password in UT0. - 2. Select the block(s) to be checked by writing 1s to the LMS register. 57 Note that Lock and Select are independent. If a block is selected and locked, no Array Integrity Check will occur. - Set UT0[AIS] bit for a sequential addressing only. - 4. Change the value in the UT0[MRE] bit from 0 to 1. - 5. Select the Margin level: UT0[MRV] = 0 for 0s margin, UT0[MRV] = 1 for 1s margin. - 6. Write a logic 1 to the UT0[AIE] bit to start the Margin Read. - 7. Wait until the UT0[AID] bit goes high. - 8. Compare UMISR[0:4] content with the expected result. - 9. Write a logic 0 to the UT0[AIE], UT0[MRE] and UT0[MRV] bits. - 10. If more blocks are to be checked, return to step 2. It is mandatory to leave UT0[AIS] at 1 and use the linear address sequence (that also takes less time). During the execution of the Margin Mode operation it is forbidden to modify the content of Block Select (LMS) and Lock (LML, SLL) registers, otherwise the MISR value can vary in an unpredictable way. The read accesses will be done with the addition of a proper number of wait states to guarantee the correctness of the result. While UT0[AID] is low and UT0[AIE] is high, the user may clear AIE, resulting in a Array Integrity Check termination. UT0[AID] must be checked to know when the terminating command has completed. #### **Example 6** Margin Read Check versus 1s ``` UTO = 0xF9F99999; /* Set UTE in UTO: Enable User Test */ LMS = 0x00000006; /* Set LSL2-1 in LMS: Select Sectors */ UTO = 0x80000004; /* Set AIS in UTO: Select Operation */ UTO = 0x80000024; /* Set MRE in UTO: Select Operation */ UT0 = 0x80000034; /* Set MRV in UT0: Select Margin versus 1's */ UT0 = 0x80000036; /* Set AIE in UT0: Operation Start */ do /* Loop to wait for AID=1 */ { tmp = UT0; /* Read UT0 */ } while ( !(tmp & 0x00000001) ); data0 = UMISR0; /* Read UMISR0 content*/ data1 = UMISR1; /* Read UMISR1 content*/ data2 = UMISR2; /* Read UMISR2 content*/ data3 = UMISR3; /* Read UMISR3 content*/ data4 = UMISR4; /* Read UMISR4 content*/ UT0 = 0x80000034; /* Reset AIE in UT0: Operation End */ UT0 = 0x00000000; /* Reset UTE, MRE, MRV, AIS in UT0: Deselect Op. */ ``` #### 17.3.8.1.3.3 ECC logic check ECC logic can be checked by forcing the input of ECC logic: The 64 bits of data and the 8 bits of ECC syndrome can be individually forced and they will drive simultaneously at the same value the ECC logic of the whole page (2 double words). The results of the ECC Logic Check can be verified by reading the MISR value. The ECC Logic Check operation consists of the following sequence of events: - Set UT0[UTE] by writing the related password in UT0. - 2. Write the double word input value to UT1[DAI31-0] and UT2[DAI[63-32]. - 3. Write the Syndrome Input value to UT0[DSI7-0]. - 4. Select the ECC Logic Check: write a logic 1 to the UT0[EIE] bit. - 5. Write a logic 1 to the UT0[AIE] bit to start the ECC Logic Check. - 6. Wait until the UT0[AID] bit goes high. - 7. Compare the contents of the UMISR0–4 registers with the expected results. - 8. Write a logic 0 to the UT0[AIE] bit. Notice that when UT0[AID] = 0, the UMISR0–4 and UT1–2 registers and the UT0[MRE], UT0[MRV], UT0[EIE], UT0[AIS], and UT0[DSI7–0] bits are not accessible. Reads return indeterminate data; writes have no effect. #### Example 7 ECC logic check ``` UTO = 0xF9F99999;/* Set UTE in UTO: Enable User Test */ UT1 = 0x555555555;/* Set DAI31-0 in UT1: Even Word Input Data */ UT2 = 0xAAAAAAA;/* Set DAI63-32 in UT2: Odd Word Input Data */ UT0 = 0x80FF0000;/* Set DSI7-0 in UT0: Syndrome Input Data */ UT0 = 0x80FF0008;/* Set EIE in UT0: Select ECC Logic Check */ UTO = 0x80FF000A;/* Set AIE in UTO: Operation Start */ /* Loop to wait for AID=1 */ { tmp = UT0; /* Read UT0 */ } while ( !(tmp & 0x00000001) ); data0 = UMISR0;/* Read UMISR0 content (expected 0x55555555) */ data1 = UMISR1;/* Read UMISR1 content (expected 0xAAAAAAAA) */ data2 = UMISR2; /* Read UMISR2 content (expected 0x55555555) */ data3 = UMISR3;/* Read UMISR3 content (expected 0xAAAAAAAA) */ data4 = UMISR4;/* Read UMISR4 content (expected 0x00FF00FF) */ = 0x00000000; /* Reset UTE, AIE and EIE in UTO: Operation End */ ``` ## 17.3.8.2 Error Correction Code (ECC) The Flash macrocell provides a method to improve the reliability of the data stored in Flash: the usage of an Error Correction Code. The word size is fixed at 64 bits. Each double word of 64 bits has an associated 8 ECC bits that are programmed in such a way to guarantee a Single Error Correction and a Double Error Detection (SEC-DED). ECC circuitry provides correction of single bit faults and is used to achieve automotive reliability targets. Some units will experience single bit corrections throughout the life of the product with no impact on product reliability. #### 17.3.8.2.1 ECC algorithms The Flash macrocell supports the ECC algorithm "All 1s No Error". #### 17.3.8.2.2 All 1s No Error The All 1s No Error algorithm detects as valid any double word read on a just erased sector (all the 72 bits are 1s). This option allows performing a Blank Check after a Sector Erase operation. #### 17.3.8.3 EEPROM emulation The chosen ECC algorithm allows some bit manipulations so that a Double Word can be rewritten several times without needing an erase of the sector. This allows to use a Double Word to store flags useful for the EEPROM emulation. As an example the chosen ECC algorithm allows to start from an All '1's Double Word value and rewrite whichever of its four 16-bit Half-Words to an All '0's content by keeping the same ECC value. Table 204 shows a set of Double Words sharing the same ECC value. Table 204. Bits manipulation: double words with the same ECC value | Double word | ECC value - All 1s No Error | |-----------------------|-----------------------------| | 0xFFFF_FFFF_FFFF | 0xFF | | 0xFFFF_FFFF_0000 | 0xFF | | 0xFFFF_FFFF_0000_FFFF | 0xFF | | 0xFFFF_0000_FFFF_FFFF | 0xFF | | 0x0000_FFFF_FFFF | 0xFF | | 0xFFFF_FFFF_0000_0000 | 0xFF | | 0xFFFF_0000_FFFF_0000 | 0xFF | | 0x0000_FFFF_FFFF_0000 | 0xFF | | 0xFFFF_0000_0000_FFFF | 0xFF | | 0x0000_FFFF_0000_FFFF | 0xFF | | 0x0000_0000_FFFF_FFF | 0xFF | | 0xFFFF_0000_0000_0000 | 0xFF | | 0x0000_FFFF_0000_0000 | 0xFF | | 0x0000_0000_0000 | 0xFF | When some Flash sectors are used to perform an EEPROM emulation, it is recommended for safety reasons to reserve at least three sectors for this purpose. #### 17.3.8.4 Protection strategy Two kinds of protection are available: Modify Protection to avoid unwanted program/erase in Flash sectors, and Censored mode to avoid piracy. ## 17.3.8.4.1 Modify protection The Flash modify protection information is stored in non-volatile Flash cells located in the TestFlash. This information is read once during the Flash initialization phase following the exit from reset and they are stored in Volatile registers that act as actuators. The reset state of all the volatile modify protection registers is the protected state. All the non-volatile modify protection registers can be programmed through a normal double word program operation at the related locations in TestFlash. The non-volatile modify protection registers cannot be erased. - The non-volatile modify protection registers are physically located in TestFlash. Their bits can be programmed to 0 only once, after which they cannot be restored to 1. - The volatile modify protection registers are read/write registers containing bits that can be written at 0 or 1 by the user application. A software mechanism is provided to independently lock/unlock each Low, Mid, and High Address Space block against program and erase. Software locking is done through the LML (Low/Mid Address Space Block Lock Register) register. An alternate means to enable software locking for blocks of Low Address Space only is through the SLL (Secondary Low/Mid Address Space Block Lock Register). All these registers have a non-volatile image stored in TestFlash (NVLML, NVSLL), so that the locking information is kept on reset. On delivery the TestFlash non-volatile image is at all 1s, meaning all sectors are locked. By programming the non-volatile locations in TestFlash, the selected sectors can be unlocked. Because the TestFlash is one-time programmable (that is, not erasable), once the sectors have been unlocked, they cannot be locked again. Of course, on the contrary, all the volatile registers can be written at 0 or 1 at any time, therefore the user application can lock and unlock sectors when desired. #### 17.3.8.4.2 Censored mode The Censored mode information is stored in non-volatile Flash cells located in the Shadow Sector. This information is read once during the Flash initialization phase following the exit from Reset and they are stored in Volatile registers that act as actuators. The reset state of all the volatile censored mode registers is the protected state. All the non-volatile censored mode registers can be programmed through a normal double word program operation at the related locations in the Shadow Sector. The non-volatile censored mode registers can be erased by erasing the Shadow Sector. - The non-volatile censored mode registers are physically located in the Shadow Sector their bits can be programmed to 0 and eventually restored to 1 by erasing the Shadow Sector. - The volatile censored mode registers are registers not accessible by the user application. 577 RM0083 Flash Memory The Flash block provides two levels of protection against piracy: • If bits NVSCI0[CW[15:0]] are programmed to 0x55AA and NVSC1 = NVSCI0, Censored mode is disabled. All other possible values enable Censored mode. • If bits NVSCI0[SC[15:0]] are programmed to 0x55AA and NVSC1 = NVSCI0, Public Access is disabled. All other possible values enable Public Access. The parts are delivered to the user with Censored mode and public access disabled. The chosen Flash ECC algorithm allows to modify the censorship status without erasing the Shadow sector, as shown in *Table 205*. Table 205. Bits manipulation: censorship management | | • | | | |---------------|---------------|-------------|-------------| | Censored mode | Public access | NVSCI0 | NVSCI1 | | Enabled | Enabled | 0xFFFF_FFFF | 0xFFFF_FFFF | | Disabled | Enabled | 0xFFFF_55AA | 0xFFFF_55AA | | Enabled | Disabled | 0x55AA_FFFF | 0x55AA_FFFF | | Disabled | Disabled | 0x55AA_55AA | 0x55AA_55AA | | Enabled | Disabled | 0x55AA_0000 | 0x55AA_0000 | | Disabled | Enabled | 0x0000_55AA | 0x0000_55AA | | Enabled | Enabled | 0x0000_0000 | 0x0000_0000 | # 18 Memory Protection Unit (MPU) ### 18.1 Introduction The Memory Protection Unit (MPU) provides hardware access control for all memory references generated in a device. Using region descriptors which define memory spaces and their associated access rights, the MPU concurrently monitors all system bus transactions and evaluates the appropriateness of each transfer. Memory references that have sufficient access control rights are allowed to complete, while references that are not mapped to any region descriptor or have insufficient rights are terminated with a protection error response. The MPU implements a set of program-visible region descriptors which are used to monitor all system bus addresses. The result is a hardware structure with a two-dimensional connection matrix, where the region descriptors represent one dimension and the individual system bus addresses and attributes are the second dimension. # 18.2 Block diagram A simplified block diagram of the MPU module is shown in *Figure 199*. The hardware's two-dimensional connection matrix is clearly visible with the basic access evaluation "macro" shown as the replicated submodule block. The AHB<sup>(1)</sup> bus slave ports (s{0,1,2,3}\_h\*) are shown on the left side of the diagram, the region descriptor registers in the middle and the IPS bus interface (ips\_\*) on the right side. The evaluation macro contains the two magnitude comparators connected to the start and end address registers from each region descriptor (rgd*n*) as well as the combinational logic blocks to determine the region hit and the access protection error. For information on the details of the access evaluation macro, see *Section 18.7.1: Access evaluation macro*. i. ARM's Advanced High-performance Bus. **Bus slave ports** Address phase signals ips\_wdata s{1,2,3}\_h\* s0\_h\* ips\_addr decode control rgd0 rgd1 start end error hit\_b rgd(n-1) start end r,w,x hit\_b error 0 ips\_rdata <u>≥</u> **IPS** bus ahb\_error\_ap error\_detail (EDRn) error\_address (EARn) Figure 199. MPU block diagram # 18.3 Features The MPU implements a two-dimensional hardware array of memory region descriptors and the crossbar slave AHB ports to continuously monitor the legality of every memory reference generated by each bus master in the system. The feature set includes: - Support for 16 memory region descriptors - Specification of start and end addresses provide granularity for region sizes from 32 bytes to 4 GB - 2 bus masters (processor cores) support the traditional {read, write, execute} permissions with independent definitions for supervisor and user mode accesses, while 4 bus masters (non-core masters) support {read, writes} attributes - Automatic hardware maintenance of the region descriptor valid bit removes issues associated with maintaining a coherent image of the descriptor - Alternate memory view of the access control word for each descriptor provides an efficient mechanism to dynamically alter only the access rights of a descriptor - For overlapping region descriptors, priority is given to permission granting over access denying as this approach provides more flexibility to system software. See Section 18.7.2: Putting it all together and AHB error terminations, for details and Section 18.9: Application information, for an example. - Support for 3 AHB slave port connections - MPU hardware continuously monitors every AHB slave port access using the preprogrammed memory region descriptors - An access protection error is detected if a memory reference does not hit in any memory region or the reference is flagged as illegal in all memory regions where it does hit. In the event of an access error, the AHB reference is terminated with an error response and the MPU inhibits the bus cycle being sent to the targeted slave device. This results in a Machine Check Exception. - 64-bit error registers, one for each AHB slave port, capture the last faulting address, attributes and "detail" information - Global MPU enable/disable control bit provides a mechanism to easily load region descriptors during system startup or allow complete access rights during debug with the module disabled The MPU port allocation is shown in Table 206. AXBS slave port MPU\_0 MPU\_1 Flash memory Port 0 Port 0 SRAM Port 1 Port 1 Peripheral bridge Port 2 Port 2 Table 206. MPU port allocation # 18.4 Modes of operation The MPU module does not support any special modes of operation. As a memory-mapped device located on the platform's high-speed system bus, it responds based strictly on the memory addresses of the connected system buses. The IPS bus is used to access the MPU's programming model and the memory protection functions are evaluated on a reference-by-reference basis using the addresses from the AHB system bus port(s). Power dissipation is minimized when the MPU's global enable/disable bit is cleared (MPU\_CESR[VLD] = 0). # 18.5 External signal description The MPU module does not include any external interface. # 18.6 Memory map and register definition The MPU module provides an IPS programming model mapped to an SPP-standard onplatform 16 KB space. The programming model is partitioned into three groups: - · Control/status registers - The data structure containing the region descriptors - The alternate view of the region descriptor access control values The programming model can only be referenced using 32-bit (word) accesses. Attempted references using different access sizes, to undefined (reserved) addresses, or with a non-supported access type (for example, a write to a read-only register or a read of a write-only register) generate an IPS error termination. The MPU programming model map is shown in *Table 207*. Table 207. MPU memory map | Offset address<br>0xFFF1_0000 (MPU_0)<br>0x8FF1_0000 (MPU_1) | Register name | Register description | | Location | |--------------------------------------------------------------|---------------|------------------------------------------|-----|-------------| | 0x0000 | MPU_CESR | MPU Control/Error Status Register | 32 | on page 438 | | 0x0004-0x000F | | Reserved | | | | 0x0010 | MPU_EAR0 | MPU Error Address Register, Slave Port 0 | 32 | on page 439 | | 0x0014 | MPU_EDR0 | MPU Error Detail Register, Slave Port 0 | 32 | on page 440 | | 0x0018 | MPU_EAR1 | MPU Error Address Register, Slave Port 1 | 32 | on page 439 | | 0x001C | MPU_EDR1 | MPU Error Detail Register, Slave Port 1 | 32 | on page 440 | | 0x0020 | MPU_EAR2 | MPU Error Address Register, Slave Port 2 | 32 | on page 439 | | 0x0024 | MPU_EDR2 | MPU Error Detail Register, Slave Port 2 | 32 | on page 440 | | 0x0028-0x03FF | Reserved | | | | | 0x0400 | MPU_RGD0 | MPU Region Descriptor 0 | 128 | on page 441 | | 0x0410 | MPU_RGD1 | MPU Region Descriptor 1 | 128 | on page 441 | | 0x0420 | MPU_RGD2 | MPU Region Descriptor 2 | 128 | on page 441 | | 0x0430 | MPU_RGD3 | MPU Region Descriptor 3 | 128 | on page 441 | | 0x0440 | MPU_RGD4 | MPU Region Descriptor 4 | 128 | on page 441 | | 0x0450 | MPU_RGD5 | MPU Region Descriptor 5 | 128 | on page 441 | Table 207. MPU memory map(Continued) | Offset address<br>0xFFF1_0000 (MPU_0)<br>0x8FF1_0000 (MPU_1) | Register name | Register description | Size<br>(bits) | Location | |--------------------------------------------------------------|---------------|-------------------------------------|----------------|-------------| | 0x0460 | MPU_RGD6 | MPU Region Descriptor 6 | | on page 441 | | 0x0470 | MPU_RGD7 | MPU Region Descriptor 7 | 128 | on page 441 | | 0x0480 | MPU_RGD8 | MPU Region Descriptor 8 | 128 | on page 441 | | 0x0490 | MPU_RGD9 | MPU Region Descriptor 9 | 128 | on page 441 | | 0x04A0 | MPU_RGD10 | MPU Region Descriptor 10 | 128 | on page 441 | | 0x04B0 | MPU_RGD11 | MPU Region Descriptor 11 | 128 | on page 441 | | 0x04C0 | MPU_RGD12 | MPU Region Descriptor 12 | 128 | on page 441 | | 0x04D0 | MPU_RGD13 | MPU Region Descriptor 13 | 128 | on page 441 | | 0x04E0 | MPU_RGD14 | MPU Region Descriptor 14 | 128 | on page 441 | | 0x04F0 | MPU_RGD15 | MPU Region Descriptor 15 | 128 | on page 441 | | 0x0500-0x07FF | Reserved | | | | | 0x0800 | MPU_RGDAAC0 | MPU RGD Alternate Access Control 0 | 32 | on page 445 | | 0x0804 | MPU_RGDAAC1 | MPU RGD Alternate Access Control 1 | 32 | on page 445 | | 0x0808 | MPU_RGDAAC2 | MPU RGD Alternate Access Control 2 | 32 | on page 445 | | 0x080C | MPU_RGDAAC3 | MPU RGD Alternate Access Control 3 | 32 | on page 445 | | 0x0810 | MPU_RGDAAC4 | MPU RGD Alternate Access Control 4 | 32 | on page 445 | | 0x0814 | MPU_RGDAAC5 | MPU RGD Alternate Access Control 5 | 32 | on page 445 | | 0x0818 | MPU_RGDAAC6 | MPU RGD Alternate Access Control 6 | 32 | on page 445 | | 0x081C | MPU_RGDAAC7 | MPU RGD Alternate Access Control 7 | 32 | on page 445 | | 0x0820 | MPU_RGDAAC8 | MPU RGD Alternate Access Control 8 | 32 | on page 445 | | 0x0824 | MPU_RGDAAC9 | MPU RGD Alternate Access Control 9 | 32 | on page 445 | | 0x0828 | MPU_RGDAAC10 | MPU RGD Alternate Access Control 10 | 32 | on page 445 | | 0x082C | MPU_RGDAAC11 | MPU RGD Alternate Access Control 11 | 32 | on page 445 | | 0x0830 | MPU_RGDAAC12 | MPU RGD Alternate Access Control 12 | 32 | on page 445 | | 0x0834 | MPU_RGDAAC13 | MPU RGD Alternate Access Control 13 | 32 | on page 445 | | 0x0838 | MPU_RGDAAC14 | MPU RGD Alternate Access Control 14 | 32 | on page 445 | | 0x083C | MPU_RGDAAC15 | MPU RGD Alternate Access Control 15 | 32 | on page 445 | | | | Reserved | | | # 18.6.1 MPU Control/Error Status Register (MPU\_CESR) The MPU\_CESR provides one byte of error status plus three bytes of configuration information. A global MPU enable/disable bit is also included in this register. Figure 200. MPU Control/Error Status Register (MPU\_CESR) Table 208. MPU\_CESR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SPERR | Slave Port n Error, where the slave port number matches the bit number. Each bit in this field represents a flag maintained by the MPU for signaling the presence of a captured error contained in the MPU_EARn and MPU_EDRn registers. The individual bit is set when the hardware detects an error and records the faulting address and attributes. It is cleared when the corresponding bit is written as a logical one. If another error is captured at the exact same cycle as a write of a logical one, this flag remains set. A "find first one" instruction (or equivalent) can be used to detect the presence of a captured error. 1 The corresponding MPU_EARn/MPU_EDRn registers do not contain a captured error. 1 The corresponding MPU_EARn/MPU_EDRn registers do contain a captured error. | | HRL | Hardware Revision Level. This 4-bit read-only field specifies the MPU's hardware and definition revision level. It can be read by software to determine the functional definition of the module. | | NSP | Number of Slave Ports. This 4-bit read-only field specifies the number of slave ports connected to the MPU. For this device, NSP = 3. | | NRGD | Number of Region Descriptors. This 4-bit read-only field specifies the number of region descriptors implemented in the MPU. The defined encodings include: 0b00 8 region descriptors 0b01 12 region descriptors 0b10 16 region descriptors (correct value for this device) | | VLD | Valid. This bit provides a global enable/disable for the MPU. O The MPU is disabled. 1 The MPU is enabled. While the MPU is disabled, all accesses from all bus masters are allowed. | # 18.6.2 MPU Error Address Register, Slave Port n (MPU\_EARn) When the MPU detects an access error on slave port n, the 32-bit reference address is captured in this read-only register and the corresponding bit in the MPU\_CESR[SPERR] field set. Additional information about the faulting access is captured in the corresponding MPU\_EDRn register at the same time. This register and the corresponding MPU\_EDRn register contain the most recent access error; there are no hardware interlocks with the MPU\_CESR[SPERR] field as the error registers are always loaded upon the occurrence of each protection violation. Figure 201. MPU Error Address Register, Slave Port n (MPU\_EARn) Table 209. MPU\_EARn field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------| | 0–31 | Error Address. This read-only field is the reference address from slave port n that generated the | | EADDR | access error. | # 18.6.3 MPU Error Detail Register, Slave Port n (MPU\_EDRn) When the MPU detects an access error on slave port n, 32 bits of error detail are captured in this read-only register and the corresponding bit in the MPU\_CESR[SPERR] field set. Information on the faulting address is captured in the corresponding MPU\_EARn register at the same time. Note this register and the corresponding MPU\_EARn register contain the most recent access error; there are no hardware interlocks with the MPU\_CESR[SPERR] field as the error registers are always loaded upon the occurrence of each protection violation. Figure 202. MPU Error Detail Register, Slave Port n (MPU\_EDRn) Table 210. MPU\_EDRn field descriptions | Field | Description | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–15 | Error Access Control Detail. This 16-bit read-only field implements one bit per region descriptor and is an indication of the region descriptor hit where the error occurred. The MPU performs a reference-by-reference evaluation to determine the presence/absence of an access error. When an error is detected, the hit-qualified access control vector is captured in this field. | | EACD | If the MPU_EDRn register contains a captured error and the EACD field is all zeroes, this signals an access that did not hit in any region descriptor. All non-zero EACD values signal references that hit in a region descriptor(s), but failed due to a protection error as defined by the specific set bits. If only a single EACD bit is set, then the protection error was caused by a single non-overlapping region descriptor. If two or more EACD bits are set, then the protection error was caused in an overlapping set of region descriptors. | | 16–23<br>EPID | Error Process Identification. This 8-bit read-only field records the process identifier of the faulting reference. The process identifier is typically driven only by processor cores; for other bus masters, this field is cleared. | | 24–27<br>EMN | Error Master Number. This 4-bit read-only field records the logical master number of the faulting reference. This field is used to determine the bus master that generated the access error. | | 28–30<br>EATTR | Error Attributes. This 3-bit read-only field records attribute information about the faulting reference. The supported encodings are defined as: 0b00 User mode, instruction access 0b01 User mode, data access 0b10 Supervisor mode, instruction access 0b11 Supervisor mode, data access All other encodings are reserved. For non-core bus masters, the access attribute information is typically wired to supervisor, data (0b011). | | 31<br>ERW | Error Read/Write. This 1-bit read-only field signals the access type (read, write) of the faulting reference. 0 Read 1 Write | # 18.6.4 MPU Region Descriptor n (MPU\_RGDn) Each 128-bit (four 32-bit word) region descriptor specifies a given memory space and the access attributes associated with that space. The descriptor definition is the very essence of the operation of the Memory Protection Unit. The region descriptors are organized sequentially in the MPU's programming model and each of the four 32-bit words are detailed in the subsequent sections. # 18.6.4.1 MPU Region Descriptor n, Word 0 (MPU\_RGDn.Word0) The first word of the MPU region descriptor defines the 0-modulo-32 byte start address of the memory region. Writes to this word clear the region descriptor's valid bit (see *Section 18.6.4.4: MPU Region Descriptor n, Word 3 (MPU\_RGDn.Word3)*, for more information). Figure 203. MPU Region Descriptor, Word 0 Register (MPU\_RGDn.Word0) Table 211. MPU\_RGDn.Word0 field descriptions | Field | Description | |---------|----------------------------------------------------------------------------------------------------------| | 0–26 | Start Address. This field defines the most significant bits of the 0-modulo-32 byte start address of the | | SRTADDR | memory region. | # 18.6.4.2 MPU Region Descriptor n, Word 1 (MPU\_RGDn.Word1) The second word of the MPU region descriptor defines the 31-modulo-32 byte end address of the memory region. Writes to this word clear the region descriptor's valid bit (see Section 18.6.4.4: MPU Region Descriptor n, Word 3 (MPU\_RGDn.Word3), for more information). Figure 204. MPU Region Descriptor, Word 1 Register (MPU\_RGDn.Word1) Table 212. MPU\_RGDn.Word1 field descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–26<br>ENDADDR | End Address. This field defines the most significant bits of the 31-modulo-32 byte end address of the memory region. There are no hardware checks to verify that ENDADDR >= SRTADDR; it is software's responsibility to properly load these region descriptor fields. | # 18.6.4.3 MPU Region Descriptor n, Word 2 (MPU\_RGDn.Word2) The third word of the MPU region descriptor defines the access control rights of the memory region. Bus masters 0-3 have a 6-bit field defining separate privilege rights for user and supervisor mode accesses as well as the optional inclusion of a process identification field within the definition. For these fields, the bus master number refers to the logical master number as specified in *Section 14.1.4: Logical master IDs.* (Nexus controllers have IDs 8 and 9, but only the last 3 bits of the ID are used for this purposes, so they share privileges with cores 0 and 1.) For the processor privilege rights, there are three flags associated with this function: {read, write, execute}. In this context, these flags follow the traditional definition: - Read (r) permission refers to the ability to access the referenced memory address using an operand (data) fetch. - Write (w) permission refers to the ability to update the referenced memory address using a store (data) instruction. - Execute (x) permission refers to the ability to read the referenced memory address using an instruction fetch. Writes to this word clear the region descriptor's valid bit (see Section 18.6.4.4: MPU Region Descriptor n, Word 3 (MPU\_RGDn.Word3), for more information). Since it is also expected that system software may adjust only the access controls within a region descriptor (MPU\_RGDn.Word2) as different tasks execute, an alternate programming view of this 32-bit entity is provided. If only the access controls are being updated, this operation should be performed by writing to MPU\_RGDAACn (Alternate Access Control n) as stores to these locations do not affect the descriptor's valid bit. Figure 205. MPU Region Descriptor, Word 2 Register (MPU\_RGDn.Word2) Table 213. MPU\_RGDn.Word2 field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | МЗРЕ | Bus master 3 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | | M3SM | Bus master 3 supervisor mode access control. This 2-bit field defines the access controls for bus master 3 when operating in supervisor mode. The M3SM field is defined as: $0b00 r, \ \text{w}, \ \text{x} = \text{read}, \text{write and execute allowed} \\ 0b01 r, \ -, \ \text{x} = \text{read and execute allowed, but no write} \\ 0b10 r, \ \text{w}, \ - = \text{read and write allowed, but no execute} \\ 0b11 \text{Same access controls as that defined by M3UM for user mode}$ | | M3UM | Bus master 3 user mode access control. This 3-bit field defines the access controls for bus master 3 when operating in user mode. The M3UM field consists of three independent bits, enabling read, write and execute permissions: $\{r, w, x\}$ . If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | | M2PE | Bus master 2 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | Table 213. MPU\_RGDn.Word2 field descriptions(Continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | M2SM | Bus master 2 supervisor mode access control. This 2-bit field defines the access controls for bus master 2 when operating in supervisor mode. The M2SM field is defined as: $0b00 \text{r}, \text{w}, \text{x} = \text{read}, \text{write and execute allowed} \\ 0b01 \text{r}, -, \text{x} = \text{read and execute allowed}, \text{but no write} \\ 0b10 \text{r}, \text{w}, - = \text{read and write allowed}, \text{but no execute} \\ 0b11 \text{Same access controls as that defined by M2UM for user mode}$ | | M2UM | Bus master 2 user mode access control. This 3-bit field defines the access controls for bus master 2 when operating in user mode. The M2UM field consists of three independent bits, enabling read, write and execute permissions: $\{r, w, x\}$ . If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | | M1PE | Bus master 1 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | | M1SM | Bus master 1 supervisor mode access control. This 2-bit field defines the access controls for bus master 1 when operating in supervisor mode. The M1SM field is defined as: $0b00 r, \ \ w, \ \ x = \text{read}, \text{ write and execute allowed} \\ 0b01 r, \ \ -, \ \ x = \text{read and execute allowed, but no write} \\ 0b10 r, \ \ w, \ \ - = \text{read and write allowed, but no execute} \\ 0b11 \text{ Same access controls as that defined by M1UM for user mode}$ | | M1UM | Bus master 1 user mode access control. This 3-bit field defines the access controls for bus master 1 when operating in user mode. The M1UM field consists of three independent bits, enabling read, write and execute permissions: $\{x, w, x\}$ . If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | | MOPE | Bus master 0 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | | MOSM | Bus master 0 supervisor mode access control. This 2-bit field defines the access controls for bus master 0 when operating in supervisor mode. The M0SM field is defined as: $0b00r,\ \ w,\ \ x=\text{read}, \text{ write and execute allowed} \\ 0b01\ r,\ \ -,\ \ x=\text{read and execute allowed}, \text{ but no write} \\ 0b10\ r,\ \ w,\ \ -=\text{read and write allowed}, \text{ but no execute} \\ 0b11\ \text{Same access controls as that defined by M0UM for user mode}$ | | моим | Bus master 0 user mode access control. This 3-bit field defines the access controls for bus master 0 when operating in user mode. The M0UM field consists of three independent bits, enabling read, write and execute permissions: $\{r, w, x\}$ . If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | # 18.6.4.4 MPU Region Descriptor n, Word 3 (MPU\_RGDn.Word3) The fourth word of the MPU region descriptor contains the optional process identifier and mask, plus the region descriptor's valid bit. Since the region descriptor is a 4-word entity, there are potential coherency issues as this structure is being updated since multiple writes are required to update the entire descriptor. Accordingly, the MPU hardware assists in the operation of the descriptor valid bit to prevent incoherent region descriptors from generating spurious access errors. In particular, it is expected that a complete update of a region descriptor is typically done with sequential writes to MPU\_RGDn.Word0, then MPU\_RGDn.Word1,... and finally MPU\_RGDn.Word3. The MPU hardware automatically clears the valid bit on any writes to words {0,1,2} of the descriptor. Writes to this word set/clear the valid bit in a normal manner. Since it is also expected that system software may adjust only the access controls within a region descriptor (MPU\_RGDn.Word2) as different tasks execute, an alternate programming view of MPU\_RGDn.Word2 is provided. If only the access controls are being updated, this operation should be performed by writing to MPU\_RGDAACn (Alternate Access Control n) as stores to these locations do *not* affect the descriptor's valid bit. Figure 206. MPU Region Descriptor, Word 3 Register (MPU\_RGDn.Word3) Field Description Process Identifier. This 8-bit field specifies that the optional process identifier is to be included in the 0 - 7determination of whether the current access hits in the region descriptor. This field is combined with PID the PIDMASK and included in the region hit determination if MPU\_RGDn.Word2[MxPE] is set. Process Identifier Mask. This 8-bit field provides a masking capability so that multiple process identifiers can be included as part of the region hit determination. If a bit in the PIDMASK is set, then 8-15 the corresponding bit of the PID is ignored in the comparison. This field is combined with the PID and **PIDMASK** included in the region hit determination if MPU RGDn.Word2[MxPE] is set. For more information on the handling of the PID and PIDMASK, see Section 18.7.1.1: Access evaluation – hit determination. Valid. This bit signals the region descriptor is valid. Any write to MPU RGDn.Word{0,1,2} clears this bit, while a write to MPU RGDn. Word3 sets or clears this bit depending on bit 31 of the write 31 operand. **VLD** Table 214. MPU\_RGDn.Word3 field descriptions ### 18.6.5 MPU Region Descriptor Alternate Access Control n (MPU RGDAACn) As noted in Section 18.6.4.3: MPU Region Descriptor n, Word 2 (MPU\_RGDn.Word2), it is expected that since system software may adjust only the access controls within a region descriptor (MPU\_RGDn.Word2) as different tasks execute, an alternate programming view of this 32-bit entity is desired. If only the access controls are being updated, this operation should be performed by writing to MPU\_RGDAACn (Alternate Access Control n) as stores to these locations do not affect the descriptor's valid bit. The memory address therefore provides an alternate location for updating MPU\_RGDn.Word2. 0 Region descriptor is invalid Region descriptor is valid Figure 207. MPU RGD Alternate Access Control n (MPU\_RGDAACn) Since the MPU\_RGDAACn register is simply another memory mapping for MPU\_RGDn.Word2, the field definitions shown in *Table 215* are identical to those presented in *Table 213*. Table 215. MPU\_RGDAACn field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | M3PE | Bus master 3 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | | M3SM | Bus master 3 supervisor mode access control. This 2-bit field defines the access controls for bus master 3 when operating in supervisor mode. The M3SM field is defined as: $0b00 \text{r}$ , w, x = read, write and execute allowed $0b01 \text{r}$ , -, x = read and execute allowed, but no write $0b10 \text{r}$ , w, - = read and write allowed, but no execute $0b10 \text{r}$ , w, - = read and write allowed, but no execute $0b11 \text{Same}$ access controls as that defined by M3UM for user mode | | мзим | Bus master 3 user mode access control. This 3-bit field defines the access controls for bus master 3 when operating in user mode. The M3UM field consists of three independent bits, enabling read, write and execute permissions: $\{r, w, x\}$ . If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | | M2PE | Bus master 2 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU_RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. | | M2SM | Bus master 2 supervisor mode access control. This 2-bit field defines the access controls for bus master 2 when operating in supervisor mode. The M2SM field is defined as: $0b00 \text{r}$ , w, x = read, write and execute allowed $0b01 \text{r}$ , $-$ , x = read and execute allowed, but no write $0b10 \text{r}$ , w, $-$ = read and write allowed, but no execute $0b11 \text{Same}$ access controls as that defined by M2UM for user mode | | M2UM | Bus master 2 user mode access control. This 3-bit field defines the access controls for bus master 2 when operating in user mode. The M2UM field consists of three independent bits, enabling read, write and execute permissions: {r,w,x}. If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. | Field **Description** Bus master 1 process identifier enable. If set, this flag specifies that the process identifier and mask M1PE (defined in MPU RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the region hit evaluation does not include the process identifier. Bus master 1 supervisor mode access control. This 2-bit field defines the access controls for bus master 1 when operating in supervisor mode. The M1SM field is defined as: 0b00 r, w, x = read, write and execute allowed M1SM 0b01 r, -, x = read and execute allowed, but no write 0b10 r, w, - = read and write allowed, but no execute 0b11 Same access controls as that defined by M1UM for user mode Bus master 1 user mode access control. This 3-bit field defines the access controls for bus master 1 when operating in user mode. The M1UM field consists of three independent bits, enabling read, M1UM write and execute permissions: { r, w, x }. If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by any other descriptor) and the access not performed. Bus master 0 process identifier enable. If set, this flag specifies that the process identifier and mask (defined in MPU RGDn.Word3) are to be included in the region hit evaluation. If cleared, then the M0PE region hit evaluation does not include the process identifier. Bus master 0 supervisor mode access control. This 2-bit field defines the access controls for bus master 0 when operating in supervisor mode. The M0SM field is defined as: 0b00 r, w, x = read, write and execute allowed M0SM 0b01 r, -, x = read and execute allowed, but no write 0b10 r, w, - = read and write allowed, but no execute 0b11 Same access controls as that defined by M0UM for user mode Bus master 0 user mode access control. This 3-bit field defines the access controls for bus master 0 when operating in user mode. The M0UM field consists of three independent bits, enabling read, Table 215. MPU\_RGDAACn field descriptions(Continued) # 18.7 Functional description any other descriptor) and the access not performed. In this section, the functional operation of the MPU is detailed. In particular, subsequent sections discuss the operation of the access evaluation macro as well as the handling of error-terminated AHB bus cycles. write and execute permissions: {r, w, x}. If set, the bit allows the given access type to occur; if cleared, an attempted access of that mode may be terminated with an access error (if not allowed by ### 18.7.1 Access evaluation macro As previously discussed, the basic operation of the MPU is performed in the access evaluation macro, a hardware structure replicated in the two-dimensional connection matrix. As shown in *Figure 208*, the access evaluation macro inputs the AHB system bus address phase signals (AHB\_ap) and the contents of a region descriptor (RGDn) and performs two major functions: region hit determination ( $hit_b$ ) and detection of an access protection violation (exrox). M0UM Figure 208. MPU access evaluation macro *Figure 208* is not intended to be a schematic of the actual access evaluation macro, but rather a generalized block diagram showing the major functions included in this logic block. #### 18.7.1.1 Access evaluation – hit determination To determine if the current AHB reference hits in the given region, two magnitude comparators are used in conjunction with the region's start and end addresses. The boolean equation for this portion of the hit determination is defined as: ### Equation 13 region\_hit =((haddr[0:26]>= rgdn.srtaddr[0:26]) & (haddr[0:26] <= rgdn.endaddr[0:26])) #### & rgdn.vld where haddr[\*] is the current AHB reference address, rgdn.srtaddr[\*] and rgdn.endaddr[\*] are the start and end addresses, and rgdn.vld is the valid bit, all from region descriptor n. Recall there are no hardware checks to verify that rgdn.endaddr > rgdn.srtaddr, and it is software's responsibility to properly load appropriate values into these fields of the region descriptor. In addition to the algebraic comparison of the AHB reference address versus the region descriptor's start and end addresses, the optional process identifier is examined against the region descriptor's PID and PIDMASK fields. Using the hmaster[\*] number to select the appropriate MxPE field from the region descriptor, a process identifier hit term is formed as: #### Equation 14 pid\_hit #### =~rqdn.mxpe ### | ((current\_pid[0:7] | rgdn.pidmask[0:7])== (rgdn.pid[0:7] | rgdn.pidmask[0:7])) where the <code>current\_pid[\*]</code> is the selected process identifier from the current bus master, and <code>rgdn.pid[\*]</code> and <code>rgdn.pidmask[\*]</code> are the appropriate process identifier fields from the region descriptor n. For AHB bus masters that do *not* output a process identifier, the MPU forces the <code>pid</code> hit term to be asserted. As shown in *Figure 208*, the access evaluation macro actually forms the logical complement (*hit b*) of the combined region hit and pid hit boolean equations. ### 18.7.1.2 Access evaluation – privilege violation determination While the access evaluation macro is making the region hit determination, the logic is also evaluating if the current access is allowed by the permissions defined in the region descriptor. Using the AHB hmaster[\*] and hprot[1] (supervisor/user mode) signals, a set of effective permissions (eff\_rgd[r,w,x]) is generated from the appropriate fields in the region descriptor. The protection violation logic then evaluates the access against the effective permissions using the specification shown in *Table 216*. Inputs Output Description **Protection** hwrite hprot[0] eff\_rgd[r] eff\_rgd[w] eff\_rgd[x] Violation? inst fetch read 0 0 0 yes, no x permission inst fetch read 0 0 1 no, access is allowed 0 1 0 data read yes, no r permission 1 data read 0 1 no, access is allowed data write 1 0 yes, no w permission 1 data write no, access is allowed Table 216. Protection violation definition The resulting boolean equation for the processor protection violations is: Equation 15 cpu protection violation = ~hwrite & ~hprot[0] & ~eff\_rgdn[x]// ifetch & no x | ~hwrite & hprot[0] & ~eff\_rgdn[r]// data\_read & no r | hwrite& ~eff rgdn[w] // data write& no w The resulting boolean equation for the non-processor protection violations is: Equation 16 protection\_violation = ~hwrite & ~eff rgdn[r]// data read & no r | hwrite& ~eff\_rgdn[w] // data\_write& no w As shown in *Figure 208*, the output of the protection violation logic is the *error* signal, that is, *error* = protection violation. The access evaluation macro then uses the $hit\_b$ and error signals to form two outputs. The combined $(hit\_b \mid error)$ signal is used to signal the current access is not allowed and $(\sim hit\_b \& error)$ is used as the input to MPU\_EDRn (error detail register) in the event of an error. The critical timing arc through the access evaluation macro involves the delay from the arrival of haddr[\*] through the two magnitude comparators and through the $hit_b$ generation as shown in *Figure 209*. Figure 209. Access evaluation macro critical timing path # 18.7.2 Putting it all together and AHB error terminations For each AHB slave port being monitored, the MPU performs a **reduction-AND** of all the individual $(hit\_b \mid error)$ terms from each access evaluation macro. This expression then terminates the bus cycle with an error and reports a protection error for three conditions: - 1. If the access does not hit in any region descriptor, a protection error is reported. - 2. If the access hits in a single region descriptor and that region signals a protection violation, then a protection error is reported. - 3. If the access hits in multiple (overlapping) regions and *all* regions signal protection violations, then a protection error is reported. The third condition reflects that priority is given to *permission granting over access denying* for overlapping regions as this approach provides more flexibility to system software in region descriptor assignments. For an example of the use of overlapping region descriptors, see *Section 18.9: Application information*. The handling of the AHB bus cycle with a protection error requires two distinct actions. First, recall the protection error logic resides within the AHB address phase pipeline stage. In the event of a protection error, the reference must be inhibited from entering the AHB data phase for the targeted slave device. Stated differently, the reference's address phase must be aborted as viewed by the targeted slave device. This is accomplished by dynamically revising the htrans[\*] signal sent to the slave device. The htrans[\*] attribute signals an idle or valid reference (as a non-sequential or sequential access), and this signal is "intercepted" by the MPU. If the access is allowed, then the MPU simply passes the original htrans[\*] value to the slave device. However if a protection error is detected, then the MPU forces htrans[\*] sent to the slave to the IDLE encoding. This effectively cancels the transaction before it is seen by the slave device. While forcing htrans[\*] = IDLE effectively prevents the bus cycle from being transmitted to the slave device, the AHB transaction has already been "committed" in other portions of the platform, namely in the initiating bus master and the crossbar switch. To properly terminate the bus cycle for these modules, it is necessary to post the standard 2-cycle AHB error response. For this response, the hresp[\*] signal is forced to the ERROR encoding for 2 cycles, the first with hready negated and the second with hready asserted. To perform these termination functions, the MPU "intercepts" the hready and hresp[\*] signals from the slave devices, performs the required logic functions to force the response on the bus cycle with a protection error, and then outputs the adjusted values to the crossbar switch. ### 18.8 Initialization information The reset state of MPU\_CESR[VLD] disables the entire module. Recall while the MPU is disabled, all accesses from all bus masters are allowed. This state also minimizes the power dissipation of the MPU. The power dissipation of each access evaluation macro is minimized when the associated region descriptor is marked as invalid or when MPU\_CESR[VLD] = 0. Typically the appropriate number of region descriptors (MPU\_RGDn) are loaded at system startup, including the setting of the MPU\_RGDn.Word3[VLD] bits, before MPU\_CESR[VLD] is set, enabling the module. This approach allows all the loaded region descriptors to be enabled simultaneously. Recall if a memory reference does not hit in any region descriptor, the attempted access is terminated with an error. # 18.9 Application information In an operational system, interfacing with the MPU can generally be classified into the following activities: - Creation of a new memory region requires loading the appropriate region descriptor into an available register location. When a new descriptor is loaded into a RGDn, it would typically be performed using four 32-bit word writes. As discussed in Section 18.6.4.4: MPU Region Descriptor n, Word 3 (MPU\_RGDn.Word3), the hardware assists in the maintenance of the valid bit, so if this approach is followed, there are no coherency issues associated with the multi-cycle descriptor writes. Deletion/removal of an existing memory region is performed simply by clearing MPU RGDn.Word3[VLD]. - 2. If only the access rights for an existing region descriptor need to change, a 32-bit write to the alternate version of the access control word (MPU\_RGDAACn) would typically be performed. Recall writes to the region descriptor using this alternate access control location do not affect the valid bit, so there are, by definition, no coherency issues involved with the update. The access rights associated with the memory region switch instantaneously to the new value as the IPS write completes. - 3. If the region's start and end addresses are to be changed, this would typically be performed by writing a minimum of three words of the region descriptor: MPU\_RGDn.Word{0,1,3}, where the writes to Word0 and Word1 redefine the start and end addresses respectively and the write to Word3 re-enables the region descriptor valid bit. In many situations, all four words of the region descriptor would be rewritten. - 4. Typically, references to the MPU's programming model would be restricted to supervisor mode accesses from a specific processor(s), so a region descriptor would be specifically allocated for this purpose with attempted accesses from other masters or while in user mode terminated with an error. - 5. When the MPU detects an access error, the current AHB bus cycle is terminated with an error response and information on the faulting reference captured in the MPU\_EARn and MPU\_EDRn registers. The error-terminated AHB bus cycle typically initiates some type of error response in the originating bus master. For example, a processor core may respond with a bus error exception, while a data movement bus master may respond with an error interrupt. In any event, the processor can retrieve the captured error address and detail information simply be reading the MPU\_E{A,D}Rn registers. Information on which error registers contain captured fault data is signaled by MPU\_CESR[SPERR]. - 6. Finally, consider the use of overlapping region descriptors. Application of overlapping regions can often reduce the number of descriptors required for a given set of access controls. It is important to note that, in the overlapping memory space, the protection rights of the corresponding region descriptors are logically summed together (the boolean OR operator). In the following example of a dual-core system, there are four bus masters: the two processors (CP0, CP1) and two DMA engines (DMA1, a traditional data movement engine transferring data between RAM and peripherals and DMA2, a second engine transferring data to/from the RAM only). Consider the region descriptor assignments in *Table 217*. In this example, there are 8 descriptors used to span 9 regions in the three main spaces of the system memory map (flash, RAM and IPS peripheral space). Each region indicates the specific permissions for each of the four bus masters and this definition provides an appropriate set of shared, private and executable memory spaces. Of particular interest are the two overlapping spaces: region descriptors 2 & 3 and 3 & 4. The space defined by RGD2 with no overlap is a private data and stack area that provides read/write access to CP0 only. The overlapping space between RGD2 and RGD3 defines a shared data space for passing data from CP0 to CP1 and the access controls are defined by the logical OR of the two region descriptors. Thus, CP0 has (rw-|r--)=(rw-) permissions, while CP1 has (---|r--)=(r--) permission in this space. Both DMA engines are excluded from this shared processor data region. The overlapping spaces between RGD3 and RGD4 defines another shared data space, this one for passing data from CP1 to CP0. For this overlapping space, CP0 has (r--|---)=(r--) permission, while CP1 has (rw-|-r--)=(rw-) permission. The non-overlapped space of RGD4 defines a private data and stack area for CP1 only. The space defined by RGD5 is a shared data region, accessible by all four bus masters. Finally, the slave peripheral space mapped onto the IPS bus is partitioned into two regions: one containing the MPU's programming model accessible only to the two processor cores and the remaining peripheral region accessible to both processors and the traditional DMA1 master. This simple example is intended to show one possible application of the capabilities of the Memory Protection Unit in a typical system. Table 217. Overlapping region descriptor example | Region description | RGDn | CP0 | CP1 | DMA1 | DMA2 | System space | |--------------------|------|-----|-----|------|------|-------------------| | CP0 code | 0 | rwx | r | | | Flash memory | | CP1 code | 1 | r | rwx | | | r lastrificitiory | Table 217. Overlapping region descriptor example(Continued) | Region description | RGDn | | CP0 | CP1 | DMA1 | DMA2 | System space | |-----------------------|------|---|-----|-----|------|------|--------------| | CP0 data and stack | 2 | 2 | rw- | | | | | | CP0 → CP1 shared data | | 3 | r | r | | | | | CP1 → CP0 shared data | | | | 1 | | | SRAM | | CP1 data and stack | 2 | | | rw- | | | | | Shared DMA data | 5 | | rw- | rw- | rw | rw | | | MPU | 6 | | rw- | rw- | | | IPS | | Peripherals | 7 | | rw- | rw- | rw | | IF3 | # 19 Enhanced Direct Memory Access (eDMA) # 19.1 Introduction This chapter describes the enhanced Direct Memory Access (eDMA) Controller, a second-generation module capable of performing complex data transfers with minimal intervention from a host processor. # 19.2 Overview The enhanced direct memory access (eDMA) controller hardware microarchitecture includes a DMA engine that performs source and destination address calculations, and the actual data movement operations, along with SRAM-based local memory containing the transfer control descriptors (TCD) for the channels. Figure 210 is a block diagram of the eDMA module. Figure 210. eDMA block diagram ## 19.3 Features The eDMA is a highly programmable data transfer engine, which has been optimized to minimize the required intervention from the host processor. It is intended for use in applications where the data size to be transferred is statically known, and is *not* defined within the data packet itself. The eDMA module features: - All data movement via dual-address transfers: read from source, write to destination - Programmable source, destination addresses, transfer size, plus support for enhanced addressing modes - 16-channel implementation performs complex data transfers with minimal intervention from a host processor - 32 bytes of data registers, used as temporary storage to support burst transfers (refer to SSIZE bit) - Connections to the crossbar switch for bus mastering the data movement - Transfer control descriptor (TCD) organized to support two-deep, nested transfer operations - 32-byte TCD per channel stored in local memory - An inner data transfer loop defined by a minor byte transfer count - An outer data transfer loop defined by a major iteration count - Channel activation via one of three methods: - Explicit software initiation - Initiation via a channel-to-channel linking mechanism for continual transfers - Peripheral-paced hardware requests (one per channel) Note: For all three methods, one activation per execution of the minor loop is required. - Support for fixed-priority and round-robin channel arbitration - Channel completion reported via optional interrupt requests - 1 interrupt per channel, optionally asserted at completion of major iteration count - Error terminations are enabled per channel, and logically summed together to form a single error interrupt. - Support for scatter/gather DMA processing - Any channel can be programmed so that it can be suspended by a higher priority channel's activation, before completion of a minor loop. Throughout this chapter, *n* is used to reference the channel number. Additionally, data sizes are defined as byte (8-bit), halfword (16-bit), word (32-bit) and doubleword (64-bit). # 19.4 Modes of operation #### 19.4.1 Normal mode In normal mode, the eDMA transfers data between a source and a destination. The source and destination can be a memory block or an I/O block capable of operation with the eDMA. # 19.4.2 Debug mode If enabled by EDMA\_CR[EDBG] and the CPU enters debug mode, the eDMA does not grant a service request when the debug input signal is asserted. If the signal asserts during a data block transfer as described by a minor loop in the current active channel's TCD, the eDMA continues the operation until the minor loop completes. # 19.5 Memory map and register definition # 19.5.1 Memory map The eDMA programming model is partitioned into two regions: Region 1 defines control registers; Region 2 defines the local transfer control for the descriptor memory. Table 218 is a 32-bit view of the eDMA memory map. Table 218. eDMA memory map | Offset from<br>EDMA_BASE<br>(0xFFF4_4000) | Register | Location | |-------------------------------------------|------------------------------------------------------|-------------| | 0x0000 | EDMA_CR—Control Register | on page 458 | | 0x0004 | EDMA_ESR—eDMA Error Status Register | on page 459 | | 0x0008 | Reserved | | | 0x000C | EDMA_ERQL—eDMA Enable Request Register | on page 461 | | 0x0010 | Reserved | | | 0x0014 | EDMA_EEIRL—eDMA Enable Error Interrupt Register | on page 462 | | 0x0018 | EDMA_SERQR—eDMA Set Enable Request Register | on page 463 | | 0x0019 | EDMA_CERQR—eDMA Clear Enable Request Register | on page 464 | | 0x001A | EDMA_SEEI—eDMA Set Enable Error Interrupt Register | on page 464 | | 0x001B | EDMA_CEEI—eDMA Clear Enable Error Interrupt Register | on page 465 | | 0x001C | EDMA_CIRQR—eDMA Clear Interrupt Request Register | on page 465 | | 0x001D | EDMA_CER—eDMA Clear Error Register | on page 466 | | 0x001E | EDMA_SSBR—eDMA Set START Bit Register | on page 466 | | 0x001F | EDMA_CDSBR—eDMA Clear DONE Status Register | on page 467 | | 0x0020 | Reserved | | | 0x0024 | EDMA_IRQRL—eDMA Interrupt Request Register | on page 468 | | 0x0028 | Reserved | | | 0x002C | EDMA_ERL—eDMA Error Register | on page 468 | | 0x0030 | Reserved | | | 0x0034 | EDMA_HRSL—eDMA Hardware Request Status Register | on page 469 | Table 218. eDMA memory map(Continued) | Offset from<br>EDMA_BASE<br>(0xFFF4_4000) | Register | Location | |-------------------------------------------|----------------------------------------------|-------------| | 0x0038-0x00FF | Reserved | | | 0x0100 | EDMA_CPR0—eDMA Channel 0 Priority Register | on page 470 | | 0x0101 | EDMA_CPR1—eDMA Channel 1 Priority Register | on page 470 | | 0x0102 | EDMA_CPR2—eDMA Channel 2 Priority Register | on page 470 | | 0x0103 | EDMA_CPR3—eDMA Channel 3 Priority Register | on page 470 | | 0x0104 | EDMA_CPR4—eDMA Channel 4 Priority Register | on page 470 | | 0x0105 | EDMA_CPR5—eDMA Channel 5 Priority Register | on page 470 | | 0x0106 | EDMA_CPR6—eDMA Channel 6 Priority Register | on page 470 | | 0x0107 | EDMA_CPR7—eDMA Channel 7 Priority Register | on page 470 | | 0x0108 | EDMA_CPR8—eDMA Channel 8 Priority Register | on page 470 | | 0x0109 | EDMA_CPR9—eDMA Channel 9 Priority Register | on page 470 | | 0x010A | EDMA_CPR10—eDMA Channel 10 Priority Register | on page 470 | | 0x010B | EDMA_CPR11—eDMA Channel 11 Priority Register | on page 470 | | 0x010C | EDMA_CPR12—eDMA Channel 12 Priority Register | on page 470 | | 0x010D | EDMA_CPR13—eDMA Channel 13 Priority Register | on page 470 | | 0x010E | EDMA_CPR14—eDMA Channel 14 Priority Register | on page 470 | | 0x010F | EDMA_CPR15—eDMA Channel 15 Priority Register | on page 470 | | 0x0110-0x0FFF | Reserved | | | 0x1000 | TCD00—Transfer Control Descriptor 0 | on page 471 | | 0x1020 | TCD01—Transfer Control Descriptor 1 | on page 471 | | 0x1040 | TCD02—Transfer Control Descriptor 2 | on page 471 | | 0x1060 | TCD03—Transfer Control Descriptor 3 | on page 471 | | 0x1080 | TCD04—Transfer Control Descriptor 4 | on page 471 | | 0x10A0 | TCD05—Transfer Control Descriptor 5 | on page 471 | | 0x10C0 | TCD06—Transfer Control Descriptor 6 | on page 471 | | 0x10E0 | TCD07—Transfer Control Descriptor 7 | on page 471 | | 0x1100 | TCD08—Transfer Control Descriptor 8 | on page 471 | | 0x1120 | TCD09—Transfer Control Descriptor 9 | on page 471 | | 0x1140 | TCD10—Transfer Control Descriptor 10 | on page 471 | | 0x1160 | TCD11—Transfer Control Descriptor 11 | on page 471 | | 0x1180 | TCD12—Transfer Control Descriptor 12 | on page 471 | | 0x11A0 | TCD13—Transfer Control Descriptor 13 | on page 471 | | 0x11C0 | TCD14—Transfer Control Descriptor 14 | on page 471 | | Table 216. edwA memory map(Continued) | | | | | |---------------------------------------|----------|--|--|--| | | | | | | | Register | Location | | | | Table 218 aDMA memory man(Continued) | 0x11E0 | TCD15—Transfer Control Descriptor 15 | on page 47 | |---------------|--------------------------------------|------------| | 0x1200-0x3FFF | Reserved | | | | | | #### 19.5.2 Register descriptions Offset from EDMA\_BASE (0xFFF4\_4000) Read operations on reserved bits in a register return undefined data. Do not write operations to reserved bits. Writing to reserved bits in a register can generate errors. The maximum register bit-width for this device is 16 bits wide. #### 19.5.2.1 eDMA Control Register (EDMA\_CR) The 32-bit EDMA\_CR defines the basic operating configuration of the eDMA. The eDMA arbitrates channel service requests in one group of 16 channels. Arbitration can be configured to use either fixed-priority or round-robin. In fixed-priority arbitration, the highest priority channel requesting service is selected to execute. The priorities are assigned by the channel priority registers. In round-robin arbitration mode, the channel priorities are ignored and the channels are cycled through, from channel 15 down to channel 0, without regard to priority. Refer to Section 19.5.2.16: eDMA Channel n Priority Registers (EDMA\_CPRn). Figure 211. eDMA Control Register (EDMA\_CR) Table 219. EDMA\_CR field descriptions | Field | Description | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-28 | Reserved. | | 29<br>ERCA | Enable round-robin channel arbitration. 0 Fixed-priority arbitration is used for channel selection within each group. 1 Round-robin arbitration is used for channel selection within each group. | | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 30<br>EDBG | <ul> <li>Enable debug.</li> <li>The assertion of the system debug control input is ignored.</li> <li>The assertion of the system debug control input causes the eDMA to stall the start of a new channel. Executing channels are allowed to complete. Channel execution resumes when either the system debug control input is negated or the EDBG bit is cleared.</li> </ul> | | 31 | Reserved. | Table 219, EDMA CR field descriptions(Continued) ### 19.5.2.2 eDMA Error Status Register (EDMA\_ESR) The EDMA\_ESR provides information concerning the last recorded channel error. Channel errors can be caused by a configuration error (an illegal setting in the transfer control descriptor or an illegal priority register setting in fixed arbitration mode) or an error termination to a bus master read or write cycle. A configuration error is caused when the starting source or destination address, source or destination offsets, minor loop byte count, and the transfer size represent an inconsistent state. The addresses and offsets must be aligned on 0-modulo-transfer\_size boundaries, and the minor loop byte count must be a multiple of the source and destination transfer sizes. All source reads and destination writes must be configured to the natural boundary of the programmed transfer size respectively. In fixed arbitration mode, a configuration error is caused by any two channel priorities being equal within a group, or any group priority levels being equal among the groups. For either type of priority configuration error, the ERRCHN field is undefined. All channel priority levels within a group must be unique and all group priority levels among the groups must be unique when fixed arbitration mode is enabled. If a scatter/gather operation is enabled upon channel completion, a configuration error is reported if the scatter/gather address (DLAST\_SGA) is not aligned on a 32-byte boundary. If minor loop channel linking is enabled upon channel completion, a configuration error is reported when the link is attempted if the TCD.CITER.E\_LINK bit does not equal the TCD.BITER.E\_LINK bit. All configuration error conditions except scatter/gather and minor loop link error are reported as the channel is activated and assert an error interrupt request if enabled. When properly enabled, a scatter/gather configuration error is reported when the scatter/gather operation begins at major loop completion. A minor loop channel link configuration error is reported when the link operation is serviced at minor loop completion. If a system bus read or write is terminated with an error, the data transfer is immediately stopped and the appropriate bus error flag is set. In this case, the state of the channel's transfer control descriptor is updated by the eDMA engine with the current source address, destination address, and minor loop byte count at the point of the fault. If a bus error occurs on the last read prior to beginning the write sequence, the write executes using the data captured during the bus error. If a bus error occurs on the last write prior to switching to the next read sequence, the read sequence executes before the channel is terminated due to the destination bus error. The occurrence of any type of error causes the eDMA engine to stop the active channel, and the appropriate channel bit in the eDMA error register to be asserted. At the same time, the details of the error condition are loaded into the EDMA\_ESR. The major loop complete indicators, setting the transfer control descriptor DONE flag and the possible assertion of an interrupt request, are *not* affected when an error is detected. After the error status has been updated, the eDMA engine continues to operate by servicing the next appropriate channel. A channel that experiences an error condition is not automatically disabled. If a channel is terminated by an error and then issues another service request before the error is fixed, that channel executes and terminates with the same error condition. Figure 212. eDMA Error Status Register (EDMA\_ESR) Table 220. EDMA\_ESR field descriptions | Field | Description | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>VLD | Logical OR of all EDMA_ERH and EDMA_ERL status bits. 0 No EDMA_ER bits are set. 1 At least one EDMA_ER bit is set indicating a valid error exists that has not been cleared. | | 1–15 | Reserved. | | 17<br>CPE | Channel priority error. 0 No channel priority error. 1 The last recorded error was a configuration error in the channel priorities within a group, indicating not all channel priorities within a group are unique. | | 18–23<br>ERRCHN[0:5] | Error channel number. Channel number of the last recorded error (excluding GPE and CPE errors). Note: Do not rely on the number in the ERRCHN field for group and channel priority errors. Group and channel priority errors need to be resolved by inspection. The application code must interrogate the priority registers to find groups or channels with duplicate priority level. | | 24<br>SAE | Source address error. 0 No source address configuration error. 1 The last recorded error was a configuration error detected in the TCD.SADDR field, indicating TCD.SADDR is inconsistent with TCD.SSIZE. | | 25<br>SOE | Source offset error. 0 No source offset configuration error. 1 The last recorded error was a configuration error detected in the TCD.SOFF field, indicating TCD.SOFF is inconsistent with TCD.SSIZE. | | 26<br>DAE | Destination address error. 0 No destination address configuration error. 1 The last recorded error was a configuration error detected in the TCD.DADDR field, indicating TCD.DADDR is inconsistent with TCD.DSIZE. | Table 220. EDMA\_ESR field descriptions(Continued) | Field | Description | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27<br>DOE | Destination offset error. 0 No destination offset configuration error. 1 The last recorded error was a configuration error detected in the TCD.DOFF field, indicating TCD.DOFF is inconsistent with TCD.DSIZE. | | 28<br>NCE | NBYTES/CITER configuration error. No NBYTES/CITER configuration error. The last recorded error was a configuration error detected in the TCD.NBYTES or TCD.CITER fields, indicating the following conditions exist: TCD.NBYTES is not a multiple of TCD.SSIZE and TCD.DSIZE, or TCD.CITER is equal to zero, or TCD.CITER.E_LINK is not equal to TCD.BITER.E_LINK. | | 29<br>SGE | Scatter/gather configuration error. No scatter/gather configuration error. The last recorded error was a configuration error detected in the TCD.DLAST_SGA field, indicating TCD.DLAST_SGA is not on a 32-byte boundary. This field is checked at the beginning of a scatter/gather operation after major loop completion if TCD.E_SG is enabled. | | 30<br>SBE | Source bus error. 0 No source bus error. 1 The last recorded error was a bus error on a source read. | | 31<br>DBE | Destination bus error. 0 No destination bus error. 1 The last recorded error was a bus error on a destination write. | # 19.5.2.3 eDMA Enable Request Register (EDMA\_ERQRL) The EDMA\_ERQRL provides a bit map for the 16 implemented channels to enable the request signal for each channel. EDMA\_ERQRL maps to channels 15–0. The state of any given channel enable is directly affected by writes to this register; the state is also affected by writes to the EDMA\_SERQR and EDMA\_CERQR. The EDMA\_CERQR and EDMA\_SERQR are provided so that the request enable for a *single* channel can easily be modified without the need to perform a read-modify-write sequence to the EDMA\_ERQRL. Both the DMA request input signal and this enable request flag must be asserted before a channel's hardware service request is accepted. The state of the eDMA enable request flag does *not* affect a channel service request made explicitly through software or a linked channel request. Figure 213. eDMA Enable Request Register (EDMA\_ERQRL) Table 221. EDMA\_ERQRL field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 16–31 | Enable DMA hardware service request <i>n</i> . 0 The DMA request signal for channel n is disabled. 1 The DMA request signal for channel n is enabled. | As a given channel completes the processing of its major iteration count, there is a flag in the transfer control descriptor that can affect the ending state of the EDMA ERQR bit for that channel. If the TCD.D REQ bit is set, then the corresponding EDMA ERQR bit is cleared after the major loop is complete, disabling the DMA hardware request. Otherwise if the D REQ bit is cleared, the state of the EDMA ERQR bit is unaffected. #### 19.5.2.4 eDMA Enable Error Interrupt Register (EDMA\_EEIRL) The EDMA EEIRL provides a bit map for the 16 channels to enable the error interrupt signal for each channel. EDMA EEIRL maps to channels 15-0. The state of any given channel's error interrupt enable is directly affected by writes to these registers; it is also affected by writes to the EDMA SEEIR and EDMA CEEIR. The EDMA SEEIR and EDMA CEEIR are provided so that the error interrupt enable for a single channel can easily be modified without the need to perform a read-modify-write sequence to the EDMA EEIRL. Both the DMA error indicator and this error interrupt enable flag must be asserted before an error interrupt request for a given channel is asserted. Figure 214. eDMA Enable Error Interrupt Register (EDMA\_EEIRL) Table 222. EDMA\_EEIRL field descriptions | Field | Description | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16-31<br>EEI <i>n</i> | Enable error interrupt <i>n</i> . 0 The error signal for channel <i>n</i> does not generate an error interrupt. 1 The assertion of the error signal for channel <i>n</i> generate an error interrupt request. | ### 19.5.2.5 eDMA Set Enable Request Register (EDMA\_SERQR) The EDMA\_SERQR provides a simple memory-mapped mechanism to set a given bit in the EDMA\_ERQRL to enable the DMA request for a given channel. The data value on a register write causes the corresponding bit in the EDMA\_ERQRL to be set. Setting bit 1 (SERQn) provides a global set function, forcing the entire contents of EDMA\_ERQRL to be asserted. Reads of this register return all zeroes. Figure 215. eDMA Set Enable Request Register (EDMA\_SERQR) Table 223. EDMA\_SERQR field descriptions | Field | Descriptions | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7 | Set enable request. 0–15 Set corresponding bit in EDMA_ERQRL 16–63Reserved 64–127Set all bits in EDMA_ERQRL Note: Bit 2 (SERQ1) is not used. | ## 19.5.2.6 eDMA Clear Enable Request Register (EDMA\_CERQR) The EDMA\_CERQR provides a simple memory-mapped mechanism to clear a given bit in the EDMA\_ERQRL to disable the DMA request for a given channel. The data value on a register write causes the corresponding bit in the EDMA\_ERQRL to be cleared. Setting bit 1 (CERQn) provides a global clear function, forcing the entire contents of the EDMA\_ERQRL to be zeroed, disabling all DMA request inputs. Reads of this register return all zeroes. Figure 216. eDMA Clear Enable Request Register (EDMA\_CERQR) | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>CERQ[0:6] | Clear enable request. 0–15 Clear corresponding bit in EDMA_ERQRL 16–63Reserved 64–127Clear all bits in EDMA_ERQRL | | | Note: Bit 2 (CERQ1) is not used. | Table 224. EDMA\_CERQR field descriptions # 19.5.2.7 eDMA Set Enable Error Interrupt Register (EDMA\_SEEIR) The EDMA\_SEEIR provides a simple memory-mapped mechanism to set a given bit in the EDMA\_EEIRL to enable the error interrupt for a given channel. The data value on a register write causes the corresponding bit in the EDMA\_EEIRL to be set. Setting bit 1 (SEEI*n*) provides a global set function, forcing the entire contents of EDMA\_EEIRL to be asserted. Reads of this register return all zeroes. Figure 217. eDMA Set Enable Error Interrupt Register (EDMA\_SEEIR) | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>SEEI[0:6] | Set enable error interrupt. 0–15 Set corresponding bit in EDMA_EIRRL 16–63 Reserved 64–127 Set all bits in EDMA_EEIRL | | | Note: Bit 2 (SEEI1) is not used. | Table 225. EDMA SEEIR field descriptions # 19.5.2.8 eDMA Clear Enable Error Interrupt Register (EDMA\_CEEIR) The EDMA\_CEEIR provides a simple memory-mapped mechanism to clear a given bit in the EDMA\_EEIRL to disable the error interrupt for a given channel. The data value on a register write causes the corresponding bit in the EDMA\_EEIRL to be cleared. Setting bit 1 (CEEIn) provides a global clear function, forcing the entire contents of the EDMA\_EEIRL to be zeroed, disabling error interrupts for all channels. Reads of this register return all zeroes. Figure 218. eDMA Set Enable Error Interrupt Register (EDMA\_SEEIR) | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>CEEI[0:6] | Clear enable error interrupt. 0–15 Clear corresponding bit in EDMA_EEIRL 16–63 Reserved 64–127 Clear all bits in EDMA_EEIRL | | | Note: Bit 2 (CEEI1) is not used. | Table 226. EDMA\_CEEIR field descriptions # 19.5.2.9 eDMA Clear Interrupt Request Register (EDMA\_CIRQR) The EDMA\_CIRQR provides a simple memory-mapped mechanism to clear a given bit in the EDMA\_IRQRL to disable the interrupt request for a given channel. The given value on a register write causes the corresponding bit in the EDMA\_IRQRL to be cleared. Setting bit 1 (CINT*n*) provides a global clear function, forcing the entire contents of the EDMA\_IRQRL to be zeroed, disabling all DMA interrupt requests. Reads of this register return all zeroes. Figure 219. eDMA Clear Interrupt Request (EDMA\_CIRQR) Table 227. EDMA\_CIRQR field descriptions | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>CINT[0:6] | Clear interrupt request. 0–15 Clear corresponding bit in EDMA_IRQRL 16–63 Reserved 64–127 Clear all bits in EDMA_IRQRL Note: Bit 2 (CINT1) is not used. | ## 19.5.2.10 eDMA Clear Error Register (EDMA\_CER) The EDMA\_CER provides a simple memory-mapped mechanism to clear a given bit in the EDMA\_ERL to disable the error condition flag for a given channel. The given value on a register write causes the corresponding bit in the EDMA\_ERL to be cleared. Setting bit 1 (CERn) provides a global clear function, forcing the entire contents of the EDMA\_ERL to be zeroed, clearing all channel error indicators. Reads of this register return all zeroes. Figure 220. eDMA Clear Error Register (EDMA\_CER) Table 228. EDMA\_CER field descriptions | Field | Description | |-----------------|------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>CER[0:6] | Clear error indicator. 0–15 Clear corresponding bit in EDMA_ERL 16–63 Reserved 64–127 Clear all bits in EDMA_ERL | ## 19.5.2.11 eDMA Set START Bit Register (EDMA\_SSBR) The EDMA\_SSBR provides a simple memory-mapped mechanism to set the START bit in the TCD of the given channel. The data value on a register write causes the START bit in the corresponding transfer control descriptor to be set. Setting bit 1 (SSB*n*) provides a global set function, forcing all START bits to be set. Reads of this register return all zeroes. Figure 221. eDMA Set START Bit Register (EDMA\_SSBR) Table 229. EDMA\_SSBR field descriptions | Field | Description | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>SSB[0:6] | Set START bit (channel service request). 0–15 Set the corresponding channel's TCD START bit 16–63 Reserved 64–127 Set all TCD START bits Note: Bit 2 (SSB1) is not used. | # 19.5.2.12 eDMA Clear DONE Status Bit Register (EDMA\_CDSBR) The EDMA\_CDSBR provides a simple memory-mapped mechanism to clear the DONE bit in the TCD of the given channel. The data value on a register write causes the DONE bit in the corresponding transfer control descriptor to be cleared. Setting bit 1 (CDSBn) provides a global clear function, forcing all DONE bits to be cleared. Figure 222. eDMA Clear DONE Status Bit Register (EDMA\_CDSBR) Table 230. EDMA\_CDSBR field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------| | 0 | Reserved. | | 1–7<br>CDSB[0:6] | Clear DONE status bit. 0–15 Clear the corresponding channel's DONE bit 16–63 Reserved 64–127 Clear all TCD DONE bits | | | Note: Bit 2 (CDSB1) is not used. | ## 19.5.2.13 eDMA Interrupt Request Register (EDMA\_IRQRL) The EDMA\_IRQRL provide a bit map for the 16 channels signaling the presence of an interrupt request for each channel. EDMA\_IRQRL maps to channels 15–0. The eDMA engine signals the occurrence of a programmed interrupt upon the completion of a data transfer as defined in the transfer control descriptor by setting the appropriate bit in this register. The outputs of this register are directly routed to the interrupt controller (INTC). During the execution of the interrupt service routine associated with any given channel, it is software's responsibility to clear the appropriate bit, negating the interrupt request. Typically, a write to the EDMA CIRQR in the interrupt service routine is used for this purpose. The state of any given channel's interrupt request is directly affected by writes to this register; it is also affected by writes to the EDMA\_CIRQR. On writes to the EDMA\_IRQRL, a 1 in any bit position clears the corresponding channel's interrupt request. A zero in any bit position has no affect on the corresponding channel's current interrupt status. The EDMA\_CIRQR is provided so the interrupt request for a *single* channel can easily be cleared without the need to perform a read-modify-write sequence to the EDMA\_IRQRL. Figure 223. eDMA Interrupt Request Low Register (EDMA\_IRQRL) Table 231. EDMA\_IRQRL field descriptions | Field | Description | |-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 16–31<br>INT <i>n</i> | eDMA interrupt request <i>n</i> . 0 The interrupt request for channel <i>n</i> is cleared. 1 The interrupt request for channel <i>n</i> is active. | # 19.5.2.14 eDMA Error Register (EDMA\_ERL) The EDMA\_ERL provides a bit map for the 16 channels signaling the presence of an error for each channel. EDMA\_ERL maps to channels 15-0. The eDMA engine signals the occurrence of a error condition by setting the appropriate bit in this register. The outputs of this register are enabled by the contents of the EDMA\_EEIR, then logically summed across groups of 16 and 32 channels to form several group error interrupt requests that are then routed to the interrupt controller. During the execution of the interrupt service routine associated with any DMA errors, it is software's responsibility to clear the appropriate bit, negating the error interrupt request. Typically, a write to the EDMA\_CER in the interrupt service routine is used for this purpose. Recall the normal DMA channel completion indicators, setting the transfer control descriptor DONE flag and the possible assertion of an interrupt request, are *not* affected when an error is detected. The contents of this register can also be polled and a non-zero value indicates the presence of a channel error, regardless of the state of the EDMA\_EEIR. The EDMA\_ESR[VLD] bit is a logical OR of all bits in this register and it provides a single bit indication of any errors. The state of any given channel's error indicators is affected by writes to this register; it is also affected by writes to the EDMA\_CER. On writes to EDMA\_ERL, a 1 in any bit position clears the corresponding channel's error status. A 0 in any bit position has no affect on the corresponding channel's current error status. The EDMA\_CER is provided so the error indicator for a *single* channel can easily be cleared. Figure 224. eDMA Error Low Register (EDMA\_ERL) Table 232. EDMA\_ERL field descriptions | Field | Description | |-----------------------|-----------------------------------------------------------------------------------------------------------------------| | 16–31<br>ERR <i>n</i> | eDMA Error <i>n</i> . 0 An error in channel <i>n</i> has not occurred. 1 An error in channel <i>n</i> has occurred. | ### 19.5.2.15 eDMA Hardware Request Status (eDMA\_HRSL) The eDMA\_HRSL registers provide a bit map for the implemented channels 16 to show the current hardware request status for each channel. Hardware request status reflects the current state of the enabled hardware requests as seen by the eDMA's arbitration logic. This view into the hardware request signals may be used for debug purposes. Figure 225. EDMA Hardware Request Status Register Low (EDMA\_HRSL) DocID018714 Rev 5 Table 233. EDMA HRSL field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | DMA Hardware Request Status | | | 0 A hardware service request for channel n is not present. | | 16–31 | 1 A hardware service request for channel n is present. | | HRSn | <b>Note:</b> The hardware request status reflects the state of the request as seen by the arbitration logic. Therefore, this status is affected by the EDMA_ERQRL[ERQn] bit. | ### 19.5.2.16 eDMA Channel n Priority Registers (EDMA\_CPRn) When the fixed-priority channel arbitration mode is enabled (EDMA\_CR[ERCA] = 0), the contents of these registers define the unique priorities associated with each channel within a group. The channel priorities are evaluated by numeric value; that is, 0 is the lowest priority, 1 is the next higher priority, then 2, 3, etc. If software chooses to modify channel priority values, then the software must ensure that the channel priorities contain unique values, otherwise a configuration error is reported. The range of the priority value is limited to the values of 0 through 15. When read, the GRPPRI bits of the EDMA\_CPRn register reflect the current priority level of the group of channels in which the corresponding channel resides. GRPPRI bits are not affected by writes to the EDMA\_CPRn registers. The group priority is assigned in the EDMA\_CR. Refer to Figure 211 and Table 219 for the EDMA CR definition. Channel preemption is enabled on a per-channel basis by setting the ECP bit in the EDMA\_CPRn register. Channel preemption allows the executing channel's data transfers to be temporarily suspended in favor of starting a higher priority channel. After the preempting channel has completed all of its minor loop data transfers, the preempted channel is restored and resumes execution. After the restored channel completes one read/write sequence, it is again eligible for preemption. If any higher priority channel is requesting service, the restored channel is suspended and the higher priority channel is serviced. Nested preemption (attempting to preempt a preempting channel) is not supported. After a preempting channel begins execution, it cannot be preempted. Preemption is only available when fixed arbitration is selected for both group and channel arbitration modes. The reset value for the channel priority fields, GRPPRI[0-1] and CHPRI[0-3] is the channel number for the priority register; EDMA CPR15[CHPRI] = 0b1111. Figure 226. eDMA Channel *n* Priority Register (EDMA\_CPR*n*) The following table describes the fields in the eDMA channel *n* priority register: Table 234. EDMA\_CPRn field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>ECP | Enable channel preemption. 0 Channel <i>n</i> cannot be suspended by a higher priority channel's service request. 1 Channel <i>n</i> can be temporarily suspended by the service request of a higher priority channel. | | 1-3 | Reserved. | | 4–7<br>CHPRI[0:3] | Channel <i>n</i> arbitration priority. Channel priority when fixed-priority arbitration is enabled. The reset value for the channel priority fields CHPRI[0–3], is equal to the corresponding channel number for each priority register; that is, EDMA_CPR31[CHPRI] = 0b1111. | ## 19.5.2.17 Transfer Control Descriptor (TCD) Each channel requires a 256-bit transfer control descriptor for defining the desired data movement operation. The channel descriptors are stored in the local memory in sequential order: channel 0, channel 1,... channel 15. The definitions of the TCD are presented as 23 variable-length fields. Table 235 defines the fields of the basic TCD structure. Table 235. TCDn 32-bit memory structure | eDMA Bit Offset | Bit<br>Length | TCD <i>n</i> Field Name | TCD <i>n</i><br>Abbreviation | Word # | |------------------------------|---------------|-----------------------------------------------------------------|------------------------------|--------| | $0x1000 + (32 \times n) + 0$ | 32 | Source address | SADDR | Word 0 | | 0x1000 + (32 × n) + 32 | 5 | Source address modulo | SMOD | | | 0x1000 + (32 × n) + 37 | 3 | Source data transfer size | SSIZE | | | 0x1000 + (32 × n) + 40 | 5 | Destination address modulo | DMOD | Word 1 | | 0x1000 + (32 × n) + 45 | 3 | Destination data transfer size | DSIZE | | | 0x1000 + (32 × n) + 48 | 16 | Signed Source Address Offset | SOFF | | | 0x1000 + (32 × n) + 64 | 32 | Inner minor byte count | NBYTES | Word 2 | | 0x1000 + (32 × n) + 96 | 32 | Last Source Address Adjustment | SLAST | Word 3 | | 0x1000 + (32 × n) + 128 | 32 | Destination Address | DADDR | Word 4 | | 0x1000 + (32 × n) + 160 | 1 | Channel-to-channel Linking on Minor Loop Complete | CITER.E_LINK | | | 0x1000 + (32 × n) + 161 | 6 | Current Major Iteration Count or Link Channel Number | CITER or<br>CITER.LINKCH | Word 5 | | 0x1000 + (32 × n) + 167 | 9 | Current Major Iteration Count | CITER | | | 0x1000 + (32 × n) + 176 | 16 | Destination Address Offset (Signed) | DOFF | | | 0x1000 + (32 × n) + 192 | 32 | Last Destination Address Adjustment /<br>Scatter Gather Address | DLAST_SGA | Word 6 | Table 235. TCDn 32-bit memory structure(Continued) | eDMA Bit Offset | Bit<br>Length | TCD <i>n</i> Field Name | TCD <i>n</i><br>Abbreviation | Word # | | |-------------------------|---------------|---------------------------------------------------------------------------------------|------------------------------|--------|--| | 0x1000 + (32 × n) + 224 | 1 | Channel-to-channel Linking on Minor Loop Complete | BITER.E_LINK | | | | 0x1000 + (32 × n) + 225 | 6 | Starting Major Iteration Count or Link Channel Number | BITER or<br>BITER.LINKCH | | | | 0x1000 + (32 × n) + 231 | 9 | Starting Major Iteration Count | BITER | | | | 0x1000 + (32 × n) +240 | 2 | Bandwidth Control | BWC | = | | | 0x1000 + (32 × n) + 242 | 6 | Link Channel Number | MAJOR.LINKCH | | | | 0x1000 + (32 × n) + 248 | 1 | Channel Done | DONE | | | | 0x1000 + (32 × n) + 249 | 1 | Channel Active | ACTIVE | = | | | 0x1000 + (32 × n) + 250 | 1 | Channel-to-channel Linking on Major<br>Loop Complete | MAJOR.E_LINK | Word 7 | | | 0x1000 + (32 × n) + 251 | 1 | Enable Scatter/Gather Processing E_SG | | = | | | 0x1000 + (32 × n) + 252 | 1 | Disable Request | D_REQ | = | | | 0x1000 + (32 × n) + 253 | 1 | Channel Interrupt Enable When Current Major INT_HALF Iteration Count is Half Complete | | | | | 0x1000 + (32 × n) + 254 | 1 | Channel Interrupt Enable When<br>Current Major<br>Iteration Count Complete | INT_MAJ | | | | 0x1000 + (32 × n) + 255 | 1 | Channel Start | START | | | *Figure 227* defines the fields of the TCD*n* structure. ### Figure 227. TCD structure - If channel linking on minor link completion is disabled, TCD bits [161:175] form a 15-bit CITER field; if channel-to-channel linking is enabled, CITER becomes a 9-bit field. - If channel linking on minor link completion is disabled, TCD bits [225:239] form a 15-bit BITER field; if channel-to-channel linking is enabled, BITER becomes a 9-bit field. Note: The TCD structures for the eDMA channels shown in Figure 227 are implemented in internal SRAM. These structures are not initialized at reset. Therefore, all channel TCD parameters must be initialized by the application code before activating that channel. Table 236 gives a detailed description of the TCNn fields. Table 236. TCDn field descriptions | Bits<br>Word Offset<br>[n:n] | Field Name | Description | | Description | | | |------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-------------|--|--| | 0–31<br>0x0 [0:31] | SADDR<br>[0:31] | Source address. Memory address pointing to the source data. Word 0x0, bits 0–31. | | | | | | 32–36<br>0x4 [0:4] | SMOD<br>[0:4] | Source address modulo. Source address modulo feature is disabled. This value defines a specific address range that is specified to be either the value after SADDR + SOFF calculation is performed or the original register value. The setting of this field provides the ability to easily implement a circular data queue. For data queues requiring power-of-2 "size" bytes, start the queue at a 0-modulo-size address and set the SMOD field to the value for the queue, freezing the desired number of upper address bits. The value programmed into this field specifies the number of lower address bits that are allowed to change. For this circular queue application, the SOFF is typically set to the transfer size to implement post-increment addressing with the SMOD function constraining the addresses to a 0-modulo-size range. | | | | | 474/1102 Table 236. TCDn field descriptions(Continued) | | Table 230. Tobii field descriptions(Continued) | | | | | |------------------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bits<br>Word Offset<br>[n:n] | Field Name | Description | | | | | 37–39<br>0x4 [5:7] | SSIZE<br>[0:2] | Source data transfer size. 000 8-bit 001 16-bit 010 32-bit 011 64-bit 100 32-bit 101 32-byte burst (64-bit x 4) 110 Reserved 111 Reserved The attempted specification of a 'reserved' encoding causes a configuration error. | | | | | 40–44<br>0x4 [8:12] | DMOD<br>[0:4] | Destination address modulo. Refer to the SMOD[0:5] definition. | | | | | 45–47<br>0x4 [13:15] | DSIZE<br>[0:2] | Destination data transfer size. Refer to the SSIZE[0:2] definition. | | | | | 48–63<br>0x4 [16:31] | SOFF<br>[0:15] | Source address signed offset. Sign-extended offset applied to the current source address to form the next-state value as each source read is completed. | | | | | 64–95<br>0x8 [0:31] | NBYTES<br>[0:31] | Inner "minor" byte transfer count. Number of bytes to be transferred in each service request of the channel. As a channel is activated, the contents of the appropriate TCD is loaded into the eDMA engine, and the appropriate reads and writes performed until the complete byte transfer count has been transferred. This is an indivisible operation and cannot be stalled or halted. Once the minor count is exhausted, the current values of the SADDR and DADDR are written back into the local memory, the major iteration count is decremented and restored to the local memory. If the major iteration count is completed, additional processing is performed. Note: The NBYTES value of 0x0000_0000 is interpreted as 0x1_0000_0000, thus specifying a four GB transfer. | | | | | 96–127<br>0xC [0:31] | SLAST<br>[0:31] | Last source address adjustment. Adjustment value added to the source address at the completion of the outer major iteration count. This value can be applied to "restore" the source address to the initial value, or adjust the address to reference the next data structure. | | | | | 128–159<br>0x10 [0:31] | DADDR<br>[0:31] | Destination address. Memory address pointing to the destination data. | | | | | 160<br>0x14 [0] | CITER.E_LINK | Enable channel-to-channel linking on minor loop completion. As the channel completes the inner minor loop, this flag enables the linking to another channel, defined by CITER.LINKCH[0:5]. The link target channel initiates a channel service request via an internal mechanism that sets the TCD.START bit of the specified channel. If channel linking is disabled, the CITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJOR.E_LINK channel linking. 0 The channel-to-channel linking is disabled. 1 The channel-to-channel linking is enabled. Note: This bit must be equal to the BITER.E_LINK bit otherwise a configuration error is reported. | | | | Table 236. TCDn field descriptions(Continued) | Bits<br>Word Offset<br>[n:n] | Field Name | Description | |------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 161–166<br>0x14 [1:6] | CITER<br>[0:5]<br>or<br>CITER.LINKCH<br>[0:5] | Current "major" iteration count or link channel number. If channel-to-channel linking is disabled (TCD.CITER.E_LINK = 0), then No channel-to-channel linking (or chaining) is performed after the inner minor loop is exhausted. TCD bits [161:175] form a 15-bit CITER field. otherwise After the minor loop is exhausted, the eDMA engine initiates a channel service request at the channel defined by CITER.LINKCH[0:5] by setting that channel's TCD.START bit. | | 167–175<br>0x14 [7:15] | CITER<br>[6:14] | Current "major" iteration count. This 9 or 15-bit count represents the current major loop count for the channel. It is decremented each time the minor loop is completed and updated in the transfer control descriptor memory. After the major iteration count is exhausted, the channel performs a number of operations (for example, final source and destination address calculations), optionally generating an interrupt to signal channel completion before reloading the CITER field from the beginning iteration count (BITER) field. Note: When the CITER field is initially loaded by software, it must be set to the same value as that contained in the BITER field. Note: If the channel is configured to execute a single service request, the initial values of BITER and CITER must be 0x0001. | | 176–191<br>0x14 [16:31] | DOFF<br>[0:15] | Destination address signed offset. Sign-extended offset applied to the current destination address to form the next-state value as each destination write is completed. | | 192–223<br>0x18 [0:31] | DLAST_SGA<br>[0:31] | Last destination address adjustment or the memory address for the next transfer control descriptor to be loaded into this channel (scatter/gather). If scatter/gather processing for the channel is disabled (TCD.E_SG = 0) then Adjustment value added to the destination address at the completion of the outer major iteration count. This value can be applied to "restore" the destination address to the initial value, or adjust the address to reference the next data structure. Otherwise This address points to the beginning of a 0-modulo-32 byte region containing the next transfer control descriptor to be loaded into this channel. This channel reload is performed as the major iteration count completes. The scatter/gather address must be 0-modulo-32 byte, otherwise a configuration error is reported. | Table 236. TCDn field descriptions(Continued) | Table 230. Tobii field descriptions(continued) | | | | | |------------------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bits<br>Word Offset<br>[n:n] | Field Name | Description | | | | 224<br>0x1C [0] | BITER.E_LINK | Enables channel-to-channel linking on minor loop complete. As the channel completes the inner minor loop, this flag enables the linking to another channel, defined by BITER.LINKCH[0:5]. The link target channel initiates a channel service request via an internal mechanism that sets the TCD.START bit of the specified channel. If channel linking is disabled, the BITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJOR.E_LINK channel linking. 0 The channel-to-channel linking is disabled. 1 The channel-to-channel linking is enabled. | | | | | | Note: When the TCD is first loaded by software, this field must be set equal to the corresponding CITER field, otherwise a configuration error is reported. As the major iteration count is exhausted, the contents of this field is reloaded into the CITER field. | | | | | | Beginning or starting "major" iteration count or link channel number. If channel-to-channel linking is disabled (TCD.BITER.E_LINK = 0), then | | | | 225–230<br>0x1C [1:6] | BITER<br>[0:5]<br>or<br>BITER.LINKCH<br>[0:5] | <ul> <li>No channel-to-channel linking (or chaining) is performed after the inner minor loop is exhausted. TCD bits [225:239] form a 15-bit BITER field.</li> <li>Otherwise</li> <li>After the minor loop is exhausted, the eDMA engine initiates a channel service request at the channel, defined by BITER.LINKCH[0:5], by setting that channel's TCD.START bit.</li> <li>Note: When the TCD is first loaded by software, this field must be set equal to the</li> </ul> | | | | | | corresponding CITER field, otherwise a configuration error is reported. As the major iteration count is exhausted, the contents of this field is reloaded into the CITER field. | | | | 231–239<br>0x1C [7:15] | BITER<br>[6:14] | Beginning or starting major iteration count. As the transfer control descriptor is first loaded by software, this field must be equal to the value in the CITER field. As the major iteration count is exhausted, the contents of this field is reloaded into the CITER field. Note: If the channel is configured to execute a single service request, the initial values of BITER and CITER must be 0x0001. | | | | 240–241<br>0x1C [16:17] | BWC<br>[0:1] | Bandwidth control. This two-bit field provides a mechanism to effectively throttle the amount of bus bandwidth consumed by the eDMA. In general, as the eDMA processes the inner minor loop, it continuously generates read/write sequences until the minor count is exhausted. This field forces the eDMA to stall after the completion of each read/write access to control the bus request bandwidth seen by the system bus crossbar switch (XBAR). To minimize start-up latency, bandwidth control stalls are suppressed for the first two system bus cycles and after the last write of each minor loop. | | | | | | 00 No eDMA engine stalls 01 Reserved 10 eDMA engine stalls for four cycles after each r/w 11 eDMA engine stalls for eight cycles after each r/w | | | Table 236. TCDn field descriptions(Continued) | Bits | | | | |-------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Word Offset<br>[n:n] | Field Name | Description | | | 242–247<br>0x1C [18:23] | MAJOR.LINKC<br>H<br>[0:5] | Link channel number. If channel-to-channel linking on major loop complete is disabled (TCD.MAJOR.E_LINK = 0) then: - No channel-to-channel linking (or chaining) is performed after the outer major loop counter is exhausted. Otherwise - After the major loop counter is exhausted, the eDMA engine initiates a channel service request at the channel defined by MAJOR.LINKCH[0:5] by setting that channel's TCD.START bit. | | | 248<br>0x1C [24] | DONE | Channel done. This flag indicates the eDMA has completed the outer major loop. It is set by the eDMA engine as the CITER count reaches zero; it is cleared by software or hardware when the channel is activated (when the channel has begun to be processed by the eDMA engine, not when the first data transfer occurs). Note: This bit must be cleared to write the MAJOR.E_LINK or E_SG bits. | | | 249<br>0x1C [25] | ACTIVE | Channel active. This flag signals the channel is currently in execution. It is set when channel service begins, and is cleared by the eDMA engine as the inner minor loop completes or if any error condition is detected. | | | 250<br>0x1C [26] | MAJOR.E_LINK | Enable channel-to-channel linking on major loop completion. As the channel completes the outer major loop, this flag enables the linking to another channel, defined by MAJOR.LINKCH[0:5]. The link target channel initiates a channel service request via an internal mechanism that sets the TCD.START bit of the specified channel. NOTE: To support the dynamic linking coherency model, this field is forced to zero when written to while the TCD.DONE bit is set. 0 The channel-to-channel linking is disabled. 1 The channel-to-channel linking is enabled. | | | 251<br>0x1C [27] | E_SG | Enable scatter/gather processing. As the channel completes the outer major loop, this flag enables scatter/gather processing in the current channel. If enabled, the eDMA engine uses DLAST_SGA as a memory pointer to a 0-modulo-32 address containing a 32-byte data structure that is loaded as the transfer control descriptor into the local memory. NOTE: To support the dynamic scatter/gather coherency model, this field is forced to zero when written to while the TCD.DONE bit is set. 1 The current channel's TCD is "normal" format. 1 The current channel's TCD specifies a scatter gather format. The DLAST_SGA field provides a memory pointer to the next TCD to be loaded into this channel after the outer major loop completes its execution. | | | 252<br>0x1C [28] | D_REQ | Disable hardware request. If this flag is set, the eDMA hardware automatically clears the corresponding EDMA_ERQL bit when the current major iteration count reaches zero. 0 The channel's EDMA_ERQL bit is not affected. 1 The channel's EDMA_ERQL bit is cleared when the outer major loop is complete. | | | Bits<br>Word Offset<br>[n:n] | Field Name | Description | | | |------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 253<br>0x1C [29] | INT_HALF | Enable an interrupt when major counter is half complete. If this flag is set, the channel generates an interrupt request by setting the bit in the EDMA_ERQL when the current major iteration count reaches the halfway point. The eDMA engine performs the compare (CITER == (BITER >> 1)). This halfway point interrupt request supports double-buffered (aka ping-pong) schemes, or where the processor needs an early indication of the data transfer's progress during data movement. CITER = BITER = 1 with INT_HALF enabled generates an interrupt as it satisfies the equation (CITER == (BITER >> 1)) after a single activation. O The half-point interrupt is disabled. 1 The half-point interrupt is enabled. | | | | 254<br>0x1C [30] | INT_MAJ | Enable an interrupt when major iteration count completes. If this flag is set, the channel generates an interrupt request by setting the appropriate bit in the EDMA_ERQL when the current major iteration count reaches zero. 0 The end-of-major loop interrupt is disabled. 1 The end-of-major loop interrupt is enabled. | | | | 255<br>0x1C [31] | START | Channel start. If this flag is set, the channel is requesting service. The eDMA hardware automatically clears this flag after the channel begins execution. O The channel is not explicitly started. The channel is explicitly started via a software initiated service request. | | | Table 236. TCDn field descriptions(Continued) ## 19.6 Functional description This section provides an overview of the microarchitecture and functional operation of the eDMA module. #### 19.6.1 eDMA microarchitecture The eDMA module is partitioned into two major modules: the eDMA engine and the transfer control descriptor local memory. Additionally, the eDMA engine is further partitioned into four submodules, as shown in the following list: #### eDMA engine Address path: This module implements registered versions of two channel transfer control descriptors: channel 'x' and channel 'y,' and is responsible for all the master bus address calculations. All the implemented channels provide the exact same functionality. This hardware structure allows the data transfers associated with one channel to be preempted after the completion of a read/write sequence if a higher priority channel service request is asserted while the first channel is active. After a channel is activated, it runs until the minor loop is completed unless preempted by a higher priority channel. This capability provides a mechanism (optionally enabled by EDMA\_CPRn[ECP]) where a large data move operation can be preempted to minimize the time another channel is blocked from execution. When any other channel is activated, the contents of its transfer control descriptor is read from the local memory and loaded into the registers of the other address path channel{x,y}. After the inner minor loop completes execution, the address path hardware writes the new values for the TCDn.{SADDR, DADDR, CITER} back into the local memory. If the major iteration count is exhausted, additional processing is performed, including the final address pointer updates, reloading the TCDn.CITER field, and a possible fetch of the next TCDn from memory as part of a scatter/gather operation. - Data path: This module implements the actual bus master read/write datapath. It includes 32 bytes of register storage (matching the maximum transfer size) and the necessary mux logic to support any required data alignment. The system read data bus is the primary input, and the system write data bus is the primary output. The address and data path modules directly support the 2-stage pipelined system bus. The address path module represents the 1st stage of the bus pipeline (the address phase), while the data path module implements the 2nd stage of the pipeline (the data phase). - Program model/channel arbitration: This module implements the first section of eDMA's programming model as well as the channel arbitration logic. The programming model registers are connected to the slave bus (not shown). The eDMA peripheral request inputs and eDMA interrupt request outputs are also connected to this module (via the Control logic). - Control: This module provides all the control functions for the eDMA engine. For data transfers where the source and destination sizes are equal, the eDMA engine performs a series of source read, destination write operations until the number of bytes specified in the inner 'minor loop' byte count has been moved. A minor loop interaction is defined as the number of bytes to transfer (*n*bytes) divided by the transfer size. Transfer size is defined as the following: ``` if (SSIZE < DSIZE) transfer size = destination transfer size (# of bytes) else transfer size = source transfer size (# of bytes)</pre> ``` Minor loop TCD variables are SOFF, SMOD, DOFF, DMOD, NBYTES, SADDR, DADDR, BWC, ACTIVE, AND START. Major loop TCD variables are DLAST, SLAST, CITER, BITER, DONE, D\_REQ, INT\_MAJ, MAJOR\_LNKCH, and INT HALF. For descriptors where the sizes are not equal, multiple access of the smaller size data are required for each reference of the larger size. As an example, if the source size references 16-bit data and the destination is 32-bit data, two reads are performed, then one 32-bit write. ## TCD local memory - Memory controller: This logic implements the required dual-ported controller, handling accesses from both the eDMA engine as well as references from the slave bus. As noted earlier, in the event of simultaneous accesses, the eDMA engine is given priority and the slave transaction is stalled. The hooks to a BIST controller for the local TCD memory are included in this module. - Memory array: The TCD is implemented using a single-ported, synchronous compiled RAM memory array. #### 19.6.2 eDMA basic data flow The basic flow of a data transfer can be partitioned into three segments. As shown in *Figure 228*, the first segment involves the channel service request. In the diagram, this example uses the assertion of the eDMA peripheral request signal to request service for channel *n*. Channel service request via software and the TCDn.START bit follows the same basic flow as an eDMA peripheral request. The eDMA peripheral request input signal is registered internally and then routed through the eDMA engine, first through the control module, then into the program model/channel arbitration module. In the next cycle, the channel arbitration is performed, either using the fixed-priority or round-robin algorithm. After the arbitration is complete, the activated channel number is sent through the address path and converted into the required address to access the TCD local memory. Next, the TCD memory is accessed and the required descriptor read from the local memory and loaded into the eDMA engine address path channel{x,y} registers. The TCD memory is organized 64-bits in width to minimize the time needed to fetch the activated channel's descriptor and load it into the eDMA engine address path channel{x,y} registers. Figure 228. eDMA operation, part 1 In the second part of the basic data flow as shown in *Figure 229*, the modules associated with the data transfer (address path, data path and control) sequence through the required source reads and destination writes to perform the actual data movement. The source reads are initiated and the fetched data is temporarily stored in the data path module until it is gated onto the system bus during the destination write. This source read/destination write processing continues until the inner minor byte count has been transferred. The eDMA Done Handshake signal is asserted at the end of the minor byte count transfer. Figure 229. eDMA operation, part 2 After the inner minor byte count has been moved, the final phase of the basic data flow is performed. In this segment, the address path logic performs the required updates to certain fields in the channel's TCD: for example., SADDR, DADDR, CITER. If the outer major iteration count is exhausted, then additional operations are performed. These include the final address adjustments and reloading of the BITER field into the CITER. Additionally, assertion of an optional interrupt request occurs at this time, as does a possible fetch of a new TCD from memory using the scatter/gather address pointer included in the descriptor. The updates to the TCD memory and the assertion of an interrupt request are shown in *Figure 230*. Figure 230. eDMA operation, part 3 ## 19.6.3 eDMA performance This section addresses the performance of the eDMA module, focusing on two separate metrics. In the traditional data movement context, performance is best expressed as the peak data transfer rates achieved using the eDMA. In most implementations, this transfer rate is limited by the speed of the source and destination address spaces. In a second context where device-paced movement of single data values to/from peripherals is dominant, a measure of the requests that can be serviced in a fixed time is a more useful metric. In this environment, the speed of the source and destination address spaces remains important, but the microarchitecture of the eDMA also factors significantly into the resulting metric. The peak transfer rates for several different source and destination transfers are shown in *Table 237*. The following assumptions apply to *Table 237* and *Table 238*: - Internal SRAM can be accessed with zero wait-states when viewed from the system bus data phase. - All slave reads require two wait-states, and slave writes three wait-states, again viewed from the system bus data phase. - All slave accesses are 32-bits in size. | System Speed,<br>Transfer Size | Internal SRAM-to-<br>Internal SRAM | 32-bit Slave-to-<br>Internal SRAM | Internal SRAM-to-<br>32-bit Slave<br>(buffering disabled) | Internal SRAM-to-<br>32-bit Slave<br>(buffering enabled) | |-----------------------------------|------------------------------------|-----------------------------------|-----------------------------------------------------------|----------------------------------------------------------| | 66.7 MHz, 32-bit | 66.7 | 66.7 | 53.3 | 88.7 | | 66.7 MHz, 64-bit | 133.3 | 66.7 | 53.3 | 88.7 | | 66.7 MHz, 256-bit <sup>(1)</sup> | 213.4 | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | | 83.3 MHz, 32-bit | 83.3 | 83.3 | 66.7 | 110.8 | | 83.3 MHz, 64-bit | 166.7 | 83.3 | 66.7 | 110.8 | | 83.3 MHz, 256-bit <sup>(1)</sup> | 266.6 | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | | 100.0 MHz, 32-bit | 100.0 | 100.0 | 80.0 | 133.0 | | 100.0 MHz, 64-bit | 200.0 | 100.0 | 80.0 | 133.0 | | 100.0 MHz, 256-bit <sup>(1)</sup> | 320.0 | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | | 132.0 MHz, 32-bit | 132.0 | 132.0 | 105.6 | 175.6 | | 132.0 MHz, 64-bit | 264.0 | 132.0 | 105.6 | 175.6 | | 132.0 MHz, 256-bit <sup>(1)</sup> | 422.4 | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | N/A <sup>(2)</sup> | Table 237. eDMA peak transfer rates (MB/Sec) *Table 237* presents a peak transfer rate comparison, measured in MBs per second where the internal-SRAM-to-internal-SRAM transfers occur at the core's datapath width; that is, either 32- or 64-bits per access. For all transfers involving the slave bus, 32-bit transfer sizes are used. In all cases, the transfer rate includes the time to read the source plus the time to write the destination. The second performance metric is a measure of the number of DMA requests that can be serviced in a given amount of time. For this metric, it is assumed the peripheral request causes the channel to move a single slave-mapped operand to/from internal SRAM. The same timing assumptions used in the previous example apply to this calculation. In particular, this metric also reflects the time required to activate the channel. The eDMA design supports the following hardware service request sequence: - Cycle 1: eDMA peripheral request is asserted. - Cycle 2: The eDMA peripheral request is registered locally in the eDMA module and qualified. (TCD.START bit initiated requests start at this point with the registering of the slave write to TCD bit 255). - Cycle 3: Channel arbitration begins. - Cycle 4: Channel arbitration completes. The transfer control descriptor local memory read is initiated. - Cycle 5–6: The first two parts of the activated channel's TCD is read from the local memory. The memory width to the eDMA engine is 64 bits, so the entire descriptor can be accessed in four cycles. <sup>1.</sup> A 256-bit transfer occurs as a burst of four 64-bit beats. <sup>2.</sup> Not applicable: burst access to a slave port is not supported. - Cycle 7: The first system bus read cycle is initiated, as the third part of the channel's TCD is read from the local memory. Depending on the state of the crossbar switch, arbitration at the system bus can insert an additional cycle of delay here. - Cycle 8 n: The last part of the TCD is read in. This cycle represents the 1st data phase for the read, and the address phase for the destination write. The exact timing from this point is a function of the response times for the channel's read and write accesses. In this case of an slave read and internal SRAM write, the combined data phase time is 4 cycles. For an SRAM read and slave write, it is 5 cycles. - Cycle n + 1: This cycle represents the data phase of the last destination write. - Cycle n + 2: The eDMA engine completes the execution of the inner minor loop and prepares to write back the required TCDn fields into the local memory. The control/status fields at word offset 0x1C in TCDn are read. If the major loop is complete, the MAJOR.E LINK and E SG bits are checked and processed if enabled. - Cycle n + 3: The appropriate fields in the first part of the TCDn are written back into the local memory. - Cycle n + 4: The fields in the second part of the TCDn are written back into the local memory. This cycle coincides with the next channel arbitration cycle start. - Cycle n + 5: The next channel to be activated performs the read of the first part of its TCD from the local memory. This is equivalent to Cycle 4 for the first channel's service Assuming zero wait states on the system bus, DMA requests can be processed every 9 cycles. Assuming an average of the access times associated with slave-to-SRAM (4 cycles) and SRAM-to-slave (5 cycles), DMA requests can be processed every 11.5 cycles (4 + (4 + 5)/2 + 3). This is the time from Cycle 4 to Cycle "n 5." The resulting peak request rate, as a function of the system frequency, is shown in Table 238. This metric represents millions of requests per second. | System Frequency<br>(MHz) | Request Rate<br>(Zero Wait States) | Request Rate<br>(with Wait States) | |---------------------------|------------------------------------|------------------------------------| | 66.6 | 7.4 | 5.8 | | 83.3 | 9.2 | 7.2 | | 100.0 | 11.1 | 8.7 | | 133.3 | 14.8 | 11.6 | | 150.0 | 16.6 | 13.0 | Table 238. eDMA peak request Rate (MReq/sec) A general formula to compute the peak request rate (with overlapping requests) is: #### **Equation 17** PEAKreg = freg / [entry + (1 + read ws) + (1 + write ws) + exit] #### where: ``` PEAKreq — peak request rate freq — system frequency entry — channel startup (four cycles) read_ws — wait states seen during the system bus read data phase write_ws — wait states seen during the system bus write data phase exit — channel shutdown (three cycles) ``` For example: consider a system with the following characteristics: - Internal SRAM can be accessed with one wait-state when viewed from the system bus data phase. - All slave reads require two wait-states, and slave writes three wait-states, again viewed from the system bus data phase. - System operates at 150 MHz. For an SRAM to slave transfer, #### **Equation 18** ``` PEAKreq = 150 MHz / [4 + (1 + 1) + (1 + 3) + 3] cycles = 11.5 Mreq/sec ``` For an slave to SRAM transfer, #### **Equation 19** ``` PEAKreq = 150 MHz / [4 + (1 + 2) + (1 + 1) + 3] cycles = 12.5 Mreq/sec ``` Assuming an even distribution of the two transfer types, the average peak request rate is: #### **Equation 20** PEAKreg = (11.5 Mreg/sec + 12.5 Mreg/sec) / 2 = 12.0 Mreg/sec The minimum number of cycles to perform a single read/write, zero wait states on the system bus, from a cold start (no channel is executing, eDMA is idle) are the following: - 11 cycles for a software (TCD.START bit) request - 12 cycles for a hardware (eDMA peripheral request signal) request Two cycles account for the arbitration pipeline and one extra cycle on the hardware request resulting from the internal registering of the eDMA peripheral request signals. For the peak request rate calculations above, the arbitration and request registering is absorbed in or overlap the previous executing channel. Note: When channel linking or scatter/gather is enabled, a two-cycle delay is imposed on the next channel selection and startup. This allows the link channel or the scatter/gather channel to be eligible and considered in the arbitration pool for next channel selection. # 19.7 Initialization / application information #### 19.7.1 eDMA initialization A typical initialization of the eDMA has the following sequence: - 1. Write the EDMA CR if a configuration other than the default is desired. - 2. Write the channel priority levels into the EDMA\_CPR*n* registers if a configuration other than the default is desired. - Enable error interrupts in the EDMA EEIRL and/or EDMA EEIRH registers (optional). - 4. Write the 32-byte TCD for each channel that can request service. - Enable any hardware service requests via the EDMA\_ERQRH and/or EDMA\_ERQRL registers. - 6. Request channel service by either software (setting the TCD.START bit) or by hardware (slave device asserting its eDMA peripheral request signal). After any channel requests service, a channel is selected for execution based on the arbitration and priority levels written into the programmer's model. The eDMA engine reads the entire TCD, including the primary transfer control parameter shown in *Table 239*, for the selected channel into its internal address path module. As the TCD is being read, the first transfer is initiated on the system bus unless a configuration error is detected. Transfers from the source (as defined by the source address, TCD.SADDR) to the destination (as defined by the destination address, TCD.DADDR) continue until the specified number of bytes (TCD.NBYTES) have been transferred. When the transfer is complete, the eDMA engine's local TCD.SADDR, TCD.DADDR, and TCD.CITER are written back to the main TCD memory and any minor loop channel linking is performed, if enabled. If the major loop is exhausted, further post processing is executed: for example, interrupts, major loop channel linking, and scatter/gather operations, if enabled. Table 239. TCD primary control and status fields | TCD Field<br>Name | Description | | |-------------------|-------------------------------------------------------------------------------------------------------------------------|--| | START | Control bit to explicitly start channel when using a software initiated DMA service (Automatically cleared by hardware) | | | ACTIVE | Status bit indicating the channel is currently in execution | | | DONE | Status bit indicating major loop completion (Cleared by software when using a software initiated DMA service) | | | D_REQ | Control bit to disable DMA request at end of major loop completion when using a hardware-initiated DMA service | | | BWC | Control bits for "throttling" bandwidth control of a channel | | | E_SG | Control bit to enable scatter-gather feature | | | INT_HALF | Control bit to enable interrupt when major loop is half complete | | | INT_MAJ | Control bit to enable interrupt when major loop completes | | *Figure 231* shows how each DMA request initiates one minor loop transfer (iteration) without CPU intervention. DMA arbitration can occur after each minor loop, and one level of minor loop DMA preemption is allowed. The number of minor loops in a major loop is specified by the beginning iteration count (biter). Example Memory Array Current Major Loop Iteration Count (CITER) Minor Loop 3 DMA Request Minor Loop Major Loop 2 DMA Request Minor Loop Minor Loop 1 Figure 231. Example of multiple loop iterations Figure 232 lists the memory array terms and how the TCD settings interrelate. | xADDR:<br>(Starting Address) | xSIZE:<br>(Size of one data<br>transfer) | Minor Loop<br>(NBYTES in<br>Minor Loop, often<br>the same value<br>as xSIZE) | Offset (xOFF): Number of<br>bytes added to current<br>address after each transfer<br>(Often the same value<br>as xSIZE) | |------------------------------------------------------------------------------------------------------------|------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | | | Minor Loop | Each DMA Source (S) and Destination (D) has its own: • Address (xADDR) • Size (xSIZE) • Offset (xOFF) • Modulo (xMOD) | | xLAST: Number of bytes<br>added to current address<br>after Major Loop<br>(Typically used to<br>loop back) | • | Last Minor Loop | Last Address Adjustment (xLAST) where x = S or D Peripheral queues typically have size and offset equal to NBYTES | Figure 232. Memory array terms ## 19.7.2 DMA programming errors The eDMA performs various tests on the transfer control descriptor to verify consistency in the descriptor data. Most programming errors are reported on a per channel basis with the exception of two errors: group priority error and channel priority error, or EDMA\_ESR[GPE] and EDMA\_ESR[CPE], respectively. For all error types other than group or channel priority errors, the channel number causing the error is recorded in the EDMA\_ESR. If the error source is not removed before the next activation of the problem channel, the error is detected and recorded again. If priority levels are not unique, the highest (channel/group) priority that has an active request is selected, but the lowest numbered (channel/group) with that priority is selected by arbitration and executed by the eDMA engine. The hardware service request handshake signals, error interrupts and error reporting are associated with the selected channel. ## 19.7.3 DMA request assignments The assignments between the DMA requests from the modules to the channels of the eDMA are shown in *Table 240*. The source column is written in C language syntax. The syntax is module\_instance.register[bit]. | DMA Request | Ch. | Source | Description | |---------------------------|-----|----------------------------|---------------------------| | DMA_MUX_CHCONFIG0_SOURCE | 0 | DMA_MUX.CHCONFIG0[SOURCE] | DMA MUX channel 0 source | | DMA_MUX_CHCONFIG1_SOURCE | 1 | DMA_MUX.CHCONFIG1[SOURCE] | DMA MUX channel 1 source | | DMA_MUX_CHCONFIG2_SOURCE | 2 | DMA_MUX.CHCONFIG2[SOURCE] | DMA MUX channel 2 source | | DMA_MUX_CHCONFIG3_SOURCE | 3 | DMA_MUX.CHCONFIG3[SOURCE] | DMA MUX channel 3 source | | DMA_MUX_CHCONFIG4_SOURCE | 4 | DMA_MUX.CHCONFIG4[SOURCE] | DMA MUX channel 4 source | | DMA_MUX_CHCONFIG5_SOURCE | 5 | DMA_MUX.CHCONFIG5[SOURCE] | DMA MUX channel 5 source | | DMA_MUX_CHCONFIG6_SOURCE | 6 | DMA_MUX.CHCONFIG6[SOURCE] | DMA MUX channel 6 source | | DMA_MUX_CHCONFIG7_SOURCE | 7 | DMA_MUX.CHCONFIG7[SOURCE] | DMA MUX channel 7 source | | DMA_MUX_CHCONFIG8_SOURCE | 8 | DMA_MUX.CHCONFIG8[SOURCE] | DMA MUX channel 8 source | | DMA_MUX_CHCONFIG9_SOURCE | 9 | DMA_MUX.CHCONFIG9[SOURCE] | DMA MUX channel 9 source | | DMA_MUX_CHCONFIG10_SOURCE | 10 | DMA_MUX.CHCONFIG10[SOURCE] | DMA MUX channel 10 source | | DMA_MUX_CHCONFIG11_SOURCE | 11 | DMA_MUX.CHCONFIG11[SOURCE] | DMA MUX channel 11 source | Table 240. DMA request summary for eDMA ### 19.7.4 DMA arbitration mode considerations ## 19.7.4.1 Fixed-channel arbitration In this mode, the channel service request from the highest priority channel is selected to execute. The advantage of this scenario is that latency can be small for channels that need to be serviced quickly. Preemption is available in this scenario only. ## 19.7.4.2 Fixed-group arbitration, round-robin channel arbitration Channels are serviced starting with the highest channel number and rotating through to the lowest channel number without regard to the channel priority levels assigned within the group. ## 19.7.5 DMA transfer #### 19.7.5.1 Single request To perform a simple transfer of 'n' bytes of data with one activation, set the major loop to 1 (TCD.CITER = TCD.BITER = 1). The data transfer begins after the channel service request is acknowledged and the channel is selected to execute. After the transfer completes, the TCD.DONE bit is set and an interrupt is generated if correctly enabled. For example, the following TCD entry is configured to transfer 16 bytes of data. The eDMA is programmed for one iteration of the major loop transferring 16 bytes per iteration. The source memory has a byte-wide memory port located at 0x1000. The destination memory has a word-wide port located at 0x2000. The address offsets are programmed in increments to match the size of the transfer; one byte for the source and four bytes for the destination. The final source and destination addresses are adjusted to return to their beginning values. ``` TCD.CITER = TCD.BITER = 1 TCD.NBYTES = 16 TCD.SADDR = 0x1000 TCD.SOFF = 1 TCD.SSIZE = 0 TCD.SLAST = -16 TCD.DADDR = 0x2000 TCD.DOFF = 4 TCD.DSIZE = 2 TCD.DLAST_SGA= -16 TCD.INT_MAJ = 1 TCD.START = 1 (Initialize all other fields before writing to this bit) All other TCD fields = 0 ``` This generates the following sequence of events: - 1. Slave write to the TCD.START bit requests channel service. - 2. The channel is selected by arbitration for servicing. - 3. eDMA engine writes: TCD.DONE = 0, TCD.START = 0, TCD.ACTIVE = 1. - 4. eDMA engine reads: channel TCD data from local memory to internal register file. - 5. The source to destination transfers are executed as follows: - a) read\_byte (0x1000), read\_byte(0x1001), read\_byte(0x1002), read\_byte(0x1003) - b) write word $(0x2000) \rightarrow$ first iteration of the minor loop - c) read\_byte (0x1004), read\_byte(0x1005), read\_byte(0x1006), read\_byte(0x1007) - d) write word $(0x2004) \rightarrow$ second iteration of the minor loop - e) read\_byte (0x1008), read\_byte(0x1009), read\_byte(0x100a), read\_byte(0x100b) - f) write word $(0x2008) \rightarrow$ third iteration of the minor loop - g) read byte (0x100c), read byte(0x100d), read byte(0x100e), read byte(0x100f) - h) write\_word $(0x200c) \rightarrow last$ iteration of the minor loop $\rightarrow$ major loop complete - eDMA engine writes: TCD.SADDR = 0x1000, TCD.DADDR = 0x2000, TCD.CITER = 1 (TCD.BITER). - 7. eDMA engine writes: TCD.ACTIVE = 0, TCD.DONE = 1, EDMA IRQRn = 1. - 8. The channel retires. The eDMA goes idle or services the next channel. ## 19.7.5.2 Multiple requests The next example is the same as previous with the exception of transferring 32 bytes via two hardware requests. The only fields that change are the major loop iteration count and the final address offsets. The eDMA is programmed for two iterations of the major loop transferring 16 bytes per iteration. After the channel's hardware requests are enabled in the EDMA\_ERQR, channel service requests are initiated by the slave device (set ERQR after TCD; TCD.START = 0). ``` TCD.CITER = TCD.BITER = 2 TCD.NBYTES = 16 TCD.SADDR = 0x1000 TCD.SOFF = 1 TCD.SSIZE = 0 TCD.SLAST = -32 TCD.DADDR = 0x2000 TCD.DOFF = 4 TCD.DSIZE = 2 TCD.DLAST_SGA = -32 TCD.INT_MAJ = 1 TCD.START = 0 (Initialize all other fields before writing this bit.) All other TCD fields = 0 ``` This generates the following sequence of events: - 1. First hardware (eDMA peripheral request) request for channel service. - 2. The channel is selected by arbitration for servicing. - 3. eDMA engine writes: TCD.DONE = 0, TCD.START = 0, TCD.ACTIVE = 1. - 4. eDMA engine reads: channel TCD data from local memory to internal register file. - 5. The source to destination transfers execute as follows: - a) read byte (0x1000), read byte (0x1001), read byte (0x1002), read byte (0x1003) - b) write\_word (0x2000) → first iteration of the minor loop - c) read byte (0x1004), read byte (0x1005), read byte (0x1006), read byte (0x1007) - d) write\_word (0x2004) → second iteration of the minor loop - e) read\_byte (0x1008), read\_byte (0x1009), read\_byte (0x100a), read\_byte (0x100b) - f) write word $(0x2008) \rightarrow$ third iteration of the minor loop - g) read byte (0x100c), read byte (0x100d), read byte (0x100e), read byte (0x100f) - h) write word $(0x200c) \rightarrow last$ iteration of the minor loop - eDMA engine writes: TCD.SADDR = 0x1010, TCD.DADDR = 0x2010, TCD.CITER = 1. - 7. eDMA engine writes: TCD.ACTIVE = 0. - 8. The channel retires $\rightarrow$ one iteration of the major loop. 577 The eDMA goes idle or services the next channel. - 9. Second hardware (eDMA peripheral request) requests channel service. - 10. The channel is selected by arbitration for servicing. - 11. eDMA engine writes: TCD.DONE = 0, TCD.START = 0, TCD.ACTIVE = 1. - 12. eDMA engine reads: channel TCD data from local memory to internal register file. - 13. The source to destination transfers execute as follows: - a) read byte (0x1010), read byte (0x1011), read byte (0x1012), read byte (0x1013) - b) write\_word (0x2010) → first iteration of the minor loop - c) read byte (0x1014), read byte (0x1015), read byte (0x1016), read byte (0x1017) - d) write\_word (0x2014) → second iteration of the minor loop - e) read byte (0x1018), read byte (0x1019), read byte (0x101a), read byte (0x101b) - f) write word $(0x2018) \rightarrow$ third iteration of the minor loop - g) read\_byte (0x101c), read\_byte (0x101d), read\_byte (0x101e), read\_byte (0x101f) - h) write\_word (0x201c) $\rightarrow$ last iteration of the minor loop $\rightarrow$ major loop complete - 14. eDMA engine writes: TCD.SADDR = 0x1000, TCD.DADDR = 0x2000, TCD.CITER = 2 (TCD.BITER). - 15. eDMA engine writes: TCD.ACTIVE = 0, TCD.DONE = 1, EDMA IRQRn = 1. - 16. The channel retires $\rightarrow$ major loop complete. The eDMA goes idle or services the next channel. #### 19.7.5.3 Modulo feature The modulo feature of the eDMA provides the ability to easily implement a circular data queue in which the size of the queue is a power of 2. MOD is a 5-bit field for the source and destination in the TCD, and specifies which lower address bits are incremented from their original value after the address + offset calculation. All upper address bits remain the same as in the original value. Clearing this field to 0 disables the modulo feature. *Table 241* shows how the transfer addresses are specified based on the setting of the MOD field. Here a circular buffer is created where the address wraps to the original value while the 28 upper address bits (0x1234567x) retain their original value. In this example the source address is set to 0x1234567x, the offset is set to 4 bytes and the mod field is set to 4, allowing for a $2^4$ byte (16-byte) size queue. Table 241. Modulo feature example | Transfer Number | Address | |-----------------|------------| | 1 | 0x12345670 | | 2 | 0x12345674 | | 3 | 0x12345678 | | 4 | 0x1234567C | | 5 | 0x12345670 | | 6 | 0x12345674 | #### 19.7.6 TCD status #### 19.7.6.1 Minor loop complete There are two methods to test for minor loop completion when using software initiated service requests. The first method is to read the TCD.CITER field and test for a change. Another method can be extracted from the following sequence. The second method is to test the TCD.START bit AND the TCD.ACTIVE bit. The minor loop complete condition is indicated by both bits reading zero after the TCD.START was written to a one. Polling the TCD.ACTIVE bit can be inconclusive because the active status can be missed if the channel execution is short in duration. The TCD status bits execute the following sequence for a software activated channel: - TCD.START = 1, TCD.ACTIVE = 0, TCD.DONE = 0 (issued service request via software) - 2. TCD.START = 0, TCD.ACTIVE = 1, TCD.DONE = 0 (executing) - TCD.START = 0, TCD.ACTIVE = 0, TCD.DONE = 0 (completed minor loop and is idle) or - 4. TCD.START = 0, TCD.ACTIVE = 0, TCD.DONE = 1 (completed major loop and is idle) The best method to test for minor loop completion when using hardware initiated service requests is to read the TCD.CITER field and test for a change. The hardware request and acknowledge handshakes signals are not visible in the programmer's model. The TCD status bits execute the following sequence for a hardware activated channel: - 1. eDMA peripheral request asserts (issued service request via hardware) - 2. TCD.START = 0, TCD.ACTIVE = 1, TCD.DONE = 0 (executing) - 3. TCD.START = 0, TCD.ACTIVE = 0, TCD.DONE = 0 (completed minor loop and is idle) or - 4. TCD.START = 0, TCD.ACTIVE = 0, TCD.DONE = 1 (completed major loop and is idle) For both activation types, the major loop complete status is explicitly indicated via the TCD.DONE bit. The TCD.START bit is cleared automatically when the channel begins execution regardless of how the channel was activated. #### 19.7.6.2 Active channel TCD reads the eDMA reads the true TCD.SADDR, TCD.DADDR, and TCD.NBYTES values if read while a channel is executing. The true values of the SADDR, DADDR, and NBYTES are the values the eDMA engine is currently using in its internal register file and not the values in the TCD local memory for that channel. The addresses (SADDR and DADDR) and NBYTES (decrements to zero as the transfer progresses) can give an indication of the progress of the transfer. All other values are read back from the TCD local memory. ### 19.7.6.3 Preemption status Preemption is only available when fixed arbitration is selected for both group and channel arbitration modes. A preempt-able situation is one in which a preempt-enabled channel is running and a higher priority request becomes active. When the eDMA engine is not operating in fixed group, fixed channel arbitration mode, the determination of the relative priority of the actively running and the outstanding requests become undefined. Channel and/or group priorities are treated as equal (or more exactly, constantly rotating) when round-robin arbitration mode is selected. The TCD.ACTIVE bit for the preempted channel remains asserted throughout the preemption. The preempted channel is temporarily suspended while the preempting channel executes one iteration of the major loop. Two TCD.ACTIVE bits set at the same time in the overall TCD map indicates a higher priority channel is actively preempting a lower priority channel. ## 19.7.7 Channel linking Channel linking (or chaining) is a mechanism where one channel sets the TCD.START bit of another channel (or itself) thus initiating a service request for that channel. This operation is automatically performed by the eDMA engine at the conclusion of the major or minor loop when properly enabled. The minor loop channel linking occurs at the completion of the minor loop (or one iteration of the major loop). The TCD.CITER.E\_LINK field determines whether a minor loop link is requested. When enabled, the channel link is made after each iteration of the minor loop except for the last. When the major loop is exhausted, only the major loop channel link fields are used to determine whether to make a channel link. For example, with the initial fields of: TCD.CITER.E\_LINK = 1 TCD.CITER.LINKCH = 0xC TCD.CITER value = 0x4 TCD.MAJOR.E\_LINK = 1 TCD.MAJOR.LINKCH = 0x7 channel linking executes as: - 1. Minor loop done → set channel 12 TCD.START bit - 2. Minor loop done → set channel 12 TCD.START bit - 3. Minor loop done → set channel 12 TCD.START bit - 4. Minor loop done, major loop done $\rightarrow$ set channel 7 TCD.START bit When minor loop linking is enabled (TCD.CITER.E\_LINK = 1), the TCD.CITER field uses a nine bit vector to form the current iteration count. When minor loop linking is disabled (TCD.CITER.E\_LINK = 0), the TCD.CITER field uses a 15-bit vector to form the current iteration count. The bits associated with the TCD.CITER.LINKCH field are concatenated onto the CITER value to increase the range of the CITER. Note: After configuration, the TCD.CITER.E\_LINK bit and the TCD.BITER.E\_LINK bit must be equal or a configuration error is reported. The CITER and BITER vector widths must be equal to calculate the major loop, half-way done interrupt point. *Table 242* summarizes how a DMA channel can "link" to another DMA channel, i.e, use another channel's TCD, at the end of a loop. | Desired Link<br>Behavior | TCD Control Field Name | Description | |--------------------------|------------------------|--------------------------------------------------------------------------------| | Link at end of | citer.e_link | Enable channel-to-channel linking on minor loop completion (current iteration) | | Minor Loop | citer.linkch | Link channel number when linking at end of minor loop (current iteration) | | Link at end of | major.e_link | Enable channel-to-channel linking on major loop completion | | Major Loop | major.linkch | Link channel number when linking at end of major loop | Table 242. Channel linking parameters ## 19.7.8 Dynamic programming This section provides recommended methods to change the programming model during channel execution. #### 19.7.8.1 Dynamic channel linking and dynamic scatter/gather Dynamic channel linking and dynamic scatter/gather is the process of changing the TCD.MAJOR.E\_LINK or TCD.E\_SG bits during channel execution. These bits are read from the TCD local memory at the *end* of channel execution thus allowing the user to enable either feature during channel execution. Because the user is allowed to change the configuration during execution, a coherency model is needed. Consider the scenario where the user attempts to execute a dynamic channel link by enabling the TCD.MAJOR.E\_LINK bit at the same time the eDMA engine is retiring the channel. The TCD.MAJOR.E\_LINK is set in the programmer's model, but it is unclear whether the link completed before the channel retired. Use the following coherency model when executing a dynamic channel link or dynamic scatter/gather request: - Set the TCD.MAJOR.E LINK bit - 2. Read the TCD.MAJOR.E LINK bit - 3. Test the TCD.MAJOR.E\_LINK request status: - a) If the bit is set, the dynamic link attempt was successful.D - b) If the bit is cleared, the channel had already retired before the dynamic link completed. This same coherency model is true for dynamic scatter/gather operations. For both dynamic requests, the TCD local memory controller forces the TCD.MAJOR.E\_LINK and TCD.E\_SG bits to zero on any writes to a channel's TCD after that channel's TCD.DONE bit is set indicating the major loop is complete. Note: The user must clear the TCD.DONE bit before writing the TCD.MAJOR.E\_LINK or TCD.E\_SG bits. The TCD.DONE bit is cleared automatically by the eDMA engine after a channel begins execution. # 20 DMA Channel Mux (DMA\_MUX) ## 20.1 Introduction ### 20.1.1 Overview The DMA Mux allows to route a configurable amount of DMA sources (slots) to a configurable amount of DMA channels. This is illustrated in *Figure 233*. Figure 233. DMA Mux block diagram ## 20.1.2 Features The DMA Mux has these major features: - 16 independently selectable DMA channel routers - 4 channels with normal or periodic triggering capability - 12 channels with normal capability - Each channel router can be assigned to 1 of 21 possible peripheral DMA sources ## 20.1.3 Modes of operation The following operation modes are available: Disabled Mode In this mode, the DMA channel is disabled. Since disabling and enabling of DMA channels is done primarily via the DMA configuration registers, this mode is used mainly as the reset state for a DMA channel in the DMA Channel Mux. It may also be used to temporarily suspend a DMA channel while reconfiguration of the system takes place (for example, changing the period of a DMA trigger). Normal Mode In this mode, a DMA source (such as DSPI\_0\_TX or DSPI\_0\_RX example) is routed directly to the specified DMA channel. The operation of the DMA Mux in this mode is completely transparent to the system. Periodic Trigger Mode In this mode, a DMA source may only request a DMA transfer (such as when a transmit buffer becomes empty or a receive buffer becomes full) periodically. Configuration of the period is done in the registers of the Periodic Interrupt Timer (PIT). DMA channels 0–3 may be used in all the modes listed above but channels 4–15 may be configured only to disabled or normal mode. ## 20.2 External signal description #### 20.2.1 Overview The DMA Mux has no external pins. # 20.3 Memory map and register definition This section provides a detailed description of all memory-mapped registers in the DMA Mux. ## 20.3.1 Memory map Table 243 shows the memory map for the DMA Mux. Note that all addresses are offsets; the absolute address may be computed by adding the specified offset to the base address of the DMA Mux. Table 243. DMA\_MUX memory map | Offset from DMA_MUX_BASE (0xFFFD_C000) | Register | Location | |----------------------------------------|--------------------------------------|-------------| | 0x0000 | Channel #0 Configuration (CHCONFIG0) | on page 497 | | 0x0001 | Channel #1 Configuration (CHCONFIG1) | on page 497 | | 0x0002 | Channel #2 Configuration (CHCONFIG2) | on page 497 | | 0x0003 | Channel #3 Configuration (CHCONFIG3) | on page 497 | | 0x0004 | Channel #4 Configuration (CHCONFIG4) | on page 497 | | Offset from DMA_MUX_BASE (0xFFFD_C000) | Register | Location | |----------------------------------------|----------------------------------------|-------------| | 0x0005 | Channel #5 Configuration (CHCONFIG5) | on page 497 | | 0x0006 | Channel #6 Configuration (CHCONFIG6) | on page 497 | | 0x0007 | Channel #7 Configuration (CHCONFIG7) | on page 497 | | 0x0008 | Channel #8 Configuration (CHCONFIG8) | on page 497 | | 0x0009 | Channel #9 Configuration (CHCONFIG9) | on page 497 | | 0x000A | Channel #10 Configuration (CHCONFIG10) | on page 497 | | 0x000B | Channel #11 Configuration (CHCONFIG11) | on page 497 | | 0x000C | Channel #12 Configuration (CHCONFIG12) | on page 497 | | 0x000D | Channel #13 Configuration (CHCONFIG13) | on page 497 | | 0x000E | Channel #14 Configuration (CHCONFIG14) | on page 497 | | 0x000F | Channel #15 Configuration (CHCONFIG15) | on page 497 | | 0x001F-0x3FFF | Reserved | | Table 243. DMA\_MUX memory map(Continued) All registers are accessible via 8-bit, 16-bit or 32-bit accesses. However, 16-bit accesses must be aligned to 16-bit boundaries, and 32-bit accesses must be aligned to 32-bit boundaries. As an example, CHCONFIG0 through CHCONFIG3 are accessible by a 32-bit READ/WRITE to address 'Base + 0x0000', but performing a 32-bit access to address 'Base + 0x0001' is illegal. ## 20.3.2 Register descriptions ## 20.3.2.1 Channel Configuration Registers Each of the DMA channels can be independently enabled/disabled and associated with one of the #SRC + #ALE total DMA sources in the system. Figure 234. Channel Configuration Registers (CHCONFIG#n) Table 244. CHCONFIG#x field descriptions | Field | Description | | | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7<br>ENBL | DMA Channel Enable ENBL enables the DMA Channel. DMA channel is disabled. This mode is primarily used during configuration of the DMA Mux. The DMA has separate channel enables/disables that should be used to disable or reconfigure a DMA channel. DMA channel is enabled. | | | | 6<br>TRIG | <ul> <li>DMA Channel Trigger Enable (for triggered channels only)</li> <li>TRIG enables the periodic trigger capability for the DMA Channel.</li> <li>Triggering is disabled. If triggering is disabled, and the ENBL bit is set, the DMA Channel routes the specified source to the DMA channel.</li> <li>Triggering is enabled.</li> </ul> | | | | 5–0<br>SOURCE | DMA Channel Source (slot) SOURCE specifies which DMA source, if any, is routed to a particular DMA channel. See <i>Table 246</i> . | | | Table 245. Channel and trigger enabling | ENBL | TRIG | Function | Mode | |------|------|---------------------------------------------------------|--------------------------| | 0 | Х | DMA Channel is disabled | Disabled Mode | | 1 | 0 | DMA Channel is enabled with no triggering (transparent) | Normal Mode | | 1 | 1 | DMA Channel is enabled with triggering | Periodic Trigger<br>Mode | Note: Setting multiple CHCONFIG registers with the same Source value will result in unpredictable behavior. Note: Before changing the trigger or source settings a DMA channel must be disabled via the CHCONFIG[#n].ENBL bit. # 20.4 DMA request mapping Table 246. DMA channel mapping | DMA_CH_MUX channel | Module | DMA requesting module | DMA Mux input # | |--------------------|--------|-----------------------|-------------------| | 1 | DSPI_0 | DSPI_0 TX | DMA MUX Source #1 | | 2 | DSPI_0 | DSPI_0 RX | DMA MUX Source #2 | | 3 | DSPI_1 | DSPI_1 TX | DMA MUX Source #3 | | 4 | DSPI_1 | DSPI_1 RX | DMA MUX Source #4 | | 5 | DSPI_2 | DSPI_2 TX | DMA MUX Source #5 | | 6 | DSPI_2 | DSPI_2 RX | DMA MUX Source #6 | | 7 | DSPI_3 | DSPI_3 TX | DMA MUX Source #7 | | 8 | DSPI_3 | DSPI_3 RX | DMA MUX Source #8 | **DMA** requesting DMA\_CH\_MUX Module **DMA Mux input #** channel module 9 CTU 0 CTU DMA MUX Source #9 10 CTU 0 CTU FIFO 0 DMA MUX Source #10 CTU 0 CTU FIFO 1 DMA MUX Source #11 11 12 CTU 0 CTU FIFO 2 DMA MUX Source #12 13 CTU 0 DMA MUX Source #13 CTU FIFO 3 14 Not connected DMA MUX Source #14 15 DSPI\_4 DMA MUX Source #15 DSPI\_4 TX 16 eTimer\_0 CH0 DMA MUX Source #16 etimer\_0 17 DMA MUX Source #17 eTimer\_0 CH1 etimer\_0 DMA MUX Source #18 18 eTimer\_1 CH0 etimer 1 DMA MUX Source #19 19 eTimer 1 CH1 etimer 1 20 ADC 0 DMA MUX Source #20 adc 0 DSPI\_4 RX DMA MUX Source #21 21 DSPI 4 DMA MUX Source #22 22 ALWAYS requestors 23 **ALWAYS** requestors DMA MUX Source #23 24 **ALWAYS** requestors DMA MUX Source #24 25 **ALWAYS** requestors DMA MUX Source #25 26 **ALWAYS** requestors DMA MUX Source #26 **ALWAYS** requestors DMA MUX Source #27 28 **ALWAYS** requestors DMA MUX Source #28 **ALWAYS** requestors DMA MUX Source #29 30 **ALWAYS** requestors DMA MUX Source #30 Table 246. DMA channel mapping(Continued) ## 20.5 Functional description This section provides a complete functional description of the DMA Mux. The primary purpose of the DMA Mux is to provide flexibility in the system's use of the available DMA channels. As such, configuration of the DMA Mux is intended to be a static procedure done during execution of the system boot code. However, if the procedure outlined in Section 20.6.2: Enabling and configuring sources is followed, the configuration of the DMA Mux may be changed during the normal operation of the system. Functionally, the DMA Mux channels may be divided into two classes: Channels that implement the normal routing functionality plus periodic triggering capability, and channels that implement only the normal routing functionality. ## 20.5.1 DMA channels with periodic triggering capability Besides the normal routing functionality, the first four channels of the DMA Mux provide a special periodic triggering capability that can be used to provide an automatic mechanism to transmit bytes, frames or packets at fixed intervals without the need for processor intervention. The trigger is generated by the Periodic Interrupt Timer (PIT); as such, the configuration of the periodic triggering interval is done via configuration registers in the PIT. Please refer to *Chapter 32: Periodic Interrupt Timer (PIT)* for more information on this topic. Note: Because of the dynamic nature of the system (i.e., DMA channel priorities, bus arbitration, interrupt service routine lengths, etc.), the number of clock cycles between a trigger and the actual DMA transfer cannot be guaranteed. Figure 235. DMA mux triggered channels diagram The DMA channel triggering capability allows the system to "schedule" regular DMA transfers, usually on the transmit side of certain peripherals, without the intervention of the processor. This trigger works by gating the request from the peripheral to the DMA until a trigger event has been seen. This is illustrated in *Figure 236*. 57 Peripheral Request Trigger DMA Request Figure 236. DMA mux channel triggering: normal operation Once the DMA request has been serviced, the peripheral will negate its request, effectively resetting the gating mechanism until the peripheral re-asserts its request AND the next trigger event is seen. This means that if a trigger is seen, but the peripheral is not requesting a transfer, that triggered will be ignored. This situation is illustrated in *Figure 237*. Figure 237. DMA mux channel triggering: ignored trigger This triggering capability may be used with any peripheral that supports DMA transfers, and is most useful for two types of situations: - Periodically polling external devices on a particular bus. As an example, the transmit side of an SPI is assigned to a DMA channel with a trigger, as described above. Once setup, the SPI will request DMA transfers (presumably from memory) as long as its transmit buffer is empty. By using a trigger on this channel, the SPI transfers can be automatically performed every 5 µs (as an example). On the receive side of the SPI, the SPI and DMA can be configured to transfer receive data into memory, effectively implementing a method to periodically read data from external devices and transfer the results into memory without processor intervention. - Using the GPIO Ports to drive or sample waveforms. By configuring the DMA to transfer data to one or more GPIO ports, it is possible to create complex waveforms using tabular data stored in on-chip memory. Conversely, using the DMA to periodically transfer data from one or more GPIO ports, it is possible to sample complex waveforms and store the results in tabular form in on-chip memory. A more detailed description of the capability of each trigger (for example, resolution, range of values, etc.) may be found in *Chapter 32: Periodic Interrupt Timer (PIT)*. ## 20.5.2 DMA channels with no triggering capability Channels 4–15 of the DMA Mux provide the normal routing functionality as described in Section 20.1.3: Modes of operation. Figure 238. DMA mux channel 4-15 block diagram # 20.6 Initialization/application information ### 20.6.1 Reset The reset state of each individual bit is shown within the register description section (see Section 20.3.2: Register descriptions). In summary, after reset, all channels are disabled and must be explicitly enabled before use. ## 20.6.2 Enabling and configuring sources Enabling a source with periodic triggering: - 1. Determine with which DMA channel the source will be associated. Remember that only the first four DMA channels have periodic triggering capability. - 2. Clear the ENBL and TRIG bits of the DMA channel. - 3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point. - 4. In the PIT, configure the corresponding timer. - 5. Select the source to be routed to the DMA channel. Write to the corresponding CHCONFIG register, ensuring that the ENBL and TRIG bits are set. **Example 8** Configure source #5 Transmit for use with DMA channel 2, with periodic triggering capability - 1. Write 0x00 to CHCONFIG2 (Base Address + 0x02). - 2. Configure Channel 2 in the DMA, including enabling the channel. - 3. Configure Timer 3 in the Periodic Interrupt Timer (PIT) for the desired trigger interval. - Write 0xC5 to CHCONFIG2 (Base Address + 0x02). The following code example illustrates steps 1 and 4 above: ``` In File registers.h: #define DMAMUX BASE ADDR 0xFC084000/* Example only ! */ /* Following example assumes char is 8-bits */ volatile unsigned char *CHCONFIG0 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0000); volatile unsigned char *CHCONFIG1 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0001); volatile unsigned char *CHCONFIG2 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0002); volatile unsigned char *CHCONFIG3 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0003); volatile unsigned char *CHCONFIG4 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0004); volatile unsigned char *CHCONFIG5 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0005); volatile unsigned char *CHCONFIG6 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0006); volatile unsigned char *CHCONFIG7 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0007); volatile unsigned char *CHCONFIG8 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0008); volatile unsigned char *CHCONFIG9 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0009); volatile unsigned char *CHCONFIG10= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000A); volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000E); volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000F); ``` In File main.c: ``` #include "registers.h" : : *CHCONFIG2 = 0x00; *CHCONFIG2 = 0xC5; ``` Enabling a source without periodic triggering: - 1. Determine with which DMA channel the source will be associated. Remember that only DMA channels 0–7 have periodic triggering capability. - 2. Clear the ENBL and TRIG bits of the DMA channel. - 3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point. - Select the source to be routed to the DMA channel. Write to the corresponding CHCONFIG register, ensuring that the ENBL is set and the TRIG bit is cleared. **Example 9** Configure source #5 Transmit for use with DMA Channel 2, with <u>no</u> periodic triggering capability. - 1. Write 0x00 to CHCONFIG2 (Base Address + 0x02). - 2. Configure Channel 2 in the DMA, including enabling the channel. - Write 0x85 to CHCONFIG2 (Base Address + 0x02). The following code example illustrates steps 1 and 3 above: ``` In File registers.h: #define DMAMUX_BASE_ADDR 0xFC084000/* Example only ! */ /* Following example assumes char is 8-bits */ volatile unsigned char *CHCONFIG0 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0000); volatile unsigned char *CHCONFIG1 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0001); volatile unsigned char *CHCONFIG2 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0002); volatile unsigned char *CHCONFIG3 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0003); volatile unsigned char *CHCONFIG4 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0004); volatile unsigned char *CHCONFIG5 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0005); volatile unsigned char *CHCONFIG6 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0006); volatile unsigned char *CHCONFIG7 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0007); volatile unsigned char *CHCONFIG8 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0008); volatile unsigned char *CHCONFIG9 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0009); volatile unsigned char *CHCONFIG10= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000A); volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000E); ``` ``` volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000F); In File main.c: #include "registers.h" : : *CHCONFIG2 = 0x00; *CHCONFIG2 = 0x85; ``` ### Disabling a source: A particular DMA source may be disabled by not writing the corresponding source value into any of the CHCONFIG registers. Additionally, some module specific configuration may be necessary. Please refer to the appropriate section for more details. Switching the source of a DMA channel: - 1. Disable the DMA channel in the DMA and reconfigure the channel for the new source. - 2. Clear the ENBL and TRIG bits of the DMA channel. - Select the source to be routed to the DMA channel. Write to the corresponding CHCONFIG register, ensuring that the ENBL and TRIG bits are set. **Example 10** Switch DMA Channel 8 from source #5 transmit to source #7 transmit - In the DMA configuration registers, disable DMA channel 8 and reconfigure it to handle the DSPI\_0 transmits. This example assumes channel 0...7 have triggering capability (#TRG = 8). - 2. Write 0x00 to CHCONFIG8 (Base Address + 0x08). - 3. Write 0x87 to CHCONFIG8 (Base Address + 0x08). In this case, setting the TRIG bit would have no effect, because channels 8 and above do not support the periodic triggering functionality. The following code example illustrates steps 2 and 3 above: ``` In File registers.h: #define DMAMUX_BASE_ADDR 0xFC084000/* Example only ! */ /* Following example assumes char is 8-bits */ volatile unsigned char *CHCONFIG0 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0000); volatile unsigned char *CHCONFIG1 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0001); volatile unsigned char *CHCONFIG2 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0002); volatile unsigned char *CHCONFIG3 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0003); volatile unsigned char *CHCONFIG4 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0004); volatile unsigned char *CHCONFIG5 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0005); volatile unsigned char *CHCONFIG6 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0006); volatile unsigned char *CHCONFIG7 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0007); volatile unsigned char *CHCONFIG8 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0008); volatile unsigned char *CHCONFIG9 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0009); ``` ``` volatile unsigned char *CHCONFIG10= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000A); volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000E); volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000F); In File main.c: #include "registers.h" *CHCONFIG8 = 0x00; *CHCONFIG8 = 0x87; ``` # 21 FlexRay Communication Controller (FlexRay) ### 21.1 Introduction ### 21.1.1 Color coding Throughout this chapter types of items are highlighted through the use of an italicized color font. FlexRay protocol parameters, constants and variables are highlighted with *blue italics*. An example is the parameter *gdActionPointOffset*. FlexRay protocol states are highlighted in *green italics*. An example is the state *POC:normal active*. #### 21.1.2 Overview The controller is a FlexRay communication controller that implements the *FlexRay Communications System Protocol Specification, Version 2.1 Rev A.* The controller has three main components: - Controller host interface (CHI) - Protocol engine (PE) - Clock domain crossing unit (CDC) A block diagram of the controller with its surrounding modules is given in Figure 239. Figure 239. FlexRay block diagram The protocol engine has two transmitter units TxA and TxB and two receiver units RxA and RxB for sending and receiving frames through the two FlexRay channels. The time control 577 unit (TCU) is responsible for maintaining global clock synchronization to the FlexRay network. The overall activity of the PE is controlled by the sequencer engine (SEQ). The controller host interface provides host access to the module's configuration, control, and status registers, as well as to the message buffer configuration, control, and status registers. The message buffers themselves, which contain the frame header and payload data received or to be transmitted, and the slot status information, are stored in the FlexRay memory. The clock domain crossing unit implements signal crossing from the CHI clock domain to the PE clock domain and vice versa, to allow for asynchronous PE and CHI clock domains. The controller stores the frame header and payload data of frames received or of frames to be transmitted in the FlexRay memory. The application accesses the FlexRay memory to retrieve and provide the frames to be processed by the controller. In addition to the frame header and payload data, the controller stores the synchronization frame related tables in the FlexRay memory for application processing. The FlexRay memory is located in the system memory of the MCU. The controller has access to the FlexRay memory via its bus master interface (BMIF). The host provides the start address of the FlexRay memory window within the system memory by programming the Section 21.5.2.5: System Memory Base Address High Register (SYMBADHR) and System Memory Base Address Low Register (SYMBADLR). All FlexRay memory related offsets are stored in offset registers. The physical address pointer into the FlexRay memory window of the MCU system memory is calculated using the offset values the FlexRay memory base address. Note: The controller does not provide a memory protection scheme for the FlexRay memory. #### 21.1.3 Features The controller provides the following features: - FlexRay Communications System Protocol Specification, Version 2.1 Rev A compliant protocol implementation - FlexRay Communications System Electrical Physical Layer Specification, Version 2.1 Rev A compliant bus driver interface - Single channel support - FlexRay Port A can be configured to be connected either to physical FlexRay channel A or physical FlexRay channel B. - FlexRay bus data rates of 10 Mbit/s, 8 Mbit/s, 5 Mbit/s, and 2.5 Mbit/s supported - 64 configurable message buffers with - Individual frame ID filtering - Individual channel ID filtering - Individual cycle counter filtering - Message buffer header, status and payload data stored in dedicated FlexRay memory - Allows for flexible and efficient message buffer implementation - Consistent data access ensured by means of buffer locking scheme - Application can lock multiple buffers at the same time - Size of message buffer payload data section configurable from 0 to 254 bytes - 2 independent message buffer segments with configurable size of payload data section - Each segment can contain message buffers assigned to the static segment and message buffers assigned to the dynamic segment at the same time - Zero padding for transmit message buffers in static segment - Applied when the frame payload length exceeds the size of the message buffer data section - Transmit message buffers configurable with state/event semantics - Message buffers can be configured as - Receive message buffer - Single buffered transmit message buffer - Double buffered transmit message buffer (combines two single buffered message buffer) - Individual message buffer reconfiguration supported - Means provided to safely disable individual message buffers - Disabled message buffers can be reconfigured - 2 independent receive FIFOs - 1 receive FIFO per channel - As many as 255 entries for each FIFO - Global frame ID filtering, based on both value/mask filters and range filters - Global channel ID filtering - Global message ID filtering for the dynamic segment - 4 configurable slot error counters - 4 dedicated slot status indicators - Used to observe slots without using receive message buffers - Measured value indicators for the clock synchronization - Internal synchronization frame ID and synchronization frame measurement tables can be copied into the FlexRay memory - Fractional macroticks are supported for clock correction - Maskable interrupt sources provided via individual and combined interrupt lines - 1 absolute timer - 1 timer that can be configured to absolute or relative ### 21.1.4 Modes of operation This section describes the basic operational power modes of the controller. #### 21.1.4.1 Disabled mode The controller enters the Disabled Mode during hard reset. The controller indicates that it is in the Disabled Mode by negating the module enable bit MEN in the Section 21.5.2.4: Module Configuration Register (MCR). No communication is performed on the FlexRay bus. All registers with the write access conditions *Any Time* and *Disabled Mode* can be accessed for writing as stated in *Section 21.5.2: Register descriptions*. The application configures the controller by accessing the configuration bits and fields in the Section 21.5.2.4: Module Configuration Register (MCR). #### 21.1.4.1.1 Leave disabled mode The controller leaves the Disabled Mode and enters the Normal Mode, when the application writes 1 to the module enable bit MEN in the Section 21.5.2.4: Module Configuration Register (MCR). Note: When the controller was enabled, it cannot be disabled the later on. ### 21.1.4.2 Normal mode In this mode the controller is fully functional. The controller indicates that it is in Normal Mode by asserting the module enable bit MEN in the Section 21.5.2.4: Module Configuration Register (MCR). #### 21.1.4.2.1 Enter normal mode This mode is entered when the application requests the controller to leave the Disabled Mode. If the Normal Mode was entered by leaving the Disabled Mode, the application has to perform the protocol initialization described in *Section 21.7.1.2: Protocol initialization*. to achieve full FlexRay functionality. Depending on the values of the SCM, CHA, and CHB bits in the *Section 21.5.2.4: Module Configuration Register (MCR)*, the corresponding FlexRay bus driver ports are enabled and driven. ### 21.2 External signal description This section lists and describes the controller signals, connected to external pins. These signals are summarized in *Table 247* and described in detail in *Section 21.2.1: Detailed signal descriptions*. Note: The off-chip signals FR\_A\_RX, FR\_A\_TX, and <Overbar>FR\_A\_TX\_EN are available on each package option. The availability of the other off-chip signals depends on the package option. Table 247. External signal properties | Name | Direction | Active | Reset | Function | |-------------------------------------------|-----------|--------|-------|---------------------------| | FR_A_RX | Input | _ | _ | Receive Data Channel A | | FR_A_TX | Output | _ | 1 | Transmit Data Channel A | | <overbar>FR_A<br/>_TX_EN Output</overbar> | | Low | 1 | Transmit Enable Channel A | | FR_B_RX Input | | _ | _ | Receive Data Channel B | | FR_B_TX | Output | _ | 1 | Transmit Data Channel B | | <overbar>FR_B<br/>_TX_EN Output</overbar> | | Low | 1 | Transmit Enable Channel B | | FR_DBG[0] | Output | _ | 0 | Debug Strobe Signal 0 | | FR_DBG[1] Output | | _ | 0 | Debug Strobe Signal 1 | | FR_DBG[2] Output | | _ | 0 | Debug Strobe Signal 2 | | FR_DBG[3] Output | | _ | 0 | Debug Strobe Signal 3 | ### 21.2.1 Detailed signal descriptions This section provides a detailed description of the controller signals, connected to external pins. ### 21.2.1.1 FR\_A\_RX — receive data channel A The FR\_A\_RX signal carries the receive data for channel A from the corresponding FlexRay bus driver. ### 21.2.1.2 FR\_A\_TX — transmit data channel A The FR\_A\_TX signal carries the transmit data for channel A to the corresponding FlexRay bus driver. ### 21.2.1.3 <Overbar>FR\_A\_TX\_EN — transmit enable channel A The <Overbar>FR\_A\_TX\_EN signal indicates to the FlexRay bus driver that the controller is attempting to transmit data on channel A. ### 21.2.1.4 FR\_B\_RX — receive data channel B The FR\_B\_RX signal carries the receive data for channel B from the corresponding FlexRay bus driver. ### 21.2.1.5 FR B TX — transmit data channel B The FR\_B\_TX signal carries the transmit data for channel B to the corresponding FlexRay bus driver. ### 21.2.1.6 <Overbar>FR\_B\_TX\_EN — transmit enable channel B The <Overbar>FR\_B\_TX\_EN signal indicates to the FlexRay bus driver that the controller is attempting to transmit data on channel B. ### 21.2.1.7 FR\_DBG[3], FR\_DBG[2], FR\_DBG[1], FR\_DBG[0] — strobe signals These signals provide the selected debug strobe signals. For details on the debug strobe signal selection refer to Section 21.6.16: Strobe signal support. ### 21.3 Controller host interface clocking The clock for the CHI is derived from the system bus clock and has the same phase and frequency as the system bus clock. Since the FlexRay protocol requires data delivery at fixed points in time, the memory read cycles from the FlexRay memory must be finished after a fixed amount of time. To ensure this, a minimum frequency $f_{chi}$ of the CHI clock is required, which is given in *Equation 21*. ### **Equation 21** $f_{chi} \ge 32MHz$ Additional requirements for the minimum frequency of the CHI clock result from the number of message buffers. These requirements are provided in *Section 21.7.3: Number of usable message buffers*. ### 21.4 Protocol engine clocking The clock for the protocol engine can be generated by two sources. The first source is the internal crystal oscillator and the second source is an internal PLL. The clock source to be used is selected by the clock source select bit CLKSEL in the Section 21.5.2.4: Module Configuration Register (MCR). ### 21.4.1 PLL Clocking If the protocol engine is clocked by the internal FMPLL\_0, select FVCO/6 from FMPLL\_0 to have 80 MHz. In this case the system clock is available with the constraint of 60 MHz. ### 21.4.2 Oscillator Clocking If the protocol engine is clocked by the internal crystal oscillator, a 40Mhz crystal clock must be connected to the oscillator pins. # 21.5 Memory map and register description The controller occupies 512 bytes of address space starting at the controller's base address defined by the memory map of the MCU. ### 21.5.1 Memory map The complete memory map of the controller is shown in *Table 248*. The addresses presented here are the offsets relative to the controller base address 0xFFFE\_0000. Table 248. FlexRay memory map | Offset | Register | | |--------|---------------------------------------------------------------------------------------------------------------|-----| | | Module Configuration and Control | | | 0x0000 | Module Version Register (MVR) | R | | 0x0002 | Module Configuration Register (MCR) | R/W | | 0x0004 | System Memory Base Address High Register (SYMBADHR) and System Memory Base<br>Address Low Register (SYMBADLR) | R/W | | 0x0006 | System Memory Base Address High Register (SYMBADHR) and System Memory Base<br>Address Low Register (SYMBADLR) | R/W | | 8000x0 | Strobe Signal Control Register (STBSCR) | R/W | | 0x000A | Reserved | R | | 0x000C | Message Buffer Data Size Register (MBDSR) | R/W | | 0x000E | Message Buffer Segment Size and Utilization Register (MBSSUTR) | R/W | | | Test Registers | • | | 0x0010 | Reserved | R | | 0x0012 | Reserved | R | | | Interrupt and Error Handling | • | | 0x0014 | Protocol Operation Control Register (POCR) | R/W | | 0x0016 | Global Interrupt Flag and Enable Register (GIFER) | R/W | | 0x0018 | Protocol Interrupt Flag Register 0 (PIFR0) | R/W | | 0x001A | Protocol Interrupt Flag Register 1 (PIFR1) | R/W | | 0x001C | Protocol Interrupt Enable Register 0 (PIER0) | R/W | | 0x001E | Protocol Interrupt Enable Register 1 (PIER1) | R/W | | 0x0020 | CHI Error Flag Register (CHIERFR) | R/W | | 0x0022 | Message Buffer Interrupt Vector Register (MBIVEC) | R | | 0x0024 | Channel A Status Error Counter Register (CASERCR) | R | | 0x0026 | Channel B Status Error Counter Register (CBSERCR) | R | | | Protocol Status | | | 0x0028 | Protocol Status Register 0 (PSR0) | R | | 0x002A | Protocol Status Register 1 (PSR1) | R | Table 248. FlexRay memory map (Continued) | Offset | Register | Access | |----------|--------------------------------------------------------------------|----------| | 0x002C | Protocol Status Register 2 (PSR2) | R | | 0x002E | Protocol Status Register 3 (PSR3) | R/W | | 0x0030 | Macrotick Counter Register (MTCTR) | R | | 0x0032 | Cycle Counter Register (CYCTR) | R | | 0x0034 | Slot Counter Channel A Register (SLTCTAR) | R | | 0x0036 | Slot Counter Channel B Register (SLTCTBR) | R | | 0x0038 | Rate Correction Value Register (RTCORVR) | R | | 0x003A | Offset Correction Value Register (OFCORVR) | R | | 0x003C | Combined Interrupt Flag Register (CIFRR) | R | | 0x003E | System Memory Access Time-Out Register (SYMATOR) | R/W | | | Sync Frame Counter and Tables | | | 0x0040 | Sync Frame Counter Register (SFCNTR) | R | | 0x0042 | Sync Frame Table Offset Register (SFTOR) | R/W | | 0x0044 | Sync Frame Table Configuration, Control, Status Register (SFTCCSR) | R/W | | <u> </u> | Sync Frame Filter | l . | | 0x0046 | Sync Frame ID Rejection Filter Register (SFIDRFR) | R/W | | 0x0048 | Sync Frame ID Acceptance Filter Value Register (SFIDAFVR) | R/W | | 0x004A | Sync Frame ID Acceptance Filter Mask Register (SFIDAFMR) | R/W | | <u> </u> | Network Management Vector | l . | | 0x004C | Network Management Vector Register 0 (NMVR0) | R | | 0x004E | Network Management Vector Register 1 (NMVR1) | R | | 0x0050 | Network Management Vector Register 2 (NMVR2) | R | | 0x0052 | Network Management Vector Register 3 (NMVR3) | R | | 0x0054 | Network Management Vector Register 4 (NMVR4) | R | | 0x0056 | Network Management Vector Register 5 (NMVR5) | R | | 0x0058 | Network Management Vector Length Register (NMVLR) | R/W | | · | Timer Configuration | · | | 0x005A | Timer Configuration and Control Register (TICCR) | R/W | | 0x005C | Timer 1 Cycle Set Register (TI1CYSR) | R/W | | 0x005E | Timer 1 Macrotick Offset Register (TI1MTOR) | R/W | | 0x0060 | Timer 2 Configuration Register 0 (TI2CR0) | R/W | | 0x0062 | Timer 2 Configuration Register 1 (TI2CR1) | R/W | | • | Slot Status Configuration | <u> </u> | | 0x0064 | Slot Status Selection Register (SSSR) | R/W | Table 248. FlexRay memory map (Continued) | Offset | Register | Access | |----------|----------------------------------------------------------------------|--------| | 0x0066 | Slot Status Counter Condition Register (SSCCR) | R/W | | • | Slot Status | • | | 0x0068 | Slot Status Register 0 (SSR0) | R | | 0x006A | Slot Status Register 1 (SSR1) | R | | 0x006C | Slot Status Register 2 (SSR2) | R | | 0x006E | Slot Status Register 3 (SSR3) | R | | 0x0070 | Slot Status Register 4 (SSR4) | R | | 0x0072 | Slot Status Register 5 (SSR5) | R | | 0x0074 | Slot Status Register 6 (SSR6) | R | | 0x0076 | Slot Status Register 7 (SSR7) | R | | 0x0078 | Slot Status Counter Register 0 (SSCR0) | R | | 0x007A | Slot Status Counter Register 1 (SSCR1) | R | | 0x007C | Slot Status Counter Register 2 (SSCR2) | R | | 0x007E | Slot Status Counter Register 3 (SSCR3) | R | | • | MTS Generation | • | | 0x0080 | MTS A Configuration Register (MTSACFR) | R/W | | 0x0082 | MTS B Configuration Register (MTSBCFR) | R/W | | | Shadow Buffer Configuration | · | | 0x0084 | Receive Shadow Buffer Index Register (RSBIR) | R/W | | <u> </u> | Receive FIFO — Configuration | | | 0x0086 | Receive FIFO Selection Register (RFSR) | R/W | | 0x0088 | Receive FIFO Start Index Register (RFSIR) | R/W | | 0x008A | Receive FIFO Depth and Size Register (RFDSR) | R/W | | • | Receive FIFO - Status | • | | 0x008C | Receive FIFO A Read Index Register (RFARIR) | R | | 0x008E | Receive FIFO B Read Index Register (RFBRIR) | R | | ļ | Receive FIFO - Filter | | | 0x0090 | Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) | R/W | | 0x0092 | Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) | R/W | | 0x0094 | Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) | R/W | | 0x0096 | Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) | R/W | | 0x0098 | Receive FIFO Range Filter Configuration Register (RFRFCFR) | R/W | | 0x009A | Receive FIFO Range Filter Control Register (RFRFCTR) | R/W | Table 248. FlexRay memory map (Continued) | Offset | Register | Access | |------------|----------------------------------------------------------------------|---------| | | Dynamic Segment Status | | | 0x009C | Last Dynamic Transmit Slot Channel A Register (LDTXSLAR) | R | | 0x009E | Last Dynamic Transmit Slot Channel B Register (LDTXSLBR) | R | | | Protocol Configuration | | | 0x00A0 | Protocol Configuration Register 0 (PCR0) | R/W | | <br>0x00DC | Protocol Configuration Register 30 (PCR30) | <br>R/W | | 0x00DE | | | | <br>0x00FE | Reserved | R | | | Message Buffers Configuration, Control, Status | | | 0x0100 | Message Buffer Configuration, Control, Status Register 0 (MBCCSR0) | R/W | | 0x0102 | Message Buffer Cycle Counter Filter Register 0 (MBCCFR0) | R/W | | 0x0104 | Message Buffer Frame ID Register 0 (MBFIDR0) | R/W | | 0x0106 | Message Buffer Index Register 0 (MBIDXR0) | R/W | | | | | | 0x02F8 | Message Buffer Configuration, Control, Status Register 63 (MBCCSR63) | R/W | | 0x02FA | Message Buffer Cycle Counter Filter Register 63 (MBCCFR63) | R/W | | 0x02FC | Message Buffer Frame ID Register 63 (MBFIDR63) | R/W | | 0x02FE | Message Buffer Index Register 63 (MBIDXR63) | R/W | ### 21.5.2 Register descriptions This section provides detailed descriptions of all registers in ascending address order, presented as 16-bit wide entities *Table 249* provides a key for the register figures and register tables. Table 249. Register access conventions | Convention | Convention Description | | |------------|------------------------------------------------------------------------------------------------------------------|--| | | Depending on its placement in the read or write row, indicates that the bit is not readable or not writeable. | | | R* | Reserved bit or field, will not be changed. Application must not write any value different from the reset value. | | | FIELDNAME | FIELDNAME Identifies the field. Its presence in the read or write row indicates that it can be read or written. | | | | Register Field Types | | | rwm | A read/write bit that may be modified by a hardware in some fashion other than by a reset. | | | w1c | Write one to clear. A flag bit that can be read, is cleared by writing a one, writing 0 has no effect. | | | ······································ | | | |----------------------------------------|-----------------|--| | Convention | Description | | | Reset Value | | | | 0 | Resets to zero. | | | 1 | Resets to one. | | Table 249. Register access conventions(Continued) Not defined after reset and not affected by reset. #### 21.5.2.1 Register reset All registers except the Message Buffer Cycle Counter Filter Registers (MBCCFRn), Message Buffer Frame ID Registers (MBFIDRn), and Message Buffer Index Registers (MBIDXRn) are reset to their reset value on system reset. The registers mentioned above are located in physical memory blocks and, thus, they are not affected by reset. For some register fields, additional reset conditions exist. These additional reset conditions are mentioned in the detailed description of the register. The additional reset conditions are explained in Table 250. Table 250. Additional register reset conditions | Condition | Description | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Protocol RUN Command | The register field is reset when the application writes to RUN command "0101" to the POCCMD field in the Section 21.5.2.9: Protocol Operation Control Register (POCR). | | Message Buffer Disable | The register field is reset when the application has disabled the message buffer. This happens when the application writes 1 to the message buffer disable trigger bit MBCCSRn[EDT] while the message buffer is enabled (MBCCSn[EDS] = 1) and the controller grants the disable to the application by clearing the MBCCSRn[EDS] bit. | #### 21.5.2.2 Register write access This section describes the write access restriction terms that apply to all registers. #### 21.5.2.2.1 Register write access restriction For each register bit and register field, the write access conditions are specified in the detailed register description. A description of the write access conditions is given in Table 251. If, for a specific register bit or field, none of the given write access conditions is fulfilled, any write attempt to this register bit or field is ignored without any notification. The values of the bits or fields are not changed. The condition term [A or B] indicates that the register or field can be written to if at least one of the conditions is fulfilled. Table 251. Register write access restrictions | Condition | Indication | Description | |------------------|--------------|------------------------------------------------------------| | Any Time | _ | No write access restriction. | | Disabled<br>Mode | MCR[MEN] = 0 | Write access only when the controller is in Disabled Mode. | | Normal Mode | MCR[MEN] = 1 | Write access only when the controller is in Normal Mode. | Condition Description POC:config PSR0[PROTSTATE] = POC:config state. Write access only when the Protocol is in the POC:config state. MB\_DIS MBCCSR[EDS] = 0 Write access only when the related Message Buffer is disabled. MB\_LCK MBCCSRn[LCKS] = 1 Write access only when the related Message Buffer is locked. Table 251. Register write access restrictions(Continued) ### 21.5.2.2.2 Register write access requirements All registers can be accessed with 8-bit, 16-bit and 32-bit wide operations. For some of the registers, at least a 16-bit wide write access is required to ensure correct operation. This write access requirement is stated in the detailed register description for each register affected ### 21.5.2.2.3 Internal register access The following memory mapped registers are used to access multiple internal registers. - Section 21.5.2.6: Strobe Signal Control Register (STBSCR) - Section 21.5.2.44: Slot Status Selection Register (SSSR) - Section 21.5.2.45: Slot Status Counter Condition Register (SSCCR) - Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR) Each of these memory mapped registers provides a SEL field and a WMD bit. The SEL field selects the internal register. The WMD bit controls the write mode. If the WMD bit is set to 0 during the write access, all fields of the internal register are updated. If the WMD bit set to 1, only the SEL field is changed. All other fields of the internal register remain unchanged. This allows for reading back the values of the selected internal register in a subsequent read access. #### 21.5.2.3 Module Version Register (MVR) Figure 240. Module Version Register (MVR) This register provides the controller version number. The module version number is derived from the CHI version number and the PE version number. Table 252. MVR field descriptions | Field | Description | |--------|-----------------------------------------------------------------------------------------------| | CHIVER | CHI Version Number — This field provides the version number of the controller host interface. | | PEVER | PE Version Number — This field provides the version number of the protocol engine. | ### 21.5.2.4 Module Configuration Register (MCR) Figure 241. Module Configuration Register (MCR) This register defines the global configuration of the controller. Table 253. MCR field descriptions | Table 255. MON field descriptions | | | |-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Field | Description | | | MEN | Module Enable — This bit indicates whether or not the controller is in the Disabled Mode. The application requests the controller to leave the Disabled Mode by writing 1 to this bit Before leaving the Disabled Mode, the application must configure the SCM, SBFF, CHB, CHA, TMODE, BITRATE values. For details see Section 21.1.4: Modes of operation. 0 Write: ignored, controller disable not possible. Read: controller disabled. 1 Write: enable controller. Read: controller enabled. Note: If the controller is enabled it cannot be disabled. | | | SBFF | System Bus Failure Freeze — This bit controls the behavior of the controller in case of a system bus failure. 0 Continue normal operation. 1 Transition to freeze mode. | | | SCM | Single Channel Device Mode — This control bit defines the channel device mode of the controller as described in Section 21.6.10: Channel device modes. 0 controller works in dual channel device mode. 1 controller works in single channel device mode. | | | CHB<br>CHA | <b>Channel Enable</b> — protocol related parameter: <i>pChannels</i> The semantic of these control bits depends on the channel device mode controlled by the SCM bit and is given <i>Table 254</i> . | | | SFFE | Synchronization Frame Filter Enable — This bit controls the filtering for received synchronization frames. For details see Section 21.6.15: Sync frame filtering. 0 Synchronization frame filtering disabled. 1 Synchronization frame filtering enabled. | | | R* | Reserved — This bit is reserved. It is read as 0. Application must not write 1 to this bit. | | | CLKSEL | Protocol Engine Clock Source Select — This bit is used to select the clock source for the protocol engine. 0 PE clock source is generated by on-chip crystal oscillator. 1 PE clock source is generated by on-chip PLL. | | | BITRATE | FlexRay Bus Bit Rate — This bit field defines the bit rate of the FlexRay channels according to Table 255. | | Table 254. FlexRay channel selection | CCM | SCM CHB CHA Description | | | |-------|-------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SCIVI | СНВ | СНА | Description | | | | | Dual channel device modes | | | 0 | 0 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN not driven by controller ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN not driven by controller</overbar></overbar> | | | 0 | 1 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel A ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN not driven by controller</overbar></overbar> | | 0 | 1 | 0 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN not driven by controller ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel B</overbar></overbar> | | | 1 | 1 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel A ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel B</overbar></overbar> | | | | | Single channel device mode | | | 0 | 0 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN not driven by controller ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN not driven by controller</overbar></overbar> | | 1 | 0 | 1 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel A ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN not driven by controller</overbar></overbar> | | | 1 | 0 | ports FR_A_RX, FR_A_TX, and <overbar>FR_A_TX_EN driven by controller - connected to FlexRay channel B ports FR_B_RX, FR_B_TX, and <overbar>FR_A_TX_EN not driven by controller</overbar></overbar> | | | 1 | 1 | reserved | Table 255. FlexRay channel bit rate selection | MCR[BITRATE] | FlexRay channel bit rate [Mbit/s] | |--------------|-----------------------------------| | 000 | 10.0 | | 001 | 5.0 | | 010 | 2.5 | | 011 | 8.0 | | 100 | reserved | | 101 | reserved | | 110 | reserved | | 111 | reserved | # 21.5.2.5 System Memory Base Address High Register (SYMBADHR) and System Memory Base Address Low Register (SYMBADLR) Figure 242. System Memory Base Address High Register (SYMBADHR) Figure 243. System Memory Base Address Low Register (SYMBADLR) Note: The system memory base address must be set before the controller is enabled. The system memory base address registers define the base address of the FlexRay memory within the system memory. The base address is used by the BMIF to calculate the physical memory address for system memory accesses. Table 256. SYMBADHR and SYMBADLR field descriptions | Field Description | | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SYS_MEM_<br>BASE_ADDR | This base address will be added to all system memory offset values stored in registers or calculated in the controller before the controller accesses the system memory via its bus master interface. The system memory base address must be aligned to a 16-byte boundary. | #### 21.5.2.6 Strobe Signal Control Register (STBSCR) Figure 244. Strobe Signal Control Register (STBSCR) This register assigns the individual protocol timing related strobe signals given in *Table 258* to the external strobe ports. Each strobe signal can be assigned to at most one strobe port. Each write access to registers overwrites the previously written ENB and STBPSEL values for the signal indicated by SEL. If more than one strobe signal is assigned to one strobe port, the current values of the strobe signals are combined with a binary OR and presented at the strobe port. If no strobe signal is assigned to a strobe port, the strobe port carries logic 0. For more detailed and timing information refer to *Section 21.6.16*: *Strobe signal support*. Note: In single channel device mode, channel B related strobe signals are undefined and should not be assigned to the strobe ports. Table 257. STBSCR field descriptions | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WMD | Write Mode — This control bit defines the write mode of this register. 0 Write to all fields in this register on write access. 1 Write to SEL field only on write access. | | SEL | Strobe Signal Select — This control field selects one of the strobe signals given in <i>Table 258</i> to be enabled or disabled and assigned to one of the four strobe ports given in <i>Table 258</i> . | | ENB | Strobe Signal Enable — This control bit enables and disables the strobe signal selected by STBSSEL. 0 Strobe signal is disabled and not assigned to any strobe port. 1 Strobe signal is enabled and assigned to the strobe port selected by STBPSEL. | | STBPSEL | Strobe Port Select — This field selects the strobe port that the strobe signal selected by the SEL is assigned to. All strobe signals that are enabled and assigned to the same strobe port are combined with a binary OR operation. 00 Assign selected signal to FR_DBG[0]. 01 Assign selected signal to FR_DBG[1]. 10 Assign selected signal to FR_DBG[2]. 11 Assign selected signal to FR_DBG[3]. | Table 258. Strobe signal mapping | SI | SEL Description Channel | | Channol | Туре | Offset <sup>(1)</sup> | Reference | |-----|-------------------------|-----------------------------------------------|------------|--------|-----------------------|-----------| | dec | hex | Description | Citatillei | туре | Oliset | Reference | | 0 | 0x00 | poc_startup_state[0] (for coding see PSR0[4]) | | | | MT start | | 1 | 0x01 | poc_startup_state[1] (for coding see PSR0[5]) | | | | | | 2 | 0x02 | poc_startup_state[2] (for coding see PSR0[6]) | | | | | | 3 | 0x03 | poc_startup_state[3] (for coding see PSR0[7]) | – | value | 0 | | | 4 | 0x04 | poc_state[0] (for coding see PSR0[8]) | | | | | | 5 | 0x05 | poc_state[1] (for coding see PSR0[9]) | | | | | | 6 | 0x06 | poc_state[2] (for coding see PSR0[10]) | | | | | | 7 | 0x07 | channel idle indicator A | level | /el +5 | FR_A_RX | | | 8 | 0x08 | Charmer fulle indicator | В | ievei | +5 | FR_B_RX | | 9 | 0x09 | receive data after glitch filtering | А | value | +4 | FR_A_RX | | 10 | 0x0A | receive data after glitch filtering | В | value | +4 | FR_B_RX | | 11 | 0x0B | cynchronization adda stroba | A | pulco | +4 | FR_A_RX | | 12 | 0x0C | synchronization edge strobe | В | pulse | 74 | FR_B_RX | | 13 | 0x0D | header received | А | pulso | +4 | FR_A_RX | | 14 | 0x0E | neader received | B pulse | +4 | FR_B_RX | | Table 258. Strobe signal mapping(Continued) | SEL | | David (I) | | | (1) | | |-----|------|------------------------------------------|---------|--------|-----------------------|-----------| | dec | hex | Description | Channel | Туре | Offset <sup>(1)</sup> | Reference | | 15 | 0x0F | wakaup aymbal daaadad | А | nulaa | | FR_A_RX | | 16 | 0x10 | wakeup symbol decoded | В | pulse | +5 | FR_B_RX | | 17 | 0x11 | MTC or CAC averaged decoded | А | nula a | | FR_A_RX | | 18 | 0x12 | MTS or CAS symbol decoded | В | pulse | +4 | FR_B_RX | | 19 | 0x13 | frame decoded | Α | pulse | +4 | FR_A_RX | | 20 | 0x14 | manie decoded | В | puise | 74 | FR_B_RX | | 21 | 0x15 | shannal idla datastad | А | nulaa | | FR_A_RX | | 22 | 0x16 | channel idle detected | В | pulse | +4 | FR_B_RX | | 23 | 0x17 | start of communication element detected | А | nulaa | | FR_A_RX | | 24 | 0x18 | start of communication element detected | В | pulse | +4 | FR_B_RX | | 25 | 0x19 | notantial frame start shannel | Α | nulaa | | FR_A_RX | | 26 | 0x1A | potential frame start channel | В | pulse | +4 | FR_B_RX | | 27 | 0x1B | wakeup collision detected | Α | pulgo | .5 | FR_A_RX | | 28 | 0x1C | wakeup comsion detected | В | pulse | +5 | FR_B_RX | | 29 | 0x1D | content error detected | Α | lovol | +4 | FR_A_RX | | 30 | 0x1E | content error detected | В | level | 74 | FR_B_RX | | 31 | 0x1F | ayatay arrar dataatad | Α | nulaa | +4 | FR_A_RX | | 32 | 0x20 | syntax error detected | В | pulse | 74 | FR_B_RX | | 33 | 0x21 | start transmission of wakeup pattern | Α | nulaa | -1 | FR_A_TX | | 34 | 0x22 | start transmission of wakeup pattern | В | pulse | -1 | FR_B_TX | | 35 | 0x23 | start transmission of MTS or CAS symbol | Α | pulse | -1 | FR_A_TX | | 36 | 0x24 | start transmission of MT3 of CA3 symbol | В | puise | -1 | FR_B_TX | | 37 | 0x25 | start of transmission | Α | pulse | -1 | FR_A_TX | | 38 | 0x26 | Start Of transmission | В | puise | -1 | FR_B_TX | | 39 | 0x27 | end of transmission | Α | pulse | -1 | FR_A_TX | | 40 | 0x28 | end of transmission | В | puise | -1 | FR_B_TX | | 41 | 0x29 | static segment indicator | _ | level | 0 | MT start | | 42 | 0x2A | dynamic segment indicator | _ | level | 0 | MT start | | 43 | 0x2B | symbol window indicator | _ | level | 0 | MT start | | 44 | 0x2C | NIT indicator | _ | level | 0 | MT start | | 45 | 0x2D | action point | _ | pulse | -1 | FR_A_TX | | 46 | 0x2E | sync calculation complete <sup>(2)</sup> | _ | pulse | _ | _ | | 47 | 0x2F | start of offset correction | _ | pulse | -2 | MT start | Table 258. Strobe signal mapping(Continued) | SI | EL | Description | | <b>T</b> | Offset <sup>(1)</sup> | Deferre | |-----|------|----------------|---------|----------|-----------------------|-------------| | dec | hex | Description | Channel | Туре | Offset | Reference | | 48 | 0x30 | cycle count[0] | | | | MT start | | 49 | 0x31 | cycle count[1] | | | | | | 50 | 0x32 | cycle count[2] | | | | | | 51 | 0x33 | cycle count[3] | _ | value | -2 | | | 52 | 0x34 | cycle count[4] | | | | | | 53 | 0x35 | cycle count[5] | | | | | | 54 | 0x36 | slot count[0] | | | | | | 55 | 0x37 | slot count[1] | | | | | | 56 | 0x38 | slot count[2] | | | | | | 57 | 0x39 | slot count[3] | | | | | | 58 | 0x3A | slot count[4] | | | | MT start | | 59 | 0x3B | slot count[5] | Α | value | alue 0 | | | 60 | 0x3C | slot count[6] | | | | | | 61 | 0x3D | slot count[7] | | | | | | 62 | 0x3E | slot count[8] | | | | | | 63 | 0x3F | slot count[9] | | | | | | 64 | 0x40 | slot count[10] | | | | | | 65 | 0x41 | slot count[0] | | | | | | 66 | 0x42 | slot count[1] | | | | | | 67 | 0x43 | slot count[2] | | | | | | 68 | 0x44 | slot count[3] | | | | | | 69 | 0x45 | slot count[4] | | | | | | 70 | 0x46 | slot count[5] | В | value | 0 | MT start | | 71 | 0x47 | slot count[6] | | | | | | 72 | 0x48 | slot count[7] | | | | | | 73 | 0x49 | slot count[8] | | | | | | 74 | 0x4A | slot count[9] | | | | | | 75 | 0x4B | slot count[10] | | | | | | 76 | 0x4C | cycle start | _ | pulse | 0 | MT start | | 77 | 0x4D | slot start | Α | pulse | 0 | MT start | | 78 | 0x4E | Siot start | В | pulse | J | ivi i Start | | 79 | 0x4F | minislot start | _ | pulse | 0 | MT start | | SI | EL | Description | Channel | Туре | Offset <sup>(1)</sup> | Reference | |-----|------|-------------|---------|-------|-----------------------|------------| | dec | hex | Description | Chamer | туре | Oliset | Kelefelice | | 80 | 0x50 | arm | _ | value | +1 | MT start | | 81 | 0x51 | mt | _ | value | +1 | MT start | Table 258. Strobe signal mapping(Continued) - 1. Given in PE clock cycles - 2. Indicates internal PE event not directly related to FlexRay bus timing ### 21.5.2.7 Message Buffer Data Size Register (MBDSR) Figure 245. Message Buffer Data Size Register (MBDSR) This register defines the size of the message buffer data section for the two message buffer segments in a number of two-byte entities. The controller provides two independent segments for the individual message buffers. All individual message buffers within one segment have to have the same size for the message buffer data section. This size can be different for the two message buffer segments. Table 259. MBDSR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <b>Message Buffer Segment 2 Data Size</b> — The field defines the size of the message buffer data section in two-byte entities for message buffers within the <i>second</i> message buffer segment. | | | <b>Message Buffer Segment 1 Data Size</b> — The field defines the size of the message buffer data section in two-byte entities for message buffers within the <i>first</i> message buffer segment. | ### 21.5.2.8 Message Buffer Segment Size and Utilization Register (MBSSUTR) Figure 246. Message Buffer Segment Size and Utilization Register (MBSSUTR) This register defines the last individual message buffer that belongs to the first message buffer segment and the number of the last used individual message buffer. Table 260. MBSSUTR field descriptions | Field | Description | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | LAST_MB_SEG1 | Last Message Buffer In Segment 1 — This field defines the message buffer number of the last individual message buffer that is assigned to the <i>first</i> message buffer segment. The individual message buffers in the <i>first</i> segment correspond to the message buffer control registers MBCCSRn, MBCCFRn, MBFIDRn, MBIDXRn with n <= LAST_MB_SEG1. The first message buffer segment contains LAST_MB_SEG1+1 individual message buffers. Note: The <i>first</i> message buffer segment contains at least one individual message buffer. The individual message buffers in the second message buffer segment correspond to the message buffer control registers MBCCSRn, MBCCFRn, MBFIDRn, MBIDXRn with | | | | LAST_MB_SEG1 < n < 32. Note: If LAST_MB_SEG1 = 31 all individual message buffers belong to the <i>first</i> message buffer segment and the <i>second</i> message buffer segment is empty. | | | LAST_MB_UTIL | Last Message Buffer Utilized — This field defines the message buffer number of last utilized individual message buffer. The message buffer search engine examines all individual message buffer with a message buffer number n <= LAST_MB_UTIL. Note: If LAST_MB_UTIL=LAST_MB_SEG1 all individual message buffers belong to the first message buffer segment and the second message buffer segment is empty. | | ### 21.5.2.9 Protocol Operation Control Register (POCR) Figure 247. Protocol Operation Control Register (POCR) The application uses this register to issue: - protocol control commands - external clock correction commands Protocol control commands are issued by writing to the POCCMD field. For more information on protocol control commands, see *Section 21.7.4: Protocol control command execution*. External clock correction commands are issued by writing to the EOC\_AP and ERC\_AP fields. For more information on external clock correction, refer to Section 21.6.11: External clock synchronization. Table 261. POCR field descriptions | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WME | Write Mode External Correction — This bit controls the write mode of the EOC_AP and ERC_AP fields. 0 Write to EOC AP and ERC AP fields on register write. | | | 1 No write to EOC_AP and ERC_AP fields on register write. | | EOC_AP | External Offset Correction Application — This field triggers the application of the external offset correction value defined in the Section 21.5.2.64.30: Protocol Configuration Register 29 (PCR29). 00 Do not apply external offset correction value. 01 Reserved. 10 Subtract external offset correction value. 11 Add external offset correction value. | | ERC_AP | External Rate Correction Application — This field triggers application of the external rate correction value defined in the Section 21.5.2.64.22: Protocol Configuration Register 21 (PCR21) 00 Do not apply external rate correction value. 01 Reserved. 10 Subtract external rate correction value. 11 Add external rate correction value. | | BSY | Protocol Control Command Write Busy — This status bit indicates the acceptance of the protocol control command issued by the application via the POCCMD field. The controller sets this status bit when the application has issued a protocol control command via the POCCMD field. The controller clears this status bit when protocol control command was accepted by the PE.When the application issues a protocol control command while the BSY bit is asserted, the controller ignores this command, sets the protocol command ignored error flag PCMI_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR), and will not change the value of the POCCMD field. 0Command write idle, command accepted and ready to receive new protocol command. 1Command write busy, command not yet accepted, not ready to receive new protocol command. Write Mode Command — This bit controls the write mode of the POCCMD field. | | WMC | Write to POCCMD field on register write. Do not write to POCCMD field on register write. | | POCCMD | Protocol Control Command — The application writes to this field to issue a protocol control command to the PE. The controller sends the protocol command to the PE immediately. While the transfer is running, the BSY bit is set. 0000 ALLOW_COLDSTART — Immediately activate capability of node to cold start cluster. 0001 ALL_SLOTS — Delayed <sup>(1)</sup> transition to the all slots transmission mode. 0010 CONFIG — Immediately transition to the POC:config state. 0011 FREEZE — Immediately transition to the POC:halt state. 0100 READY, CONFIG_COMPLETE — Immediately transition to the POC:ready state. 0111 RUN — Immediately transition to the POC:startup start state. 0110 DEFAULT_CONFIG — Immediately transition to the POC:default config state. 0111 HALT — Delayed transition to the POC:halt state 1000 WAKEUP — Immediately initiate the wakeup procedure. 1001 Reserved. 1010 RESET <sup>(2)</sup> — Immediately reset the Protocol Engine (see Section 21.7.5: Protocol reset command). 1101 Reserved. 1111 Reserved. 1110 Reserved. | <sup>1.</sup> Delayed means on completion of current communication cycle. 2. Additional to FlexRay Communications System Protocol Specification, Version 2.1 Rev A ### 21.5.2.10 Global Interrupt Flag and Enable Register (GIFER) Figure 248. Global Interrupt Flag and Enable Register (GIFER) This register provides the means to control some of the interrupt request lines and provides the corresponding interrupt flags. The interrupt flags MIF, PRIF, CHIF, RBIF, and TBIF are the outcome of a binary OR of the related individual interrupt flags and interrupt enables. The generation scheme for these flags is shown in *Figure 383*. For more details on interrupt generation, see *Section 21.6.20: Interrupt support*. These flags are cleared automatically when all of the corresponding interrupt flags or interrupt enables in the related interrupt flag and enable registers are cleared by the application. Table 262. GIFER field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MIF | <ul> <li>Module Interrupt Flag — This flag is set if at least one of the other interrupt flags is in this register is asserted and the related interrupt enable is asserted, too. The controller generates the module interrupt request if MIE is asserted.</li> <li>0 No interrupt flag is asserted or no interrupt enable is set.</li> <li>1 At least one of the other interrupt flags in this register is asserted and the related interrupt bit is asserted, too.</li> </ul> | | PRIF | Protocol Interrupt Flag — This flag is set if at least one of the individual protocol interrupt flags in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) and Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1) is asserted and the related interrupt enable flag is asserted, too. The controller generates the combined protocol interrupt request if the PRIE flag is asserted. O All individual protocol interrupt flags are equal to 0 or no interrupt enable bit is set. At least one of the individual protocol interrupt flags and the related interrupt enable is equal to 1. | | CHIF | CHI Interrupt Flag — This flag is set if at least one of the individual CHI error flags in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is asserted and the chi error interrupt enable GIFER[CHIE] is asserted. The controller generates the combined CHI error interrupt if the CHIE flag is asserted, too. O All CHI error flags are equal to 0 or the chi error interrupt is disabled. At least one CHI error flag is asserted and chi error interrupt is enabled. | | WUPIF | Wakeup Interrupt Flag — This flag is set when the controller has received a wakeup symbol on the FlexRay bus. The application can determine on which channel the wakeup symbol was received by reading the related wakeup flags WUB and WUA in the Section 21.5.2.22: Protocol Status Register 3 (PSR3). The controller generates the wakeup interrupt request if the WUPIE flag is asserted. 0 No wakeup condition or interrupt disabled. 1 Wakeup symbol received on FlexRay bus and interrupt enabled. | Table 262. GIFER field descriptions(Continued) | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FNEBIF | Receive FIFO channel B Not Empty Interrupt Flag — This flag is set when the receive FIFO for channel B is not empty. If the application writes 1 to this bit, the controller updates the FIFO status, increments or wraps the FIFO read index in the Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR) and clears the interrupt flag if the FIFO B is now empty. If the FIFO is still not empty, the controller sets this flag again. The controller generates the Receive FIFO B Not empty interrupt if the FNEBIE flag is asserted. O Receive FIFO B is empty or interrupt is disabled. Receive FIFO B is not empty and interrupt enabled. | | FNEAIF | Receive FIFO channel A Not Empty Interrupt Flag — This flag is set when the receive FIFO for channel A is not empty. If the application writes 1 to this bit, the controller updates the FIFO status, increments or wraps the FIFO read index in the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) and clears the interrupt flag if the FIFO A is now empty. If the FIFO is still not empty, the controller sets this flag again. The controller generates the Receive FIFO A Not empty interrupt if the FNEAIE flag is asserted. O Receive FIFO A is empty or interrupt is disabled. 1 Receive FIFO A is not empty and interrupt enabled. | | RBIF | Receive Message Buffer Interrupt Flag — This flag is set if for at least one of the individual receive message buffers (MBCCSn[MTD] = 0) both the interrupt flag MBIF and the interrupt enable bit MBIE in the corresponding Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) are asserted. The application cannot clear this RBIF flag directly. This flag is cleared by the controller when all of the interrupt flags MBIF of the individual receive message buffers are cleared by the application or if the application has cleared the interrupt enables bit MBIE. 0 None of the individual receive message buffers has the MBIF and MBIE flag asserted. 1 At least one individual receive message buffer has the MBIF and MBIE flag asserted. | | TBIF | Transmit Buffer Interrupt Flag — This flag is set if for at least one of the individual single or double transmit message buffers (MBCCSn[MTD] = 0) both the interrupt flag MBIF and the interrupt enable bit MBIE in the corresponding Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) are equal to 1. The application cannot clear this TBIF flag directly. This flag is cleared by the controller when either all of the individual interrupt flags MBIF of the individual transmit message buffers are cleared by the application or the host has cleared the interrupt enables bit MBIE. O None of the individual transmit message buffers has the MBIF and MBIE flag asserted. 1 At least one individual transmit message buffer has the MBIF and MBIE flag asserted. | | MIE | Module Interrupt Enable — This flag controls if the module interrupt line is asserted when the MIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | PRIE | Protocol Interrupt Enable — This flag controls if the protocol interrupt line is asserted when the PRIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | CHIE | CHI Interrupt Enable — This flag controls if the CHI interrupt line is asserted when the CHIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | Table 262. GIFER field descriptions(Continued) | Field | Description | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | WUPIE | Wakeup Interrupt Enable — This flag controls if the wakeup interrupt line is asserted when the WUPIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | | FNEBIE | Receive FIFO channel B Not Empty Interrupt Enable — This flag controls if the receive FIFO B interrupt line is asserted when the FNEBIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | | FNEAIE | Receive FIFO channel A Not Empty Interrupt Enable — This flag controls if the receive FIFO A interrupt line is asserted when the FNEAIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | | RBIE | Receive Buffer Interrupt Enable — This flag controls if the receive buffer interrupt line is asserted when the RBIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | | TBIE | Transmit Interrupt Enable — This flag controls if the transmit buffer interrupt line is asserted when the TBIF flag is set. 0 Disable interrupt line 1 Enable interrupt line | | ### 21.5.2.11 Protocol Interrupt Flag Register 0 (PIFR0) Figure 249. Protocol Interrupt Flag Register 0 (PIFR0) The register holds one set of the protocol-related individual interrupt flags. Table 263. PIFR0 field description | Field Description | | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | i ieiu | Fatal Protocol Error Interrupt Flag — This flag is set when the protocol engine has detected a | | | | fatal protocol error. In this case, the protocol engine goes into the <i>POC:halt</i> state immediately. The fatal protocol errors are: | | | FATL_IF | 1) <i>pLatestTx</i> violation, as described in the MAC process of the FlexRay protocol | | | _ | <ul> <li>2) transmission across slot boundary violation, as described in the FSP process of the FlexRay protocol</li> <li>No such event.</li> <li>1 Fatal protocol error detected.</li> </ul> | | | INTL_IF | Internal Protocol Error Interrupt Flag — This flag is set when the protocol engine has detected an internal protocol error. In this case, the protocol engine goes into the <i>POC:halt</i> state immediately. An internal protocol error occurs when the protocol engine has not finished a calculation and a new calculation is requested. This can be caused by a hardware error. O No such event. Internal protocol error detected. | | | | · | | | | <b>Illegal Protocol Configuration Interrupt Flag</b> — This flag is set when the protocol engine has detected an illegal protocol configuration parameter setting. In this case, the protocol engine goes into the <i>POC:halt</i> state immediately. | | | ILCF_IF | The protocol engine checks the <i>listen_timeout</i> value programmed into the <i>Section 21.5.2.64.15:</i> Protocol Configuration Register 14 (PCR14) and Section 21.5.2.64.16: Protocol Configuration Register 15 (PCR15) when the CONFIG_COMPLETE command was sent by the application via the Section 21.5.2.9: Protocol Operation Control Register (POCR). If the value of <i>listen_timeout</i> is equal to zero, the protocol configuration setting is considered as illegal. O No such event. | | | | Illegal protocol configuration detected. | | | CSA_IF | Cold Start Abort Interrupt Flag — This flag is set when the configured number of allowed cold start attempts is reached and none of these attempts was successful. The number of allowed cold start attempts is configured by the coldstart_attempts field in the Section 21.5.2.64.4: Protocol Configuration Register 3 (PCR3). | | | | No such event. Cold start aborted and no more coldstart attempts allowed. | | | MRC_IF | Missing Rate Correction Interrupt Flag — This flag is set when an insufficient number of measurements is available for rate correction at the end of the communication cycle. O No such event Insufficient number of measurements for rate correction detected | | | | Missing Offset Correction Interrupt Flag — This flag is set when an insufficient number of | | | MOC_IF | measurements is available for offset correction. This is related to the MISSING_TERM event in the CSP process for offset correction in the FlexRay protocol. 0 No such event. 1 Insufficient number of measurements for offset correction detected. | | | | Clock Correction Limit Reached Interrupt Flag — This flag is set when the internal calculated | | | CCL_IF | offset or rate calculation values have reached or exceeded its configured thresholds as given by the offset_coorection_out field in the Section 21.5.2.64.10: Protocol Configuration Register 9 (PCR9) and the rate_correction_out field in the Section 21.5.2.64.15: Protocol Configuration Register 14 (PCR14). | | | | No such event. Offset or rate correction limit reached. | | Table 263. PIFR0 field description(Continued) | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MXS_IF | <ul> <li>Max Sync Frames Detected Interrupt Flag — This flag is set when the number of synchronization frames detected in the current communication cycle exceeds the value of the node_sync_max field in the Section 21.5.2.64.31: Protocol Configuration Register 30 (PCR30).</li> <li>No such event.</li> <li>More than node_sync_max sync frames detected.</li> <li>Note: Only synchronization frames that have passed the synchronization frame acceptance and rejection filters are taken into account.</li> </ul> | | MTX_IF | Media Access Test Symbol Received Interrupt Flag — This flag is set when the MTS symbol was received on channel A or channel B. 0 No such event. 1 MTS symbol received. | | LTXB_IF | <ul> <li>pLatestTx Violation on Channel B Interrupt Flag — This flag is set when the frame transmission on channel B in the dynamic segment exceeds the dynamic segment boundary. This is related to the pLatestTx violation, as described in the MAC process of the FlexRay protocol.</li> <li>No such event.</li> <li>pLatestTx violation occurred on channel B.</li> </ul> | | LTXA_IF | <ul> <li>pLatestTx Violation on Channel A Interrupt Flag — This flag is set when the frame transmission on channel A in the dynamic segment exceeds the dynamic segment boundary. This is related to the pLatestTx violation as described in the MAC process of the FlexRay protocol.</li> <li>No such event.</li> <li>pLatestTx violation occurred on channel A.</li> </ul> | | TBVB_IF | Transmission across boundary on channel B Interrupt Flag — This flag is set when the frame transmission on channel B crosses the slot boundary. This is related to the transmission across slot boundary violation as described in the FSP process of the FlexRay protocol. O No such event. Transmission across boundary violation occurred on channel B. | | TBVA_IF | Transmission across boundary on channel A Interrupt Flag — This flag is set when the frame transmission on channel A crosses the slot boundary. This is related to the transmission across slot boundary violation as described in the FSP process of the FlexRay protocol. O No such event. Transmission across boundary violation occurred on channel A. | | TI2_IF | Timer 2 Expired Interrupt Flag — This flag is set whenever timer 2 expires. 0 No such event. 1 Timer 2 has reached its time limit. | | TI1_IF | Timer 1 Expired Interrupt Flag — This flag is set whenever timer 1 expires. 0 No such event 1 Timer 1 has reached its time limit | | CYS_IF | Cycle Start Interrupt Flag — This flag is set when a communication cycle starts. 0 No such event 1 Communication cycle started. | ### 21.5.2.12 Protocol Interrupt Flag Register 1 (PIFR1) Base + 0x001A Write: Normal Mode 12 13 15 10 11 REMC ODT IPC PEC PSC SSI3 SSI2 SSI1 SSI0 EVT 0 0 0 0 0 0 F\_IF IF IF \_IF \_IF \_IF \_IF \_IF \_IF \_IF w1c w1c w1c w1c w1c w1c w1c w1c W w1c w1c 0 0 0 0 0 0 0 0 0 0 0 0 Reset 0 0 Figure 250. Protocol Interrupt Flag Register 1 (PIFR1) The register holds one set of the protocol-related individual interrupt flags. Table 264. PIFR1 field descriptions | Field | Description | |------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EMC_IF | Error Mode Changed Interrupt Flag — This flag is set when the value of the ERRMODE bit field in the Section 21.5.2.19: Protocol Status Register 0 (PSR0) is changed by the controller. 0 No such event. 1 ERRMODE field changed. | | IPC_IF | Illegal Protocol Control Command Interrupt Flag — This flag is set when the PE tries to execute a protocol control command, which was issued via the POCCMD field of the Section 21.5.2.9: Protocol Operation Control Register (POCR), and detects that this protocol control command is not allowed in the current protocol state. In this case the command is not executed. For more details, see Section 21.7.4: Protocol control command execution. O No such event. Illegal protocol control command detected. | | PECF_IF | Protocol Engine Communication Failure Interrupt Flag — This flag is set if the controller has detected a communication failure between the protocol engine and the controller host interface 0 No such event. 1 Protocol Engine Communication Failure detected. | | PSC_IF | Protocol State Changed Interrupt Flag — This flag is set when the protocol state in the PROTSTATE field in the Section 21.5.2.19: Protocol Status Register 0 (PSR0) has changed. 0 No such event. 1 Protocol state changed. | | SSI3_IF<br>SSI2_IF<br>SSI1_IF<br>SSI0_IF | Slot Status Counter Incremented Interrupt Flag — Each of these flags is set when the SLOTSTATUSCNT field in the corresponding Section 21.5.2.47: Slot Status Counter Registers (SSCR0–SSCR3) is incremented. 0 No such event. 1 The corresponding slot status counter has incremented. | | EVT_IF | Even Cycle Table Written Interrupt Flag — This flag is set if the controller has written the sync frame measurement / ID tables into the FlexRay memory for the even cycle. 0 No such event. 1 Sync frame measurement table written | | ODT_IF | Odd Cycle Table Written Interrupt Flag — This flag is set if the controller has written the sync frame measurement / ID tables into the FlexRay memory for the odd cycle. 0 No such event. 1 Sync frame measurement table written | ### 21.5.2.13 Protocol Interrupt Enable Register 0 (PIER0) Base + 0x001C Write: Anytime 6 10 12 13 14 15 11 TBV **FATL** INTL **ILCF** CSA MRC MOC CCL MXS MTX LTXB LTXA TBVA TI2 TI1 CYS В \_IE 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Reset Figure 251. Protocol Interrupt Enable Register 0 (PIER0) This register defines whether or not the individual interrupt flags defined in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) can generate a protocol interrupt request. Table 265. PIER0 field descriptions | Field Description | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11010 | Fatal Protocol Error Interrupt Enable — This bit controls FATL_IF interrupt request generation. | | FATL_IE | interrupt request generation disabled. interrupt request generation enabled. | | INTL_IE | Internal Protocol Error Interrupt Enable — This bit controls INTL_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | ILCF_IE | <ul> <li>Illegal Protocol Configuration Interrupt Enable — This bit controls ILCF_IF interrupt request generation.</li> <li>o interrupt request generation disabled.</li> <li>interrupt request generation enabled.</li> </ul> | | CSA_IE | Cold Start Abort Interrupt Enable — This bit controls CSA_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | MRC_IE | Missing Rate Correction Interrupt Enable — This bit controls MRC_IF interrupt request generation. o interrupt request generation disabled. interrupt request generation enabled. | | MOC_IE | Missing Offset Correction Interrupt Enable — This bit controls MOC_IF interrupt request generation. o interrupt request generation disabled. interrupt request generation enabled. | | CCL_IE | Clock Correction Limit Reached Interrupt Enable — This bit controls CCL_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | MXS_IE | Max Sync Frames Detected Interrupt Enable — This bit controls MXS_IF interrupt request generation. o interrupt request generation disabled. interrupt request generation enabled. | | MTX_IE | Media Access Test Symbol Received Interrupt Enable — This bit controls MTX_IF interrupt request generation. interrupt request generation disabled. interrupt request generation enabled. | Table 265. PIER0 field descriptions | Field | Description | | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | LTXB_IE | <ul> <li>pLatestTx Violation on Channel B Interrupt Enable — This bit controls LTXB_IF interrupt request generation.</li> <li>interrupt request generation disabled.</li> <li>interrupt request generation enabled.</li> </ul> | | | LTXA_IE | <ul> <li>pLatestTx Violation on Channel A Interrupt Enable — This bit controls LTXA_IF interrupt request generation.</li> <li>interrupt request generation disabled.</li> <li>interrupt request generation enabled.</li> </ul> | | | TBVB_IE | Transmission across boundary on channel B Interrupt Enable — This bit controls TBVB_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | TBVA_IE | Transmission across boundary on channel A Interrupt Enable — This bit controls TBVA_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | TI2_IE | Timer 2 Expired Interrupt Enable — This bit controls TI1_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | TI1_IE | Timer 1 Expired Interrupt Enable — This bit controls TI1_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | CYS_IE | Cycle Start Interrupt Enable — This bit controls CYC_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | ### 21.5.2.14 Protocol Interrupt Enable Register 1 (PIER1) Figure 252. Protocol Interrupt Enable Register 1 (PIER1) This register defines whether or not the individual interrupt flags defined in Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1) can generate a protocol interrupt request. Table 266. PIER1 field descriptions | Field | Description | | |------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | EMC_IE | Error Mode Changed Interrupt Enable — This bit controls EMC_IF interrupt request generation. 0interrupt request generation disabled. 1 interrupt request generation enabled. | | | IPC_IE | Illegal Protocol Control Command Interrupt Enable — This bit controls IPC_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | PECF_IE | Protocol Engine Communication Failure Interrupt Enable — This bit controls PECF_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | PSC_IE | Protocol State Changed Interrupt Enable — This bit controls PSC_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | SSI3_IE<br>SSI2_IE<br>SSI1_IE<br>SSI0_IE | Slot Status Counter Incremented Interrupt Enable — This bit controls SSI[3:0]_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | EVT_IE | Even Cycle Table Written Interrupt Enable — This bit controls EVT_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | | ODT_IE | Odd Cycle Table Written Interrupt Enable — This bit controls ODT_IF interrupt request generation. 0 interrupt request generation disabled. 1 interrupt request generation enabled. | | ### 21.5.2.15 CHI Error Flag Register (CHIERFR) Base + 0x0020 Write: Normal Mode 12 14 15 8 9 10 11 13 FRLA FOV FID DPL PCMI FOV MBS MBU LCK DBL SBC SPL NML NMF ILSA **FRLB** EF EF EF B EF A\_EF \_EF EF \_EF EF F\_EF \_EF \_EF \_EF EF \_EF \_EF w1c Reset 0 0 0 0 0 0 0 0 Figure 253. CHI Error Flag Register (CHIERFR) This register holds the CHI related error flags. The interrupt generation for each of these error flags is controlled by the CHI interrupt enable bit CHIE in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). Table 267. CHIERFR field descriptions | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FRLB_EF | Frame Lost Channel B Error Flag — This flag is set if a complete frame was received on channel B but could not be stored in the selected individual message buffer because this message buffer is currently locked by the application. In this case, the frame and the related slot status information are lost. O No such event Frame lost on channel B detected | | FRLA_EF | Frame Lost Channel A Error Flag — This flag is set if a complete frame was received on channel A but could not be stored in the selected individual message buffer because this message buffer is currently locked by the application. In this case, the frame and the related slot status information are lost. O No such error Trame lost on channel A detected | | PCMI_EF | Protocol Command Ignored Error Flag — This flag is set if the application has issued a POC command by writing to the POCCMD field in the Section 21.5.2.9: Protocol Operation Control Register (POCR) while the BSY flag is equal to 1. In this case the command is ignored by the controller and is lost. 0 No such error 1 POC command ignored | | FOVB_EF | Receive FIFO Overrun Channel B Error Flag — This flag is set when an overrun of the Receive FIFO for channel B occurred. This error occurs if a semantically valid frame was received on channel B and matches the all criteria to be appended to the FIFO for channel B but the FIFO is full. In this case, the received frame and its related slot status information is lost. O No such error Receive FIFO overrun on channel B has been detected | | FOVA_EF | Receive FIFO Overrun Channel A Error Flag — This flag is set when an overrun of the Receive FIFO for channel A occurred. This error occurs if a semantically valid frame was received on channel A and matches the all criteria to be appended to the FIFO for channel A but the FIFO is full. In this case, the received frame and its related slot status information is lost. 0 No such error 1 Receive FIFO overrun on channel B has been detected | | MSB_EF | Message Buffer Search Error Flag — This flag is set if the message buffer search engine is still running while the next search cycle must be started due to the FlexRay protocol timing. In this case, not all message buffers are considered while searching. O No such event Search engine active while search start appears | | MBU_EF | Message Buffer Utilization Error Flag — This flag is asserted if the application writes to a message buffer control field that is beyond the number of utilized message buffers programmed in the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR). If the application writes to a MBCCSRn register with n > LAST_MB_UTIL, the controller ignores the write attempt and asserts the message buffer utilization error flag MBU_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR). O No such event Non-utilized message buffer enabled. | | LCK_EF | Lock Error Flag — This flag is set if the application tries to lock a message buffer that is already locked by the controller due to internal operations. In that case, the controller does not grant the lock to the application. The application must issue the lock request again. O No such error Lock error detected | Table 267. CHIERFR field descriptions(Continued) | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DBL_EF | Double Transmit Message Buffer Lock Error Flag — This flag is set if the application tries to lock the transmit side of a double transmit message buffer. In this case, the controller does not grant the lock to the transmit side of a double transmit message buffer. O No such event Double transmit buffer lock error occurred | | SBCF_EF | System Bus Communication Failure Error Flag — This flag is set if a system bus access was not finished within the required amount of time (see Section 21.6.19.2: System bus access timeout). 0 No such event 1 System bus access not finished in time | | FID_EF | Frame ID Error Flag — This flag is set if the frame ID stored in the message buffer header area differs from the frame ID stored in the message buffer control register. 0 No such error occurred 1 Frame ID error occurred | | DPL_EF | Dynamic Payload Length Error Flag — This flag is set if the payload length written into the message buffer header field of a single or double transmit message buffer assigned to the dynamic segment is greater than the maximum payload length for the dynamic segment as it is configured in the corresponding protocol configuration register field max_payload_length_dynamic in the Section 21.5.2.64.25: Protocol Configuration Register 24 (PCR24). 0 No such error occurred | | SPL_EF | Static Payload Length Error Flag — This flag is set if the payload length written into the message buffer header field of a single or double transmit message buffer assigned to the static segment is different from the payload length for the static segment as it is configured in the corresponding protocol configuration register field payload_length_static in the Section 21.5.2.64.20: Protocol Configuration Register 19 (PCR19). O No such error occurred Static payload length error occurred | | NML_EF | Network Management Length Error Flag — This flag is set if the payload length written into the header structure of a receive message buffer assigned to the static segment is less than the configured length of the Network Management Vector as configured in the Section 21.5.2.38: Network Management Vector Length Register (NMVLR). In this case the received part of the Network Management Vector will be used to update the Network Management Vector. O No such error occurred Network management length error occurred | | NMF_EF | Network Management Frame Error Flag — This flag is set if a received message in the static segment with a Preamble Indicator flag PP asserted has its Null Frame indicator flag NF asserted as well. In this case, the Global Network Management Registers (see Section 21.5.2.37: Network Management Vector Registers (NMVR0–NMVR5)) are not updated. 0 No such error occurred 1 Network management frame error occurred | | ILSA_EF | Illegal System Bus Address Error Flag — This flag is set if the external system bus subsystem has detected an access to an illegal system bus address from the controller (see Section 21.6.19.1: System bus illegal address access). 0 No such event 1 Illegal system bus address accessed | ### 21.5.2.16 Message Buffer Interrupt Vector Register (MBIVEC) Figure 254. Message Buffer Interrupt Vector Register (MBIVEC) This register indicates the lowest numbered receive message buffer and the lowest numbered transmit message buffer that have their interrupt status flag MBIF and interrupt enable MBIE bits asserted. This means that message buffers with lower message buffer numbers have higher priority. Table 268. MBIVEC field descriptions | Field | Description | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TBIVEC | <b>Transmit Buffer Interrupt Vector</b> — This field provides the number of the lowest numbered enabled transmit message buffer that has its interrupt status flag MBIF and its interrupt enable bit MBIE set. If there is no transmit message buffer with the interrupt status flag MBIF and the interrupt enable MBIE bits asserted, the value in this field is set to 0. | | RBIVEC | Receive Buffer Interrupt Vector — This field provides the message buffer number of the lowest numbered receive message buffer which has its interrupt flag MBIF and its interrupt enable bit MBIE asserted. If there is no receive message buffer with the interrupt status flag MBIF and the interrupt enable MBIE bits asserted, the value in this field is set to 0. | ### 21.5.2.17 Channel A Status Error Counter Register (CASERCR) Figure 255. Channel A Status Error Counter Register (CASERCR) This register provides the channel status error counter for channel A. The protocol engine generates a slot status vector for each static slot, each dynamic slot, the symbol window, and the NIT. The slot status vector contains the four protocol related error indicator bits vSs!SyntaxError, vSs!ContentError, vSs!BViolation, and vSs!TxConflict. The controller increments the status error counter by 1 if, for a slot or segment, at least one error indicator bit is set to 1. The counter wraps around after it has reached the maximum value. For more information on slot status monitoring, see Section 21.6.18: Slot status monitoring. Table 269. CASERCR field descriptions | Field | Description | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STATUS_ERR_CNT | <b>Channel Status Error Counter</b> — This field provides the current value channel status error counter. The counter value is updated within the first macrotick of the following slot or segment. | ### 21.5.2.18 Channel B Status Error Counter Register (CBSERCR) Figure 256. Channel B Status Error Counter Register (CBSERCR) This register provides the channel status error counter for channel B. The protocol engine generates a slot status vector for each static slot, each dynamic slot, the symbol window, and the NIT. The slot status vector contains the four protocol related error indicator bits vSS!SyntaxError, vSS!ContentError, vSS!BViolation, and vSS!TxConflict. The controller increments the status error counter by 1 if, for a slot or segment, at least one error indicator bit is set to 1. The counter wraps around after it has reached the maximum value. For more information on slot status monitoring see Section 21.6.18: Slot status monitoring. Table 270. CBSERCR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <b>Channel Status Error Counter</b> — This field provides the current channel status error count. The counter value is updated within the first macrotick of the following slot or segment. | ### 21.5.2.19 Protocol Status Register 0 (PSR0) Figure 257. Protocol Status Register 0 (PSR0) This register provides information about the current protocol status. DocID018714 Rev 5 540/1102 Table 271. PSR0 field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ERRMODE | Error Mode — protocol related variable: vPOC!ErrorMode. This field indicates the error mode of the protocol. 00 ACTIVE 01 PASSIVE 10 COMM_HALT 11 reserved | | SLOTMODE | Slot Mode — protocol related variable: vPOC!SlotMode. This field indicates the slot mode of the protocol. 00 SINGLE 01 ALL_PENDING 10 ALL 11 reserved | | PROTSTATE | Protocol State — protocol related variable: vPOC!State. This field indicates the state of the protocol. 000 POC:default config 001 POC:config 010 POC:wakeup 011 POC:ready 100 POC:normal passive 101 POC:normal active 110 POC:halt 111 POC:startup | | STARTUP<br>STATE | Startup State — protocol related variable: vPOC!StartupState. This field indicates the current substate of the startup procedure. 0000 reserved 0001 reserved 0010 POC:coldstart collision resolution 0011 POC:coldstart listen 0100 POC:integration consistency check 0101 POC:integration listen 0110 reserved 0111 POC:initialize schedule 1000 reserved 1001 reserved 1001 reserved 1101 POC:coldstart consistency check 1011 reserved 1101 POC:coldstart consistency check 1101 POC:integration coldstart check 1110 POC:coldstart gap 1111 POC:coldstart join | | WAKEUP<br>STATUS | Wakeup Status — protocol related variable: vPOC!WakeupStatus. This field provides the outcome of the execution of the wakeup mechanism. 000 UNDEFINED 001 RECEIVED_HEADER 010 RECEIVED_WUP 011 COLLISION_HEADER 100 COLLISION_WUP 101 COLLISION_UNKNOWN 110 TRANSMITTED 111 reserved | # 21.5.2.20 Protocol Status Register 1 (PSR1) Figure 258. Protocol Status Register 1 (PSR1) Table 272. PSR1 field descriptions | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CSAA | Cold Start Attempt Aborted Flag — protocol related event: 'set coldstart abort indicator in CHI' This flag is set when the controller has aborted a cold start attempt. 0 No such event 1 Cold start attempt aborted | | CSP | Leading Cold Start Path — This status bit is set when the controller has reached the POC:normal active state via the leading cold start path. This indicates that this node has started the network 0 No such event 1 POC:normal active reached from POC:startup state via leading cold start path | | REMCSAT | Remaining Coldstart Attempts — protocol related variable: vRemainingColdstartAttempts This field provides the number of remaining cold start attempts that the controller will execute. | | CPN | Leading Cold Start Path Noise — protocol related variable: vPOC!ColdstartNoise This status bit is set if the controller has reached the POC:normal active state via the leading cold start path under noise conditions. This indicates there was some activity on the FlexRay bus while the controller was starting up the cluster. O No such event 1 POC:normal active state was reached from POC:startup state via noisy leading cold start path | | HHR | Host Halt Request Pending — protocol related variable: vPOC!CHIHaltRequest This status bit is set when controller receives the HALT command from the application via the Section 21.5.2.9: Protocol Operation Control Register (POCR). The controller clears this status bit after a hard reset condition or when the protocol is in the POC:default config state. 0 No such event 1 HALT command received | | FRZ | Freeze Occurred — protocol related variable: vPOC!Freeze This status bit is set when the controller has reached the POC:halt state due to the host FREEZE command or due to an internal error condition requiring immediate halt. The controller clears this status bit after a hard reset condition or when the protocol is in the POC:default config state. 0 No such event 1 Immediate halt due to FREEZE or internal error condition | | APTAC | Allow Passive to Active Counter — protocol related variable: vPOC!vAllowPassivetoActive This field provides the number of consecutive even/odd communication cycle pairs that have passed with valid rate and offset correction terms, but the protocol is still in the POC:normal passive state due to an application configured delay to enter POC:normal active state. This delay is defined by the allow_passive_to_active field in the Section 21.5.2.64.13: Protocol Configuration Register 12 (PCR12). | # 21.5.2.21 Protocol Status Register 2 (PSR2) Figure 259. Protocol Status Register 2 (PSR2) This register provides a snapshot of status information about the Network Idle Time NIT, the Symbol Window and the clock synchronization. The NIT related status bits NBVB, NSEB, NBVA, and NSEA are updated by the controller after the end of the NIT and before the end of the first slot of the next communication cycle. The Symbol Window related status bits STCB, SBVB, SSEB, MTB, STCA, SBVA, SSEB, and MTA are updated by the controller after the end of the symbol window and before the end of the current communication cycle. If no symbol window is configured, the symbol window related status bits remain in their reset state. The clock synchronization related CLKCORRFAILCNT is updated by the controller after the end of the static segment and before the end of the current communication cycle. Table 273. PSR2 field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NBVB | NIT Boundary Violation on Channel B — protocol related variable: vSS!BViolation for NIT on channel B This status bit is set when there was some media activity on the FlexRay bus channel B at the end of the NIT. No such event Media activity at boundaries detected | | NSEB | NIT Syntax Error on Channel B — protocol related variable: vSS!SyntaxError for NIT on channel B This status bit is set when a syntax error was detected during NIT on channel B. 0 No such event 1 Syntax error detected | | STCB | Symbol Window Transmit Conflict on Channel B — protocol related variable: vSS!TxConflict for symbol window on channel B This status bit is set if there was a transmission conflict during the symbol window on channel B. No such event Transmission conflict detected | | SBVB | Symbol Window Boundary Violation on Channel B — protocol related variable: vSS!BViolation for symbol window on channel B This status bit is set if there was some media activity on the FlexRay bus channel B at the start or at the end of the symbol window. No such event Media activity at boundaries detected | | SSEB | Symbol Window Syntax Error on Channel B — protocol related variable: vSS/SyntaxError for symbol window on channel B This status bit is set when a syntax error was detected during the symbol window on channel B. No such event Syntax error detected | Table 273. PSR2 field descriptions(Continued) | Field | Description | |---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | МТВ | Media Access Test Symbol MTS Received on Channel B — protocol related variable: vSs!ValidMTS for Symbol Window on channel B This status bit is set if the Media Access Test Symbol MTS was received in the symbol window on channel B. 0 No such event 1 MTS symbol received | | NBVA | NIT Boundary Violation on Channel A — protocol related variable: vSS!BViolation for NIT on channel A This status bit is set when there was some media activity on the FlexRay bus channel A at the end of the NIT. 0 No such event 1 Media activity at boundaries detected | | NSEA | NIT Syntax Error on Channel A — protocol related variable: vSS!SyntaxError for NIT on channel A This status bit is set when a syntax error was detected during NIT on channel A. 0 No such event 1 Syntax error detected | | STCA | Symbol Window Transmit Conflict on Channel A — protocol related variable: vSS!TxConflict for symbol window on channel A This status bit is set if there was a transmission conflicts during the symbol window on channel A. No such event Transmission conflict detected | | SBVA | Symbol Window Boundary Violation on Channel A — protocol related variable: vSS!BViolation for symbol window on channel A This status bit is set if there was some media activity on the FlexRay bus channel A at the start or at the end of the symbol window. No such event Media activity at boundaries detected | | SSEA | Symbol Window Syntax Error on Channel A — protocol related variable: vSS!SyntaxError for symbol window on channel A This status bit is set when a syntax error was detected during the symbol window on channel A. No such event Syntax error detected | | МТА | Media Access Test Symbol MTS Received on Channel A — protocol related variable: vSs!ValidMTS for symbol window on channel A This status bit is set if the Media Access Test Symbol MTS was received in the symbol window on channel A. 1 MTS symbol received 0 No such event | | CLKCORR-<br>FAILCNT | Clock Correction Failed Counter — protocol related variable: vClockCorrectionFailed This field provides the number of consecutive even/odd communication cycle pairs that have passed without clock synchronization having performed an offset or a rate correction due to lack of synchronization frames. It is not incremented when it has reached the configured value of either max_without_clock_correction_fatal or max_without_clock_correction_passive as defined in the Section 21.5.2.64.9: Protocol Configuration Register 8 (PCR8). The controller resets this counter on a hard reset condition, when the protocol enters the POC:normal active state, or when both the rate and offset correction terms have been calculated successfully. | ## 21.5.2.22 Protocol Status Register 3 (PSR3) Figure 260. Protocol Status Register 3 (PSR3) This register provides aggregated channel status information as an accrued status of channel activity for all communication slots, regardless of whether they are assigned for transmission or subscribed for reception. It provides accrued information for the symbol window, the NIT, and the wakeup status. Table 274. PSR3 field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUB | Wakeup Symbol Received on Channel B — This flag is set when a wakeup symbol was received on channel B. No wakeup symbol received Wakeup symbol received | | ABVB | Aggregated Boundary Violation on Channel B — This flag is set when a boundary violation has been detected on channel B. Boundary violations are detected in the communication slots, the symbol window, and the NIT. 0 No boundary violation detected 1 Boundary violation detected | | AACB | Aggregated Additional Communication on Channel B — This flag is set when at least one valid frame was received on channel B in a slot that also contained an additional communication with either syntax error, content error, or boundary violations. O No additional communication detected Additional communication detected | | ACEB | Aggregated Content Error on Channel B — This flag is set when a content error has been detected on channel B. Content errors are detected in the communication slots, the symbol window, and the NIT. 0 No content error detected 1 Content error detected | | ASEB | Aggregated Syntax Error on Channel B — This flag is set when a syntax error has been detected on channel B. Syntax errors are detected in the communication slots, the symbol window and the NIT. 0 No syntax error detected 1 Syntax errors detected | | AVFB | Aggregated Valid Frame on Channel B — This flag is set when a syntactically correct valid frame has been received in any static or dynamic slot through channel B. 1 At least one syntactically valid frame received 0 No syntactically valid frames received | Table 274. PSR3 field descriptions (Continued) | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUA | Wakeup Symbol Received on Channel A — This flag is set when a wakeup symbol was received on channel A. 0 No wakeup symbol received 1 Wakeup symbol received | | ABVA | Aggregated Boundary Violation on Channel A — This flag is set when a boundary violation has been detected on channel A. Boundary violations are detected in the communication slots, the symbol window, and the NIT. O No boundary violation detected Boundary violation detected | | AACA | Aggregated Additional Communication on Channel A — This flag is set when a valid frame was received in a slot on channel A that also contained an additional communication with either syntax error, content error, or boundary violations. O No additional communication detected Additional communication detected | | ACEA | Aggregated Content Error on Channel A — This flag is set when a content error has been detected on channel A. Content errors are detected in the communication slots, the symbol window, and the NIT. O No content error detected Content error detected | | ASEA | Aggregated Syntax Error on Channel A — This flag is set when a syntax error has been detected on channel A. Syntax errors are detected in the communication slots, the symbol window, and the NIT. O No syntax error detected Syntax errors detected | | AVFA | Aggregated Valid Frame on Channel A — This flag is set when a syntactically correct valid frame has been received in any static or dynamic slot through channel A. 0 No syntactically valid frames received 1 At least one syntactically valid frame received | # 21.5.2.23 Macrotick Counter Register (MTCTR) Figure 261. Macrotick Counter Register (MTCTR) This register provides the macrotick count of the current communication cycle. Table 275. MTCTR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------| | МТСТ | Macrotick Counter — protocol related variable: vMacrotick This field provides the macrotick count of the current communication cycle. | ## 21.5.2.24 Cycle Counter Register (CYCTR) Base + 0x0032 Figure 262. Cycle Counter Register (CYCTR) This register provides the number of the current communication cycle. #### Table 276. CYCTR field descriptions | Field | Description | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CYCCNT | Cycle Counter — protocol related variable: vCycleCounter This field provides the number of the current communication cycle. If the counter reaches the maximum value of 63, the counter wraps and starts from zero again. | # 21.5.2.25 Slot Counter Channel A Register (SLTCTAR) Base + 0x0034 Figure 263. Slot Counter Channel A Register (SLTCTAR) This register provides the number of the current slot in the current communication cycle for channel A. Table 277. SLTCTAR field descriptions | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SLOTCNTA | Slot Counter Value for Channel A — protocol related variable: <i>vSlotCounter</i> for channel A This field provides the number of the current slot in the current communication cycle. | #### 21.5.2.26 Slot Counter Channel B Register (SLTCTBR) Base + 0x0036 Figure 264. Slot Counter Channel B Register (SLTCTBR) This register provides the number of the current slot in the current communication cycle for channel B. Table 278. SLTCTBR field descriptions | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SLOTCNTA | Slot Counter Value for Channel B — protocol related variable: <i>vSlotCounter</i> for channel B This field provides the number of the current slot in the current communication cycle. | #### 21.5.2.27 Rate Correction Value Register (RTCORVR) Figure 265. Rate Correction Value Register (RTCORVR) This register provides the sign extended rate correction value in microticks as it was calculated by the clock synchronization algorithm. The controller updates this register during the NIT of each odd numbered communication cycle. Table 279. RTCORVR field descriptions | Field | Description | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Rate Correction Value — protocol related variable: <i>vRateCorrection</i> (before value limitation and external rate correction) | | RATECORR | This field provides the sign extended rate correction value in microticks as it was calculated by the clock synchronization algorithm. The value is represented in 2's complement format. This value does not include the value limitation and the application of the external rate correction. If the magnitude of the internally calculated rate correction value exceeds the limit given by rate_correction_out in the Section 21.5.2.64.14: Protocol Configuration Register 13 (PCR13), the clock correction reached limit interrupt flag CCL_IF is set in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0). | | | <b>Note:</b> If the controller was not able to calculate a new rate correction term due to a lack of synchronization frames, the RATECORR value is not updated. | ### 21.5.2.28 Offset Correction Value Register (OFCORVR) Figure 266. Offset Correction Value Register (OFCORVR) This register provides the sign extended offset correction value in microticks as it was calculated by the clock synchronization algorithm. The controller updates this register during the NIT. | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OFFSET-<br>CORR | Offset Correction Value — protocol related variable: vOffsetCorrection (before value limitation and external offset correction) This field provides the sign extended offset correction value in microticks as it was calculated by the clock synchronization algorithm. The value is represented in 2's complement format. This value does not include the value limitation and the application of the external offset correction. If the magnitude of the internally calculated rate correction value exceeds the limit given by offset_correction_out field in the Section 21.5.2.64.30: Protocol Configuration Register 29 (PCR29), the clock correction reached limit interrupt flag CCL_IF is set in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0). Note: If the controller was not able to calculate an new offset correction term due to a lack of synchronization frames, the OFFSETCORR value is not updated. | Table 280. OFCORVR field descriptions ### 21.5.2.29 Combined Interrupt Flag Register (CIFRR) Figure 267. Combined Interrupt Flag Register (CIFRR) This register provides five combined interrupt flags and a copy of three individual interrupt flags. The combined interrupt flags are the result of a binary OR of the values of other interrupt flags regardless of the state of the interrupt enable bits. The generation scheme for the combined interrupt flags is shown in *Figure 384*. The individual interrupt flags WUPIF, FNEBIF, and FNEAIF are copies of corresponding flags in the *Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER)* and are provided here to simplify the application interrupt flag check. To clear the individual interrupt flags, the application must use the *Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER)*. Note: The meanings of the combined status bits MIF, PRIF, CHIF, RBIF, and TBIF are different from those mentioned in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). Table 281. CIFRR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MIF | Module Interrupt Flag — This flag is set if there is at least one interrupt source that has its interrupt flag asserted. 0 No interrupt source has its interrupt flag asserted. | | | At least one interrupt source has its interrupt flag asserted. | | PRIF | Protocol Interrupt Flag — This flag is set if at least one of the individual protocol interrupt flags in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) or Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1) is equal to 1. | | | O All individual protocol interrupt flags are equal to 0. At least one of the individual protocol interrupt flags is equal to 1. | Table 281. CIFRR field descriptions(Continued) | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CHIF | CHI Interrupt Flag — This flag is set if at least one of the individual CHI error flags in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is equal to 1. 0 All CHI error flags are equal to 0. 1 At least one CHI error flag is equal to 1. | | WUPIF | Wakeup Interrupt Flag — Provides the same value as GIFER[WUPIF] | | FNEBIF | Receive FIFO channel B Not Empty Interrupt Flag — Provides the same value as GIFER[FNEBI] | | FNEAIF | Receive FIFO channel A Not Empty Interrupt Flag — Provides the same value as GIFER[FNEAIF] | | RBIF | Receive Message Buffer Interrupt Flag — This flag is set if for at least one of the individual receive message buffers (MBCCSRn[MTD] = 0) the interrupt flag MBIF in the corresponding Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) is equal to 1. 0 None of the individual receive message buffers has the MBIF flag asserted. | | | 1 At least one individual receive message buffers has the MBIF flag asserted. | | TBIF | Transmit Message Buffer Interrupt Flag — This flag is set if for at least one of the individual single or double transmit message buffers (MBCCSRn[MTD] = 1) the interrupt flag MBIF in the corresponding Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) is equal to 1. 0 None of the individual transmit message buffers has the MBIF flag asserted. 1 At least one individual transmit message buffers has the MBIF flag asserted. | # 21.5.2.30 System Memory Access Time-Out Register (SYMATOR) Figure 268. System Memory Access Time-Out Register (SYMATOR) Table 282. SYMATOR field descriptions | Field | Description | |---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIMEOUT | System Memory Access Time-Out — This value defines the maximum amount of time to finish a system bus access in order to ensure correct frame transmission and reception (see Section 21.6.19.2: System bus access timeout). | ### 21.5.2.31 Sync Frame Counter Register (SFCNTR) Figure 269. Sync Frame Counter Register (SFCNTR) This register provides the number of synchronization frames that are used for clock synchronization in the last even and in the last odd numbered communication cycle. This register is updated after the start of the NIT and before 10 MT after offset correction start. Note: If the application has locked the even synchronization table at the end of the static segment of an even communication cycle, the controller will not update the fields SFEVB and SFEVA. If the application has locked the odd synchronization table at the end of the static segment of an odd communication cycle, the controller will not update the values SFODB and SFODA. Table 283. SFCNTR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SFEVB | Sync Frames Channel B, even cycle — protocol related variable: size of ( <i>vsSyncIdListB</i> for even cycle) This field provides the size of the internal list of frame IDs of received synchronization frames used for clock synchronization. | | SFEVB | Sync Frames Channel A, even cycle — protocol related variable: size of ( <i>vsSyncIdListA</i> for even cycle) This field provides the size of the internal list of frame IDs of received synchronization frames used for clock synchronization. | | SFODB | Sync Frames Channel B, odd cycle — protocol related variable: size of ( <i>vsSyncldListB</i> for odd cycle) This field provides the size of the internal list of frame IDs of received synchronization frames used for clock synchronization. | | SFODA | Sync Frames Channel A, odd cycle — protocol related variable: size of ( <i>vsSyncldListA</i> for odd cycle) This field provides the size of the internal list of frame IDs of received synchronization frames used for clock synchronization. | ### 21.5.2.32 Sync Frame Table Offset Register (SFTOR) Figure 270. Sync Frame Table Offset Register (SFTOR) This register defines the FlexRay Memory related offset for sync frame tables. For more details, see Section 21.6.12: Sync frame ID and sync frame deviation tables. Table 284. SFTOR field description | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SFTOR | Sync Frame Table Offset — The offset of the Sync Frame Tables in the FlexRay Memory. This offset is required to be 16-bit aligned. Thus STF_OFFSET[0] is always 0. | #### 21.5.2.33 Sync Frame Table Configuration, Control, Status Register (SFTCCSR) Figure 271. Sync Frame Table Configuration, Control, Status Register (SFTCCSR) This register provides configuration, control, and status information related to the generation and access of the clock sync ID tables and clock sync measurement tables. For a detailed description, see Section 21.6.12: Sync frame ID and sync frame deviation tables. Table 285. SFTCCSR field descriptions | Field | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ELKT | Even Cycle Tables Lock/Unlock Trigger — This trigger bit locks and unlocks the even cycle tables. 0 No effect 1 Triggers lock/unlock of the even cycle tables. | | OLKT | Odd Cycle Tables Lock/Unlock Trigger — This trigger bit locks and unlocks the odd cycle tables. 0 No effect 1 Triggers lock/unlock of the odd cycle tables. | | CYCNUM | Cycle Number — This field provides the number of the cycle in which the currently locked table was recorded. If none or both tables are locked, this value is related to the even cycle table. | | ELKS | Even Cycle Tables Lock Status — This status bit indicates whether the application has locked the even cycle tables. O Application has not locked the even cycle tables. Application has locked the even cycle tables. | | OLKS | Odd Cycle Tables Lock Status — This status bit indicates whether the application has locked the odd cycle tables. O Application has not locked the odd cycle tables. Application has locked the odd cycle tables. | Table 285. SFTCCSR field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EVAL | Even Cycle Tables Valid — This status bit indicates whether the Sync Frame ID and Sync Frame Deviation Tables for the even cycle are valid. The controller clears this status bit when it starts updating the tables, and sets this bit when it has finished the table update. 0 Tables are not valid (update is ongoing) 1 Tables are valid (consistent). | | OVAL | Odd Cycle Tables Valid — This status bit indicates whether the Sync Frame ID and Sync Frame Deviation Tables for the odd cycle are valid. The controller clears this status bit when it starts updating the tables, and sets this bit when it has finished the table update. O Tables are not valid (update is ongoing) 1 Tables are valid (consistent). | | ОРТ | One Pair Trigger — This trigger bit controls whether the controller writes continuously or only one pair of Sync Frame Tables into the FlexRay memory. If this trigger is set to 1 while SDVEN or SIDEN is set to 1, the controller writes only one pair of the enabled Sync Frame Tables corresponding to the next even-odd-cycle pair into the FlexRay memory. In this case, the controller clears the SDVEN or SIDEN bits immediately. If this trigger is set to 0 while SDVEN or SIDEN is set to 1, the controller writes continuously the enabled Sync Frame Tables into the FlexRay memory. O Write continuously pairs of enabled Sync Frame Tables into FlexRay memory. Write only one pair of enabled Sync Frame Tables into FlexRay memory. | | | Do not write Sync Frame Deviation Tables. Write Sync Frame Deviation Tables into FlexRay memory. | | SIDEN | Sync Frame ID Table Enable — This bit controls the generation of the Sync Frame ID Tables. The application must set this bit to 1 to request the controller to write the Sync Frame ID Tables into the FlexRay memory. O Do not write Sync Frame ID Tables. Write Sync Frame ID Tables into FlexRay memory. | # 21.5.2.34 Sync Frame ID Rejection Filter Register (SFIDRFR) Figure 272. Sync Frame ID Rejection Filter Register (SFIDRFR) This register defines the Sync Frame Rejection Filter ID. The application must update this register outside of the static segment. If the application updates this register in the static segment, it can appear that the controller accepts the sync frame in the current cycle. #### Table 286. SFIDRFR field descriptions | Field | Description | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SYNFRID | Sync Frame Rejection ID — This field defines the frame ID of a frame that must not be used for clock synchronization. For details see Section 21.6.15.2: Sync frame rejection filtering. | #### 21.5.2.35 Sync Frame ID Acceptance Filter Value Register (SFIDAFVR) Figure 273. Sync Frame ID Acceptance Filter Value Register (SFIDAFVR) This register defines the sync frame acceptance filter value. For details on filtering, see *Section 21.6.15: Sync frame filtering.* Table 287. SFIDAFVR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------| | FVAL | Filter Value — This field defines the value for the sync frame acceptance filtering. | ## 21.5.2.36 Sync Frame ID Acceptance Filter Mask Register (SFIDAFMR) Figure 274. Sync Frame ID Acceptance Filter Mask Register (SFIDAFMR) This register defines the sync frame acceptance filter mask. For details on filtering see Section 21.6.15.1: Sync frame acceptance filtering. Table 288. SFIDAFMR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------| | FMSK | Filter Mask — This field defines the mask for the sync frame acceptance filtering. | ### 21.5.2.37 Network Management Vector Registers (NMVR0-NMVR5) Base + 0x004C (NMVR0) Base + 0x004E (NMVR1) Base + 0x0050 (NMVR2) Base + 0x0052 (NMVR3) Base + 0x0054 (NMVR4) Base + 0x0056 (NMVR5) Figure 275. Network Management Vector Registers (NMVR0-NMVR5) Each of these six registers holds one part of the Network Management Vector. The length of the Network Management Vector is configured in the Section 21.5.2.38: Network Management Vector Length Register (NMVLR). If NMVLR is programmed with a value that is less than 12 bytes, the remaining bytes of the Section 21.5.2.37: Network Management Vector Registers (NMVR0-NMVR5), which are not used for the Network Management Vector accumulating, will remain 0. The NMVR provides accrued information over all received NMVs in the last communication cycle. All NMVs received in one cycle are ORed into the NMVR. The NMVR is updated at the end of the communication cycle. Table 289. NMVR[0:5] field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NMVP | Network Management Vector Part — The mapping between the Section 21.5.2.37: Network Management Vector Registers (NMVR0–NMVR5) and the receive message buffer payload bytes in NMV[0:11] is shown in Table 290. | Table 290. Mapping of NMVRn to received payload bytes NMVn | NMVn Received Payload | |-----------------------| | NMV0 | | NMV1 | | NMV2 | | NMV3 | | | | NMV10 | | NMV11 | | | ### 21.5.2.38 Network Management Vector Length Register (NMVLR) Figure 276. Network Management Vector Length Register (NMVLR) This register defines the length of the network management vector in bytes. Table 291. NMVLR field descriptions | Field | Description | | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | NMVL | Network Management Vector Length — protocol related variable: gNetworkManagementVectorLength This field defines the length of the Network Management Vector in bytes. Legal values are between 0 and 12. | | | #### 21.5.2.39 Timer Configuration and Control Register (TICCR) Figure 277. Timer Configuration and Control Register (TICCR) This register configures and controls the two timers T1 and T2. For timer details, see *Section 21.6.17: Timer support.* The Timer T1 is an absolute timer. The Timer T2 can be configured as an absolute or relative timer. Table 292. TICCR field descriptions | Field | Description | | | |------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | T2_CFG | Timer T2 Configuration — This bit configures the time base mode of Timer T2. 0 T2 is absolute timer. 1 T2 is relative timer. | | | | Timer T2 Repetitive Mode — This bit configures the repetition mode of Timer T2. T2_REP 0 T2 is non repetitive 1 T2 is repetitive | | | | | T2SP | Timer T2 Stop — This trigger bit stops timer T2. 0 no effect 1 stop timer T2 | | | | Field | Description | |--------|-----------------------------------------------------------------------------------------------------------------------------| | T2TR | Timer T2 Trigger — This trigger bit starts timer T2. 0 no effect 1 start timer T2 | | T2ST | Timer T2 State — This status bit provides the current state of timer T2. 0 timer T2 is idle 1 timer T2 is running | | T1_REP | Timer T1 Repetitive Mode — This bit configures the repetition mode of timer T1. 0 T1 is non repetitive 1 T1 is repetitive | | T1SP | Timer T1 Stop — This trigger bit stops timer T1. 0 no effect 1 stop timer T1 | | T1TR | Timer T1 Trigger — This trigger bit starts timer T1. 0 no effect 1 start timer T1 | | T1ST | Timer T1 State — This status bit provides the current state of timer T1. 0 timer T1 is idle 1 timer T1 is running | Table 292. TICCR field descriptions(Continued) Note: Both timers are deactivated immediately when the protocol enters a state different from POC:normal active or POC:normal passive. ### 21.5.2.40 Timer 1 Cycle Set Register (TI1CYSR) Figure 278. Timer 1 Cycle Set Register (TI1CYSR) This register defines the cycle filter value and the cycle filter mask for timer T1. For a detailed description of timer T1, refer to Section 21.6.17.1: Absolute timer T1. Table 293. TI1CYSR field descriptions | Field | Description | |------------|---------------------------------------------------------------------------------------| | T1_CYC_VAL | Timer T1 Cycle Filter Value — This field defines the cycle filter value for timer T1. | | T1_CYC_MSK | Timer T1 Cycle Filter Mask — This field defines the cycle filter mask for timer T1. | Note: If the application modifies the value in this register while the timer is running, the change becomes effective immediately and timer T1 will expire according to the changed value. ### 21.5.2.41 Timer 1 Macrotick Offset Register (TI1MTOR) Figure 279. Timer 1 Macrotick Offset Register (TI1MTOR) This register holds the macrotick offset value for timer T1. For a detailed description of timer T1, refer to Section 21.6.17.1: Absolute timer T1. Table 294. TI1MTOR field descriptions | Field | Description | |-------------|----------------------------------------------------------------------------------------------| | T1_MTOFFSET | <b>Timer 1 Macrotick Offset</b> — This field defines the macrotick offset value for timer 1. | Note: If the application modifies the value in this register while the timer is running, the change becomes effective immediately and timer T1 will expire according to the changed value. #### 21.5.2.42 Timer 2 Configuration Register 0 (TI2CR0) Figure 280. Timer 2 Configuration Register 0 (TI2CR0) The content of this register depends on the value of the T2\_CFG bit in the Section 21.5.2.39: Timer Configuration and Control Register (TICCR). For a detailed description of timer T2, refer to Section 21.6.17.2: Absolute / relative timer T2. Table 295. TI2CR0 field descriptions | Field | Description | | | |-----------------|-------------------------------------------------------------------------------------------------------------|--|--| | | Fields for absolute timer T2 (TICCR[T2_CFG] = 0) | | | | T2_CYC_VAL | Timer T2 Cycle Filter Value — This field defines the cycle filter value for timer T2. | | | | T2_CYC_MSK | Timer T2 Cycle Filter Mask — This field defines the cycle filter mask for timer T2. | | | | | Fields for relative timer T2 (TICCR[T2_CFG = 1) | | | | T2_MTCNT[31:16] | <b>Timer T2 Macrotick High Word</b> — This field defines the high word of the macrotick count for timer T2. | | | Note: If timer T2 is configured as an absolute timer and the application modifies the values in this register while the timer is running, the change becomes effective immediately and timer T2 will expire according to the changed values. If timer T2 is configured as a relative timer and the application changes the values in this register while the timer is running, the change becomes effective when the timer has expired according to the old values. #### 21.5.2.43 Timer 2 Configuration Register 1 (TI2CR1) Figure 281. Timer 2 Configuration Register 1 (TI2CR1) The content of this register depends on the value of the T2\_CFG bit in the Section 21.5.2.39: Timer Configuration and Control Register (TICCR). For a detailed description of timer T2, refer to Section 21.6.17.2: Absolute / relative timer T2. #### Table 296. TI2CR1 field descriptions | Field | Description | |---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | | Fields for absolute timer T2 (TICCR[T2_CFG] = 0) | | T2_MTOFFSET Timer T2 Macrotick Offset — This field holds the macrotick offset value for timer T2. | | | | Fields for relative timer T2 (TICCR[T2_CFG] = 1) | | T2_MTCNT[15:0] | <b>Timer T2 Macrotick Low Word</b> — This field defines the low word of the macrotick value for timer T2. | Note: If timer T2 is configured as an absolute timer and the application modifies the values in this register while the timer is running, the change becomes effective immediately and the timer T2 will expire according to the changed values. If timer T2 is configured as a relative timer and the application changes the values in this register while the timer is running, the change becomes effective when the timer has expired according to the old values. #### 21.5.2.44 Slot Status Selection Register (SSSR) Figure 282. Slot Status Selection Register (SSSR) DocID018714 Rev 5 This register accesses the four internal non memory-mapped slot status selection registers SSSR0 to SSSR3. Each internal registers selects a slot, or symbol window/NIT, whose status vector will be saved in the corresponding *Section 21.5.2.46*: *Slot Status Registers* (SSR0–SSR7) according to *Table 298*. For a detailed description of slot status monitoring, refer to *Section 21.6.18*: *Slot status monitoring*. Table 297. SSSR field descriptions | Field | Description | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | WMD | Write Mode — This control bit defines the write mode of this register. 0 Write to all fields in this register on write access. 1 Write to SEL field only on write access. | | | | | SEL | Selector — This field selects one of the four internal slot status selection registers for access. 00 select SSSR0. 01 select SSSR1. 10 select SSSR2. 11 select SSSR3. | | | | | SLOTNUMBER Slot Number — This field specifies the number of the slot whose status will be saved corresponding slot status registers. Note: If this value is set to 0, the related slot status register provides the status of the window after the NIT start, and provides the status of the NIT after the cycle sta | | | | | Table 298. Mapping between SSSRn and SSRn | | Write the Slot Status of the Slot Selected by SSSRn for each | | | | |----------------------|--------------------------------------------------------------|---------------|-------------------------|---------------| | Internal Slot Status | Even Communication Cycle | | Odd Communication Cycle | | | Selection Register | For Channel B | For Channel A | For Channel B | For Channel A | | | to | to | to | to | | SSSR0 | SSR0[15:8] | SSR0[7:0] | SSR1[15:8] | SSR1[7:0] | | SSSR1 | SSR2[15:8] | SSR2[7:0] | SSR3[15:8] | SSR3[7:0] | | SSSR2 | SSR4[15:8] | SSR4[7:0] | SSR5[15:8] | SSR5[7:0] | | SSSR3 | SSR6[15:8] | SSR6[7:0] | SSR7[15:8] | SSR7[7:0] | ## 21.5.2.45 Slot Status Counter Condition Register (SSCCR) Figure 283. Slot Status Counter Condition Register (SSCCR) This register accesses and programs the four internal non-memory mapped Slot Status Counter Condition Registers SSCCR0 to SSCCR3. Each of these four internal slot status counter condition registers defines the mode and the conditions for incrementing the counter in the corresponding Section 21.5.2.47: Slot Status Counter Registers (SSCR0– SSCR3). The correspondence is given in *Table 300*. For a detailed description of slot status counters, refer to *Section 21.6.18.4*: *Slot status counter registers*. Table 299. SSCCR field descriptions | Field | Description | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | WMD | Write Mode — This control bit defines the write mode of this register. 0 Write to all fields in this register on write access. 1 Write to SEL field only on write access. | | | | | SEL | Selector — This field selects one of the four internal slot counter condition registers for acce 00 select SSCCR0. 01 select SSCCR1. 10 select SSCCR2. 11 select SSCCR3. | | | | | CNTCFG | Counter Configuration — These bit field controls the channel related incrementing of the slot status counter. On increment by 1 if condition is fulfilled on channel A. Increment by 1 if condition is fulfilled on channel B. increment by 1 if condition is fulfilled on at least one channel. increment by 2 if condition is fulfilled on both channels channel. increment by 1 if condition is fulfilled on only one channel. | | | | | Multi Cycle Selection — This bit defines whether the slot status counter accumulates over multiple communication cycles or provides information for the previous communication cycle only. The Slot Status Counter provides information for the previous communication cycle only. The Slot Status Counter accumulates over multiple communication cycles. | | | | | | VFR | Valid Frame Restriction — This bit restricts the counter to received valid frames. O The counter is not restricted to valid frames only. The counter is restricted to valid frames only. | | | | | SYF | Sync Frame Restriction — This bit restricts the counter to received frames with the sync frame indicator bit set to 1. O The counter is not restricted with respect to the sync frame indicator bit. The counter is restricted to frames with the sync frame indicator bit set to 1. | | | | | NUF | Null Frame Restriction — This bit restricts the counter to received frames with the null frame indicator bit set to 0. 0 The counter is not restricted with respect to the null frame indicator bit. 1 The counter is restricted to frames with the null frame indicator bit set to 0. | | | | | SUF | Startup Frame Restriction — This bit restricts the counter to received frames with the startup frame indicator bit set to 1. O The counter is not restricted with respect to the startup frame indicator bit. The counter is restricted to received frames with the startup frame indicator bit set to 1. | | | | | STATUS<br>MASK[3:0] | Slot Status Mask — This bit field enables the counter with respect to the four slot status error indicator bits. STATUSMASK[3] — This bit enables the counting for slots with the syntax error indicator bit set to 1. STATUSMASK[2] — This bit enables the counting for slots with the content error indicator bit set to 1. STATUSMASK[1] — This bit enables the counting for slots with the boundary violation indicator bit set to 1. STATUSMASK[0] — This bit enables the counting for slots with the transmission conflict indicator bit set to 1. | | | | Condition Register Condition Defined for Register SSCCR0 SSCR0 SSCCR1 SSCR1 SSCCR2 SSCR2 SSCR3 Table 300. Mapping between internal SSCCRn and SSCRn #### 21.5.2.46 Slot Status Registers (SSR0-SSR7) SSCCR3 Base + 0x0068 (SSR0) Base + 0x006A (SSR1) Base + 0x006C (SSR2) Base + 0x006E (SSR3) Base + 0x0070 (SSR4) Base + 0x0072 (SSR5) Base + 0x0074 (SSR6) Base + 0x0076 (SSR7) Figure 284. Slot Status Registers (SSR0-SSR7) Each of these eight registers holds the status vector of the slot specified in the corresponding internal slot status selection register, which can be programmed using the Section 21.5.2.44: Slot Status Selection Register (SSSR). Each register is updated after the end of the corresponding slot as shown in Figure 381. The register bits are directly related to the protocol variables and described in more detail in Section 21.6.18: Slot status monitoring. Table 301. SSR0-SSR7 field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | VFB | Valid Frame on Channel B — protocol related variable: vSS!ValidFrame channel B 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | SYB | Sync Frame Indicator Channel B — protocol related variable: vRF!Header!SyFIndicator channel B 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | NFB | Null Frame Indicator Channel B — protocol related variable: vRF!Header!NFIndicator channel B 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUB | Startup Frame Indicator Channel B — protocol related variable: vRF!Header!SuFIndicator channel B 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | Table 301. SSR0-SSR7 field descriptions(Continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | SEB | Syntax Error on Channel B — protocol related variable: vSS!SyntaxError channel B 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | CEB | Content Error on Channel B — protocol related variable: vSS!ContentError channel B 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVB | Boundary Violation on Channel B — protocol related variable: vSS!BViolation channel B 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | | ТСВ | Transmission Conflict on Channel B — protocol related variable: vSS!TxConflict channel B 0 vSS!TxConflict = 0. 1 vSS!TxConflict = 1. | | VFA | Valid Frame on Channel A — protocol related variable: vSS!ValidFrame channel A 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | SYA | Sync Frame Indicator Channel A — protocol related variable: vRF!Header!SyFIndicator channel A 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | NFA | Null Frame Indicator Channel A — protocol related variable: vRF!Header!NFIndicator channel A 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUA | Startup Frame Indicator Channel A — protocol related variable: vRF!Header!SuFIndicator channel A 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | | SEA | Syntax Error on Channel A — protocol related variable: vSS!SyntaxError channel A 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | CEA | Content Error on Channel A — protocol related variable: vSS!ContentError channel A 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVA | Boundary Violation on Channel A — protocol related variable: vSS!BViolation channel A 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | | TCA | Transmission Conflict on Channel A — protocol related variable: vSS!TxConflict channel A 0 vSS!TxConflict = 0. 1 vSS!TxConflict = 1. | ### 21.5.2.47 Slot Status Counter Registers (SSCR0-SSCR3) Figure 285. Slow Status Counter Registers (SSCR0-SSCR3) Each of these four registers provides the slot status counter value for the previous communication cycle(s) and is updated at the cycle start. The provided value depends on the control bits and fields in the related internal slot status counter condition register SSCCRn, which can be programmed by using the Section 21.5.2.45: Slot Status Counter Condition Register (SSCCR). For more details, see Section 21.6.18.4: Slot status counter registers. Note: If the counter has reached its maximum value 0xFFFF and is in the multicycle mode, i.e., SSCCRn[MCY] = 1, the counter is not reset to 0x0000. The application can reset the counter by clearing the SSCCRn[MCY] bit and waiting for the next cycle start, when the controller clears the counter. Subsequently, the counter can be set into the multicycle mode again. Table 302. SSCR0-SSCR3 field descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------------| | SLOTSTATUSCNT | Slot Status Counter — This field provides the current value of the Slot Status Counter. | #### 21.5.2.48 MTS A Configuration Register (MTSACFR) Figure 286. MTS A Configuration Register (MTSACFR) This register controls the transmission of the Media Access Test Symbol MTS on channel A. For more details, see *Section 21.6.13: MTS generation*. | Field | Description | | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | MTE | Media Access Test Symbol Transmission Enable — This control bit enables and disables the transmission of the Media Access Test Symbol in the selected set of cycles. 0 MTS transmission disabled. 1 MTS transmission enabled. | | | CYCCNTMSK | Cycle Counter Mask — This field provides the filter mask for the MTS cycle count filter. | | | CYCCNTVAL | Cycle Counter Value — This field provides the filter value for the MTS cycle count filter. | | Table 303. MTSACFR field descriptions ## 21.5.2.49 MTS B Configuration Register (MTSBCFR) Figure 287. MTS B Configuration Register (MTSBCFR) This register controls the transmission of the Media Access Test Symbol MTS on channel B. For more details, see *Section 21.6.13: MTS generation*. Table 304. MTSBCFR field descriptions | Field | Description | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MTE | Media Access Test Symbol Transmission Enable — This control bit enables and disables the transmission of the Media Access Test Symbol in the selected set of cycles. 0 MTS transmission disabled. 1 MTS transmission enabled. | | CYCCNTMSK | Cycle Counter Mask — This field provides the filter mask for the MTS cycle count filter. | | CYCCNTVAL | Cycle Counter Value — This field provides the filter value for the MTS cycle count filter. | ### 21.5.2.50 Receive Shadow Buffer Index Register (RSBIR) Figure 288. Receive Shadow Buffer Index Register (RSBIR) This register provides and retrieves the indices of the message buffer header fields currently associated with the receive shadow buffers. For more details on the receive shadow buffer 577 concept, refer to Section 21.6.6.3.5: Receive Shadow Buffers Concept. Table 305. RSBIR field descriptions | Field | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WMD | Write Mode — This bit controls the write mode for this register. 0 update SEL and RSBIDX field on register write 1 update only SEL field on register write | | SEL | Selector — This field selects the internal receive shadow buffer index register for access. 00 RSBIR_A1 — receive shadow buffer index register for channel A, segment 1 01 RSBIR_A2 — receive shadow buffer index register for channel A, segment 2 10 RSBIR_B1 — receive shadow buffer index register for channel B, segment 1 11 RSBIR_B2 — receive shadow buffer index register for channel B, segment 2 | | RSBIDX | Receive Shadow Buffer Index — This field contains the current index of the message buffer header field of the receive shadow message buffer selected by the SEL field. The controller uses this index to determine the physical location of the shadow buffer header field in the FlexRay memory. The controller will update this field during receive operation. The application provides initial message buffer header index value in the configuration phase. controller: Updates the message buffer header index after successful reception. Application: Provides initial message buffer header index. | ### 21.5.2.51 Receive FIFO Selection Register (RFSR) Figure 289. Receive FIFO Selection Register (RFSR) This register selects a receiver FIFO for subsequent access through the receiver FIFO configuration registers summarized in *Table 306*. Table 306. SEL controlled receiver FIFO registers | Register | | |-----------------------------------------------------------------------------------------|--| | Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR) | | | Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR) | | | Section 21.5.2.56: Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) | | | Section 21.5.2.57: Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) | | | Section 21.5.2.58: Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) | | | Section 21.5.2.59: Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) | | | Section 21.5.2.60: Receive FIFO Range Filter Configuration Register (RFRFCFR) | | | Section 21.5.2.61: Receive FIFO Range Filter Control Register (RFRFCTR) | | Table 307. RFSR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | SEL | Select — This control bit selects the receiver FIFO for subsequent programming. 0 Receiver FIFO for channel A selected 1 Receiver FIFO for channel B selected | ### 21.5.2.52 Receive FIFO Start Index Register (RFSIR) Figure 290. Receive FIFO Start Index Register (RFSIR) This register defines the message buffer header index of the first message buffer of the selected FIFO. Table 308. RFSIR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SIDX | Start Index — This field defines the number of the message buffer header field of the first message buffer of the selected receive FIFO. The controller uses the value of the SIDX field to determine the physical location of the receiver FIFO's first message buffer header field. | ### 21.5.2.53 Receive FIFO Depth and Size Register (RFDSR) Figure 291. Receive FIFO Depth and Size Register (RFDSR) This register defines the structure of the selected FIFO, i.e., the number of entries and the size of each entry. Table 309. RFDSR field descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------| | | <b>FIFO Depth</b> — This field defines the depth of the selected receive FIFO, i.e., the number of entries. | | ENTRY_SIZE | <b>Entry Size</b> — This field defines the size of the frame data sections for the selected receive FIFO in 2 byte entities. | ### 21.5.2.54 Receive FIFO A Read Index Register (RFARIR) Base + 0x008C Figure 292. Receive FIFO A Read Index Register (RFARIR) This register provides the message buffer header index of the next available receive FIFO A entry that the application can read. Table 310. RFARIR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RDIDX | <b>Read Index</b> — This field provides the message buffer header index of the next available receive FIFO message buffer that the application can read. The controller increments this index when the application writes to the FNEAIF flag in the <i>Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER)</i> . The index wraps back to the first message buffer header index if the end of the FIFO was reached. | Note: If the receive FIFO not empty flag FNEAIF is not set, the RDIDX field points to an physical message buffer which content is not valid. Only when FNEAIF is set, the message buffer indicated by RDIDX contains valid data. #### 21.5.2.55 Receive FIFO B Read Index Register (RFBRIR) Base + 0x008E Figure 293. Receive FIFO B Read Index Register (RFBRIR) This register provides the message buffer header index of the next available receive FIFO B entry that the application can read. Table 311. RFBRIR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RDIDX | <b>Read Index</b> — This field provides the message buffer header index of the next available receive FIFO entry that the application can read. The controller increments this index when the application writes to the FNEBIF flag in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). The index wraps back to the first message buffer header index if the end of the FIFO was reached. | Note: If the receive FIFO not empty flag FNEBIF is not set, the RDIDX field points to an physical message buffer which content is not valid. Only when FNEBIF is set, the message buffer indicated by RDIDX contains valid data. #### 21.5.2.56 Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) Figure 294. Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) This register defines the filter value for the message ID acceptance filter of the selected receive FIFO. For details on message ID filtering see Section 21.6.9.5: Receive FIFO filtering. Table 312. RFMIDAFVR field descriptions | Field | Description | |----------|-----------------------------------------------------------------------------------------| | MIDAFVAL | Message ID Acceptance Filter Value — Filter value for the message ID acceptance filter. | ### 21.5.2.57 Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) Figure 295. Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) This register defines the filter mask for the message ID acceptance filter of the selected receive FIFO. For details on message ID filtering see Section 21.6.9.5: Receive FIFO filtering. Table 313. RFMIAFMR field descriptions | Field | Description | |----------|---------------------------------------------------------------------------------------| | MIDAFMSK | Message ID Acceptance Filter Mask — Filter mask for the message ID acceptance filter. | ### 21.5.2.58 Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) Figure 296. Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) This register defines the filter value for the frame ID rejection filter of the selected receive FIFO. For details on frame ID filtering see *Section 21.6.9.5*: *Receive FIFO filtering*. Table 314. RFFIDRFVR field descriptions | Field | Description | |----------|-----------------------------------------------------------------------------------| | FIDRFVAL | Frame ID Rejection Filter Value — Filter value for the frame ID rejection filter. | #### 21.5.2.59 Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) Figure 297. Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) This register defines the filter mask for the frame ID rejection filter of the selected receive FIFO. For details on frame ID filtering see *Section 21.6.9.5*: *Receive FIFO filtering*. Table 315. RFFIDRFMR field descriptions | Field | Description | |----------|---------------------------------------------------------------------------------| | FIDRFMSK | Frame ID Rejection Filter Mask — Filter mask for the frame ID rejection filter. | #### 21.5.2.60 Receive FIFO Range Filter Configuration Register (RFRFCFR) Figure 298. Receive FIFO Range Filter Configuration Register (RFRFCFR) This register provides access to the four internal frame ID range filter boundary registers of the selected receive FIFO. For details on frame ID range filter see Section 21.6.9.5: Receive FIFO filtering. Table 316. RFRFCFR field descriptions | Field | Description | | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | WMD | Write Mode — This control bit defines the write mode of this register. 0 Write to all fields in this register on write access. 1 Write to SEL and IBD field only on write access. | | | IBD | Interval Boundary — This control bit selects the interval boundary to be programmed with the SID value. 0 Program lower interval boundary. 1 Program upper interval boundary. | | | SEL | Filter Selector — This control field selects the frame ID range filter to be accessed. 00 Select frame ID range filter 0. 01 Select frame ID range filter 1. 10 Select frame ID range filter 2. 11 Select frame ID range filter 3. | | | SID | Slot ID — Defines the IBD-selected frame ID boundary value for the SEL-selected range filter. | | ### 21.5.2.61 Receive FIFO Range Filter Control Register (RFRFCTR) Figure 299. Receive FIFO Range Filter Control Register (RFRFCTR) This register enables and disables each frame ID range filter and defines whether it is running as acceptance or rejection filter. Table 317. RFRFCTR field descriptions | Field | Description | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | F3MD | Range Filter 3 Mode — This control bit defines the filter mode of the frame ID range filter 3. 0 range filter 3 runs as acceptance filter. 1 range filter 3 runs as rejection filter. | | | | | F2MD Range Filter 2 Mode — This control bit defines the filter mode of the frame ID range 0 range filter 2 runs as acceptance filter. 1 range filter 2 runs as rejection filter. | | | | | | F1MD Range Filter 1 Mode — This control bit defines the filter mode of the frame ID range filt 0 range filter 1 runs as acceptance filter. 1 range filter 1 runs as rejection filter. | | | | | Reset 0 0 Table 317. RFRFCTR field descriptions(Continued) | Field | Description | | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | F0MD | Range Filter 0 Mode — This control bit defines the filter mode of the frame ID range filter 0. 0 range filter 0 runs as acceptance filter. 1 range filter 0 runs as rejection filter. | | | | F3EN | Range Filter 3 Enable — This control bit enables and disables the frame ID range filter 3. 0 range filter 3 disabled. 1 range filter 3 enabled. | | | | F2EN | Range Filter 2 Enable — This control bit enables and disables the frame ID range filter 2. 0 range filter 2 disabled. 1 range filter 2 enabled. | | | | F1EN | Range Filter 1 Enable — This control bit enables and disables the frame ID range filter 1. 0 range filter 1 disabled. 1 range filter 1 enabled. | | | | F0EN | Range Filter 0 Enable — This control bit enables and disables the frame ID range filter 0. 0 range filter 0 disabled. 1 range filter 0 enabled. | | | # 21.5.2.62 Last Dynamic Transmit Slot Channel A Register (LDTXSLAR) 0 0 Figure 300. Last Dynamic Slot Channel A Register (LDTXSLAR) This register provides the number of the last transmission slot in the dynamic segment for channel A. This register is updated after the end of the dynamic segment and before the start of the next communication cycle. 0 Table 318. LDTXSLAR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <b>Last Dynamic Transmission Slot Channel A</b> — protocol related variable: <i>zLastDynTxSlot</i> channel A | | | Number of the last transmission slot in the dynamic segment for channel A. If no frame was transmitted during the dynamic segment on channel A, the value of this field is set to 0. | ## 21.5.2.63 Last Dynamic Transmit Slot Channel B Register (LDTXSLBR) Figure 301. Last Dynamic Slot Channel B Register (LDTXSLBR) This register provides the number of the last transmission slot in the dynamic segment for channel B. This register is updated after the end of the dynamic segment and before the start of the next communication cycle. Table 319. LDTXSLBR field descriptions | Field | Description | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LASTDYNTX<br>SLOTB | Last Dynamic Transmission Slot Channel B — protocol related variable: <i>zLastDynTxSlot</i> channel B Number of the last transmission slot in the dynamic segment for channel B. If no frame was transmitted during the dynamic segment on channel B the value of this field is set to 0. | ### 21.5.2.64 Protocol configuration registers The following configuration registers provide the necessary configuration information to the protocol engine. The individual values in the registers are described in *Table 320*. For more details about the FlexRay related configuration parameters and the allowed parameter ranges, see *FlexRay Communications System Protocol Specification, Version 2.1 Rev A.* Table 320. Protocol configuration register fields | Name | Description <sup>(1)</sup> | Min | Max | Unit | PCR | |----------------------------------|-------------------------------------------------|-----|-----|----------|-----| | coldstart_attempts | gColdstartAttempts | | | number | 3 | | action_point_offset | gdActionPointOffset - 1 | | | MT | 0 | | cas_rx_low_max | gdCASRxLowMax - 1 | | | gdBit | 4 | | dynamic_slot_idle_phase | gdDynamicSlotIdlePhase | | | minislot | 28 | | minislot_action_point_offset | gdMinislotActionPointOffset - 1 | | | MT | 3 | | minislot_after_action_point | gdMinislot -<br>gdMinislotActionPointOffset - 1 | | | MT | 2 | | static_slot_length | gdStaticSlot | | | MT | 0 | | static_slot_after_action_point | gdStaticSlot - gdActionPointOffset - 1 | | | MT | 13 | | symbol_window_exists | gdSymbolWindow!=0 | 0 | 1 | bool | 9 | | symbol_window_after_action_point | gdSymbolWindow -<br>gdActionPointOffset - 1 | | | MT | 6 | | tss_transmitter | gdTSSTransmitter | | | gdBit | 5 | | wakeup_symbol_rx_idle | gdWakeupSymbolRxIdle | | | gdBit | 5 | | wakeup_symbol_rx_low | gdWakeupSymbolRxLow | | | gdBit | 3 | Table 320. Protocol configuration register fields(Continued) | Name | Description <sup>(1)</sup> | Min | Max | Unit | PCR | |--------------------------------------|--------------------------------------------------------------|-----|-----|-------------|-------| | wakeup_symbol_rx_window | gdWakeupSymbolRxWindow | | | gdBit | 4 | | wakeup_symbol_tx_idle | gdWakeupSymbolTxIdle | | | gdBit | 8 | | wakeup_symbol_tx_low | gdWakeupSymbolTxLow | | | gdBit | 5 | | noise_listen_timeout | (gListenNoise × pdListenTimeout) - 1 | | | μТ | 16/17 | | macro_initial_offset_a | pMacroInitialOffset[A] | | | MT | 6 | | macro_initial_offset_b | pMacroInitialOffset[B] | | | MT | 16 | | macro_per_cycle | gMacroPerCycle | | | MT | 10 | | macro_after_first_static_slot | gMacroPerCycle - gdStaticSlot | | | MT | 1 | | macro_after_offset_correction | gMacroPerCycle -<br>gOffsetCorrectionStart | | | MT | 28 | | max_without_clock_correction_fatal | gMaxWithoutClockCorrectionFatal | | | cyclepairs | 8 | | max_without_clock_correction_passive | gMaxWithoutClockCorrectionPassive | | | cyclepairs | 8 | | minislot_exists | gNumberOfMinislots!=0 | 0 | 1 | bool | 9 | | minislots_max | gNumberOfMinislots - 1 | | | minislot | 29 | | number_of_static_slots | gNumberOfStaticSlots | | | static slot | 2 | | offset_correction_start | gOffsetCorrectionStart | | | MT | 11 | | payload_length_static | gPayloadLengthStatic | | | 2-bytes | 19 | | max_payload_length_dynamic | pPayloadLengthDynMax | | | 2-bytes | 24 | | first_minislot_action_point_offset | max(gdActionPointOffset,<br>gdMinislotActionPointOffset) - 1 | | | MT | 13 | | allow_halt_due_to_clock | pAllowHaltDueToClock | | | bool | 26 | | allow_passive_to_active | pAllowPassiveToActive | | | cyclepairs | 12 | | cluster_drift_damping | pClusterDriftDamping | | | μΤ | 24 | | comp_accepted_startup_range_a | pdAcceptedStartupRange -<br>pDelayCompensation[A] | | | μТ | 22 | | comp_accepted_startup_range_b | pdAcceptedStartupRange -<br>pDelayCompensation[B] | | | μТ | 26 | | listen_timeout | pdListenTimeout - 1 | | | μΤ | 14/15 | | key_slot_id | pKeySlotId | | | number | 18 | | key_slot_used_for_startup | pKeySlotUsedForStartup | | | bool | 11 | | key_slot_used_for_sync | pKeySlotUsedForSync | | | bool | 11 | | latest_tx | gNumberOfMinislots - pLatestTx | | | minislot | 21 | | sync_node_max | gSyncNodeMax | | | number | 30 | | micro_initial_offset_a | pMicroInitialOffset[A] | | | μΤ | 20 | | micro_initial_offset_b | pMicroInitialOffset[B] | | | μΤ | 20 | | micro_per_cycle | pMicroPerCycle | | | μΤ | 22/23 | | Name | Description <sup>(1)</sup> | Min | Max | Unit | PCR | |--------------------------|----------------------------------------------------|-------|-------|--------|-------| | micro_per_cycle_min | pMicroPerCycle - pdMaxDrift | | | μΤ | 24/25 | | micro_per_cycle_max | pMicroPerCycle + pdMaxDrift | | | μΤ | 26/27 | | micro_per_macro_nom_half | round(pMicroPerMacroNom / 2) | | | μΤ | 7 | | offset_correction_out | pOffsetCorrectionOut | | | μΤ | 9 | | rate_correction_out | pRateCorrectionOut | | | μΤ | 14 | | single_slot_enabled | pSingleSlotEnabled | | | bool | 10 | | wakeup_channel | akeup_channel pWakeupChannel see <i>Table 321</i> | | 321 | 10 | | | wakeup_pattern | pWakeupPattern | | | number | 18 | | decoding_correction_a | pDecodingCorrection +<br>pDelayCompensation[A] + 2 | | | μТ | 19 | | decoding_correction_b | pDecodingCorrection +<br>pDelayCompensation[B] + 2 | | | μТ | 7 | | key_slot_header_crc | header CRC for key slot | 0x000 | 0x7FF | number | 12 | | extern_offset_correction | pExternOffsetCorrection | | | μΤ | 29 | | extern_rate_correction | pExternRateCorrection | | | μΤ | 21 | Table 320. Protocol configuration register fields(Continued) Table 321. Wakeup channel selection | wakeup_channel | Wakeup Channel | |----------------|----------------| | 0 | А | | 1 | В | # 21.5.2.64.1 Protocol Configuration Register 0 (PCR0) Figure 302. Protocol Configuration Register 0 (PCR0) See FlexRay Communications System Protocol Specification, Version 2.1 Rev A for detailed protocol parameter definitions. #### 21.5.2.64.2 Protocol Configuration Register 1 (PCR1) Figure 303. Protocol Configuration Register 1 (PCR1) #### 21.5.2.64.3 Protocol Configuration Register 2 (PCR2) Figure 304. Protocol Configuration Register 2 (PCR2) #### 21.5.2.64.4 Protocol Configuration Register 3 (PCR3) Figure 305. Protocol Configuration Register 3 (PCR3) ### 21.5.2.64.5 Protocol Configuration Register 4 (PCR4) Figure 306. Protocol Configuration Register 4 (PCR4) #### 21.5.2.64.6 Protocol Configuration Register 5 (PCR5) Figure 307. Protocol Configuration Register 5 (PCR5) # 21.5.2.64.7 Protocol Configuration Register 6 (PCR6) Figure 308. Protocol Configuration Register 6 (PCR6) ### 21.5.2.64.8 Protocol Configuration Register 7 (PCR7) Figure 309. Protocol Configuration Register 7 (PCR7) ### 21.5.2.64.9 Protocol Configuration Register 8 (PCR8) Figure 310. Protocol Configuration Register 8 (PCR8) ### 21.5.2.64.10 Protocol Configuration Register 9 (PCR9) Figure 311. Protocol Configuration Register 9 (PCR9) 577 # 21.5.2.64.11 Protocol Configuration Register 10 (PCR10) Figure 312. Protocol Configuration Register 10 (PCR10) # 21.5.2.64.12 Protocol Configuration Register 11 (PCR11) Figure 313. Protocol Configuration Register 11 (PCR11) ### 21.5.2.64.13 Protocol Configuration Register 12 (PCR12) 21.5.2.64.14 Protocol Configuration Register 13 (PCR13) Figure 315. Protocol Configuration Register 13 (PCR13) # 21.5.2.64.15 Protocol Configuration Register 14 (PCR14) Figure 316. Protocol Configuration Register 14 (PCR14) ### 21.5.2.64.16 Protocol Configuration Register 15 (PCR15) Figure 317. Protocol Configuration Register 15 (PCR15) # 21.5.2.64.17 Protocol Configuration Register 16 (PCR16) Figure 318. Protocol Configuration Register 16 (PCR16) # 21.5.2.64.18 Protocol Configuration Register 17 (PCR17) Figure 319. Protocol Configuration Register 17 (PCR17) # 21.5.2.64.19 Protocol Configuration Register 18 (PCR18) Figure 320. Protocol Configuration Register 18 (PCR18) ### 21.5.2.64.20 Protocol Configuration Register 19 (PCR19) Figure 321. Protocol Configuration Register 19 (PCR19) ### 21.5.2.64.21 Protocol Configuration Register 20 (PCR20) Figure 322. Protocol Configuration Register 20 (PCR20) ### 21.5.2.64.22 Protocol Configuration Register 21 (PCR21) Figure 323. Protocol Configuration Register 21 (PCR21) ### 21.5.2.64.23 Protocol Configuration Register 22 (PCR22) Figure 324. Protocol Configuration Register 22 (PCR22) ### 21.5.2.64.24 Protocol Configuration Register 23 (PCR23) Figure 325. Protocol Configuration Register 23 (PCR23) # 21.5.2.64.25 Protocol Configuration Register 24 (PCR24) Figure 326. Protocol Configuration Register 24 (PCR24) ### 21.5.2.64.26 Protocol Configuration Register 25 (PCR25) Figure 327. Protocol Configuration Register 25 (PCR25) ### 21.5.2.64.27 Protocol Configuration Register 26 (PCR26) Figure 328. Protocol Configuration Register 26 (PCR26) ### 21.5.2.64.28 Protocol Configuration Register 27 (PCR27) Figure 329. Protocol Configuration Register 27 (PCR27) 5/ ### 21.5.2.64.29 Protocol Configuration Register 28 (PCR28) Figure 330. Protocol Configuration Register 28 (PCR28) #### 21.5.2.64.30 Protocol Configuration Register 29 (PCR29) Figure 331. Protocol Configuration Register 29 (PCR29) ### 21.5.2.64.31 Protocol Configuration Register 30 (PCR30) Figure 332. Protocol Configuration Register 30 (PCR30) #### 21.5.2.65 Message Buffer Configuration, Control, Status Registers (MBCCSRn) Figure 333. Message Buffer Configuration, Control, Status Registers (MBCCSRn) The content of these registers comprises message buffer configuration data, message buffer control data, message buffer status information, and message buffer interrupt flags. A detailed description of all flags can be found in *Section 21.6.6: Individual message buffer* # functional description. If the application writes 1 to the EDT bit, no write access to the other register bits is performed. If the application writes 0 to the EDT bit and 1 to the LCKT bit, no write access to the other bits is performed. Table 322. MBCCSRn field descriptions | Field | Description | | | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Message buffer configuration | | | | MCM | Message Buffer Commit Mode — This bit configures the commit mode of a double buffered message buffer. 0Streaming commit mode 1Immediate commit mode | | | | MBT | Message Buffer Type — This bit configures the buffering type of a transmit message buffer. 0 Single buffered message buffer 1 Double buffered message buffer | | | | MTD | Message Buffer Transfer Direction — This bit configures the transfer direction of a message buffer. 0 Receive message buffer 1 Transmit message buffer | | | | | Message buffer control | | | | СМТ | Commit for Transmission — This bit indicates if the transmit message buffer data are ready for transmission. O Message buffer data not ready for transmission. Message buffer data ready for transmission. | | | | EDT | Enable/Disable Trigger — If the application writes 1 to this bit, a message buffer enable or disable is triggered, depending on the current value EDS status bit is 0. 0 No effect. 1 Message buffer enable or disable is triggered. | | | | LCKT | Lock/Unlock Trigger — If the application writes 1 to this bit, a message buffer lock or unlock is triggered, depending on the current value of the LCKS status bit. 0 No effect. 1 Message buffer lock or unlock is triggered. | | | | MBIE | Message Buffer Interrupt Enable — This control bit defines whether the message buffer will generate an interrupt request when its MBIF flag is set. 0 Interrupt request generation disabled. 1 Interrupt request generation enabled. | | | Table 322. MBCCSRn field descriptions(Continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Message buffer status | | DUP | Data Updated — This status bit indicates whether the frame header in the message buffer header field and the data in the message buffer data field were updated after a frame reception. O Frame Header and Message buffer data field not updated 1 Frame Header and Message buffer data field updated | | DVAL | Data Valid — For receive message buffers this status bit indicates whether the message buffer data field contains valid frame data. For transmit message buffers the status bit indicates if a message is transferred again due to the state transmission mode of the message buffer. O receive message buffer contains no valid frame data / message is transmitted for the first time 1 receive message buffer contains valid frame data / message will be transferred again | | EDS | Enable/Disable Status — This status bit indicates whether the message buffer is enabled or disabled. 0 Message buffer is disabled. 1 Message buffer is enabled. | | LCKS | Lock Status — This status bit indicates the current lock status of the message buffer. 0 Message buffer is not locked by the application. 1 Message buffer is locked by the application. | | MBIF | Message Buffer Interrupt Flag — This flag is set when the slot status field of the message buffer was updated after frame transmission or reception, or when a transmit message buffer was just enabled by the application. O No such event Slot status field updated or transmit message buffer just enabled. | ### 21.5.2.66 Message Buffer Cycle Counter Filter Registers (MBCCFRn) Figure 334. Message Buffer Cycle Counter Filter Registers (MBCCFRn) This register contains message buffer configuration data for the transmission mode, the channel assignment, and for the cycle counter filtering. For detailed information on cycle counter filtering, refer to Section 21.6.7.1: Message buffer cycle counter filtering. Table 323. MBCCFRn field descriptions | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | МТМ | Message Buffer Transmission Mode — This control bit applies only to transmit message buffers and defines the transmission mode. 0 Event transmission mode 1 State transmission mode | | CHA<br>CHB | <b>Channel Assignment</b> — These control bits define the channel assignment and control the receive and transmit behavior of the message buffer according to <i>Table 324</i> . | | CCFE | Cycle Counter Filtering Enable — This control bit enables and disables the cycle counter filtering. O Cycle counter filtering disabled. Cycle counter filtering enabled. | | CCFMSK | Cycle Counter Filtering Mask — This field defines the filter mask for the cycle counter filtering. | | CCFVAL | Cycle Counter Filtering Value — This field defines the filter value for the cycle counter filtering. | Table 324. Channel assignment description | CHA CHB | | Transmit Me | ssage Buffer | Receive Message Buffer | | | |---------|-----|------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------|-----------------------------------------------|--| | СПА | СПВ | static segment | dynamic segment | static segment | dynamic segment | | | 1 | 1 | transmit on both<br>channel A and<br>channel B | Reserved (function not available) | store first valid frame<br>received on either<br>channel A or channel B | Reserved (function not available) | | | 0 | 1 | transmit on channel B | transmit on channel B | store first valid frame received on channel B | store first valid frame received on channel B | | | 1 | 0 | transmit on channel A | transmit on channel A | store first valid frame received on channel A | store first valid frame received on channel A | | | 0 | 0 | no frame transmission | no frame transmission | no frame stored | no frame stored | | Note: If at least one message buffer assigned to a certain slot is assigned to both channels, then all message buffers assigned to this slot have to be assigned to both channels. Otherwise, the message buffer configuration is illegal and the result of the message buffer search is not defined. # 21.5.2.67 Message Buffer Frame ID Registers (MBFIDRn) Base + 0x0104 (MBFIDR0) Base + 0x010C (MBFIDR1) ... . 0.0000 (MPEIDDO) Base + 0x02FC (MBFIDR63) Figure 335. Message Buffer Frame ID Registers (MBFIDRn) DocID018714 Rev 5 Write: POC:config or MB\_DIS Write: POC:config or MB\_DIS # Table 325. MBFIDRn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FID | Frame ID — The semantic of this field depends on the message buffer transfer type. - Receive Message Buffer: This field is used as a filter value to determine if the message buffer is used for reception of a message received in a slot with the slot ID equal to FID. - Transmit Message Buffer: This field determines the slot in which the message in this message buffer should be transmitted. | # 21.5.2.68 Message Buffer Index Registers (MBIDXRn) Base + 0x0106 (MBIDXR0) Base + 0x010E (MBIDXR1) ••• Base + 0x02FE (MBIDXR63) Figure 336. Message Buffer Index Registers (MBIDXRn) # Table 326. MBIDXRn field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MBIDX | Message Buffer Index — This field provides the index of the message buffer header field of the physical message buffer that is currently associated with this message buffer. The application writes the index of the initially associated message buffer header field into this register. The controller updates this register after frame reception or transmission. | # 21.6 Functional description This section provides a detailed description of the functionality implemented in the controller. ### 21.6.1 Message buffer concept The controller uses a data structure called *message buffer* to store frame data, configuration, control, and status data. Each message buffer consists of two parts, the *message buffer control data* and the *physical message buffer*. The message buffer control data are located in dedicated registers. The structure of the message buffer control data depends on the message buffer type and is described in *Section 21.6.3: Message buffer types*. The physical message buffer is located in the FlexRay memory and is described in *Section 21.6.2: Physical message buffer*. # 21.6.2 Physical message buffer All FlexRay messages and related frame and slot status information of received frames and of frames to be transmitted to the FlexRay bus are stored in data structures called *physical message buffers*. The physical message buffers are located in the FlexRay memory. The structure of a physical message buffer is shown in *Figure 337*. A physical message buffer consists of two fields, the *message buffer header field* and the *message buffer data field*. The message buffer header field contains the *frame header*, the *data field offset*, and the *slot status*. The message buffer data field contains the *frame data*. The connection between the two fields is established by the data field offset. Figure 337. Physical message buffer structure #### 21.6.2.1 Message buffer header field The message buffer header field is a contiguous region in the FlexRay memory and occupies ten bytes. It contains the frame header, the data field offset, and the slot status. Its structure is shown in *Figure 337*. The physical start address SADR\_MBHF of the message buffer header field must be 16-bit aligned. #### 21.6.2.1.1 Frame header The frame header occupies the first six bytes in the message buffer header field. It contains all FlexRay frame header related information according to the *FlexRay Communications System Protocol Specification, Version 2.1 Rev A.* A detailed description of the usage and the content of the frame header is provided in *Section 21.6.5.2.1: Frame header description.* #### 21.6.2.1.2 Data field offset The data field offset follows the frame header in the message buffer data field and occupies two bytes. It contains the offset of the corresponding message buffer data field with respect to the controller FlexRay memory base address as provided by SYS\_MEM\_BASE\_ADDR field in the Section 21.5.2.5: System Memory Base Address High Register (SYMBADHR) and System Memory Base Address Low Register (SYMBADLR). The data field offset determines the start address SADR\_MBDF of the corresponding message buffer data field in the FlexRay memory according to Equation 22. #### Equation 22 SADR\_MBDF = [Data Field Offset] + SYS\_MEM\_BASE\_ADDR #### 21.6.2.1.3 Slot status The slot status occupies the last two bytes of the message buffer header field. It provides the slot and frame status related information according to the *FlexRay Communications System Protocol Specification, Version 2.1 Rev A.* A detailed description of the content and usage of the slot status is provided in *Section 21.6.5.2.3: Slot status description.* ### 21.6.2.2 Message buffer data field The message buffer data field is a contiguous area of 2-byte entities. This field contains the frame payload data, or a part of it, of the frame to be transmitted to or received from the FlexRay bus. The minimum length of this field depends on the specific message buffer configuration and is specified in the message buffer descriptions given in Section 21.6.3: Message buffer types. # 21.6.3 Message buffer types The controller provides three different types of message buffers. - Individual Message Buffers - Receive Shadow Buffers - Receive FIFO Buffers For each message buffer type the structure of the physical message buffer is identical. The message buffer types differ only in the structure and content of message buffer control data, which control the related physical message buffer. The message buffer control data are described in the following sections. # 21.6.3.1 Individual message buffers The individual message buffers are used for all types of frame transmission and for dedicated frame reception based on individual filter settings for each message buffer. The controller supports three types of individual message buffers, which are described in Section 21.6.6: Individual message buffer functional description. Each individual message buffer consists of two parts, the physical message buffer, which is located in the FlexRay memory, and the message buffer control data, which are located in dedicated registers. The structure of an individual message buffer is given in *Figure 338*. Each individual message buffer has a message buffer number n assigned, which determines the set of message buffer control registers associated to this individual message buffer. The individual message buffer with message buffer number *n* is controlled by the registers MBCCSRn, MBCCFRn, MBFIDRn, and MBIDXRn. The connection between the message buffer control registers and the physical message buffer is established by the message buffer index field MBIDX in the Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn). The start address SADR\_MBHF of the related message buffer header field in the FlexRay memory is determined according to Equation 23. #### Equation 23 SADR\_MBHF = (MBIDXRn[MBIDX] × 10) + SYS\_MEM\_BASE\_ADDR Figure 338. Individual message buffer structure ### 21.6.3.1.1 Individual message buffer segments The set of the individual message buffers can be split up into two message buffer segments using the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR). All individual message buffers with a message buffer number $n \leq \text{MBSSUTR}[\text{LAST\_MB\_SEG1}]$ belong to the first message buffer segment. All individual message buffers with a message buffer number $n > \text{MBSSUTR}[\text{LAST\_MB\_SEG1}]$ belong to the second message buffer segment. The following rules apply to the length of the message buffer data field: - All physical message buffers associated to individual message buffers that belong to the same message buffer segment must have message buffer data fields of the same length. - The minimum length of the message buffer data field for individual message buffers in the first message buffer segment is 2 × MBDSR[MBSEG1DS] bytes. - The minimum length of the message buffer data field for individual message buffers assigned to the second segment is 2 × MBDSR[MBSEG2DS] bytes. #### 21.6.3.2 Receive shadow buffers The receive shadow buffers are required for the frame reception process for individual message buffers. The controller provides four receive shadow buffers, one receive shadow buffer per channel and per message buffer segment. Each receive shadow buffer consists of two parts, the physical message buffer located in the FlexRay memory and the receive shadow buffer control registers located in dedicated registers. The structure of a receive shadow buffer is shown in *Figure 339*. The four internal shadow buffer control registers can be accessed by the *Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR)*. The connection between the receive shadow buffer control register and the physical message buffer for the selected receive shadow buffer is established by the receive shadow buffer index field RSBIDX in the *Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR)*. The start address SADR\_MBHF of the related message buffer header field in the FlexRay memory is determined according to *Equation 24*. ### Equation 24 SADR\_MBHF = (RSBIR[RSBIDX] × 10) + SYS\_MEM\_BASE\_ADDR The length required for the message buffer data field depends on the message buffer segment that the receive shadow buffer is assigned to. For the receive shadow buffers assigned to the first message buffer segment, the length must be the same as for the individual message buffers assigned to the first message buffer segment. For the receive shadow buffers assigned to the second message buffer segment, the length must be the same as for the individual message buffers assigned to the second message buffer segment. The receive shadow buffer assignment is described in Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR). Figure 339. Receive shadow buffer structure #### 21.6.3.3 Receive FIFO The receive FIFO implements a frame reception system based on the FIFO concept. The controller provides two independent receive FIFOs, one per channel. A receive FIFO consists of a set of physical message buffers in the FlexRay memory and a set of receive FIFO control registers located in dedicated registers. The structure of a receive FIFO is given in *Figure 340*. The connection between the receive FIFO control registers and the set of physical message buffers is established by the start index field SIDX in the Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR), the FIFO depth field FIFO\_DEPTH in the Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR), and the read index field RDIDX Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) / Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR). The start address SADR\_MBHF\_1 of the first message buffer header field that belongs to the receive FIFO in the FlexRay memory is determined according to Equation 25. #### Equation 25 SADR MBHF[1] = (RFSIR[SIDX] × 10) + SYS MEM BASE ADDR The start address SADR\_MBHF[n] of the last message buffer header field that belongs to the receive FIFO in the FlexRay memory is determined according to *Equation 26*. Equation 26 SADR\_MBHF[n] = ((RFSIR[SIDX] + RFDSR[FIFO\_DEPTH]) × 10) + SYS MEM BASE ADDR Note: All message buffer header fields assigned to a receive FIFO must be a contiguous region. Figure 340. Receive FIFO structure ### 21.6.3.4 Message buffer configuration and control data This section describes the configuration and control data for each message buffer type. #### 21.6.3.4.1 Individual message buffer configuration data Before an individual message buffer can be used for transmission or reception, it must be configured. There is a set of common configuration parameters that applies to all individual message buffers and a set of configuration parameters that applies to each message buffer individually. ### 21.6.3.4.1.1 Common configuration data The set of common configuration data for individual message buffers is located in the following registers. - Section 21.5.2.7: Message Buffer Data Size Register (MBDSR) The MBSEG2DS and MBSEG1DS fields define the minimum length of the message buffer data field with respect to the message buffer segment. - Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR) The LAST\_MB\_SEG1 and LAST\_MB\_UTIL fields define the segmentation of the individual message buffers and the number of individual message buffers that are used. For more details, see Section 21.6.3.1.1: Individual message buffer segments. #### 21.6.3.4.1.2 Specific configuration data The set of message buffer specific configuration data for individual message buffers is located in the following registers. - Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) - The MCM, MBT, MTD bits configure the message buffer type. - Section 21.5.2.66: Message Buffer Cycle Counter Filter Registers (MBCCFRn) The MTM, CHA, CHB bits configure the transmission mode and the channel assignment. The CCFE, CCFMSK, and CCFVAL bits and fields configure the cycle counter filter. - Section 21.5.2.67: Message Buffer Frame ID Registers (MBFIDRn) For a transmit message buffer, the FID field determines the slot in which the message in this message buffer will be transmitted. - Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn) This MBIDX field provides the index of the message buffer header field of the physical message buffer that is currently associated with this message buffer. # 21.6.3.5 Individual message buffer control data During normal operation, each individual message buffer can be controlled by the control and trigger bits CMT, LCKT, EDT, and MBIE in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). #### 21.6.3.6 Receive shadow buffer configuration data Before frame reception into the individual message buffers can be performed, the receive shadow buffers must be configured. The configuration data are provided by the Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR). For each receive shadow buffer, the application provides the message buffer header index. When the protocol is in the POC:normal active or POC:normal passive state, the receive shadow buffers are under full controller control. ### 21.6.3.7 Receive FIFO control and configuration data This section describes the configuration and control data for the two receive FIFOs. ### 21.6.3.7.1 Receive FIFO configuration data The controller provides two completely independent receive FIFOs, one per channel. Each FIFO has its own set of configuration data. The configuration data are located in the following registers: - Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR) - Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR) - Section 21.5.2.56: Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) - Section 21.5.2.57: Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR) - Section 21.5.2.58: Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) - Section 21.5.2.59: Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR) - Section 21.5.2.60: Receive FIFO Range Filter Configuration Register (RFRFCFR) #### 21.6.3.7.2 Receive FIFO control data The application can access the receive FIFO at any time using the values provided in the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) and Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR). To update the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR), the application must write 1 to the FIFO A Not Empty Interrupt Flag FNEAIF in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). To update the Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR) the application must write 1 to the FIFO B Not Empty Interrupt Flag FNEBIF in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). As long as the FIFO is not empty, each update increments the related read index. If the read index has reached the last FIFO entry, it wraps back to the FIFO start index. # 21.6.4 FlexRay memory layout The controller supports a wide range of possible layouts for the FlexRay memory. *Figure 341* shows an example layout. The following set of rules applies to the layout of the FlexRay memory: - The FlexRay memory is a contiguous region. - The FlexRay memory size is maximum 64 KB. - The FlexRay memory starts at a 16 byte boundary. The FlexRay memory contains three areas: the *message buffer header area*, the *message buffer data area*, and the *sync frame table area*. The areas are described in this section. Figure 341. Example of FlexRay memory layout ### 21.6.4.1 Message buffer header area The message buffer header area contains all message buffer header fields of the physical message buffers for all message buffer types. The following rules apply to the message buffer header fields for the three type of message buffers. The start address SADR\_MBHF of each message buffer header field for individual message buffers and receive shadow buffers must fulfill Equation 27. ### Equation 27 SADR\_MBHF = $(i \times 10) + SYS_MEM_BASE_ADDR$ ; $(0 \le i \le 64)$ The start address SADR\_MBHF of each message buffer header field for the receive FIFO must fulfill Equation 28. ### Equation 28 SADR\_MBHF = $(i \times 10) + SYS_MEM_BASE_ADDR$ ; $(0 \le i \le 1024)$ The message buffer header fields for a receive FIFO have to be a contiguous area. ### 21.6.4.2 Message buffer data area The message buffer data area contains all the message buffer data fields of the physical message buffers. Each message buffer data field must start at a 16-bit boundary. #### 21.6.4.3 Sync frame table area The sync frame table area provides a copy of the internal sync frame tables for application access. Refer to *Section 21.6.12: Sync frame ID and sync frame deviation tables* for the description of the sync frame table area. # 21.6.5 Physical message buffer description This section provides a detailed description of the usage and the content of the two parts of a physical message buffer, the message buffer header field and the message buffer data field. #### 21.6.5.1 Message buffer protection and data consistency The physical message buffers are located in the FlexRay memory. The controller provides no means to protect the FlexRay memory from uncontrolled or illegal host or other client write access. To ensure data consistency of the physical message buffers, the application must follow the write access scheme that is given in the description of each of the physical message buffer fields. # 21.6.5.2 Message buffer header field description This section provides a detailed description of the usage and content of the message buffer header field. A description of the structure of the message buffer header fields is given in Section 21.6.2.1: Message buffer header field. Each message buffer header field consists of three sections: the frame header section, the data field offset, and the slot status section. For a detailed description of the Data Field Offset, see Section 21.6.2.1.2: Data field offset. #### 21.6.5.2.1 Frame header description #### 21.6.5.2.1.1 Frame header content The semantic and content of the frame header section depends on the message buffer type. For individual receive message buffers and receive FIFOs, the frame header receives the frame header data of the *first valid frame* received on the assigned channels. For receive shadow buffers, the frame header receives the frame header data of the current frame received regardless of whether the frame is valid or not. For transmit message buffers, the application writes the frame header of the frame to be transmitted into this location. The frame header will be read out when the frame is transferred to the FlexRay bus. The structure of the frame header in the message buffer header field for receive message buffers and the receive FIFO is given in *Figure 342*. A detailed description is given in *Table 328*. Figure 342. Frame header structure (Receive message buffer and receive FIFO) The structure of the frame header in the message buffer header field for transmit message buffers is given in *Figure 343*. A detailed description is given in *Table 329*. The checks that will be performed are described in *Section 21.6.5.2.1.3*: *Frame header checks*. Figure 343. Frame header structure (Transmit message buffer) The structure of the frame header in the message buffer header field for transmit message buffers assigned to key slot is given in *Figure 344*. Figure 344. Frame header structure (Transmit message buffer for key slot) #### 21.6.5.2.1.2 Frame header access The frame header is located in the FlexRay memory. To ensure data consistency, the application must follow the write access scheme described below. For receive message buffers, receive shadow buffers, and receive FIFOs, the application must not write to the frame header field. For transmit message buffers, the application must follow the write access restrictions given in *Table 327*. This table shows the condition under which the application can write to the frame header entries without corrupting the FlexRay message transmission. | Field | Single Buffered | | Double Buffered | | | | |------------------|-----------------|---------|-----------------|---------------|-----------------|---------------| | | Static Dynamic | | Static Segment | | Dynamic Segment | | | | Segment | Segment | Commit Side | Transmit Side | Commit Side | Transmit Side | | FID | | | POC:config | or MB_DIS | | | | PPI, | | | POC:config o | or MB_DIS or | | | | PLDLEN,<br>HDCRC | | MB_LCK | | | MB_LCK | | Table 327. Frame header write access constraints (Transmit message buffer) #### 21.6.5.2.1.3 Frame header checks As shown in *Figure 343* and *Figure 344* not all fields in the message buffer frame header are used for transmission. Some fields in the message buffer frame header are ignored, some are used for transmission, and some of them are checked for correct values. All checks that will be performed are described below. For message buffers assigned to the key slot, no checks will be performed. The value of the FID field must be equal to the value of the corresponding Section 21.5.2.67: Message Buffer Frame ID Registers (MBFIDRn). If the controller detects a mismatch while transmitting the frame header, it will set the frame ID error flag FID\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR). The value of the FID field will be ignored and replaced by the value provided in the Section 21.5.2.67: Message Buffer Frame ID Registers (MBFIDRn). For transmit message buffers assigned to the *static* segment, the PLDLEN value must be equal to the value of the payload\_length\_static field in the *Section 21.5.2.64.20: Protocol Configuration Register 19 (PCR19)*. If this is not fulfilled, the static payload length error flag SPL\_EF in the *Section 21.5.2.15: CHI Error Flag Register (CHIERFR)* is set when the message buffer is under transmission. A syntactically and semantically correct frame is generated with payload\_length\_static payload words and the payload length field in the transmitted frame header set to payload length static. For transmit message buffers assigned to the *dynamic* segment, the PLDLEN value must be less than or equal to the value of the max\_payload\_length\_dynamic field in the Section 21.5.2.64.25: Protocol Configuration Register 24 (PCR24). If this is not fulfilled, the dynamic payload length error flag DPL\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is set when the message buffer is under transmission. A syntactically and semantically correct dynamic frame is generated with PLDLEN payload words and the payload length field in the frame header set to PLDLEN. Table 328. Frame header field descriptions (Receive message buffer and receive FFO) | Field | Description | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------| | R | <b>Reserved Bit</b> — This is the value of the <i>Reserved bit</i> of the received frame stored in the message buffer. | | PPI | <b>Payload Preamble Indicator</b> — This is the value of the <i>Payload Preamble Indicator</i> of the received frame stored in the message buffer. | | NUF | <b>Null Frame Indicator</b> — This is the value of the <i>Null Frame Indicator</i> of the received frame stored in the message buffer. | | SYF | <b>Sync Frame Indicator</b> — This is the value of the <i>Sync Frame Indicator</i> of the received frame stored in the message buffer. | | SUF | <b>Startup Frame Indicator</b> — This is the value of the <i>Startup Frame Indicator</i> of the received frame stored in the message buffer. | | FID | <b>Frame ID</b> — This is the value of the <i>Frame ID</i> field of the received frame stored in the message buffer. | | CYCCNT | <b>Cycle Count</b> — This is the number of the communication cycle in which the frame stored in the message buffer was received. | | PLDLEN | <b>Payload Length</b> — This is the value of the <i>Payload Length</i> field of the received frame stored in the message buffer. | | HDCRC | <b>Header CRC</b> — This is the value of the <i>Header CRC</i> field of the received frame stored in the message buffer. | Table 329. Frame header field descriptions (Transmit message buffer) | Field | Description | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R | Reserved Bit — This bit is not used, the value of the Reserved bit is generated internally according to FlexRay Communications System Protocol Specification, Version 2.1 Rev A. | | PPI | Payload Preamble Indicator — This bit provides the value of the Payload Preamble Indicator for the frame transmitted from the message buffer. | | NUF | <b>Null Frame Indicator</b> — This bit is not used, the value of the <i>Null Frame Indicator</i> is generated internally according to <i>FlexRay Communications System Protocol Specification, Version 2.1 Rev A.</i> | | SYF | Sync Frame Indicator — This bit is not used, the value of the Sync Frame Indicator is generated internally according to FlexRay Communications System Protocol Specification, Version 2.1 Rev A. | | SUF | Startup Frame Indicator — This bit is not used, the value of the Startup Frame Indicator is generated internally according to FlexRay Communications System Protocol Specification, Version 2.1 Rev A. | | FID | Frame ID — This field is checked as described in Section 21.6.5.2.1.3: Frame header checks. | | CYCCNT | <b>Cycle Count</b> — This field is not used, the value of the transmitted <i>Cycle Count</i> field is taken from the internal communication cycle counter. | | PLDLEN | Payload Length — This field is checked and used as described in Section 21.6.5.2.1.3: Frame header checks. | | HDCRC | <b>Header CRC</b> — This field provides the value of the <i>Header CRC</i> field for the frame transmitted from the message buffer. | ### 21.6.5.2.2 Data field offset description #### 21.6.5.2.2.1 Data field offset content For a detailed description of the Data Field Offset, see Section 21.6.2.1.2: Data field offset. #### 21.6.5.2.2.2 Data field offset access The application shall program the Data Field Offset when configuring the message buffers either in the *POC:config* state or when the message buffer is disabled. ### 21.6.5.2.3 Slot status description The slot status is a read-only structure for the application and a write-only structure for the controller. The meaning and content of the slot status in the message buffer header field depends on the message buffer type. # 21.6.5.2.3.1 Receive message buffer and receive FIFO slot status description This section describes the slot status structure for the individual receive message buffers and receive FIFOs. The content of the slot status structure for receive message buffers depends on the message buffer type and on the channel assignment for individual receive message buffers as given by *Table 330*. Table 330. Receive message buffer slot status content | Receive Message Buffer Type | Slot Status Content | |------------------------------------------------------------------------------------------------|---------------------| | Individual Receive Message Buffer assigned to both channels MBCCSRn[CHA]=1 and MBCCSRn[CHB]=1 | see Figure 345 | | Individual Receive Message Buffer assigned to channel A MBCCSRn[CHA]=1 and MBCCSRn[CHB[=0 | see Figure 346 | | Individual Receive Message Buffer assigned to channel B MBCCSRn[CHA]=0 and MBCCSRn[CHB]=1 | see Figure 347 | | Receive FIFO Channel A Message Buffer | see Figure 346 | | Receive FIFO Channel B Message Buffer | see Figure 347 | The meaning of the bits in the slot status structure is explained in *Table 331*. Figure 345. Receive message buffer slot status structure (ChAB) Figure 346. Receive message buffer slot status structure (ChA) Figure 347. Receive message buffer slot status structure (ChB) Table 331. Receive message buffer slot status field descriptions | Field | Description | | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Common Message Buffer Status Bits | | | | VFB | Valid Frame on Channel B — protocol related variable: vSS!ValidFrame channel B 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | | | SYB | Sync Frame Indicator Channel B — protocol related variable: vRF!Header!SyFIndicator channel 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | | Table 331. Receive message buffer slot status field descriptions(Continued) | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NFB | Null Frame Indicator Channel B — protocol related variable: vRF!Header!NFIndicator channel B 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUB | Startup Frame Indicator Channel B — protocol related variable: vRF!Header!SuFIndicator channel B 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | | SEB | Syntax Error on Channel B — protocol related variable: vSS!SyntaxError channel B 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | CEB | Content Error on Channel B — protocol related variable: vSS!ContentError channel B 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVB | Boundary Violation on Channel B — protocol related variable: vSS!BViolation channel B 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | | СН | Channel first valid received — This status bit applies only to receive message buffers assigned to the static segment and to both channels. It indicates the channel that has received the first valid frame in the slot. This flag is set to 0 if no valid frame was received at all in the subscribed slot. 0 first valid frame received on channel A, or no valid frame received at all. 0 first valid frame received on channel B. | | VFA | Valid Frame on Channel A — protocol related variable: vSS!Vali. dFrame channel A 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | SYA | Sync Frame Indicator Channel A — protocol related variable: vRF!Header!SyFIndicator channel A 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | NFA | Null Frame Indicator Channel A — protocol related variable: vRF!Header!NFIndicator channel A 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUA | Startup Frame Indicator Channel A — protocol related variable: vRF!Header!SuFIndicator channel A 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | | SEA | Syntax Error on Channel A — protocol related variable: vSS!SyntaxError channel A 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | CEA | Content Error on Channel A — protocol related variable: vSS!ContentError channel A 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVA | Boundary Violation on Channel A — protocol related variable: vSS!BViolation channel A 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | ### 21.6.5.2.3.2 Transmit message buffer slot status description This section describes the slot status structure for transmit message buffers. Only the TCA and TCB status bits are directly related to the transmission process. All other status bits in this structure are related to a receive process that may have occurred. The content of the slot status structure for transmit message buffers depends on the channel assignment as given by *Table 332*. Table 332. Transmit message buffer slot status content | Transmit Message Buffer Type | Slot Status Content | |-------------------------------------------------------------------------------------------------|---------------------| | Individual Transmit Message Buffer assigned to both channels MBCCSRn[CHA]=1 and MBCCSRn[CHB]=1 | see Figure 348 | | Individual Transmit Message Buffer assigned to channel A MBCCSRn[CHA]=1 and MBCCSRn[CHB]=0 | see Figure 349 | | Individual Transmit Message Buffer assigned to channel B MBCCSRn[CHA]=0 and MBCCSRn[CHB]=1 | see Figure 350 | The meaning of the bits in the slot status structure is described in *Table 331*. Figure 348. Transmit message buffer slot status structure (ChAB) Figure 349. Transmit message buffer slot status structure (ChA) Figure 350. Transmit message buffer slot status structure (ChB) Table 333. Transmit message buffer slot status structure field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | VFB | Valid Frame on Channel B — protocol related variable: vSS!ValidFrame channel B 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | SYB | Sync Frame Indicator Channel B — protocol related variable: vRF!Header!SyFIndicator channel B 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | NFB | Null Frame Indicator Channel B — protocol related variable: vRF!Header!NFIndicator channel B 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUB | Startup Frame Indicator Channel B — protocol related variable: vRF!Header!SuFIndicator channel B 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | | SEB | Syntax Error on Channel B — protocol related variable: vSS!SyntaxError channel B 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | CEB | Content Error on Channel B — protocol related variable: vSS!ContentError channel B 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVB | Boundary Violation on Channel B — protocol related variable: vSS!BViolation channel B 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | | ТСВ | Transmission Conflict on Channel B — protocol related variable: vSS!TxConflict channel B 0 vSS!TxConflict = 0. 1 vSS!TxConflict = 1. | | VFA | Valid Frame on Channel A — protocol related variable: vSS!ValidFrame channel A 0 vSS!ValidFrame = 0. 1 vSS!ValidFrame = 1. | | SYA | Sync Frame Indicator Channel A — protocol related variable: vRF!Header!SyFIndicator channel A 0 vRF!Header!SyFIndicator = 0. 1 vRF!Header!SyFIndicator = 1. | | NFA | Null Frame Indicator Channel A — protocol related variable: vRF!Header!NFIndicator channel A 0 vRF!Header!NFIndicator = 0. 1 vRF!Header!NFIndicator = 1. | | SUA | Startup Frame Indicator Channel A — protocol related variable: vRF!Header!SuFIndicator channel A 0 vRF!Header!SuFIndicator = 0. 1 vRF!Header!SuFIndicator = 1. | | SEA | Syntax Error on Channel A — protocol related variable: vSS!SyntaxError channel A 0 vSS!SyntaxError = 0. 1 vSS!SyntaxError = 1. | | | • • • • • • • • • • • • • • • • • • • • | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Field | Description | | CEA | Content Error on Channel A — protocol related variable: vSS!ContentError channel A 0 vSS!ContentError = 0. 1 vSS!ContentError = 1. | | BVA | Boundary Violation on Channel A — protocol related variable: vSS!BViolation channel A 0 vSS!BViolation = 0. 1 vSS!BViolation = 1. | | TCA | <b>Transmission Conflict on Channel A</b> — protocol related variable: <i>vSS!TxConflict</i> channel A 0 <i>vSS!TxConflict</i> = 0. 1 <i>vSS!TxConflict</i> = 1. | Table 333. Transmit message buffer slot status structure field descriptions(Continued) # 21.6.5.3 Message buffer data field description The message buffer data field stores the frame payload data, or a part of it, of the frame to be transmitted to or received from the FlexRay bus. The minimum required length of this field depends on the message buffer type that the physical message buffer is assigned to and is given in *Table 334*. The structure of the message buffer data field is given in *Figure 351*. Table 334. Message buffer data field minimum length | physical message buffer assigned to | minimum length defined by | |----------------------------------------|-----------------------------------| | Individual Message Buffer in Segment 1 | MBDSR[MBSEG1DS] | | Receive Shadow Buffer in Segment 1 | MBDSR[MBSEG1DS] | | Individual Message Buffer in Segment 2 | MBDSR[MBSEG2DS] | | Receive Shadow Buffer in Segment 2 | MBDSR[MBSEG2DS] | | Receive FIFO for channel A | RFDSR[ENTRY_SIZE] (RFSR[SEL] = 0) | | Receive FIFO for channel B | RFDSR[ENTRY_SIZE] (RFSR[SEL] = 1) | Note: The controller will not access any locations outside the message buffer data field boundaries given by Table 334. Figure 351. Message buffer data field structure The message buffer data field is located in the FlexRay memory; thus, the controller has no means to control application write access to the field. To ensure data consistency, the application must follow a write and read access scheme. #### 21.6.5.3.1 Message buffer data field read access For transmit message buffers, the controller will not modify the content of the Message Buffer Data Field. Thus the application can read back the data at any time without any impact on data consistency. For receive message buffers the application must lock the related receive message buffer and retrieve the message buffer header index from the *Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn)*. While the message buffer is locked, the controller will not update the Message Buffer Data Field. For receive FIFOs, the application can read the message buffer indicated by the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) or the Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR) when the related receive FIFO non-empty interrupt flag FNEAIF or FNEBIF is set in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER). While the non-empty interrupt flag is set, the controller will not update the Message Buffer Data Field related to message buffer indicated by Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) or the Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR). #### 21.6.5.3.2 Message buffer data field write access For receive message buffers, receive shadow buffers, and receive FIFOs, the application must not write to the message buffer data field. For transmit message buffers, the application must follow the write access restrictions given in *Table 335*. | Field | Single buffered | Double buffered | | | |----------------|-------------------------------------------------|-----------------|----------------------|--| | i ieiu | Single bullered | Commit side | Transmit side | | | DATA, MID, NMV | DATA, MID, NMV POC:config or MB_DIS or MB_LCK | | POC:config or MB_DIS | | Table 335. Frame data write access constraints #### Table 336. Frame data field descriptions | Field | Description | |-------------|----------------------------------------------------------------------------------------------------------------------| | DATA 0, | Message Data — Provides the message data received or to be transmitted. | | DATA 1,<br> | For receive message buffer and receive FIFOs, this field provides the message data received for this message buffer. | | DATA N-1 | For transmit message buffers, the field provides the message data to be transmitted. | | Field | Description | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MID 0,<br>MID 1 | Message Identifier — If the payload preamble bit PPI is set in the message buffer frame header, the MID field holds the message ID of a dynamic frame located in the message buffer. The receive FIFO filter uses the received message ID for message ID filtering. | | NMV 0,<br>NMV 1,<br> | Network Management Vector — If the payload preamble bit PPI is set in the message buffer frame header, the network management vector field holds the network management vector of a static frame located in the message buffer. | | NMV 11 | <b>Note:</b> The MID and NMV bytes replace the corresponding DATA bytes. | Table 336. Frame data field descriptions(Continued) # 21.6.6 Individual message buffer functional description The controller provides three basic types of individual message buffers: - 1. Single Transmit Message Buffers - Double Transmit Message Buffers - Receive Message Buffers Before an individual message buffer can be used, it must be configured by the application. After the initial configuration, the message buffer can be reconfigured later. The set of the configuration data for individual message buffers is given in Section 21.6.3.4.1: Individual message buffer configuration data. # 21.6.6.1 Individual message buffer configuration The individual message buffer configuration consists of two steps. The first step is the allocation of the required amount of memory for the FlexRay memory. The second step is the programming of the message buffer configuration registers, which is described in this section. #### 21.6.6.1.1 Common configuration data One part of the message buffer configuration data is common to all individual message buffers and the receive shadow buffers. These data can only be set when the protocol is in the *POC:config* state. The application configures the number of utilized individual message buffers by writing the message buffer number of the last utilized message buffer into the LAST\_MB\_UTIL field in the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR). The application configures the size of the two segments of individual message buffers by writing the message buffer number of the last message buffer in the first segment into the LAST\_MB\_SEG1 field in the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR) The application configures the length of the message buffer data fields for both of the message buffer segments by writing to the MBSEG2DS and MBSEG1DS fields in the Section 21.5.2.7: Message Buffer Data Size Register (MBDSR). Depending on the current receive functionality of the controller, the application must configure the receive shadow buffers. For each segment and for each channel with at least one individual receive message buffer assigned, the application must configure the related receive shadow buffer using the *Section 21.5.2.50: Receive Shadow Buffer Index Register (RSBIR)*. ### 21.6.6.1.2 Specific configuration data The second part of the message buffer configuration data is specific for each message buffer. These data can be changed only when either - the protocol is in the POC:config state or - the message buffer is disabled, i.e., MBCCSRn[EDS] = 0 The individual message buffer type is defined by the MTD and MBT bits in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) as given in Table 337. | MBCCSRn[MTD] | MBCCSRn[MBT] | Individual Message Buffer Description | |--------------|--------------|---------------------------------------| | 0 | 0 | Receive Message Buffer | | 0 | 1 | Reserved | | 1 | 0 | Single Transmit Message Buffer | | 1 | 1 | Double Transmit Message Buffer | Table 337. Individual message buffer types The message buffer specific configuration data are - MCM, MBT, MTD bits in Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn) - all fields and bits in Section 21.5.2.66: Message Buffer Cycle Counter Filter Registers (MBCCFRn) - all fields and bits in Section 21.5.2.67: Message Buffer Frame ID Registers (MBFIDRn) - all fields and bits in Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn) The meaning of the specific configuration data depends on the message buffer type, as given in the detailed message buffer type descriptions Section 21.6.6.2: Single transmit message buffers, Section 21.6.6.3: Receive message buffers and Section 21.6.6.4: Double transmit message buffer. ### 21.6.6.2 Single transmit message buffers The section provides a detailed description of the functionality of single buffered transmit message buffers. A single transmit message buffer is used by the application to provide message data to the controller that will be transmitted over the FlexRay Bus. The controller uses the transmit message buffers to provide information about the transmission process and status information about the slot in which message was transmitted. The individual message buffer with message buffer number *n* is configured to be a single transmit message buffer by the following settings: - MBCCSRn[MBT] = 0 (single buffered message buffer) - MBCCSRn[MTD] = 1 (transmit message buffer) ### 21.6.6.2.1 Access regions To certain message buffer fields, both the application and the controller have access. To ensure data consistency, a message buffer locking scheme is implemented, which controls the access to the data, control, and status bits of a message buffer. The access regions for single transmit message buffers are shown in *Figure 352*. A description of the regions is given in *Table 338*. If an region is active as indicated in *Table 339*, the access scheme given for that region applies to the message buffer. Figure 352. Single transmit message buffer access regions Table 338. Single transmit message buffer access regions description | Region | Acces | s from | Region used for | |--------|-------------|------------|---------------------------------------------------| | | Application | Module | Region used for | | CFG | read/write | _ | Message Buffer Configuration | | MSG | read/write | _ | Message Data and Slot Status Access | | NF | _ | read-only | Message Header Access for Null Frame Transmission | | TX | _ | read/write | Message Transmission and Slot Status Update | | CM | _ | read-only | Message Buffer Validation | | SR | _ | read-only | Message Buffer Search | The trigger bits MBCCSRn[EDT] and MBCCSRn[LCKT], and the interrupt enable bit MBCCSRn[MBIE] are not under access control and can be accessed from the application at any time. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] are not under access control and can be accessed from the controller at any time. The interrupt flag MBCCSnR[MBIF] is not under access control and can be accessed from the application and the controller at any time. controller clear access has higher priority. The controller restricts its access to the regions depending on the current state of the message buffer. The application must adhere to these restrictions in order to ensure data consistency. The transmit message buffer states are given in *Figure 353*. A description of the states is given in *Table 339*, which also provides the access scheme for the access regions. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] provide the application with the required message buffer status information. The internal status information is not visible to the application. ### 21.6.6.2.2 Message buffer states This section describes the transmit message buffer states and provides a state diagram. Figure 353. Single transmit message buffer states Table 339. Single transmit message buffer state description | State | MBCCSRn Access Region State Description | | Description | | | |---------|-----------------------------------------|------|-------------|-----------|--------------------------------------------------------------------------------------------------------| | State | EDS | LCKS | Appl. | Module | Description | | ldle | 1 | 0 | _ | CM,<br>SR | Idle — Message Buffer is idle. Included in message buffer search. | | HDis | 0 | 0 | CFG | _ | <u>Dis</u> abled — Message Buffer under configuration. Excluded from message buffer search. | | HDisLck | 0 | 1 | CFG | _ | <u>Disabled and Locked</u> — Message Buffer under configuration. Excluded from message buffer search. | | State | MBCCSRn | | Access Region | | Description | |----------|---------|------|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | State | EDS | LCKS | Appl. | Module | Description | | HLck | 1 | 1 | MSG | SR | <u>Locked</u> — Applications access to data, control, and status. Included in message buffer search. | | CCSa | 1 | 0 | ı | _ | Slot Assigned — Message buffer assigned to next static slot. Ready for Null Frame transmission. | | HLckCCSa | 1 | 1 | MSG | _ | <u>Lock</u> ed and <u>Slot Assigned</u> — Applications access to data, control, and status. Message buffer assigned to next static slot | | CCNf | 1 | 0 | _ | NF | <u>N</u> ull <u>Frame Transmission</u><br>Header is used for null frame transmission. | | HLckCCNf | 1 | 1 | MSG | NF | <u>Lock</u> ed and <u>Null Frame Transmission — Applications access to data, control, and status. Header is used for null frame transmission.</u> | | CCMa | 1 | 0 | 1 | СМ | Message Available — Message buffer is assigned to next slot and cycle counter filter matches. | | HLckCCMa | 1 | 1 | MSG | _ | <u>Lock</u> ed and <u>Message Available</u> — Applications access to data, control, and status. Message buffer is assigned to next slot and cycle counter filter matches. | | CCTx | 1 | 0 | _ | TX | Message <u>Transmission</u> — Message buffer data transmit. Payload data from buffer transmitted | | CCSu | 1 | 0 | _ | TX | Status Update — Message buffer status update. Update of status flags, the slot status field, and the header index. | Table 339. Single transmit message buffer state description(Continued) #### 21.6.6.2.3 Message buffer transitions ### 21.6.6.2.3.1 Application transitions The application transitions can be triggered by the application using the commands described in *Table 340*. The application issues the commands by writing to the *Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn)*. Only one command can be issued with one write access. Each command is executed immediately. If the command is ignored, it must be issued again. Message Buffer Enable and Disable The enable and disable commands issued by writing 1 to the trigger bit MBCCSRn[EDT]. The transition that will be triggered by each of these command depends on the current value of the status bit MBCCSRn[EDS]. If the command triggers the disable transition HD and the message buffer is in one of the states CCSa, HLckCCSa, CCMa, HLckCCMa, CCNf, HLckCCNf, or CCTx, the disable transition has no effect (command is ignored) and the message buffer state is not changed. No notification is given to the application. Message Buffer Lock and Unlock The lock and unlock commands issued by writing 1 to the trigger bit MBCCSRn[LCKT]. The transition that will be triggered by each of these commands depends on the current value of the status bit MBCCSRn[LCKS]. If the command triggers the lock transition HL and the message buffer is in the state CCTx, the lock transition has no effect (command is ignored) and message buffer state is not changed. In this case, the message buffer lock error flag LCK\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is set. Table 340. Single transmit message buffer application transitions | Transition | Command | Condition | Description | |------------|-------------------|-------------------|----------------------------------------------| | HE | MBCCSRn[EDT]:= 1 | MBCCSRn[EDS] = 0 | Application triggers message buffer enable. | | HD | MBCC3KII[ED1] 1 | MBCCSRn[EDS] = 1 | Application triggers message buffer disable. | | HL | MBCCSRn[LCKT]:= 1 | MBCCSRn[LCKS] = 0 | Application triggers message buffer lock. | | HU | MBCC3KII[LCK1] 1 | MBCCSRn[LCKS] = 1 | Application triggers message buffer unlock. | #### 21.6.6.2.3.2 Module transitions The module transitions that can be triggered by the controller are described in *Table 341*. Each transition will be triggered for certain message buffers when the related condition is fulfilled. Table 341. Single transmit message buffer module transitions | Transition | Condition | Description | |------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | SA | slot match and static slot | Slot Assigned — Message buffer is assigned to next static slot. | | MA | slot match and<br>CycleCounter match | Message Available — Message buffer is assigned to next slot and cycle counter filter matches. | | TX | slot start and<br>MBCCSRn[CMT] = 1 | <u>Transmission Slot Start</u> — Slot Start and commit bit CMT is set. In case of a dynamic slot, pLatestTx is not exceeded. | | SU | status updated | Status Updated — Slot Status field and message buffer status flags updated. Interrupt flag set. | | STS | static slot start | Static Slot Start — Start of static slot. | | DSS | dynamic slot start or<br>symbol window start or<br>NIT start | <u>D</u> ynamic Slot or <u>S</u> egment <u>S</u> tart — Start of dynamic slot or symbol window or NIT. | | SSS | slot start or<br>symbol window start or<br>NIT start | Slot or Segment Start — Start of static slot or dynamic slot or symbol window or NIT. | # 21.6.6.2.3.3 Transition priorities The application can trigger only one transition at a time. There is no need to specify priorities among them. As shown in the first part of *Table 342*, the module transitions have a higher priority than the application transitions. For all states except the CCMa state, both a lock/unlock transition HL/HD and a module transition can be executed at the same time. The result state is reached by first applying the application transition and subsequently the module transition to the intermediately reached state. For example, if the message buffer is in the HLck state and the application unlocks the message buffer by the HU transition and the module triggers the slot assigned transition SA, the intermediate state is Idle and the resulting state is CCSa. The priorities among the module transitions is given in the second part of *Table 342*. | idade o izi o inglo di dilonit in occago banco di dilonico prioritato | | | | |-----------------------------------------------------------------------|----------------------|------------------------------------------------------------------------------------------|--| | State | Priorities | Description | | | | | module vs. application | | | ldle, HLck | SA > HD<br>MA > HD | Slot Assigned > Message Buffer Disable Message Available > Message Buffer Disable | | | CCMa | TX > HL | Transmission Start > Message Buffer Lock | | | | | module internal | | | Idle, HLck | MA > SA | Message Available > Slot Assigned | | | ССМа | TX > STS<br>TX > DSS | Transmission Slot Start > Static Slot Start Transmission Slot Start > Dynamic Slot Start | | Table 342. Single transmit message buffer transition priorities ### 21.6.6.2.4 Transmit message setup To transmit a message over the FlexRay bus, the application writes the message data into the message buffer data field and sets the commit bit CMT in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). The physical access to the message buffer data field is described in Section 21.6.3.1: Individual message buffers. As indicated by *Table 339*, the application shall write to the message buffer data field and change the commit bit CMT only if the transmit message buffer is in one of the states HDis, HDisLck, HLck, HLckCCSa, HLckCCMa, or HLckCCMa. The application can change the state of a message buffer if it issues the appropriate commands shown in *Table 340*. The state change is indicated through the MBCCSRn[EDS] and MBCCSRn[LCKS] status bits. If the transmit message buffer enters one of the states HDis, HDisLck, HLck, HLckCCSa, HLckCCMa, or HLckCCMa the MBCCSRn[DVAL] flag is negated. ### 21.6.6.2.5 Message transmission As a result of the message buffer search described in *Section 21.6.7: Individual message* buffer search the controller triggers the message available transition MA for as many as two transmit message buffers. This changes the message buffer state from Idle to CCMa and the message buffers can be used for message transmission in the next slot. The controller transmits a message from a message buffer if both of the following two conditions are fulfilled at the start of the transmission slot: - 1. the message buffer is in the message available state CCMa - the message data are still valid, i.e., MBCCSRn[CMT] = 1 In this case, the controller triggers the TX transition and changes the message buffer state to CCTx. A transmit message buffer timing and state change diagram for message transmission is given in *Figure 354*. In this example, the message buffer with message buffer number n is Idle at the start of the search slot, matches the slot and cycle number of the next slot, and message buffer data are valid, i.e., MBCCSR*n*[CMT] = 1. Figure 354. Message transmission timing Figure 355. Message transmission from HLck state with unlock The amount of message data read from the FlexRay memory and transferred to the FlexRay bus is determined by the following three items: - the message buffer segment that the message buffer is assigned to, as defined by MBSSUTR (see Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR)") - the message buffer data field size, as defined by the related field of MBDSR (see Section 21.5.2.7: Message Buffer Data Size Register (MBDSR)") - the value of the PLDLEN field in the message buffer header field, as described in Section 21.6.5.2.1: Frame header description. If a message buffer is assigned to message buffer segment 1, and PLDLEN > MBSEG1DS, then $2 \times MBSEG1DS$ bytes will be read from the message buffer data field and zero padding is used for the remaining bytes for the FlexRay bus transfer. If PLDLEN <= MBSEG1DS, the controller reads and transfers $2 \times PLDLEN$ bytes. The same holds for segment 2 and MBSEG2DS. #### 21.6.6.2.6 Null frame transmission A static slot with slot number S is assigned to the controller for channel A, if at least one transmit message buffer is configured with the MBFIDRn[FID] set to S and MBCCFRn[CHA] set to 1. A Null Frame is transmitted in the static slot S on channel A, if this slot is assigned to the controller for channel A, and all transmit message buffers with MBFIDRn[FID] = s and MBCCFRn[CHA] = 1 are either not committed, i.e., MBCCSRn[CMT] = 0, or locked by the application, i.e., MBCCSRn[LCKS] = 1, or the cycle counter filter is enabled and does not match. Additionally, the application can clear the commit bit of a message buffer that is in the CCMa state, which is called *uncommit* or *transmit abort*. This message buffer will be used for null frame transmission. As a result of the message buffer search described in Section 21.6.7: Individual message buffer search the controller triggers the slot assigned transition SA for as many as two transmit message buffers if at least one of the conditions mentioned above is fulfilled for these message buffers. The transition SA changes the message buffer states from either Idle to CCSa or from HLck to HLckCCSa. In each case, these message buffers will be used for null frame transmission in the next slot. A message buffer timing and state change diagram for null frame transmission from Idle state is given in *Figure 356*. Figure 356. Null frame transmission from idle state A message buffer timing and state change diagram for null frame transmission from HLck state is given in *Figure 357*. Figure 357. Null frame transmission from HLck state If a transmit message buffer is in the CCSa or HLckCCSa state at the start of the transmission slot, a null frame is transmitted in any case, even if the message buffer is unlocked or committed before the transmission slot starts. A transmit message buffer timing and state change diagram for null frame transmission for this case is given in *Figure 358*. Figure 358. Null frame transmission from HLck state with unlock Since the null frame transmission will not use the message buffer data, the application can lock/unlock the message buffer during null frame transmission. A transmit message buffer timing and state change diagram for null frame transmission for this case is given in *Figure 359*. Figure 359. Null frame transmission from idle state with locking # 21.6.6.2.7 Message buffer status update After the end of each slot, the PE generates the slot status vector. Depending on the this status, the transmitted frame type, and the amount of transmitted data, the message buffer status is updated. # 21.6.6.2.7.1 Message buffer status update after complete message transmission The term complete message transmission refers to the fact that all payload data stored in the message buffer were send to FlexRay bus. In this case, the controller updates the slot status field of the message buffer and triggers the status updated transition SU. With the SU transition, the controller sets the message buffer interrupt flag MBCCSn[MBIF] to indicate the successful message transmission. Depending on the transmission mode flag MBCCFRn[MTM], the controller changes the commit flag MBCCSRn[CMT] and the valid flag MBCCSRn[DVAL]. If the MBCCFRn[MTM] flag is negated, the message buffer is in the *event transmission mode*. In this case, each committed message is transmitted only once. The commit flag MBCCSRn[CMT] is cleared with the SU transition. If the MBCCFRn[MTM] flag is asserted, the message buffer is in the *state transmission mode*. In this case, each committed message is transmitted as long as the application provides new data or locks the message buffers. The controller will not clear the MBCCSRn[CMT] flag at the end of transmission and will set the valid flag MBCCSRn[DVAL] to indicate that the message will be transmitted again. ### 21.6.6.2.7.2 Message buffer status update after incomplete message transmission The term incomplete message transmission refers to the fact that not all payload data that should be transmitted were send to FlexRay bus. This may be caused by the following regular conditions in the dynamic segment: - The transmission slot starts in a minislot with a minislot number greater than pLatestTx. - The transmission slot did not exist in the dynamic segment at all. Additionally, an incomplete message transmission can be caused by internal communication errors. If those error occur, the Protocol Engine Communication Failure Interrupt Flag PECF\_IF is set in the Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1). In any of these two cases, the status of the message buffer is not changed at all with the SU transition. The slot status field is not updated, the status and control flags are not changed, and the interrupt flag is not set. # 21.6.6.2.7.3 Message buffer status update after null frame transmission After the transmission of a null frame, the status of the message buffer that was used for the null frame transmission is not changed at all. The slot status field is not updated, the status and control flags are not changed, and the interrupt flag is not set. # 21.6.6.3 Receive message buffers The section provides a detailed description of the functionality of the receive message buffers. A receive message buffer receives a message from the FlexRay Bus based on individual filter criteria. The controller uses the receive message buffer to provide the following data to the application - Message data received - information about the reception process - status information about the slot in which the message was received A individual message buffer with message buffer number n is configured as a receive message buffer by the following configuration settings - MBCCSRn[MBT] = 0 (single buffered message buffer) - MBCCSRn[MTD] = 0 (receive message buffer) To certain message buffer fields, both the application and the controller have access. To ensure data consistency, a message buffer locking scheme is implemented that controls the access to the data, control, and status bits of a message buffer. The access regions for receive message buffers are shown in *Figure 360*. A description of the regions is given in *Table 343*. If an region is active as indicated in *Table 344*, the access scheme given for that region applies to the message buffer. Figure 360. Receive message buffer access regions **Access from** Region Region used for Module **Application CFG** Message Buffer Configuration, Message Data and Status Access read/write MSG read/write Message Data, Header, and Status Access RX write-only Message Reception and Status Update SR read-only Message Buffer Search Data Table 343. Receive message buffer access region description The trigger bits MBCCSRn[EDT] and MBCCSRn[LCKT] and the interrupt enable bit MBCCSRn[MBIE] are not under access control and can be accessed from the application at any time. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] are not under access control and can be accessed from the controller at any time. The interrupt flag MBCCSRn[MBIF] is not under access control and can be accessed from the application and the controller at any time. controller set access has higher priority. The controller restricts its access to the regions depending on the current state of the message buffer. The application must adhere to these restrictions in order to ensure data consistency. The receive message buffer states are given in *Figure 361*. A description of the message buffer states is given in *Table 339*, which also provides the access scheme for the access regions. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] provide the application with the required status information. The internal status information is not visible to the application. Figure 361. Receive message buffer states | State | MBCCSRn | | Access from | | Description | |----------|---------|------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------| | State | EDS | LCKS | Appl. | Module | Description | | ldle | 1 | 0 | _ | SR | Idle — Message Buffer is idle. Included in message buffer search. | | HDis | 0 | 0 | CFG | _ | <u>Dis</u> abled — Message Buffer under configuration. Excluded from message buffer search. | | HDisLck | 0 | 1 | CFG | _ | <u>Disabled and Locked</u> — Message Buffer under configuration. Excluded from message buffer search. | | HLck | 1 | 1 | MSG | _ | <u>Locked</u> — Applications access to data, control, and status. Included in message buffer search. | | CCBs | 1 | 0 | _ | _ | <u>Buffer Subscribed</u> — Message buffer subscribed for reception. Filter matches next (slot, cycle, channel) tuple. | | HLckCCBs | 1 | 1 | MSG | _ | <u>Locked and Buffer Subscribed</u> — Applications access to data, control, and status. Message buffer subscribed for reception. | | CCRx | 1 | 0 | _ | _ | <b>Message Receive</b> — Message data received into related shadow buffer. | | HLckCCRx | 1 | 1 | MSG | _ | <u>Lock</u> ed and Message <u>Receive</u> — Applications access to data, control, and status. Message data received into related shadow buffer. | | CCSu | 1 | 0 | _ | RX | <u>Status Update</u> — Message buffer status update. Update of status flags, the slot status field, and the header index. | Table 344. Receive message buffer states and access # 21.6.6.3.1 Message buffer transitions ### 21.6.6.3.1.1 Application transitions The application transitions that can be triggered by the application using the commands described in *Table 345*. The application issues the commands by writing to the *Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn)*. Only one command can be issued with one write access. Each command is executed immediately. If the command is ignored, it must be issued again. Message Buffer Enable and Disable The enable and disable commands issued by writing 1 to the trigger bit MBCCSRn[EDT]. The transition that will be triggered by each of these command depends on the current value of the status bit MBCCSRn[EDS]. If the command triggers the disable transition HD and the message buffer is in one of the states CCBs, HLckCCBs, or CCRx, the disable transition has no effect (command is ignored) and the message buffer state is not changed. No notification is given to the application. Message Buffer Lock and Unlock The lock and unlock commands issued by writing 1 to the trigger bit MBCCSRn[LCKT]. The transition that will be triggered by each of these commands depends on the current value of the status bit MBCCSRn[LCKS]. If the command triggers the lock transition HL while the message buffer is in the state CCRx, the lock transition has no effect (command is ignored) and message buffer state is not changed. In this case, the message buffer lock error flag LCK EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is set. Transition Host Command Condition Description HE MBCCSRn[EDT]:= 1 MBCCSRn[EDS] = 0 Application triggers message buffer enable. HD MBCCSRn[EDS] = 1 Application triggers message buffer disable. HL MBCCSRn[LCKS] = 0 Application triggers message buffer lock. HU MBCCSRn[LCKS] = 1 Application triggers message buffer unlock. Table 345. Receive message buffer application transitions #### 21.6.6.3.1.2 Module transitions The module transitions that can be triggered by the controller are described in *Table 346*. Each transition will be triggered for certain message buffers when the related condition is fulfilled. | • • • • • • • • • • • • • • • • • • • • | | | | | | | | |-----------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Transition | Condition | Description | | | | | | | BS | slot match and<br>CycleCounter match | <u>B</u> uffer <u>S</u> ubscribed — The message buffer filter matches next slot and cycle. | | | | | | | SLS | slot start | Slot Start — Start of either Static Slot or Dynamic Slot. | | | | | | | SNS | symbol window start or<br>NIT start | $\underline{\underline{S}}$ ymbol Window or $\underline{\underline{N}}$ IT $\underline{\underline{S}}$ tart — Start of either Symbol Window or NIT. | | | | | | | SSS | slot start or<br>symbol window start or<br>NIT start | Slot or Segment Start — Start of either Static Slot, Dynamic Slot, Symbol Window, or NIT. | | | | | | | SU | status updated | Status Updated — Slot Status field, message buffer status flags, header index updated. Interrupt flag set. | | | | | | Table 346. Receive message buffer module transitions #### 21.6.6.3.1.3 Transition priorities The application can trigger only one transition at a time. There is no need to specify priorities among them. As shown in *Table 347*, the module transitions have a higher priority than the application transitions. For all states except the CCRx state, a module transition and the application lock/unlock transition HL/HU and can be executed at the same time. The result state is reached by first applying the module transition and subsequently the application transition to the intermediately reached state. For example, if the message buffer is in the buffer subscribed state CCBs and the module triggers the slot start transition SLS at the same time as the application locks the message buffer by the HL transition, the intermediate state is CCRx and the resulting state is locked buffer subscribed state HLckCCRx. | State | Priorities | Description | | | | |-----------------------------------------------------------|------------|----------------------------------------------------|--|--|--| | | | module vs. application | | | | | Idle | BS > HD | BS > HD Buffer Subscribed > Message Buffer Disable | | | | | HLck | BS > HD | Buffer Subscribed > Message Buffer Disable | | | | | CCRx SSS > HL Slot or Segment Start > Message Buffer Lock | | | | | | Table 347. Receive message buffer transition priorities ### 21.6.6.3.2 Message reception As a result of the message buffer search, the controller changes the state of as many as two enabled receive message buffers from either idle state Idle or locked state HLck to the either subscribed state CCBs or locked buffer subscribed state HLckCCBs by triggering the buffer subscribed transition BS. If the receive message buffers for the next slot are assigned to both channels, then at most one receive message buffer is changed to a buffer subscribed state. If more than one matching message buffers assigned to a certain channel, then only the message buffer with the lowest message buffer number is in one of the states mentioned above. With the start of the next static or dynamic slot the module trigger the slot start transition SLS. This changes the state of the subscribed receive message buffers from either CCBs to CCRx or from HLckCCBs to HLckCCRx, respectively. During the reception slot, the received frame data are written into the shadow buffers. For details on receive shadow buffers, see *Section 21.6.6.3.5: Receive Shadow Buffers Concept.* The data and status of the receive message buffers that are the CCRx or HLckCCRx are not modified in the reception slot. # 21.6.6.3.3 Message buffer update With the start of the next static or dynamic slot or with the start of the symbol window or NIT, the module triggers the slot or segment start transition SSS. This transition changes the state of the receiving receive message buffers from either CCRx to CCSu or from HLckCCRx to HLck, respectively. If a message buffer was in the locked state HLckCCRx, no update will be performed. The received data are lost. This is indicated by setting the Frame Lost Channel A/B Error Flag FRLA\_EF/FRLB\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR). If a message buffer was in the CCRx state it is now in the CCSu state. After the evaluation of the slot status provided by the PE the message buffer is updated. The message buffer update depends on the slot status bits and the segment the message buffer is assigned to. This is described in *Table 348*. vSS!ValidFrame vRF!Header!NFIndicator **Update description** Valid non-null frame received. - Message Buffer Data Field updated. - Frame Header Field updated. - Slot Status Field updated. 1 1 - DUP:= 1 - DVAL:= 1 - MBIF:= 1 Valid null frame received. - Message Buffer Data Field not updated. - Frame Header Field not updated. 0 - Slot Status Field updated. 1 - DUP:= 0 - DVAL not changed - MBIF:= 1 No valid frame received. - Message Buffer Data Field not updated. - Frame Header Field not updated. - Slot Status Field updated. - DUP:= 0 0 - DVAL not changed. - MBIF:= 1, if the slot was not an empty dynamic slot. Note: An empty dynamic slot is indicated by the following frame and slot status bit values: Table 348. Receive message buffer update Note: If the number of the last slot in the current communication cycle on a given channel is n, then all receive message buffers assigned to this channel with MBFIDRn[FID] > n will not be updated at all. vSS!ValidFrame = 0 and vSS!SyntaxError = 0 and vSS!ContentError = 0 and vSS!BViolation = 0. When the receive message buffer update has finished the status updated transition SU is triggered, which changes the buffer state from CCSu to Idle. An example receive message buffer timing and state change diagram for a normal frame reception is given in *Figure 362*. Figure 362. Message reception timing The amount of message data written into the message buffer data field of the receive shadow buffer is determined by the following three items: - 1. the message buffer segment that the message buffer is assigned to, as defined by the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR) - the message buffer data field size, as defined by the related field of the Section 21.5.2.7: Message Buffer Data Size Register (MBDSR) - the number of bytes received over the FlexRay bus If the message buffer is assigned to the message buffer segment 1, and the number of received bytes is greater than 2\*MBDSR.MBSEG1DS, the controller writes only 2\*MBDSR.MBSEG1DS bytes into the message buffer data field of the receive shadow buffer. If the number of received bytes is less than 2\*MBDSR.MBSEG1DS, the controller writes only the received number of bytes and will not change the trailing bytes in the message buffer data field of the receive shadow buffer. The same holds for the message buffer segment 2 with MBDSR.MBSEG2DS. ### 21.6.6.3.4 Received Message Access To access the message data received over the FlexRay bus, the application reads the message data stored in the message buffer data field of the corresponding receive message buffer. The access to the message buffer data field is described in *Section 21.6.3.1: Individual message buffers.* The application can read the message buffer data field if the receive message buffer is one of the states HDis, HDisLck, or HLck. If the message buffer is in one of these states, the controller will not change the content of the message buffer. ### 21.6.6.3.5 Receive Shadow Buffers Concept The receive shadow buffer concept applies only to individual receive message buffers. The intention of this concept is to ensure that only syntactically and semantically valid received non-null frames are presented to the application in a receive message buffer. The basic structure of a receive shadow buffer is described in *Section 21.6.3.2: Receive shadow buffers*. The receive shadow buffers temporarily store the received frame header and message data. After the slot boundary the slot status information is generated. If the slot status information indicates the reception of the valid non-null frame (see *Table 348*), the controller writes the slot status into the slot status field of the receive shadow buffer and exchanges the content of the *Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn)* with the content of the corresponding internal shadow buffer index register. In all other cases, the controller writes the slot status into the identified receive message buffer, depending on the slot status and the FlexRay segment the message buffer is assigned to. The shadow buffer concept, with its index exchange, results in the fact that the FlexRay memory located message buffer associated to an individual receive message buffer changes after successful reception of a valid frame. This means that the message buffer area in the FlexRay memory accessed by the application for reading the received message is different from the initial setting of the message buffer. Therefore, the application must not rely on the index information written initially into the Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn). Instead, the index of the message buffer header field must be fetched from the Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn). # 21.6.6.4 Double transmit message buffer The section provides a detailed description of the functionality of the double transmit message buffers. Double transmit message buffers are used by the application to provide the controller with the message data to be transmitted over the FlexRay Bus. The controller uses this message buffer to provide information to the application about the transmission process, and status information about the slot in which message data was transmitted. In contrast to the single transmit message buffers, the application can provide new transmission data while the transmission of the previously provided message data is running. This scheme is called double buffering and can be considered as a FIFO of depth 2. Double transmit message buffers are implemented by combining two individual message buffers that form the two sides of an double transmit message buffer. One side is called the *commit side* and will be accessed by the application to provide the message data. The other side is called the *transmit side* and is used by the controller to transmit the message data to the FlexRay bus. The two sides are located in adjacent individual message buffers. The message buffer that implements the commit side has an even message buffer number 2n. The transmit side message buffer follows the commit side message buffer and has the message buffer number 2n+1. The basic structure and data flow of a double transmit message buffer is given in *Figure 363*. Figure 363. Double transmit buffer structure and data flow 1110 00011011 211.0.2 Note: Both the commit and the transmit side must be configured with identical values except for the Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn). #### 21.6.6.4.1 Access Regions To certain message buffer fields, both the application and the controller have access. To ensure data consistency, a message buffer locking scheme is implemented, which controls the exclusive access to the data, control, and status bits of the message buffer. The access scheme for double transmit message buffers is shown in *Figure 364*. The given regions represent fields that can be accessed from both the application and the controller and, thus, require access restrictions. A description of the regions is given in *Table 349*. Figure 364. Double transmit message buffer access regions layout Table 349. Double transmit message buffer access regions description | | Access | | | | |--------|--------------|------------|-------------------------------------------------|--| | Pagion | Ту | pe | Description | | | Region | Application | Module | | | | | | | Commit Side | | | CFG | read/write | _ | Message Buffer Configuration | | | MSG | read/write | _ | Message Buffer Data and Control access | | | ITX | _ | read/write | Internal Message Transfer. | | | SS | — write-only | | Slot Status Update | | | | | | Transmit Side | | | CFG | read/write | _ | Message Buffer Configuration | | | SR | _ | read-only | Message Buffer Search | | | TX | _ | read-only | Internal Message Transfer, Message Transmission | | | SS | _ | write-only | Slot Status Update | | The trigger bits MBCCSRn[EDT] and MBCCSRn[LCKT], and the interrupt enable bit MBCCSRn[MBIE] are not under access control and can be accessed from the application at any time. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] are not under access control and can be accessed from the controller at any time. The interrupt flag MBCCSnR.MBIF is not under access control and can be accessed from the application and the controller at any time. controller set access has higher priority. The controller restricts its access to the regions, depending on the current state of the corresponding part of the double transmit message buffer. The application must adhere to these restrictions in order to ensure data consistency. The states for the commit side of a double transmit message buffer are given in *Figure 365*. A description of the states is given in *Table 351*. The states for the transmit side of a double transmit message buffer are given in *Figure 366*. A description of the states is given in *Table 351*. The description tables also provide the access scheme for the access regions. The status bits MBCCSRn[EDS] and MBCCSRn[LCKS] provide the application with the required message buffer status information. The internal status information is not visible to the application. ### 21.6.6.4.2 Message Buffer States This section describes the transmit message buffer states and provides a state diagram. Figure 365. Double transmit message buffer state diagram (commit side) A description of the states of the commit side of a double transmit message buffer is given in *Table 350*. MBCCSR(2n) **Access Region** State Description **EDS LCKS** Module Appl. common states **Disabled** — Message Buffer under configuration. **HDis** n n **CFG** Commit Side can not be used for internal message transfer. Internal Message Transfer — Message Buffer Data transferred **CCITx** 1 0 ITX from commit side to transmit side. commit side specific states ITX, Idle — Message Buffer Commit Side is idle. Idle 1 0 SS Commit Side can be used for internal message transfer. <u>Disabled and Locked</u> — Message Buffer under configuration. SS **HDisLck** 0 1 **CFG** Commit Side can *not* be used for internal message transfer. <u>Locked</u> — Applications access to data, control, and status. MSG SS HLck 1 1 Commit Side can not be used for internal message transfer. Table 350. Double transmit message buffer state description (commit side) Figure 366. Double transmit message buffer state diagram (transmit side) A description of the states of the transmit side of a double transmit message buffer is given in *Table 351*. Table 351. Double transmit message buffer state description (transmit side) | State | MBC | CSRn | Access | Region | Description | | | |---------------|-------------------------------|------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | State | EDS | LCKS | Appl. | Module | Description | | | | Common states | | | | | | | | | HDis | 0 | 0 | CFG | _ | <u>Dis</u> abled — Message Buffer under configuration. Excluded from message buffer search. | | | | CCITx | 1 | 0 | _ | TX | <u>Internal Message Transfer</u> — Message Buffer Data transferred from commit side to transmit side. | | | | Transmit side | Transmit side specific states | | | | | | | | ldle | 1 | 0 | | SR | Idle — Message Buffer Transmit Side is idle. Transmit Side is included in message buffer search. | | | | CCSa | 1 | 0 | _ | _ | Slot Assigned — Message buffer assigned to next static slot. Ready for Null Frame transmission. | | | | CCSaCCITx | 1 | 0 | _ | TX | <u>Slot Assigned and Internal Message Transfer</u> — Message buffer assigned to next static slot and Message Buffer Data transferred from commit side to transmit side. | | | | CCNf | 1 | 0 | | TX | Null Frame Transmission Header is used for null frame transmission. | | | | CCNfCCITx | 1 | 0 | _ | TX | Null Frame Transmission and Internal Message Transfer — Header is used for null frame transmission and Message Buffer Data transferred from commit side to transmit side. | | | | State | MBCCSRn | | Access Region | | Description | | |---------------|---------|------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | State | EDS | LCKS | Appl. | Module | Description | | | CCMa | 1 | 0 | _ | _ | Message Available — Message buffer is assigned to next slot and cycle counter filter matches. | | | CCMaCCIT<br>x | 1 | 0 | _ | _ | Message Available and Internal Message Transfer — Message buffer is assigned to next slot and cycle counter filter matches and Message Buffer Data transferred from commit side to transmit side. | | | CCTx | 1 | 0 | _ | TX | Message <u>Transmission</u> — Message buffer data transmit. Payload data from buffer transmitted | | | CCSu | 1 | 0 | _ | SS | Status Update — Message buffer status update. Update of status flags, the slot status field, and the header index. Note: The slot status field of the commit side is updated too, even if the application has locked the commit side. | | Table 351. Double transmit message buffer state description (transmit side)(Continued) ### 21.6.6.4.3 Message buffer transitions ### 21.6.6.4.3.1 Application transitions The application transitions that can be triggered by the application using the commands described in *Table 352*. The application issues the commands by writing to the *Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn)*. Only one command can be issued with one write access. Each command is executed immediately. If the command is ignored, it must be issued again. Message Buffer Enable and Disable The enable and disable commands can be issued on the transmit side only. Any enable or disable command issued on the commit side will be ignored without notification. The transitions that will be triggered depends on the value of the EDS bit. The enable and disable commands will affect both the commit side and the transmit side at the same time. If the application triggers the disable transition HD while the transmit side is in one of the states CCSa, CCSaCCITx, CCNf, CCNfCCITx, CCMa, CCMaCCITx, CCTx, or CCSu, the disable transition has no effect (command is ignored) and the message buffer state is not changed. No notification is given to the application. Message Buffer Lock and Unlock The lock and unlock commands can be issued on the commit side only. Any lock or unlock command issued on the transmit side will be ignored and the double transmit buffer lock error flag DBL\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) will be set. The transitions that will be triggered depends on the current value of the LCKS bit. The lock and unlock commands will only affect the commit side. If the application triggers the lock transition HL while the commit side is in the state CCITx, the message buffer state will not be changed and the message buffer lock error flag LCK\_EF in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) will be set. | Transition | Host Command | Condition | Description | | | | | | | |------------|-----------------------|-----------------------|----------------------------------------------|--|--|--|--|--|--| | HE | MBCCSR(2n+1)[EDT]:=1 | MBCCSR(2n+1)[EDS] = 0 | Application triggers message buffer enable. | | | | | | | | HD | | MBCCSR(2n+1)[EDS] = 1 | Application triggers message buffer disable. | | | | | | | | HL | MBCCSR(2n)[LCKT]:=1 | MBCCSR(2n)[LCKS] = 0 | Application triggers message buffer lock. | | | | | | | | HU | WIBCCOR(ZII)[LCRT].=1 | MBCCSR(2n)[LCKS] = 1 | Application triggers message buffer unlock. | | | | | | | **Table 352. Double Transmit Message Buffer Host Transitions** # 21.6.6.4.3.2 Module Transitions The module transitions that can be triggered by the controller are described in *Table 353*. The transitions C1 and C2 apply to both sides of the message buffer and are applied at the same time. All other controller transitions apply to the transmit side only. **Table 353. Double Transmit Message Buffer Module Transitions** | | Table 353. Double Transmit Message Burier Module Transitions | | | | | | | |---------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Transition | Condition | Description | | | | | | | common tra | nsitions | | | | | | | | IS | | Internal Message Transfer Start — Start transfer of message data from commit side to transmit side. | | | | | | | IE | see Section 21.6.6.4.5:<br>Internal message transfer | Internal Message Transfer End — Stop transfer of message data from commit side to transmit side. Note: The internal message transfer is stopped before the slot or segment start. | | | | | | | transmit side | e specific transitions | | | | | | | | SA | slot match and<br>static slot | Slot Assigned — Message buffer is assigned to next static slot. | | | | | | | MA | slot match and<br>CycleCounter match | Message Available — Message buffer is assigned to next slot and cycle counter filter matches. | | | | | | | TX | slot start and<br>MBCCSR(2n+1)[CMT]=1 | <u>Iransmission Slot Start</u> — Slot Start and commit bit CMT is set. In case of a dynamic slot, pLatestTx is not exceeded. | | | | | | | SU | status updated | Status Updated — Slot Status field and message buffer status flags updated. Interrupt flag set. | | | | | | | STS | static slot start | Static Slot Start — Start of static slot. | | | | | | | DSS | dynamic slot start or<br>symbol window start or<br>NIT start | <u>D</u> ynamic Slot or <u>S</u> egment <u>S</u> tart — Start of dynamic slot or symbol window or NIT. | | | | | | | SSS | slot start or<br>symbol window start or<br>NIT start | Slot or Segment Start — Start of static slot or dynamic slot or symbol window or NIT. | | | | | | # 21.6.6.4.3.3 Transition Priorities The application can trigger only one transition at a time. There is no need to specify priorities among them. As shown in the first part of *Table 354*, the module transitions have a higher priority than the application transitions. The priorities among the controller transitions and the related states are given in the second part of *Table 354*. These priorities apply only to the transmit side. The internal message transmit start transition IS has tho lowest priority. | | | · | | | | | | |-------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|--|--|--|--| | State | Priority Description | | | | | | | | | Module vs. Application | | | | | | | | Idle | IS > HD Internal Message Transfer Start > Message Buffer Disable IS > HL Internal Message Transfer Start > Message Buffer Lock | | | | | | | | | Module internal | | | | | | | | Idle | MA > SA | Message Available > Slot Assigned | | | | | | | ССМа | TX > STS<br>TX > DSS | Transmission Slot Start > Static Slot Start Transmission Slot Start > Dynamic Slot Start | | | | | | Table 354. Double transmit message buffer transition priorities ### 21.6.6.4.4 Message preparation The application provides the message data through the commit side. The transmission itself is executed from the transmit side. The transfer of the message data from the commit side to the transmit side is done by the *Internal Message Transfer*, which is described in *Section 21.6.6.4.5: Internal message transfer*. To transmit a message over the FlexRay bus, the application writes the message data into the message buffer data field of the commit side and sets the commit bit CMT in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). The physical access to the message buffer data field is described in Section 21.6.3.1: Individual message buffers. As indicated by *Table 350*, the application shall write to the message buffer data field and change the commit bit CMT only if the transmit message buffer is in one of the states HDis, HDisLck, or HLck. The application can change the state of a message buffer if it issues the appropriate commands shown in *Table 352*. The state change is indicated through the MBCCSRn[EDS] and MBCCSRn[LCKS] status bits. #### 21.6.6.4.5 Internal message transfer The internal message transfer transfers the message data from the commit side to the transmit side. The internal message transfer is implemented as the swapping of the content of the *Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn)* of the commit side and the transmit side. After the swapping, the commit side CMT bit is cleared, the commit side interrupt flag MBIF is set, the transmit side CMT bit is set, and the transmit side DVAL bit is cleared. The conditions and the point in time when the internal message transfer is started are controlled by the message buffer commit mode bit MCM in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). The MCM bit configures the message buffer for either the streaming commit mode or the immediate commit mode. A detailed description is given in Section 21.6.6.4.5.1: Streaming commit mode and Section 21.6.6.4.5.2: Immediate commit mode. The Internal Message Transfer is triggered with the transition IS. Both sides of the message buffer enter one of the CCITx states. The internal message transfer is finished with the transition IE. # 21.6.6.4.5.1 Streaming commit mode The intention of the streaming commit mode is to ensure that each committed message is transmitted *at least once*. The controller will not start the Internal Message Transfer for a message buffer as long as the message data on the transmit side is not transmitted at least once. The streaming commit mode is configured by clearing the message buffer commit mode bit MCM in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). In this mode, the internal message transfer from the commit side to the transmit side is started for a double transmit message buffer when all of the following conditions are fulfilled: - the commit side is in the Idle state - the commit site message data are valid, i.e., MBCCSR(2n)[CMT] = 1 - the transmit side is in one of the states Idle, CCSa, or CCMa - the transmit side contains either no valid message data, i.e., MBCCSR(2n + 1)[CMT] = 0 or the message data were transmitted at least once, i.e., MBCCSR(2n + 1)[DVAL] = 1 An example of a streaming commit mode state change diagram is given in *Figure 367*. In this example, both the commit and the transmit side do not contain valid message data and the application provides two messages. The message buffer does not match the next slot. Figure 367. Internal message transfer in streaming commit mode # 21.6.6.4.5.2 Immediate commit mode The intention of the immediate commit mode is to transmit the *latest* data provided by the application. This implies that it is not guaranteed that each provided message will be transmitted at least once. The immediate commit mode is configured by setting the message buffer commit mode bit MCM in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn). In this mode, the internal message transfer from the commit side to the transmit side is started for one double transmit message buffer when all of the following conditions are fulfilled: - 1. The commit side is in the Idle state - the commit site message data are valid, i.e., MBCCSR(2n)[CMT] = 1 - the transmit side is in one of the states Idle, CCSa, or CCMa It is not checked whether the transmit side contains no valid message data or valid message data were transmitted at least once. If message data are valid and not transmitted, they may be overwritten. An example of a streaming commit mode state change diagram is given in *Figure 368*. In this example, both the commit and the transmit side do not contain valid message data, and the application provides two messages and the first message is gets overwritten. The message buffer does not match the next slot. Figure 368. Internal message transfer in immediate commit mode ### 21.6.6.4.6 Message transmission For double transmit message buffers, the message buffer search checks only the transmit side part. The internal scheduling ensures that the internal message transfer is stopped on the message buffer search start. Thus, the transmit side of message buffer, that is not in its transmission or status update slot, is always in the Idle state. The message transmit behavior and transmission state changes of the transmit side of a double transmit message buffer are the same as for single buffered transmit buffers, except that the transmit side of double buffers cannot be locked by the application, i.e., the HU and HL transition do not exist. Therefore, refer to Section 21.6.6.2.5: Message transmission. ### 21.6.6.4.7 Message buffer status update The message buffer status update behavior of the transmit side of a double transmit message buffer is the same as for single transmit message buffers which is described in *Section 21.6.6.2.7: Message buffer status update.* Additionally, the slot status field of the commit side is update after the update of the slot status field of the transmit side, even if the commit side is locked by the application. This is implemented to provide the slot status of the most recent transmission slot. # 21.6.7 Individual message buffer search This section provides a detailed description of the message buffer search algorithm. The message buffer search determines for each enabled channel if a slot *s* in a communication cycle *c* is assigned for frame or null frame transmission or if it is subscribed for frame reception on that channel. The message buffer search is a sequential algorithm which is invoked at the following protocol related events: #### 1. NIT start - slot start in the static segment - minislot start in the dynamic segment The message buffer search within the NIT searches for message buffers assigned or subscribed to slot 1. The message buffer search within slot n searches for message buffers assigned or subscribed to slot n+1. In general, the message buffer search for the next slot n considers only message buffers that are - 1. Enabled, i.e., MBCCSRn[EDS] = 1, and - Matches the next slot n, i.e., MBFIDRn[FID] = n, and - Are the transmit side buffer in case of a double transmit message buffer. On top of that, for the static segment only those message buffers are considered, that match the condition of at least one row of *Table 355*. For the dynamic segment only those message buffers are considered, that match the condition of at least one row of *Table 356*. These message buffers are called *matching* message buffers. For each enabled channel the message buffer search may identify multiple *matching* message buffers. Among all matching message buffers the message buffers with highest priority according to *Table 355* for the static segment and according to *Table 356* for the dynamic segment are selected. Table 355. Message buffer search priority (static segment) | Priority | MTD | LCKS | СМТ | CCFM (1) | Description | Transition | |----------------|-----|------|-----|----------|----------------------------------------------------------------|------------| | (highest)<br>0 | 1 | 0 | 1 | 1 | transmit buffer, matches cycle count, not locked and committed | MA | | | 1 | _ | 0 | 1 | transmit buffer, matches cycle count, not committed | SA | | 1 | 1 | 1 | _ | 1 | transmit buffer, matches cycle count, locked | SA | | 2 | 1 | _ | _ | _ | transmit buffer | SA | | 3 | 0 | 0 | n/a | 1 | receive buffer, matches cycle count, not locked | SB | | (lowest) 4 | 0 | 1 | n/a | 1 | receive buffer, matches cycle count, locked | SB | <sup>1.</sup> Cycle Counter Filter Match, see Section 21.6.7.1: Message buffer cycle counter filtering. Table 356. Message buffer search priority (dynamic segment) | Priority | MTD | LCKS | СМТ | CCFM (1) | Description | Transition | |-------------|-----|------|-----|----------|----------------------------------------------------------------|------------| | (highest) 0 | 1 | 0 | 1 | 1 | transmit buffer, matches cycle count, not locked and committed | MA | | 1 | 0 | 0 | n/a | 1 | receive buffer, matches cycle count, not locked | SB | | (lowest) 2 | 0 | 1 | n/a | 1 | receive buffer, matches cycle count, locked | SB | <sup>1.</sup> Cycle Counter Filter Match, see Section 21.6.7.1: Message buffer cycle counter filtering. If there are multiple message buffer with highest priority, the message buffer with the lowest message buffer number is selected. All message buffer which have the highest priority must have a consistent channel assignment as specified in Section 21.6.7.2: Message buffer channel assignment consistency. Depending on the message buffer channel assignment the same message buffer can be found for both channel A and channel B. In this case, this message buffer is used as described in *Section 21.6.3.1: Individual message buffers*. ### 21.6.7.1 Message buffer cycle counter filtering The message buffer cycle counter filter is a value-mask filter defined by the CCFE, CCFMSK, and CCFVAL fields in the *Section 21.5.2.66: Message Buffer Cycle Counter Filter Registers (MBCCFRn)*. This filter determines a set of communication cycles in which the message buffer is considered for message reception or message transmission. If the cycle counter filter is disabled, i.e., CCFE = 0, this set of cycles consists of all communication cycles. If the cycle counter filter of a message buffer does not match a certain communication cycle number, this message buffer is not considered for message transmission or reception in that communication cycle. In case of a transmit message buffer assigned to a slot in the static segment, though, this buffer is added to the matching message buffers to indicate the slot assignment and to trigger the null frame transmission. The cycle counter filter of a message buffer matches the communication cycle with the number CYCCNT if at least one of the following conditions evaluates to true: **Equation 29** MBCCFRn[CCFE] = 0 #### **Equation 30** CYCCNT & MBCCFRn[CCFMSK] = MBCCFRn[CCFVAL] & MBCCFRn[CCFMSK] # 21.6.7.2 Message buffer channel assignment consistency The message buffer channel assignment given by the CHA and CHB bits in the Section 21.5.2.66: Message Buffer Cycle Counter Filter Registers (MBCCFRn) defines the channels on which the message buffer will receive or transmit. The message buffer with number n transmits or receives on channel A if MBCCFRn[CHA] = 1 and transmits or receives on channel B if MBCCFRn[CHB] = 1. To ensure correct message buffer operation, all message buffers assigned to the same slot and with the same priority must have a *consistent* channel assignment. That means they must be either assigned to one channel only, or must be assigned to *both* channels. The behavior of the message buffer search is not defined, if both types of channel assignments occur for one slot and priority. An inconsistent channel assignment for message buffer 0 and message buffer 1 is shown in *Figure 369*. Figure 369. Inconsistent channel assignment # 21.6.7.3 Node related slot multiplexing The term *Node Related Slot Multiplexing* applies to the dynamic segment only and refers to the functionality if there are transmit as well as receive message buffers are configured for the same slot. According to *Table 356* the transmit buffer is only found if the cycle counter filter matches, and the buffer is not locked and committed. In all other cases, the receive buffer will be found. Thus, if the block has no data to transmit in a dynamic slot, it is able to receive frames on that slot. ### 21.6.7.4 Message buffer search error If the message buffer search is running while the next message buffer search start event appears, the message buffer search is stopped and the Message Buffer Search Error Flag MSB\_EF is set in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR). This appears only if the CHI frequency is too low to search through all message buffers within the NIT or a minislot. The message buffer result is not defined in this case. For more details see Section 21.7.3: Number of usable message buffers. # 21.6.8 Individual message buffer reconfiguration The initial configuration of each individual message buffer can be changed even when the protocol is not in the *POC:config* state. This is referred to as individual message buffer *reconfiguration*. The configuration bits and fields that can be changed are given in the section on *Section 21.6.3.4.1.2: Specific configuration data*. The common configuration data given in the section on *Section 21.6.3.4.1.2: Specific configuration data* cannot be reconfigured when the protocol is out of the *POC:config* state. ### 21.6.8.1 Reconfiguration schemes Depending on the target and destination basic state of the message buffer that is to be reconfigured, there are three reconfiguration schemes. # 21.6.8.1.1 Basic type not changed (RC1) A reconfiguration will not change the basic type of the individual message buffer, if both the message buffer transfer direction bit MBCCSn[MTD] and the message buffer type bit MBCCSn[MBT] are not changed. This type of reconfiguration is denoted by RC1 in *Figure 370*. Single transmit and receive message buffers can be RC1-reconfigured when in the HDis or HDisLck state. Double transmit message buffers can be RC1-reconfigured if both the transmit side and the commit side are in the HDis state. ### 21.6.8.1.2 Buffer type not changed (RC2) A reconfiguration will not change the buffer type of the individual message buffer if the message buffer type bit MBCCSRn[MBT] is not changed. This type of reconfiguration is denoted by RC2 in *Figure 370*. It applies only to single transmit and receive message buffers. Single transmit and receive message buffers can be RC2-reconfigured when in the HDis or HDisLck state. ### 21.6.8.1.3 Buffer type changed (RC3) A reconfiguration will change the buffer type of the individual message buffer if the message buffer type bit MBCCSRn[MBT] is changed. This type of reconfiguration is denoted by RC3 in *Figure 370*. The RC3 reconfiguration splits one double buffer into two single buffers or combines two single buffer into one double buffer. In the later case, the two single message buffers must have consecutive message buffer numbers and the smaller one must be even. Message Buffers can be RC3 reconfigured if they are in the HDis state. RC1 single RX RC2 single TX RC1 RC3 double TX (commit side) double TX (transmit side) RC1 RC1 Figure 370. Message buffer reconfiguration scheme ### 21.6.9 Receive FIFO This section provides a detailed description of the two receive FIFOs. #### 21.6.9.1 Overview The receive FIFOs implement the queued receive buffer defined by the *FlexRay Communications System Protocol Specification, Version 2.1 Rev A.* One receive FIFO is assigned to channel A, the other receive FIFO is assigned to channel B. Both FIFOs work completely independent from each other. The message buffer structure of each FIFO is described in Section 21.6.3.3: Receive FIFO. The area in the FlexRay memory for each of the two receive FIFOs is characterized by: - The index of the first FIFO entry given by Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR) - The number of FIFO entries and the length of each FIFO entry as given by Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR) # 21.6.9.2 Receive FIFO configuration The receive FIFO control and configuration data are given in Section 21.6.3.7: Receive FIFO control and configuration data. The configuration of the receive FIFOs consists of two steps. The first step is the allocation of the required amount of FlexRay memory for the FlexRay window. This includes the allocation of the message buffer header area and the allocation of the message buffer data fields. For more details see *Section 21.6.4: FlexRay memory layout*. The second step is the programming of the configuration data register while the PE is in *POC:config.* The following steps configure the layout of the FIFO. - The number of the first message buffer header index that belongs to the FIFO is written into the Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR). - The depth of the FIFO is written into the FIFO\_DEPTH field in the Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR). - The length of the message buffer data field for the FIFO is written into the ENTRY\_SIZE field in the Section 21.5.2.53: Receive FIFO Depth and Size Register (RFDSR). Note: To ensure that the read index RDIDX always points to a message buffer that contains valid data, the receive FIFO must have at least two entries. The FIFO filters are configured through the FIFO filter registers. # 21.6.9.3 Receive FIFO reception The frame reception to the receive FIFO is enabled if, for a certain slot, no message buffer is assigned or subscribed. In this case the FIFO filter path shown in *Figure 371* is activated. When the receive FIFO filter path indicates that the received frame must be appended to the FIFO, the controller writes the received frame header and slot status into the message buffer header field indicated by the internal FIFO header write index. The payload data are written in the message buffer data field. If the status of the received frame indicates a valid frame, the internal FIFO header write index is updated and the FIFO not-empty interrupt flag FNEAIF/FNEBIF in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER) is set. # 21.6.9.4 Receive FIFO message access If the FIFO not-empty interrupt flag FNEAIF/FNEBIF in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER) is set, the receive FIFO contains valid received messages, which can be accessed by the application. The receive FIFO does not require locking to access the message buffers. To access the message the application first reads the receive FIFO read index RDIDX from the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) or Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR), respectively. This index points to the message buffer header field of the next message buffer that contains valid data. The application can access the message data as described in Section 21.6.3.3: Receive FIFO. When the application has read all message buffer data and status information, it writes 1 to the FIFO not-empty interrupt flags FNEAIF or FNEBIF. This clears the interrupt flag and updates the RDIDX field in the Section 21.5.2.54: Receive FIFO A Read Index Register (RFARIR) or Section 21.5.2.55: Receive FIFO B Read Index Register (RFBRIR), respectively. When the RDIDX value has reached the last message buffer header field that belongs to the FIFO, it wraps around to the index of the first message buffer header field that belongs to the FIFO. This value is provided by the SIDX field in the Section 21.5.2.52: Receive FIFO Start Index Register (RFSIR). # 21.6.9.5 Receive FIFO filtering The receive FIFO filtering is activated after all enabled individual receive message buffers have been searched without success for a message buffer to receive the current frame. The controller provides three sets of FIFO filters. The FIFO filters are applied to valid non-null frames only. The FIFO will not receive invalid or null-frames. For each FIFO filter, the pass criteria is specified in the related section given below. Only frames that have passed all filters will be appended to the FIFO. The FIFO filter path is shown in *Figure 371*. Figure 371. Received frame FIFO filter path A received frame passes the FIFO filtering if it has passed all three types of filter. ### 21.6.9.5.1 RX FIFO frame ID value-mask rejection filter The frame ID value-mask rejection filter is a value-mask filter and is defined by the fields in the Section 21.5.2.58: Receive FIFO Frame ID Rejection Filter Value Register (RFFIDRFVR) and the Section 21.5.2.59: Receive FIFO Frame ID Rejection Filter Mask Register (RFFIDRFMR). Each received frame with a frame ID FID that does not match the value-mask filter value passes the filter, i.e., is not rejected. Consequently, a received valid frame with the frame ID FID passes the RX FIFO Frame ID Value-Mask Rejection Filter if *Equation 31* is fulfilled. #### **Equation 31** FID & RFFIDRFMR[FIDRFMSK] # RFFIDRFVR[FIDRFVAL] & RFFIDRFMR[FIDRFMSK] The RX FIFO Frame ID Value-Mask Rejection Filter can be configured to pass all frames by the following settings. • RFFIDRFVR[FIDRFVAL] := 0x000 and RFFIDRFMR[FIDRFMSK] := 0x7FF Using the settings above, only the frame with frame ID 0 will be rejected, which is an invalid frame. All other frames will pass. The RX FIFO Frame ID Value-Mask Rejection Filter can be configured to reject all frames by the following settings. RFFIDRFMR[FIDRFMSK] := 0x000 Using the settings above, *Equation 31* can never be fulfilled (0!= 0) and thus all frames are rejected; no frame will pass. This is the reset value for the RX FIFO. ### 21.6.9.5.2 RX FIFO frame ID range rejection filter Each of the four RX FIFO Frame ID Range filters can be configured as a rejection filter. The filters are configured by the *Section 21.5.2.60: Receive FIFO Range Filter Configuration Register (RFRFCFR)* and controlled by the *Section 21.5.2.61: Receive FIFO Range Filter Control Register (RFRFCTR)*. The RX FIFO Frame ID range filters apply to all received valid frames. A received frame with the frame ID FID passes the RX FIFO Frame ID Range rejection filters if either no rejection filter is enabled, or, for all of the enabled RX FIFO Frame ID Range rejection filters, i.e., RFRFCTR.FiMD = 1 and RFRFCTR.FiEN = 1, Equation 32 is fulfilled. # **Equation 32** $$(FID < RFRFCFR_{SFI}[SID_{IBD=0}])$$ or $(RFRFCFR_{SFI}[SID_{IBD=1}] < FID)$ Consequently, all frames with a frame ID that fulfills *Equation 33* for at least one of the enabled rejection filters will be rejected and thus not pass. #### **Equation 33** $$RFRFCFR_{SEL}[SID_{IBD=0}] \le FID \le RFRFCFR_{SEL}[SID_{IBD=1}]$$ # 21.6.9.5.3 RX FIFO frame ID range acceptance filter Each of the four RX FIFO Frame ID Range filters can be configured as an acceptance filter. The filters are configured by the *Section 21.5.2.60: Receive FIFO Range Filter Configuration Register (RFRFCFR)* and controlled by the *Section 21.5.2.61: Receive FIFO Range Filter Control Register (RFRFCTR)*. The RX FIFO Frame ID range filters apply to all received valid frames. A received frame with the frame ID FID passes the RX FIFO Frame ID Range acceptance filters if either no acceptance filter is enabled, or, for at least one of the enabled RX FIFO Frame ID Range acceptance filters, i.e., RFRFCTR.FiMD = 0 and RFRFCTR.FiEN = 1, *Equation 34* is fulfilled. #### **Equation 34** $$RFRFCFR_{SEL}[SID_{IBD} = 0] \le FID \le RFRFCFR_{SEL}[SID_{IBD} = 1]$$ ### 21.6.9.5.4 RX FIFO message ID acceptance filter The RX FIFO Message ID Acceptance Filter is a value-mask filter and is defined by the Section 21.5.2.56: Receive FIFO Message ID Acceptance Filter Value Register (RFMIDAFVR) and the Section 21.5.2.57: Receive FIFO Message ID Acceptance Filter Mask Register (RFMIAFMR). This filter applies only to valid frames received in the dynamic segment with the payload preamble indicator bit PPI set to 1. All other frames will pass this filter. A received valid frame in the dynamic segment with the payload preamble indicator bit PPI set to 1 and with the message ID MID (the first two bytes of the payload) will pass the RX FIFO Message ID Acceptance Filter if *Equation 35* is fulfilled. ### **Equation 35** MID & RFMIDAFMR[MIDAFMSK] = = RFMIDAFMR[MIDAFVAL] & RFMIDAFMR[MIDAFMSK] The RX FIFO Message ID Acceptance Filter can be configured to accept all frames by setting RFMIDAFMR[MIDAFMSK] := 0x000 Using the settings above, *Equation 35* is always fulfilled and all frames will pass. ### 21.6.10 Channel device modes This section describes the two FlexRay channel device modes that are supported by the controller. #### 21.6.10.1 Dual channel device mode In the dual channel device mode, both FlexRay ports are connected to physical FlexRay bus lines. The FlexRay port consisting of FR\_A\_RX, FR\_A\_TX, and <Overbar>FR\_A\_TX\_EN is connected to the physical bus channel A and the FlexRay port consisting of FR\_B\_RX, FR\_B\_TX, and <Overbar>FR\_B\_TX\_EN is connected to the physical bus channel B. The dual channel system is shown in *Figure 372*. Figure 372. Dual channel device mode ### 21.6.10.2 Single channel device mode The single channel device mode supports devices that have only one FlexRay port available. This FlexRay port consists of the signals FR\_A\_RX, FR\_A\_TX, and <Overbar>FR\_A\_TX\_EN and can be connected to either the physical bus channel A (shown in *Figure 373*) or the physical bus channel B (shown in *Figure 374*). If the device is configured as a single channel device by setting MCR.SCD to 1, only the internal channel A and the FlexRay Port A is used. Depending on the setting of MCR.CHA and MCR.CHB, the internal channel A behaves either as a FlexRay Channel A or FlexRay Channel B. The bit MCR.CHA must be set, if the FlexRay Port A is connected to a FlexRay Channel A. The bit MCR.CHB must be set if the FlexRay Port A is connected to a FlexRay Channel B. The two FlexRay channels differ only in the initial value for the frame CRC *cCrcInit*. For a single channel device, the application can access and configure only the registers related to internal channel A. Figure 373. Single channel device mode (Channel A) Figure 374. Single channel device mode (Channel B) # 21.6.11 External clock synchronization The application of the external rate and offset correction is triggered when the application writes to the EOC\_AP and ERC\_AP fields in the Section 21.5.2.9: Protocol Operation Control Register (POCR). The PE applies the external correction values in the next even-odd cycle pair as shown in Figure 375 and Figure 376. Note: The values provided in the EOC\_AP and ERC\_AP fields are the values that were written from the application most recently. If these value were already applied, they will not be applied in the current cycle pair again. If the offset correction applied in the NIT of cycle 2n+1 shall be affect by the external offset correction, the EOC\_AP field must be written to after the start of cycle 2n and before the end of the static segment of cycle 2n+1. If this field is written to after the end of the static segment of cycle 2n+1, it is not guaranteed that the external correction value is applied in cycle 2n+1. If the value is not applied in cycle 2n+1, then the value will be applied in the cycle 2n+3. Refer to *Figure 375* for timing details. Figure 375. External offset correction write and application timing If the rate correction for the cycle pair [2n+2, 2n+3] shall be affected by the external offset correction, the ERC\_AP field must be written to after the start of cycle 2n and before the end of the static segment start of cycle 2n+1. If this field is written to after the end of the static segment of cycle 2n+1, it is not guaranteed that the external correction value is applied in cycle pair [2n+2, 2n+3]. If the value is not applied for cycle pair [2n+2, 2n+3], then the value will be applied for cycle pair [2n+4, 2n+5]. Refer to *Figure 376* for details. Figure 376. External rate correction write and application timing # 21.6.12 Sync frame ID and sync frame deviation tables The FlexRay protocol requires the provision of a snapshot of the Synchronization Frame ID tables for the even and odd communication cycle for both channels. The controller provides the means to write a copy of these internal tables into the FlexRay memory and ensures application access to consistent tables by means of table locking. Once the application has locked the table successfully, the controller will not overwrite these tables and the application can read a consistent snapshot. Note: Only synchronization frames that have passed the synchronization frame filters are considered for clock synchronization and appear in the sync frame tables. ### 21.6.12.1 Sync frame ID table content The Sync Frame ID Table is a snapshot of the protocol related variables *vsSyncldListA* and *vsSyncldListB* for each even and odd communication cycle. This table provides a list of the frame IDs of the synchronization frames received on the corresponding channel and cycle that are used for the clock synchronization. #### 21.6.12.2 Sync frame deviation table content The Sync Frame Deviation Table is a snapshot of the protocol related variable zsDev(id)(oe)(ch)!Value. Each Sync Frame Deviation Table entry provides the deviation value for the sync frame, with the frame ID presented in the corresponding entry in the Sync Frame ID Table. Figure 377. Sync table memory layout #### 21.6.12.3 Sync frame ID and sync frame deviation table setup The controller writes a copy of the internal synchronization frame ID and deviation tables into the FlexRay memory if requested by the application. The application must provide the appropriate amount of FlexRay memory for the tables. The memory layout of the tables is given in *Figure 377*. Each table occupies 120 16-bit entries. While the protocol is in *POC:config* state, the application must program the offsets for the tables into the *Section 21.5.2.32: Sync Frame Table Offset Register (SFTOR)*. ### 21.6.12.4 Sync frame ID and sync frame deviation table generation The application controls the generation process of the Sync Frame ID and Sync Frame Deviation Tables into the FlexRay memory using the *Section 21.5.2.33: Sync Frame Table Configuration, Control, Status Register (SFTCCSR)*. A summary of the copy modes is given in *Table 357*. **SFTCCSR** Description **OPT SDVEN SIDEN** 0 0 0 No Sync Frame Table copy 0 0 1 Sync Frame ID Tables will be copied continuously 0 1 0 Reserved 0 1 1 Sync Frame ID Tables and Sync Frame Deviation Tables will be copied continuously 1 0 0 No Sync Frame Table copy 1 0 1 Sync Frame ID Tables for next even-odd-cycle pair will be copied 1 0 0 Reserved Sync Frame ID Tables and Sync Frame Deviation Tables for next even-odd-cycle 1 1 1 pair will be copied Table 357. Sync frame table generation modes The Sync Frame Table generation process is described in the following for the even cycle. The same sequence applies to the odd cycle. If the application has enabled the sync frame table generation by setting SFTCCSR.SIDEN to 1, the controller starts the update of the even cycle related tables after the start of the NIT of the next even cycle. The controller checks if the application has locked the tables by reading the SFTCCSR.ELKS lock status bit. If this bit is set, the controller will not update the table in this cycle. If this bit is cleared, the controller locks this table and starts the table update. To indicate that these tables are currently updated and may contain inconsistent data, the controller clears the even table valid status bit SFTCCSR[EVAL]. Once all table entries related to the even cycle have been transferred into the FlexRay memory, the controller sets the even table valid bit SFTCCSR[EVAL] and the Even Cycle Table Written Interrupt Flag EVT\_IF in the Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1). If the interrupt enable flag EVT\_IE is set, an interrupt request is generated. To read the generated tables, the application must lock the tables to prevent the controller from updating these tables. The locking is initiated by writing a 1 to the even table lock trigger SFTCCSR.ELKT. When the even table is not currently updated by the controller, the lock is granted and the even table lock status bit SFTCCSR.ELKS is set. This indicates that the application has successfully locked the even sync tables and the corresponding status information fields SFRA, SFRB in the *Sync Frame Counter Register (SFCNTR)*. The value in the SFTCCSR.CYCNUM field provides the number of the cycle that this table is related to The number of available table entries per channel is provided in the SFCNTR.SFEVA and SFCNTR.SFEVB fields. The application can now start to read the sync table data from the locations given in *Figure 377*. After reading all the data from the locked tables, the application must unlock the table by writing to the even table lock trigger SFTCCSR.ELKT again. The even table lock status bit SFTCCSR.ELKS is reset immediately. If the sync frame table generation is disabled, the table valid bits SFTCCSR[EVAL] and SFTCCSR[EVAL] are reset when the counter values in the *Sync Frame Counter Register* (*SFCNTR*) are updated. This is done because the tables stored in the FlexRay memory are no longer related to the values in the *Sync Frame Counter Register* (*SFCNTR*). Figure 378. Sync frame table trigger and generation timing ### 21.6.12.5 Sync Frame Table Access The sync frame tables will be transferred into the FlexRay memory during the table write windows shown in *Figure 378*. During the table write, the application cannot lock the table that is currently written. If the application locks the table outside of the table write window, the lock is granted immediately. ### 21.6.12.5.1 Sync frame table locking and unlocking The application locks the even/odd sync frame table by writing 1 to the lock trigger bit ELKT/OLKT in the Section 21.5.2.33: Sync Frame Table Configuration, Control, Status Register (SFTCCSR). If the affected table is not currently written to the FlexRay memory, the lock is granted immediately, and the lock status bit ELKS/OLKS is set. If the affected table is currently written to the FlexRay memory, the lock is not granted. In this case, the application must issue the lock request again until the lock is granted. The application unlocks the even/odd sync frame table by writing 1 to the lock trigger bit ELKT/OLKT. The lock status bit ELKS/OLKS is cleared immediately. # 21.6.13 MTS generation The controller provides a flexible means to request the transmission of the Media Access Test Symbol MTS in the symbol window on channel A or channel B. The application can configure the set of communication cycles in which the MTS will be transmitted over the FlexRay bus by programming the CYCCNTMSK and CYCCNTVAL fields in the Section 21.5.2.48: MTS A Configuration Register (MTSACFR) and Section 21.5.2.49: MTS B Configuration Register (MTSBCFR). The application enables or disables the generation of the MTS on either channel by setting or clearing the MTE control bit in the *Section 21.5.2.48: MTS A Configuration Register (MTSACFR)* or *Section 21.5.2.49: MTS B Configuration Register (MTSBCFR)*. If an MTS is to be transmitted in a certain communication cycle, the application must set the MTE control bit during the static segment of the preceding communication cycle. The MTS is transmitted over channel A in the communication cycle with number CYCCNT, if *Equation 36*, *Equation 37*, and *Equation 38* are fulfilled. ### **Equation 36** PSR0[PROTSTATE] = POC:normal active #### **Equation 37** MTSACRF[MTE] = 1 #### **Equation 38** CYCCNT & MTSACFR[CYCCNTMSK] = = MTSACFR[CYCCNTVAL] & MTSACFR[CYCCNTMSK] The MTS is transmitted over channel B in the communication cycle with number CYCCNT, if *Equation 36*, *Equation 39*, and *Equation 40* are fulfilled. **Equation 39** MTSBCRF[MTE] = 1 #### **Equation 40** CYCCNT & MTSBCFR[CYCCNTMSK] = = MTSBCFR[CYCCNTVAL] & MTSBCFR[CYCCNTMSK] # 21.6.14 Key slot transmission ### 21.6.14.1 Key slot assignment A key slot is assigned to the controller if the key\_slot\_id field in the Section 21.5.2.64.19: Protocol Configuration Register 18 (PCR18) is configured with a value greater than 0 and less or equal to number\_of\_static\_slots in Section 21.5.2.64.3: Protocol Configuration Register 2 (PCR2), otherwise no key slot is assigned. ### 21.6.14.2 Key slot transmission in *POC:startup* If a key slot is assigned and the controller is in the *POC:startup* state, startup null frames will be transmitted as specified by *FlexRay Communications System Protocol Specification, Version 2.1 Rev A*. # 21.6.14.3 Key slot transmission in POC:normal active If a key slot is assigned and the controller is in *POC:normal active*, a frame of the type as shown in *Table 358* is transmitted. If a transmit message buffer is configured for the key slot and a valid message is available, a message frame is transmitted (see *Section 21.6.6.2.5: Message transmission*). If no transmit message buffer is configured for the key slot or no valid message is available, a null frame is transmitted (see *Section 21.6.6.2.6: Null frame transmission*). | PCR11[key_slot_used_for_sync] | PCR11[key_slot_used_for_startup | Key slot frame type | |-------------------------------|---------------------------------|-----------------------------| | 0 | 0 | normal frame | | 0 | 1 | normal frame <sup>(1)</sup> | | 1 | 0 | sync frame | | 1 | 1 | startup frame | Table 358. Key slot frame type # 21.6.15 Sync frame filtering Each received synchronization frame must pass the Sync Frame Acceptance Filter and the Sync Frame Rejection Filter before it is considered for clock synchronization. If the synchronization frame filtering is globally disabled, i.e., the SFFE control bit in the Section 21.5.2.4: Module Configuration Register (MCR) is cleared, all received synchronization frames are considered for clock synchronization. If a received synchronization frame did not pass at least one of the two filters, this frame is processed as a normal frame and is not considered for clock synchronization. # 21.6.15.1 Sync frame acceptance filtering The synchronization frame acceptance filter is implemented as a value-mask filter. The value is configured in the Section 21.5.2.35: Sync Frame ID Acceptance Filter Value Register (SFIDAFVR) and the mask is configured in the Section 21.5.2.36: Sync Frame ID Acceptance Filter Mask Register (SFIDAFMR). A received synchronization frame with the frame ID FID passes the sync frame acceptance filter, if Equation 41 or Equation 42 evaluates to true. Equation 41 MCR[SFFE] = 0 **Equation 42** FID & SFIDAFMR[FMSK] = SFIDAFVR[FVAL] & SFIDAFMR[FMSK] Note: Sync frames are transmitted in the static segment only. Thus FID <= 1023. ### 21.6.15.2 Sync frame rejection filtering The synchronization frame rejection filter is a comparator. The compare value is defined by the Section 21.5.2.34: Sync Frame ID Rejection Filter Register (SFIDRFR). A received synchronization frame with the frame ID FID passes the sync frame rejection filter if Equation 43 or Equation 44 evaluates to true. **Equation 43** MCR[SFFE] = 0 **Equation 44** FID ≠ SFIDRFR[SYNFRID] Note: Sync frames are transmitted in the static segment only. Thus FID <= 1023. # 21.6.16 Strobe signal support The controller provides a number of strobe signals for observing internal protocol timing related signals in the protocol engine. The signals are listed and described in *Table 258*. <sup>1.</sup> The frame transmitted has an semantically incorrect header and will be detected as an invalid frame at the receiver. # 21.6.16.1 Strobe signal assignment Each of the strobe signals listed in *Table 258* can be assigned to one of the four strobe ports using the *Section 21.5.2.6: Strobe Signal Control Register (STBSCR)*. To assign multiple strobe signals, the application must write multiple times to the *Section 21.5.2.6: Strobe Signal Control Register (STBSCR)* with appropriate settings. To read out the current settings for a strobe signal with number N, the application must execute the following sequence: - 1. Write to STBSCR with WMD = 1 and SEL = N. (updates SEL field only) - Read STBCSR. The SEL field provides N and the ENB and STBPSEL fields provides the settings for signal N. ### 21.6.16.2 Strobe signal timing This section provides detailed timing information of the strobe signals with respect to the protocol engine clock. The strobe signals display internal PE signals. Due to the internal architecture of the PE, some signals are generated several PE clock cycles before the actual action is performed on the FlexRay Bus. These signals are listed in *Table 258* with a negative clock offset. An example waveform is given in *Figure 379*. Other signals refer to events that occurred on the FlexRay Bus some cycles before the strobe signal is changed. These signals are listed in *Table 258* with a positive clock offset. An example waveform is given in *Figure 380*. Figure 380. Strobe signal timing (type = pulse, clk offset = +4) ### 21.6.17 Timer support The controller provides two timers, which run on the FlexRay time base. Each timer generates a maskable interrupt when it reaches a configured point in time. Timer T1 is an absolute timer. Timer T2 can be configured to be an absolute or a relative timer. Both timers can be configured to be repetitive. In the non-repetitive mode, timer stops if it expires. In repetitive mode, timer is restarted when it expires. Both timers are active only when the protocol is in *POC:normal active* or *POC:normal passive* state. If the protocol is not in one of these modes, the timers are stopped. The application must restart the timers when the protocol has reached the *POC:normal active* or *POC:normal passive* state. #### 21.6.17.1 Absolute timer T1 The absolute timer T1 has the protocol cycle count and the macrotick count as the time base. The timer 1 interrupt flag TI1\_IF in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) is set at the macrotick start event, if and Equation 46 are fulfilled #### **Equation 45** CYCTR[CTCCNT] & TI1CYSR[T1\_CYC\_MSK] = = TI1CYSR[T1\_CYC\_VAL] & TI1CYSR[T1\_CYC\_MSK] #### **Equation 46** MTCTR[MTCT] = TI1MTOR[T1\_MTOFFSET] If the timer 1 interrupt enable bit TI1\_IE in the Section 21.5.2.13: Protocol Interrupt Enable Register 0 (PIER0) is asserted, an interrupt request is generated. The status bit T1ST is set when the timer is triggered, and is cleared when the timer expires and is non-repetitive. If the timer expires but is repetitive, the T1ST bit is not cleared and the timer is restarted immediately. The T1ST is cleared when the timer is stopped. #### 21.6.17.2 Absolute / relative timer T2 The timer T2 can be configured to be an absolute or relative timer by setting the T2\_CFG control bit in the Section 21.5.2.39: Timer Configuration and Control Register (TICCR). The status bit T2ST is set when the timer is triggered, and is cleared when the timer expires and is non-repetitive. If the timer expires but is repetitive, the T2ST bit is not cleared and the timer is restarted immediately. The T2ST is cleared when the timer is stopped. ## 21.6.17.2.1 Absolute timer T2 If timer T2 is configured as an absolute timer, it has the same functionality timer T1 but the configuration from Section 21.5.2.42: Timer 2 Configuration Register 0 (TI2CR0) and Section 21.5.2.43: Timer 2 Configuration Register 1 (TI2CR1) is used. On expiration of timer T2, the interrupt flag TI2\_IF in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) is set. If the timer 1 interrupt enable bit TI1\_IE in the Section 21.5.2.13: Protocol Interrupt Enable Register 0 (PIER0) is asserted, an interrupt request is generated. #### 21.6.17.2.2 Relative timer T2 If the timer T2 is configured as a relative timer, the interrupt flag TI2\_IF in the Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) is set, when the programmed amount of macroticks MT[31:0], defined by Section 21.5.2.42: Timer 2 Configuration Register 0 (TI2CR0) and Section 21.5.2.43: Timer 2 Configuration Register 1 (TI2CR1), has expired since the trigger or restart of timer 2. The relative timer is implemented as a down counter and expires when it has reached 0. At the macrotick start event, the value of MT[31:0] is checked and then decremented. Thus, if the timer is started with MT[31:0] == 0, it expires at the next macrotick start. ## 21.6.18 Slot status monitoring The controller provides several means for slot status monitoring. All slot status monitors use the same slot status vector provided by the PE. The PE provides a slot status vector for each static slot, for each dynamic slot, for the symbol window, and for the NIT, on a per channel base. The content of the slot status vector is described in *Table 359*. The PE provides the slot status vector within the first macrotick after the end of the related slot/window/NIT, as shown in *Figure 381*. status(slot 1) MT Slot star Slot star MT MT Status(slot 1) MT Status(slot 1) MT Communication cycle star Status(slot 1) MT Figure 381. Slot status vector update Note: The slot status for the NIT of cycle n is provided after the start of cycle n+1. Table 359. Slot status content | | Status Content | |-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | static /<br>dynamic<br>Slot | slot related status vSs!ValidFrame - valid frame received vSs!SyntaxError - syntax error occurred while receiving vSs!ContentError - content error occurred while receiving vSs!BViolation - boundary violation while receiving for slots in which the module transmits: vSs!TxConflict - reception ongoing while transmission starts for slots in which the module does not transmit: vSs!TxConflict - reception ongoing while transmission starts first valid - channel that has received the first valid frame received frame related status extracted from a) header of valid frame, if vSs!ValidFrame = 1 b) last received header, if vSs!ValidFrame = 0 c) set to 0, if nothing was received vRF!Header!NFIndicator - Null Frame Indicator (0 for null frame) vRF!Header!SyFIndicator - Sync Frame Indicator | Table 359. Slot status content(Continued) | | Status Content | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Symbol<br>Window | window related status vSs!ValidFrame - always 0 vSs!ContentError - content error occurred while receiving vSs!SyntaxError - syntax error occurred while receiving vSs!BViolation - boundary violation while receiving vSs!TxConflict - reception ongoing while transmission starts received symbol related status vSs!ValidMTS - valid Media Test Access Symbol received received frame related status see static/dynamic slot | | NIT | NIT related status vSs!ValidFrame - always 0 vSs!ContentError - content error occurred while receiving vSs!SyntaxError - syntax error occurred while receiving vSs!BViolation - boundary violation while receiving vSs!TxConflict - always 0 received frame related status see static/dynamic slot | #### 21.6.18.1 Channel status error counter registers The two channel status error counter registers, Section 21.5.2.17: Channel A Status Error Counter Register (CASERCR) and Section 21.5.2.18: Channel B Status Error Counter Register (CBSERCR), incremented by one, if at least one of four slot status error bits, vSS!SyntaxError, vSS!ContentError, vSS!BViolation, or vSS!TxConflict is set to 1. The status vectors for all slots in the static and dynamic segment, in the symbol window, and in the NIT are taken into account. The counters wrap round after they have reached the maximum value. #### 21.6.18.2 Protocol status registers The Section 21.5.2.21: Protocol Status Register 2 (PSR2) provides slot status information about the Network Idle Time NIT and the Symbol Window. The Section 21.5.2.22: Protocol Status Register 3 (PSR3) provides aggregated slot status information. #### 21.6.18.3 Slot status registers The eight slot status registers, *Section 21.5.2.46*: *Slot Status Registers (SSR0–SSR7)*, can be used to observe the status of static slots, dynamic slots, the symbol window, or the NIT without individual message buffers. These registers provide all slot status related and received frame / symbol related status information, as given in *Table 359*, except of the *first valid* indicator for non-transmission slots. #### 21.6.18.4 Slot status counter registers The controller provides four slot status error counter registers, Section 21.5.2.47: Slot Status Counter Registers (SSCR0–SSCR3). Each of these slot status counter registers is updated with the value of an internal slot status counter at the start of a communication cycle. The internal slot status counter is incremented if its increment condition, defined by the Section 21.5.2.45: Slot Status Counter Condition Register (SSCCR), matches the status vector provided by the PE. All static slots, the symbol window, and the NIT status are taken into account. Dynamic slots are excluded. The internal slot status counting and update timing is shown in Figure 382. Figure 382. Slot status counting and SSCRn update The PE provides the status of the NIT in the first slot of the next cycle. Due to these facts, the SSCRn register reflects, in cycle n, the status of the NIT of cycle n-2, and the status of all static slots and the symbol window of cycle n-1. The increment condition for each slot status counter consists of two parts, the frame related condition part and the slot related condition part. The internal slot status counter SSCRn\_INT is incremented if at least one of the conditions is fulfilled: - 1. frame related condition: - (SSCCRn.VFR | SSCCRn.SYF | SSCCRn.NUF | SSCCRn.SUF) // count on frame condition = 1; and ((~SSCCRn.VFR | vSS!ValidFrame) & // valid frame restriction (~SSCCRn.SYF | vRF!Header!SyFIndicator) & // sync frame indicator restriction (~SSCCRn.NUF | ~vRF!Header!NFIndicator) & // null frame indicator restriction (~SSCCRn.SUF | vRF!Header!SuFIndicator)) // startup frame indicator restriction Note: The indicator bits SYF, NUF, and SUF are valid only when a valid frame was received. Thus it is required to set the VFR always, whenever count on frame condition is used. - slot related condition: - ((SSCCRn.STATUSMASK[3] & vSS!ContentError) | // increment on content error (SSCCRn.STATUSMASK[2] & vSS!SyntaxError) | // increment on syntax error (SSCCRn.STATUSMASK[1] & vSS!BViolation) | // increment on boundary violation (SSCCRn.STATUSMASK[0] & vSS!TxConflict)) // increment on transmission conflict = 1; If the slot status counter is in single cycle mode, i.e., SSCCRn[MCY] = 0, the internal slot status counter SSCRn INT is reset at each cycle start. If the slot status counter is in the multicycle mode, i.e., SSCCR*n*[MCY] = 1, the counter is not reset and incremented, until the maximum value is reached. #### 21.6.18.5 Message buffer slot status field Each individual message buffer and each FIFO message buffer provides a slot status field, which provides the information shown in *Table 359* for the static/dynamic slot. The update conditions for the slot status field depend on the message buffer type. Refer to the Message Buffer Update Sections in *Section 21.6.6: Individual message buffer functional description*. ## 21.6.19 System bus access This section provides a description of the system bus accesses performed by the controller. All FlexRay memory data located in the system memory are accessed via the system bus. There are two types of failures that can occur during the system bus access, the system bus illegal address access and the system bus access timeout. The behavior of the controller after the occurrence of a system bus failure is defined by the SBFF bit in the Section 21.5.2.4: Module Configuration Register (MCR). #### 21.6.19.1 System bus illegal address access If the system bus detects an controller access to an illegal address, the controller receives a notification from the system bus about this event and sets the ILSA\_EF flag in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR). #### 21.6.19.2 System bus access timeout The controller starts a timer when it has send an access request to the system bus. This timer expires after 2 × SYMATOR.TIMEOUT + 2 system bus clock cycles. If the access is not finished within this amount of time, the SBCF\_EF flag in the Section 21.5.2.15: CHI Error Flag Register (CHIERFR) is set. #### 21.6.19.3 Continue after system bus failure If the SBFF bit in the Section 21.5.2.4: Module Configuration Register (MCR) is 0, the controller will continue its operation after the occurrence of the system bus access failure but will not generate any system bus accesses until the start of the next communication cycle. If a frame is under transmission when the system bus failure occurs, a correct frame is generated with the remaining header and frame data are replaced by all zeros. Depending on the point in time this can affect the PPI bit, the Header CRC, the Payload Length in case of an dynamic slot, and the payload data. Starting from the next slot in the current cycle, no frames will be transmitted and received, except for the key slot, where a sync or startup null-frame is transmitted, if the key slot is assigned. If a frame is received when the system bus failure occurs, the reception is aborted and the related receive message buffer is not updated. Normal operation is resumed after the start of next communication cycle. ### 21.6.19.4 Freeze after system bus failure If the SBFF bit in the Section 21.5.2.4: Module Configuration Register (MCR) is set to 1, the controller will go into the freeze mode immediately after the occurrence of one of the system bus access failures. ### 21.6.20 Interrupt support The controller provides 8 interrupt sources, out of them 5 are combined interrupt sources. #### 21.6.20.1 Individual interrupt sources #### 21.6.20.1.1 Receive FIFO interrupts The controller provides 2 Receive FIFO interrupt sources. Each of the 2 Receive FIFO provides a Receive FIFO Not Empty Interrupt Flag. The controller sets the Receive FIFO Not Empty Interrupt Flags (GIFER.FNEBIF, GIFER.FNEAIF) in the Section 21.5.2.10: Global Interrupt Flag and Enable Register (GIFER) if the corresponding Receive FIFO is not empty. ### 21.6.20.1.2 Wakeup interrupt The controller provides one interrupt source related to the wakeup. The controller sets the Wakeup Interrupt Flag GIFER.WUPIF when it has received a wakeup symbol on the FlexRay bus. The controller generates an interrupt request if the interrupt enable bit GIFER.WUPIE is asserted. #### 21.6.20.2 Combined interrupt sources Each combined interrupt source generates an interrupt request only when at least one of the interrupt sources that is combined generates an interrupt request. #### 21.6.20.2.1 Receive message buffer interrupt The combined receive message buffer interrupt request RBIRQ is generated when at least one of the individual receive message buffers generates an interrupt request MBXIRQ[n] and the interrupt enable bit GIFER.RBIE is set. ### 21.6.20.2.2 Transmit message buffer interrupt The combined transmit message buffer interrupt request TBIRQ is generated when at least one of the individual transmit message buffers generates an interrupt request MBXIRQ[n] and the interrupt enable bit GIFER.TBIE is asserted. #### 21.6.20.2.3 Protocol interrupt The controller provides 26 interrupt sources for protocol related events. For details, see Section 21.5.2.11: Protocol Interrupt Flag Register 0 (PIFR0) and Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1). Each interrupt source has its own interrupt enable bit. The combined protocol interrupt request PRTIRQ is generated when at least one of the individual protocol interrupt sources generates an interrupt request and the interrupt enable bit GIFER.PRIE is set. # 21.6.20.2.4 Module interrupt The combined module interrupt request MIRQ is generated if at least one of the combined interrupt sources generates an interrupt request and the interrupt enable bit GIFER.MIE is set. ## 21.6.20.2.5 CHI error interrupts The controller provides 16 interrupt sources for CHI related error events. For details, see *Section 21.5.2.15: CHI Error Flag Register (CHIERFR)*. There is one common interrupt enable bit GIFER.CHIIE for all CHI error interrupt sources. Figure 383. Scheme of cascaded interrupt request Figure 384. Scheme of combined interrupt flags #### 21.6.21 Lower bit rate support The controller supports a number of lower bit rates on the FlexRay bus channels. The lower bit rates are implemented by modifying the duration of the microtick *pdMicrotick*, the number of samples per microtick *pSamplesPerMicrotick*, the number of samples per bit *cSamplesPerBit*, and the strobe offset *cStrobeOffset*. The application configures the FlexRay channel bit rate by setting the BITRATE field in the *Module Configuration Register (MCR)*. The protocol values are set internally. The available bit rates, the related BITRATE field configuration settings and related protocol parameter values are shown in *Table 360*. pSamplesPerMicrotick gdSampleClockPeriod cSamplesPerBit cStrobeOffset **adMicrotick** FlexRay Channel MCR.BITRATE **Bit Rate** [Mbit/s] 2 10.0 000 25.0 12.5 8 5 011 25.0 12.5 2 10 6 8.0 5.0 001 25.0 25.0 8 5 1 2.5 010 50.0 50.0 1 8 5 Table 360. FlexRay Channel Bit Rate Control Note: The bit rate of 8 Mbit/s is not defined by the FlexRay Communications System Protocol Specification, Version 2.1 Rev A. # 21.7 Application information # 21.7.1 Initialization sequence This section describes the required steps to initialize the controller. The first subsection describes the steps required after a system reset, the second section describes the steps required after preceding shutdown of the controller. #### 21.7.1.1 Module initialization This section describes the module related initialization steps after a system reset. - 1. Configure controller. - configure the control bits in the Section 21.5.2.4: Module Configuration Register (MCR) - configure the system memory base address in Section 21.5.2.5: System Memory Base Address High Register (SYMBADHR) and System Memory Base Address Low Register (SYMBADLR) - Enable the controller. - a) write 1 to the module enable bit MEN in the Section 21.5.2.4: Module Configuration Register (MCR) The controller now enters the Normal Mode. The application can commence with the protocol initialization described in *Section 21.7.1.2: Protocol initialization*. #### 21.7.1.2 Protocol initialization This section describes the protocol related initialization steps. - Configure the Protocol Engine. - a) issue CONFIG command via Section 21.5.2.9: Protocol Operation Control Register (POCR) - b) wait for POC:config in Section 21.5.2.19: Protocol Status Register 0 (PSR0) - c) configure the PCR0,..., PCR30 registers to set all protocol parameters - Configure the Message Buffers and FIFOs. - a) set the number of message buffers used and the message buffer segmentation in the Section 21.5.2.8: Message Buffer Segment Size and Utilization Register (MBSSUTR) - b) define the message buffer data size in the Section 21.5.2.7: Message Buffer Data Size Register (MBDSR) - c) configure each message buffer by setting the configuration values in the Section 21.5.2.65: Message Buffer Configuration, Control, Status Registers (MBCCSRn), Section 21.5.2.66: Message Buffer Cycle Counter Filter Registers (MBCCFRn), Section 21.5.2.67: Message Buffer Frame ID Registers (MBFIDRn), Section 21.5.2.68: Message Buffer Index Registers (MBIDXRn) - d) configure the receive FIFOs - e) issue CONFIG\_COMPLETE command via Section 21.5.2.9: Protocol Operation Control Register (POCR) - f) wait for POC:ready in Section 21.5.2.19: Protocol Status Register 0 (PSR0) After this sequence, the controller is configured as a FlexRay node and is ready to integrate into the FlexRay cluster. ## 21.7.2 Shut down sequence This section describes a secure shut down sequence to stop the controller gracefully. The main targets of this sequence are - finish all ongoing reception and transmission - do not corrupt FlexRay bus and do not disturb ongoing FlexRay bus communication For a graceful shutdown the application shall perform the following tasks: - 1. Disable all enabled message buffers. - a) repeatedly write 1 to MBCCSRn[EDT] until MBCCSRn[EDS] == 0. - Stop Protocol Engine. - a) issue HALT command via Section 21.5.2.9: Protocol Operation Control Register (POCR) - b) wait for POC:halt in Section 21.5.2.19: Protocol Status Register 0 (PSR0) #### 21.7.3 Number of usable message buffers This section describes the relationship between the number of message buffers that can be utilized and the required minimum CHI clock frequency. Additional constraints for the minimum CHI clock frequency are given in Section 21.3: Controller host interface clocking. The controller uses a sequential search algorithm to determine the individual message buffer assigned or subscribed to the next slot. This search must be finished within one FlexRay slot. The shortest FlexRay slot is an empty dynamic slot. An empty dynamic slot is a minislot and consists of *gdMinislot* macroticks with a nominal duration of *gdMacrotick*. The minimum duration of a corrected macrotick is $gdMacrotick_{min}$ = 39 $\mu$ T. This results in a minimum slot length of #### **Equation 47** $$\Delta_{\text{slotmin}} = 39 \cdot pdMicrotick \cdot gdMinislot$$ The search engine is located in the CHI and runs on the CHI clock. It evaluates one individual message buffer per CHI clock cycle. For internal status update and double buffer commit operations, and as a result of the clock domain crossing jitter, an additional amount of 10 CHI clock cycles is required to ensure correct operation. For a given number of message buffers and for a given CHI clock frequency f<sub>chi</sub>, this results in a search duration of #### **Equation 48** $$\Delta_{\text{search}} = \frac{1}{f_{\text{chi}}} \cdot (\text{# MessageBuffers} + 10)$$ The message buffer search must be finished within one slot which requires that *Equation 49* must be fulfilled #### **Equation 49** $$\Delta_{\text{search}} \leq \Delta_{\text{slotmin}}$$ This results in the formula given in *Equation 50* which determines the required minimum CHI frequency for a given number of message buffers that are utilized. #### **Equation 50** $$f_{chi} \ge \frac{\text{\# MessageBuffers} + 10}{39 \cdot pdMicrotick \cdot gdMinislot}$$ The minimum CHI frequency for a selected set of relevant protocol parameters is given in *Table 361*. Table 361. Minimum f<sub>chi</sub> [MHz] examples (32 message buffers) | pdMicrotick | | | gdMi | nislot | | | |-------------|-------|-------|-------|--------|------|------| | [ns] | 2 | 3 | 4 | 5 | 6 | 7 | | 25.0 | 21.54 | 14.35 | 10.77 | 8.61 | 7.18 | 6.16 | | 50.0 | 10.73 | 7.18 | 5.39 | 4.31 | 3.59 | 3.08 | #### 21.7.4 Protocol control command execution This section considers the issues of the protocol control command execution. The application issues any of the protocol control commands listed in the POCCMD field of *Table 261* by writing the command to the POCCMD field of the *Section 21.5.2.9: Protocol Operation Control Register (POCR)*. As a result the controller sets the BSY bit while the command is transferred to the PE. When the PE has accepted the command, the BSY flag is cleared. All commands are accepted by the PE. The PE maintains a protocol command vector. For each command that was accepted by the PE, the PE sets the corresponding command bit in the protocol command vector. If a command is issued while the corresponding command bit is set, the command is not queued and is lost. If the command execution block of the PE is idle, it selects the next accepted protocol command with the highest priority from the current protocol command vector according to the protocol control command priorities given in *Table 362*. If the current protocol state does not allow the execution of this protocol command (see POC state changes in *FlexRay Communications System Protocol Specification, Version 2.1 Rev A*) the controller asserts the illegal protocol command interrupt flag IPC\_IF in the *Section 21.5.2.12: Protocol Interrupt Flag Register 1 (PIFR1)*. The protocol command is not executed in this case. Some protocol commands may be interrupted by other commands or the detection of a fatal protocol error as indicated by *Table 362*. If the application issues the RESET, FREEZE, or READY command, or if the PE detects a fatal protocol error, some commands already stored in the command vector will be removed from this vector. | <b>Protocol Command</b> | Priority | Interrupted By | Cleared and Terminated By | |-------------------------|-------------|------------------------------------------------------------|-------------------------------------------------------------| | RESET | (highest) 1 | | | | FREEZE | 2 | nono | RESET | | READY | 3 | none | RESET | | CONFIG_COMPLETE | 3 | | RESET | | ALL_SLOTS | 4 | | RESET, FREEZE, READY, CONFIG_COMPLETE, fatal protocol error | | ALLOW_COLDSTART | 5 | | RESET | | RUN | 6 | RESET, FREEZE, READY, CONFIG_COMPLET, fatal protocol error | RESET, FREEZE, fatal protocol error | | WAKEUP | 7 | | RESET, FREEZE, fatal protocol error | | DEFAULT_CONFIG | 8 | | RESET, FREEZE, fatal protocol error | | CONFIG | 9 | | RESET | | HALT | (lowest) 10 | | RESET, FREEZE, READY, CONFIG_COMPLETE, fatal protocol error | Table 362. Protocol control command priorities ### 21.7.5 Protocol reset command The application can use the RESET command to initiate a reset of the protocol engine The application issues the protocol reset command by writing the RESET command to the POCCMD field of the *Section 21.5.2.9: Protocol Operation Control Register (POCR)*. As a result, the PE stops its operation within the next 500 ns. At the same time the FlexRay bus ports are put into the reset state given in *Table 247*. The protocol and message buffer configuration data are not affected by the RESET command and will not be changed. The duration of the RESET command must be at least 500 ns. Before accessing the message buffers, the application must put the protocol into the *POC:default config* state by sending the Protocol Command DEFAULT\_CONFIG via *Section 21.5.2.9: Protocol Operation Control Register (POCR)*. # 21.7.6 Message buffer search on simple message buffer configuration This sections describes the message buffer search behavior for a simplified message buffer configuration. The receive FIFO behavior is not considered in this section. ### 21.7.6.1 Simple message buffer configuration A simple message buffer configuration is a configuration that has at most one transmit message buffer and at most one receive message buffer assigned to a slot *S*. The simple configuration used in this section utilizes two message buffers, one single buffered transmit message buffer and one receive message buffer. The transmit message buffer has the message buffer number *t* and has following configuration | Register | Field | Value | Description | |----------|--------|--------|---------------------------------| | | MCM | | used only for double buffers | | MBCCSRt | MBT | 0 | single transmit buffer | | | MTD | 1 | transmit buffer | | | MTM | 0 | event transition mode | | | CHA | 1 | assigned to channel A | | MBCCFRt | СНВ | 0 | not assigned to channel B | | WIBCCFR | CCFE | 1 | cycle counter filter enabled | | | CCFMSK | 000011 | cycle set = {4n} = {0,4,8,12,} | | | CCFVAL | 000000 | Cycle Set - {411} - {0,4,0,12,} | | MBFIDRt | FID | S | assigned to slot S | Table 363. Transmit buffer configuration The availability of data in the transmit buffer is indicated by the commit bit MBCCSRt[CMT] and the lock bit MBCCSRt[LCKS]. The receive message buffer has the message buffer number r and has following configuration | Register | Field | Value | Description | |-----------------|--------|--------|-------------------------------| | | MCM | _ | n/a | | MBCCSRr | MBT | _ | n/a | | | MTD | 0 | receive buffer | | | MTM | _ | n/a | | | CHA | 1 | assigned to channel A | | MBCCF <i>r</i> | СНВ | 0 | not assigned to channel B | | IVIDCOFT | CCFE | 1 | cycle counter filter enabled | | | CCFMSK | 000001 | avela cot = [2n] = [0.2.4.6] | | | CCFVAL | 000000 | cycle set = {2n} = {0,2,4,6,} | | MBFIDR <i>r</i> | FID | S | subscribed slot | Table 364. Receive buffer configuration Furthermore the assumption is that both message buffers are enabled (MBCCSRt[EDS] = 1 and MBCCSRt[EDS] = 1) Note: The cycle set $\{4n+2\} = \{2,6,10,...\}$ is assigned to the receive buffer only. The cycle set $\{4n\}$ = $\{0,4,8,12,...\}$ is assigned to both buffers. ## 21.7.6.2 Behavior in static segment In this case, both message buffers are assigned to a slot S in the *static* segment. The configuration of a transmit buffer for a static slot *S* assigns this slot to the node as a transmit slot. The FlexRay protocol requires: • When a slot occurs, if the slot is assigned to a node on a channel that node must transmit either a normal frame or a null frame on that channel. Specifically, a null frame will be sent if there is no data ready, or if there is no match on a transmit filter (cycle counter filtering, for example). Regardless of the availability of data and the cycle counter filter, the node will transmit a frame in the static slot S. In any case, the result of the message buffer search will be the transmit message buffer t. The receive message buffer r will not be found, no reception is possible. #### 21.7.6.3 Behavior in dynamic segment In this case, both message buffers are assigned to a slot *S* in the *dynamic* segment. The FlexRay protocol requires: When a slot occurs, if a slot is assigned to a node on a channel that node only transmits a frame on that channel if there is data ready and there is a match on relevant transmit filters (no null frames are sent). The transmission of a frame in the dynamic segment is determined by the availability of data and the match of the cycle counter filter of the transmit message buffer. #### 21.7.6.3.1 Transmit data not available If transmit data are *not available*, i.e., the transmit buffer is not committed MBCCSRt[CMT] = 0 and/or locked MBCCSRt[LCKS] = 1, - a) for the cycles in the set {4n}, which is assigned to both buffers, the receive buffer will be found and the node can receive data, and - b) for the cycles in the set {4n+2}, which is assigned to the receive buffer only, the receive buffer will be found and the node can receive data. The receive cycles are shown in *Figure 385*. Figure 385. Transmit data not available #### 21.7.6.3.2 Transmit data available If transmit data are *available*, i.e., the transmit buffer is committed MBCCSRt[CMT] = 1 and not locked MBCCSRt[LCKS] = 0, - a) for the cycles in the set $\{4n\}$ , which is assigned to both buffers, the transmit buffer will be found and the node transmits data. - b) for the cycles in the set $\{4n + 2\}$ , which is assigned to the receive buffer only, the receive buffer will be found and the node can receive data. The receive and transmit cycles are shown in Figure 386. Figure 386. Transmit data not available # 22 Deserial Serial Peripheral Interface (DSPI) ## 22.1 Introduction This chapter describes the deserial serial peripheral interface (DSPI), which provides a synchronous serial bus for communication between the MCU and an external peripheral device. The SPC56xP60x/54x implements the modules DSPI0 to 4. The "x" appended to signal names signifies the module to which the signal applies. Thus CS0\_x specifies that the CS0 signal applies to DSPI module 0, 1, etc. # 22.2 Block diagram A block diagram of the DSPI is shown in Figure 387. Figure 387. DSPI block diagram # 22.3 Overview The register content is transmitted using an SPI protocol. There are five DSPI modules (DSPI $_0$ – DSPI $_4$ ) on the device. The <u>mod</u>ules are identical except that DSPI $_0$ and DSPI $_1$ have four additional chip select (CS) lines. For queued operations, the SPI queues reside in internal SRAM that is external to the DSPI. Data transfers between the queues and the DSPI FIFOs are accomplished through the use of the eDMA controller or through host software. Figure 388 shows a DSPI with external queues in internal SRAM. Figure 388. DSPI with queues and eDMA ## 22.4 Features The DSPI supports these SPI features: - Full-duplex, three-wire synchronous transfers - Master and slave modes - Buffered transmit and receive operation using the TX and RX FIFOs, with depths of 5 entries - Visibility into TX and RX FIFOs for ease of debugging - FIFO bypass mode for low-latency updates to SPI gueues - Programmable transfer attributes on a per-frame basis - 8 clock and transfer attribute registers - Serial clock with programmable polarity and phase - Programmable delays CS to SCK delay SCK to CS delay Delay between frames - Programmable serial frame size of 4 to 16 bits, expandable with software control - Continuously held chip select capability - 8 peripheral chip selects, expandable up to 256 with external demultiplexer - Deglitching support for as many as 32 peripheral chip selects with external demultiplexer - 2 DMA conditions for SPI queues residing in RAM or flash - TX FIFO is not full (TFFF) - RX FIFO is not empty (RFDF) - 6 interrupt conditions: - End of gueue reached (EOQF) - TX FIFO is not full (TFFF) - Transfer of current frame complete (TCF) - RX FIFO is not empty (RFDF) - FIFO overrun (attempt to transmit with an empty TX FIFO or serial frame received while RX FIFO is full) (RFOF) - FIFO under flow (slave only and SPI mode, the slave is asked to transfer data when the TX FIFO is empty) (TFUF) - Modified SPI transfer formats for communication with slower peripheral devices - Continuous serial communications clock (SCK) # 22.5 Modes of operation The DSPI has four modes of operation. These modes can be divided into two categories; module-specific modes such as master, slave, and module disable modes, and a second category that is an MCU-specific mode: debug mode. All four modes are implemented on this device. The module-specific modes are entered by host software writing to a register. The MCU-specific mode is controlled by signals external to the DSPI. The MCU-specific mode is a mode that the entire device may enter, in parallel to the DSPI being in one of its modulespecific modes. #### 22.5.1 Master mode Master mode allows the DSPI to initiate and control serial communication. In this mode, the SCK, $\overline{\text{CS}n}$ and SOUT signals are controlled by the DSPI and configured as outputs. For more information, refer to Section 22.8.1.1: Master mode. #### 22.5.2 Slave mode Slave mode allows the DSPI to communicate with SPI bus masters. In this mode the DSPI responds to externally controlled serial transfers. The DSPI cannot initiate serial transfers in slave mode. In slave mode, the <u>SCK</u> signal and the CS0\_x signal are configured as inputs and provided by a bus master. CS0\_x must be configured as input and pulled high. If the internal pullup is being used then the appropriate bits in the relevant SIU\_PCR must be set (SIU\_PCR [WPE = 1], [WPS = 1]). For more information, refer to Section 22.8.1.2: Slave mode. #### 22.5.3 Module disable mode The module disable mode is used for MCU power management. The clock to the non-memory mapped logic in the DSPI is stopped while in module disable mode. The DSPI enters the module disable mode when the MDIS bit in DSPIx MCR is set. For more information, refer to Section 22.8.1.3: Module disable mode. ## 22.5.4 Debug mode Debug mode is used for system development and debugging. If the device enters debug mode while the FRZ bit in the DSPIx\_MCR is set, the DSPI halts operation on the next frame boundary. If the device enters debug mode while the FRZ bit is cleared, the DSPI behavior is unaffected. For more information, refer to Section 22.8.1.4: Debug mode. # 22.6 External signal description ## 22.6.1 Signal overview Table 365 lists off-chip DSPI signals. | Name | I/O turno | Function | | | |-----------------------------------------------------------------|----------------|-------------------------------------------------------------|-----------------------|--| | Name | I/O type | Master mode | Slave mode | | | CS0_x | Output / input | Peripheral chip select 0 | Slave select | | | CS1:3_x<br>(DSPI 0: CS1:3_0, CS5_0)<br>(DSPI 1: CS1:3_1, CS5_1) | Output | Peripheral chip select 1–3 | Unused <sup>(1)</sup> | | | CS4_x | Output | Peripheral chip select 4 | Master trigger | | | CS5_x<br>(DSPI 0: CS7_0)<br>(DSPI 1: CS7_1) | Output | Peripheral chip select 5 /<br>Peripheral chip select strobe | Unused <sup>(1)</sup> | | | SIN_x | Input | Serial data in | Serial data in | | | SOUT_x | Output | Serial data out | Serial data out | | | SCK_x | Output / input | Serial clock (output) | Serial clock (input) | | Table 365. Signal properties ## 22.6.2 Signal names and descriptions ## 22.6.2.1 Peripheral Chip Select / Slave Select (CS\_0) In master mode, the CS\_0 signal is a peripheral chip select output that selects the slave device to which the current transmission is intended. In slave mode, the CS\_0 signal is a slave select input signal that allows an SPI master to select the DSPI as the target for transmission. CS\_0 must be configured as input and pulled high. If the internal pullup is being used then the appropriate bits in the relevant SIU\_PCR must be set (SIU\_PCR [WPE = 1], [WPS = 1]). Set the IBE and OBE bits in the PCR for all CS\_0 pins when the DSPI chip select or slave select primary function is selected for that pin. When the pin is used for DSPI master mode as a chip select output, set the OBE bit. When the pin is used in DSPI slave mode as a slave select input, set the IBE bit. Refer to Section 11.5.2.8: Pad Configuration Registers (PCR[0:108]) for more information. # 22.6.2.2 Peripheral Chip Selects 1-3 (CS1:3) CS1:3 are peripheral chip select output signals in master mode. In slave mode these signals are not used. # 22.6.2.3 Peripheral Chip Select 4 (CS4) CS4 is a peripheral chip select output signal in master mode. # 22.6.2.4 Peripheral Chip Select 5/Peripheral Chip Select Strobe (CS\_5) CS5 is a peripheral chip select output <u>sign</u>al. When the DSPI is in master mode and PCSSE bit in the DSPIx\_MCR is cleared, the CS5 signal selects the slave device that receives the current transfer. <sup>1.</sup> The SIUL allows you to select alternate pin functions for the device. CS5 is a strobe signal used by external logic for deglitching of the CS signals. When the DSPI is in master mode and the PCSSE bit in the DSPIx\_MCR is set, the CS5 signal indicates the timing to decode CS0:4 signals, which prevents glitches from occurring. CS5 is not used in slave mode. ## 22.6.2.5 Serial Input (SIN\_x) SIN\_x is a serial data input signal. ## 22.6.2.6 Serial Output (SOUT\_x) SOUT\_x is a serial data output signal. ## 22.6.2.7 Serial Clock (SCK\_x) SCK\_x is a serial communication clock signal. In master mode, the DSPI generates the SCK. In slave mode, SCK\_x is an input from an external bus master. # 22.7 Memory map and registers description # 22.7.1 Memory map Table 366 shows the DSPI memory map. Table 366. DSPI memory map | Offset from DSPI_BASE 0xFFF9_0000 (DSPI_0) 0xFFF9_4000 (DSPI_1) 0xFFF9_8000 (DSPI_2) 0xFFF9_C000 (DSPI_3) 0x8FFA_0000 (DSPI_4) | Register | Location | |--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------| | 0x0000 | DSPI_MCR—DSPI module configuration register | on page 672 | | 0x0004 | Reserved | | | 0x0008 | DSPI_TCR—DSPI transfer count register | on page 675 | | 0x000C | DSPI_CTAR0—DSPI clock and transfer attributes register 0 | on page 676 | | 0x0010 | DSPI_CTAR1—DSPI clock and transfer attributes register 1 | on page 676 | | 0x0014 | DSPI_CTAR2—DSPI clock and transfer attributes register 2 | on page 676 | | 0x0018 | DSPI_CTAR3—DSPI clock and transfer attributes register 3 | on page 676 | | 0x001C | DSPI_CTAR4—DSPI clock and transfer attributes register 4 | on page 676 | | 0x0020 | DSPI_CTAR5—DSPI clock and transfer attributes register 5 | on page 676 | | 0x0024 | DSPI_CTAR6—DSPI clock and transfer attributes register 6 | on page 676 | | 0x0028 | DSPI_CTAR7—DSPI clock and transfer attributes register 7 | on page 676 | | 0x002C | DSPI_SR—DSPI status register | on page 682 | | 0x0030 | DSPI_RSER—DSPI DMA/interrupt request select and enable register | on page 684 | Table 366. DSPI memory map(Continued) | Offset from DSPI_BASE 0xFFF9_0000 (DSPI_0) 0xFFF9_4000 (DSPI_1) 0xFFF9_8000 (DSPI_2) 0xFFF9_C000 (DSPI_3) 0x8FFA_0000 (DSPI_4) | Register | Location | |--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------| | 0x0034 | DSPI_PUSHR—DSPI push TX FIFO register | on page 686 | | 0x0038 | DSPI_POPR—DSPI pop RX FIFO register | on page 688 | | 0x003C | DSPI_TXFR0—DSPI transmit FIFO register 0 | on page 688 | | 0x0040 | DSPI_TXFR1—DSPI transmit FIFO register 1 | on page 688 | | 0x0044 | DSPI_TXFR2—DSPI transmit FIFO register 2 | on page 688 | | 0x0048 | DSPI_TXFR3—DSPI transmit FIFO register 3 | on page 688 | | 0x004C | DSPI_TXFR4—DSPI transmit FIFO register 4 | on page 688 | | 0x0050-0x007B | Reserved | | | 0x007C | DSPI_RXFR0—DSPI receive FIFO register 0 | on page 689 | | 0x0080 | DSPI_RXFR1—DSPI receive FIFO register 1 | on page 689 | | 0x0084 | DSPI_RXFR2—DSPI receive FIFO register 2 | on page 689 | | 0x0088 | DSPI_RXFR3—DSPI receive FIFO register 3 | on page 689 | | 0x008C | DSPI_RXFR4—DSPI receive FIFO register 4 | on page 689 | | 0x0090-0x3FFF | Reserved | | # 22.7.2 Registers description ## 22.7.2.1 DSPI Module Configuration Register (DSPIx\_MCR) The DSPIx\_MCR contains bits that configure attributes of the DSPI operation. The values of the HALT and MDIS bits can be changed at any time, but their effect begins on the next frame boundary. The HALT and MDIS bits in the DSPIx\_MCR are the only bit values software can change while the DSPI is running. Figure 389. DSPI Module Configuration Register (DSPIx\_MCR) Table 367. DSPIx\_MCR field descriptions | Field | Description | | | | | |-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 0<br>MSTR | Master/slave mode select Configures the DSPI for master mode or slave mode. 0 DSPI is in slave mode. 1 DSPI is in master mode. | | | | | | 1<br>CONT_SCKE | Continuous SCK enable Enables the serial communication clock (SCK) to run continuously. Refer to Section 22.8.6: Continuous Serial communications clock for details. Continuous SCK disabled Continuous SCK enabled Note: If the FIFO is enabled with continuous SCK mode, before setting the CONT_SCKE bit, the TX-FIFO should be cleared and only CTAR0 register should be used for transfer attributes otherwise a change in SCK frequency occurs. | | | | | | 2–3<br>DCONF<br>[0:1] | DSPI configuration The following table lists the DCONF values for the various configurations. DCONF Configuration | | | | | | 4<br>FRZ | Freeze Enables the DSPI transfers to be stopped on the next frame boundary when the device enters debug mode. 0 Do not halt serial transfers. 1 Halt serial transfers. | | | | | Table 367. DSPIx\_MCR field descriptions(Continued) | Field | Description | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5<br>MTFE | Modified timing format enable Enables a modified transfer format to be used. Refer to Section 22.8.5.4: Modified SPI transfer format (MTFE = 1, CPHA = 1) for more information. 0 Modified SPI transfer format disabled 1 Modified SPI transfer format enabled | | 6<br>PCSSE | Peripheral chip select strobe enable Enables the CS5_x to operate as a CS strobe output signal. Refer to Section 22.8.4.5: Peripheral Chip Select strobe enable (CS5_x) for more information. 0 CS5_x is used as the Peripheral chip select 5 signal. 1 CS5_x is used as an active-low CS strobe signal. | | 7<br>ROOE | Receive FIFO overflow overwrite enable Enables an RX FIFO overflow condition to ignore the incoming serial data or to overwrite existing data. If the RX FIFO is full and new data is received, the data from the transfer that generated the overflow is ignored or put in the shift register. If the ROOE bit is set, the incoming data is put in the shift register. If the ROOE bit is cleared, the incoming data is ignored. Refer to Section 22.8.7.6: Receive FIFO overflow interrupt request (RFOF) for more information. 0 Incoming data is ignored. 1 Incoming data is put in the shift register. | | 8–9 | Reserved, but implemented. These bits are writable, but have no effect. | | 10–15<br>PCSIS <i>n</i> | Peripheral chip select inactive state Determines the inactive state of the CS0_x signal. CS0_x must be configured as inactive high for slave mode operation. 0 The inactive state of CS0_x is low. 1 The inactive state of CS0_x is high. Note: PCSIS7 and PSCIS6 are implemented only on DSPI_0. | | 16 | Reserved | | 17<br>MDIS | Module disable Allows the clock to stop to the non-memory mapped logic in the DSPI, effectively putting the DSPI in a software controlled power-saving state. Refer to Section 22.8.8: Power saving features for more information." The reset value of the MDIS bit is parameterized, with a default reset value of 0. 0 Enable DSPI clocks. 1 Allow external logic to disable DSPI clocks. | | 18<br>DIS_TXF | Disable transmit FIFO Enables and disables the TX FIFO. When the TX FIFO is disabled, the transmit part of the DSPI operates as a simplified double-buffered SPI. Refer to Section 22.8.3.3: FIFO disable operation for details. 0TX FIFO enabled 1TX FIFO disabled | | 19<br>DIS_RXF | Disable receive FIFO Enables and disables the RX FIFO. When the RX FIFO is disabled, the receive part of the DSPI operates as a simplified double-buffered SPI. Refer to Section 22.8.3.3: FIFO disable operation for details. 0 RX FIFO enabled 1 RX FIFO disabled | Table 367. DSPIx\_MCR field descriptions(Continued) | Field | | | Description | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------|--| | 20<br>CLR_TXF | Clear TX FIFO Flushes the TX FIFO. Write a 1 to the CLR_TXF bit to clear the TX FIFO counter. The CLR_TXF bit is always read as 0. 0 Do not clear the TX FIFO counter. 1 Clear the TX FIFO counter. | | | | | | 21<br>CLR_RXF | Flushes the I always read 0 Do not cle | Clear RX FIFO Flushes the RX FIFO. Write a 1 to the CLR_RXF bit to clear the RX counter. The CLR_RXF bit is always read as 0. 0 Do not clear the RX FIFO counter. 1 Clear the RX FIFO counter. | | | | | | | ost software to<br>hows where t | o select when the DSPI master samples SIN in modified transfe<br>the master can sample the SIN pin. The following table lists the | | | | 22–23<br>SMPL_PT | | SMPL_PT | Number of system clock cycles between odd-numbered edge of SCK_x and sampling of SIN_x | | | | [0:1] | | 00 | 0 | | | | | | 01 | 1 | | | | | | 10 | 2 | | | | | | 11 | Invalid value | | | | 24–30 | Reserved | | | | | | 31<br>HALT | | OSPI transfers<br>fers. | r software to start and stop DSPI transfers. Refer to Section 22. s for details on the operation of this bit. | 8.2: Start | | # 22.7.2.2 DSPI Transfer Count Register (DSPIx\_TCR) The DSPIx\_TCR contains a counter that indicates the number of SPI transfers made. The transfer counter is intended to assist in queue management. The user must not write to the DSPIx\_TCR while the DSPI is running. Figure 390. DSPI Transfer Count Register (DSPIx\_TCR) Table 368. DSPIx\_TCR field descriptions | Field | Description | |----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–15<br>SPI_TCNT<br>[0:15] | SPI transfer counter Counts the number of SPI transfers the DSPI makes. The SPI_TCNT field is incremented every time the last bit of an SPI frame is transmitted. A value written to SPI_TCNT presets the counter to that value. SPI_TCNT is reset to zero at the beginning of the frame when the CTCNT field is set in the executing SPI command. The transfer counter 'wraps around,' incrementing the counter past 65535 resets the counter to zero. | | 16–31 | Reserved | #### 22.7.2.3 DSPI Clock and Transfer Attributes Registers 0–7 (DSPIx\_CTARn) The DSPI modules each contain eight clock and transfer attribute registers (DSPIx\_CTAR*n*) that define different transfer attribute configurations. Each DSPIx\_CTAR controls: - Frame size - Baud rate and transfer delay values - Clock phase - Clock polarity - MSB or LSB first DSPIx\_CTARs support compatibility with the QSPI module used in certain members of the SPC56x family of MCUs. At the initiation of an SPI transfer, control logic selects the DSPIx\_CTAR that contains the transfer's attributes. Do not write to the DSPIx\_CTARs while the DSPI is running. In master mode, the DSPIx\_CTARn registers define combinations of transfer attributes such as frame size, clock phase and polarity, data bit ordering, baud rate, and various delays. In slave mode, a subset of the bit fields in the DSPIx\_CTAR0 and DSPIx\_CTAR1 registers sets the slave transfer attributes. Refer to the individual bit descriptions for details on which bits are used in slave modes. When the DSPI is configured as an SPI master, the CTAS field in the command portion of the TX FIFO entry selects which of the DSPIx\_CTAR registers is used on a per-frame basis. When the DSPI is configured as an SPI bus slave, the DSPIx\_CTAR0 register is used. Figure 391. DSPI Clock and Transfer Attributes Registers 0-7 (DSPIx\_CTARn) Table 369. DSPIx\_CTARn field descriptions | Field | Descriptions | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0<br>DBR | Double Baud Rate The DBR bit doubles the effective baud rate of the Serial Communications Clock (SCK). This field is only used in Master Mode. It effectively halves the Baud Rate division ratio supporting faster frequencies and odd division ratios for the Serial Communications Clock (SCK). When the DBR bit is set, the duty cycle of the Serial Communications Clock (SCK) depends on the value in the Baud Rate Prescaler and the Clock Phase bit as listed in <i>Table 370</i> . See the BR[0:3] field description for details on how to compute the baud rate. If the overall baud rate is divide by two or divide by three of the system clock then neither the Continuous SCK Enable or the Modified Timing Format Enable bits should be set. 0 The baud rate is computed normally with a 50/50 duty cycle. 1 The baud rate is doubled with the duty cycle depending on the baud rate prescaler. | | | | 1–4<br>FMSZ[0:3] | Frame Size The FMSZ field selects the number of bits transferred per frame. The FMSZ field is used in Master Mode and Slave Mode. <i>Table 371</i> lists the frame size encodings. | | | | 5<br>CPOL | Clock Polarity The CPOL bit selects the inactive state of the Serial Communications Clock (SCK). This bit is used in both Master and Slave Mode. For successful communication between serial devices, devices must have identical clock polarities. When the Continuous Selection Format is select switching between clock polarities without stopping the DSPI can cause errors in the transfe due to the peripheral device interpreting the switch of clock polarity as a valid clock edge. O The inactive state value of SCK is low. The inactive state value of SCK is high. | | | | 6<br>CPHA | Clock Phase The CPHA bit selects which edge of SCK causes data to change and which edge causes data to be captured. This bit is used in both Master and Slave Mode. For successful communication between serial devices, the devices must have identical clock phase settings. Continuous SCK is only supported for CPHA = 1. Data is captured on the leading edge of SCK and changed on the following edge. Data is changed on the leading edge of SCK and captured on the following edge. | | | Table 369. DSPIx\_CTARn field descriptions(Continued) | | Descriptions | | | | | |---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--| | 7<br>LSBFE | LSB First The LSBFE bit selects if the LSB or MSB of the frame is transferred first. This bit is only used in Master Mode. 0 Data is transferred MSB first. 1 Data is transferred LSB first. | | | | | | | first edge of the S | d selects the presc<br>CK. This field is on | aler value for the delay between assertion<br>ly used in Master Mode. The table lists the<br>n for details on how to compute the PCS t | e prescaler values. | | | 8–9 | | PCSSCK | PCS to SCK delay prescaler value | | | | PCSSCK[0:1] | | 00 | 1 | | | | | | 01 | 3 | | | | | | 10 | 5 | | | | | | 11 | 7 | | | | 10–11 | See the ASC[0:3] | neid description ic | or details on how to compute the After SCI | r. delay. | | | PASC[0:1] | | 90<br>00 | After SCK delay prescaler value | | | | PASC[0:1] | | 00<br>01 | 1 3 | | | | PASC[0:1] | | 00 | 1 | | | | | at the end of a fra | 00 01 10 11 fer Prescaler ects the prescaler me and the assertiaster Mode. The ta | 1<br>3<br>5 | me. The PDT field | | | PASC[0:1] 12–13 PDT[0:1] | The PDT field sel at the end of a fra is only used in Ma | 00 01 10 11 fer Prescaler ects the prescaler me and the assertiaster Mode. The ta | 1 3 5 7 value for the delay between the negation on of PCS at the beginning of the next fraible lists the prescaler values. See the DT | me. The PDT field | | | 12–13 | The PDT field sel at the end of a fra is only used in Ma | 00 01 10 11 fer Prescaler ects the prescaler me and the assertions aster Mode. The tatails on how to con | 1 3 5 7 value for the delay between the negation on of PCS at the beginning of the next fraible lists the prescaler values. See the DT[npute the delay after transfer. | me. The PDT field | | | 12–13 | The PDT field sel at the end of a fra is only used in Ma | 00 01 10 11 fer Prescaler ects the prescaler me and the asserti aster Mode. The ta tails on how to con | 3 5 7 value for the delay between the negation on of PCS at the beginning of the next fraible lists the prescaler values. See the DT pute the delay after transfer. Delay after transfer prescaler value | me. The PDT field | | | 12–13 | The PDT field sel at the end of a fra is only used in Ma | 00 01 10 11 fer Prescaler ects the prescaler me and the assertiaster Mode. The tatails on how to con | 1 3 5 7 value for the delay between the negation on of PCS at the beginning of the next fraible lists the prescaler values. See the DT pute the delay after transfer. Delay after transfer prescaler value 1 | me. The PDT field | | Table 369. DSPIx\_CTARn field descriptions(Continued) | Field | Descriptions | | | | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--| | | Baud Rate Prescale The PBR field selects the prescaler value for the baud rate. This field is only used in Master Mode. The baud rate is the frequency of the Serial Communications Clock (SCK). The system clock is divided by the prescaler value before the baud rate selection takes place. The baud rate prescaler values are listed in the table. See the BR[0:3] field description for details on how to compute the baud rate. | | | | | 14–15<br>PBR[0:1] | PBR | Baud rate prescaler value | | | | | 00 | 2 | | | | | 01 | 3 | | | | | 10 | 5 | | | | | 11 | 7 | | | | 16–19<br>CSSCK[0:3] | PCS to SCK Delay Scaler The CSSCK field selects the scaler value for the PCS to SCK delay. This field is only used in Master Mode. The PCS to SCK delay is the delay between the assertion of PCS and the first edge of the SCK. <i>Table 372</i> lists the scaler values. The PCS to SCK delay is a multiple of the system clock period and it is computed according to the following equation: Equation 51 $t_{CSC} = \frac{1}{f_{SYS}} \times PCSSCK \times CSSCK$ | | | | | 20–23<br>ASC[0:3] | See Section 22.8.4.2: CS to SCK delay (tCSC) for more details. After SCK Delay Scaler The ASC field selects the scaler value for the After SCK delay. This field is only used in Master Mode. The After SCK delay is the delay between the last edge of SCK and the negation of PCS. Table 373 lists the scaler values. The After SCK delay is a multiple of the system clock period, and it is computed according to the following equation: Equation 52 $t_{ASC} = \frac{1}{f_{SYS}} \times PASC \times ASC$ See Section 22.8.4.3: After SCK delay (tASC) for more details. | | | | Table 369. DSPIx\_CTARn field descriptions(Continued) | Field | Descriptions | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 24–27<br>DT[0:3] | Delay after Transfer Scaler The DT field selects the delay after transfer scaler. This field is only used in Master Mode. The delay after transfer is the time between the negation of the PCS signal at the end of a frame and the assertion of PCS at the beginning of the next frame. <i>Table 374</i> lists the scaler values. In continuous serial communications clock operation, the DT value is fixed to one TSCK. The delay after transfer is a multiple of the system clock period and it is computed according to the following equation: | | | | | | Equation 53 | | | | | | $t_{DT} = \frac{1}{f_{SYS}} \times PDT \times DT$ | | | | | | See Section 22.8.4.4: Delay after transfer (tDT) for more details. | | | | | | Baud Rate Scaler The BR field selects the scaler value for the baud rate. This field is only used in Master Mode. The pre-scaled system clock is divided by the baud rate scaler to generate the frequency of the SCK. <i>Table 375</i> lists the baud rate scaler values. | | | | | 28–31 | The baud rate is computed according to the following equation: | | | | | BR[0:3] | Equation 54 | | | | | | SCK baud rate = $\frac{f_{SYS}}{PBR} \times \frac{1 + DBR}{BR}$ | | | | | | See Section 22.8.4.1: Baud rate generator for more details. | | | | Table 370. DSPI SCK duty cycle | rabio or o. Bot i bott daily by old | | | | | | |-------------------------------------|------|-----|----------------|--|--| | DBR | СРНА | PBR | SCK duty cycle | | | | 0 | any | any | 50/50 | | | | 1 | 0 | 00 | 50/50 | | | | 1 | 0 | 01 | 33/66 | | | | 1 | 0 | 10 | 40/60 | | | | 1 | 0 | 11 | 43/57 | | | | 1 | 1 | 00 | 50/50 | | | | 1 | 1 | 01 | 66/33 | | | | 1 | 1 | 10 | 60/40 | | | | 1 | 1 | 11 | 57/43 | | | Table 371. DSPI transfer frame size | FMSZ | Frame size | FMSZ | Frame size | |------|------------|------|------------| | 0000 | Reserved | 1000 | 9 | | 0001 | Reserved | 1001 | 10 | | 0010 | Reserved | 1010 | 11 | Table 371. DSPI transfer frame size(Continued) | | | <u> </u> | · | |------|------------|----------|------------| | FMSZ | Frame size | FMSZ | Frame size | | 0011 | 4 | 1011 | 12 | | 0100 | 5 | 1100 | 13 | | 0101 | 6 | 1101 | 14 | | 0110 | 7 | 1110 | 15 | | 0111 | 8 | 1111 | 16 | #### Table 372. DSPI PCS to SCK delay scaler | сѕѕск | PCS to SCK delay scaler value | сѕѕск | PCS to sck delay scaler value | |-------|-------------------------------|-------|-------------------------------| | 0000 | 2 | 1000 | 512 | | 0001 | 4 | 1001 | 1024 | | 0010 | 8 | 1010 | 2048 | | 0011 | 16 | 1011 | 4096 | | 0100 | 32 | 1100 | 8192 | | 0101 | 64 | 1101 | 16384 | | 0110 | 128 | 1110 | 32768 | | 0111 | 256 | 1111 | 65536 | # Table 373. DSPI after SCK delay scaler | rable of or Dor't aries. | | | | |--------------------------|------------------------------|------|------------------------------| | ASC | After SCK delay scaler value | ASC | After SCK delay scaler value | | 0000 | 2 | 1000 | 512 | | 0001 | 4 | 1001 | 1024 | | 0010 | 8 | 1010 | 2048 | | 0011 | 16 | 1011 | 4096 | | 0100 | 32 | 1100 | 8192 | | 0101 | 64 | 1101 | 16384 | | 0110 | 128 | 1110 | 32768 | | 0111 | 256 | 1111 | 65536 | # Table 374. DSPI delay after transfer scaler | DT | Delay after transfer scaler value | DT | Delay after transfer scaler value | |------|-----------------------------------|------|-----------------------------------| | 0000 | 2 | 1000 | 512 | | 0001 | 4 | 1001 | 1024 | | 0010 | 8 | 1010 | 2048 | | 0011 | 16 | 1011 | 4096 | Table 374. DSPI delay after transfer scaler(Continued) | DT | Delay after transfer scaler value | DT | Delay after transfer scaler value | |------|-----------------------------------|------|-----------------------------------| | 0100 | 32 | 1100 | 8192 | | 0101 | 64 | 1101 | 16384 | | 0110 | 128 | 1110 | 32768 | | 0111 | 256 | 1111 | 65536 | Table 375. DSPI baud rate scaler | BR | Baud rate scaler value | BR | Baud rate scaler value | |------|------------------------|------|------------------------| | 0000 | 2 | 1000 | 256 | | 0001 | 4 | 1001 | 512 | | 0010 | 6 | 1010 | 1024 | | 0011 | 8 | 1011 | 2048 | | 0100 | 16 | 1100 | 4096 | | 0101 | 32 | 1101 | 8192 | | 0110 | 64 | 1110 | 16384 | | 0111 | 128 | 1111 | 32768 | ## 22.7.2.4 DSPI Status Register (DSPIx\_SR) The DSPIx\_SR contains status and flag bits. The bits are set by the hardware and reflect the status of the DSPI and indicate the occurrence of events that can generate interrupt or DMA requests. Software can clear flag bits in the DSPIx\_SR by writing a 1 to clear it (w1c). Writing a 0 to a flag bit has no effect. Figure 392. DSPI Status Register (DSPIx\_SR) Table 376. DSPIx\_SR field descriptions | Field Passintian | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Field | Description | | | | 0<br>TCF | Transfer complete flag Indicates that all bits in a frame have been shifted out. The TCF bit is set after the last incoming databit is sampled, but before the tASC delay starts. Refer to Section 22.8.5.1: Classic SPI transfer format (CPHA = 0) for details. The TCF bit is cleared by writing 1 to it. 0 Transfer not complete. 1 Transfer complete. | | | | 1<br>TXRXS | TX and RX status Reflects the status of the DSPI. Refer to Section 22.8.2: Start and stop of DSPI transfers for information on what clears and sets this bit. 0 TX and RX operations are disabled (DSPI is in STOPPED state). 1 TX and RX operations are enabled (DSPI is in RUNNING state). | | | | 2 | Reserved | | | | 3<br>EOQF | End of queue flag Indicates that transmission in progress is the last entry in a queue. The EOQF bit is set when the TX FIFO entry has the EOQ bit set in the command halfword and after the last incoming databit is sampled, but before the tASC delay starts. Refer to Section 22.8.5.1: Classic SPI transfer format (CPHA = 0) for details. The EOQF bit is cleared by writing 1 to it. When the EOQF bit is set, the TXRXS bit is automatically cleared. 0 EOQ is not set in the executing command. 1 EOQ bit is set in the executing SPI command. Note: EOQF does not function in slave mode. | | | | 4<br>TFUF | Transmit FIFO underflow flag Indicates that an underflow condition in the TX FIFO has occurred. The transmit underflow condition is detected only for DSPI modules operating in slave mode and SPI configuration. The TFUF bit is set when the TX FIFO of a DSPI operating in SPI slave mode is empty, and a transfer is initiated by an external SPI master. The TFUF bit is cleared by writing 1 to it. 0 TX FIFO underflow has not occurred. 1 TX FIFO underflow has occurred. | | | | 5 | Reserved | | | | 6<br>TFFF | Transmit FIFO fill flag Indicates that the TX FIFO can be filled. Provides a method for the DSPI to request more entries to be added to the TX FIFO. The TFFF bit is set while the TX FIFO is not full. The TFFF bit can be cleared by writing 1 to it, or an by acknowledgement from the eDMA controller when the TX FIFO is full. 0 TX FIFO is full. 1 TX FIFO is not full. | | | | 7–11 | Reserved | | | | 12<br>RFOF | Receive FIFO overflow flag Indicates that an overflow condition in the RX FIFO has occurred. The bit is set when the RX FIFO and shift register are full and a transfer is initiated. The bit is cleared by writing 1 to it. 0 RX FIFO overflow has not occurred. 1 RX FIFO overflow has occurred. | | | | 13 | Reserved | | | Table 376. DSPIx\_SR field descriptions(Continued) | Field | Description | |-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14<br>RFDF | Receive FIFO drain flag Indicates that the RX FIFO can be drained. Provides a method for the DSPI to request that entries be removed from the RX FIFO. The bit is set while the RX FIFO is not empty. The RFDF bit can be cleared by writing 1 to it, or by acknowledgement from the eDMA controller when the RX FIFO is empty. 0 RX FIFO is empty. 1 RX FIFO is not empty. Note: In the interrupt service routine, RFDF must be cleared only after the DSPIx_POPR is read. | | 15 | Reserved | | 16–19<br>TXCTR<br>[0:3] | TX FIFO counter Indicates the number of valid entries in the TX FIFO. The TXCTR is incremented every time the DSPI _PUSHR is written. The TXCTR is decremented every time an SPI command is executed and the SPI data is transferred to the shift register. | | 20–23<br>TXNXTPTR<br>[0:3] | Transmit next pointer Indicates which TX FIFO entry is transmitted during the next transfer. The TXNXTPTR field is updated every time SPI data is transferred from the TX FIFO to the shift register. Refer to Section 22.8.3.4: Transmit First In First Out (TX FIFO) buffering mechanism for more details. | | 24–27<br>RXCTR<br>[0:3] | RX FIFO counter Indicates the number of entries in the RX FIFO. The RXCTR is decremented every time the DSPI _POPR is read. The RXCTR is incremented after the last incoming databit is sampled, but before the tASC delay starts. Refer to Section 22.8.5.1: Classic SPI transfer format (CPHA = 0) for details. | | 28–31<br>POPNXTPTR<br>[0:3] | Pop next pointer Contains a pointer to the RX FIFO entry that is returned when the DSPIx_POPR is read. The POPNXTPTR is updated when the DSPIx_POPR is read. Refer to Section 22.8.3.5: Receive First In First Out (RX FIFO) buffering mechanism for more details. | # 22.7.2.5 DSPI DMA / Interrupt Request Select and Enable Register (DSPIx\_RSER) The DSPIx\_RSER serves two purposes: enables flag bits in the DSPIx\_SR to generate DMA requests or interrupt requests, and selects the type of request to generate. Refer to the bit descriptions for the type of requests that are supported. Do not write to the DSPIx\_RSER while the DSPI is running. Figure 393. DSPI DMA / Interrupt Request Select and Enable Register (DSPIx\_RSER) Table 377. DSPIx\_RSER field descriptions | Field | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>TCF_RE | Transmission complete request enable Enables TCF flag in the DSPIx_SR to generate an interrupt request. 0 TCF interrupt requests are disabled. 1 TCF interrupt requests are enabled. | | 1–2 | Reserved | | 3<br>EOQF_RE | DSPI finished request enable Enables the EOQF flag in the DSPIx_SR to generate an interrupt request. 0 EOQF interrupt requests are disabled. 1 EOQF interrupt requests are enabled. | | 4<br>TFUF_RE | Transmit FIFO underflow request enable The TFUF_RE bit enables the TFUF flag in the DSPIx_SR to generate an interrupt request. 0 TFUF interrupt requests are disabled. 1 TFUF interrupt requests are enabled. | | 5 | Reserved | | 6<br>TFFF_RE | Transmit FIFO fill request enable Enables the TFFF flag in the DSPIx_SR to generate a request. The TFFF_DIRS bit selects between generating an interrupt request or a DMA requests. 0 TFFF interrupt requests or DMA requests are disabled. 1 TFFF interrupt requests or DMA requests are enabled. | | 7<br>TFFF_DIRS | Transmit FIFO fill DMA or interrupt request select Selects between generating a DMA request or an interrupt request. When the TFFF flag bit in the DSPIx_SR is set, and the TFFF_RE bit in the DSPIx_RSER is set, this bit selects between generating an interrupt request or a DMA request. 0 Interrupt request is selected. 1 DMA request is selected. | | 8–11 | Reserved | | 12<br>RFOF_RE | Receive FIFO overflow request enable Enables the RFOF flag in the DSPIx_SR to generate an interrupt requests. 0 RFOF interrupt requests are disabled. 1 RFOF interrupt requests are enabled. | Field **Description** 13 Reserved Receive FIFO drain request enable Enables the RFDF flag in the DSPIx SR to generate a request. The RFDF DIRS bit selects 14 between generating an interrupt request or a DMA request. RFDF RE 0 RFDF interrupt requests or DMA requests are disabled. 1 RFDF interrupt requests or DMA requests are enabled. Receive FIFO drain DMA or interrupt request select Selects between generating a DMA request or an interrupt request. When the RFDF flag bit in the 15 DSPIx SR is set, and the RFDF RE bit in the DSPIx RSER is set, the RFDF DIRS bit selects between generating an interrupt request or a DMA request. RFDF DIRS 0 Interrupt request is selected. 1 DMA request is selected. 16-31 Reserved Table 377. DSPIx\_RSER field descriptions(Continued) #### 22.7.2.6 DSPI PUSH TX FIFO Register (DSPIx PUSHR) The DSPIx\_PUSHR provides a means to write to the TX FIFO. Data written to this register is transferred to the TX FIFO. Refer to Section 22.8.3.4: Transmit First In First Out (TX FIFO) buffering mechanism for more information. Write accesses of 8 or 16 bits to the DSPIx\_PUSHR transfer 32 bits to the TX FIFO. Note: TXDATA is used in master and slave modes. Figure 394. DSPI PUSH TX FIFO Register (DSPIx\_PUSHR) Table 378. DSPIx\_PUSHR field descriptions | Field | | | Description | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------------------------------|--|--| | 0<br>CONT | Continuous peripheral chip select enable Selects a continuous selection format. The bit is used in SPI master mode. The bit enables the selected CS signals to remain asserted between transfers. Refer to Section 22.8.5.5: Continuous selection format for more information. 0 Return peripheral chip select signals to their inactive state between transfers. 1 Keep peripheral chip select signals asserted between transfers. | | | | | | Clock and transfer attributes select Selects which of the DSPIx_CTARs sets the transfer attributes for the SPI frame. In SF mode, DSPIx_CTAR0 is used. The following table shows how the CTAS values map to DSPIx_CTARs. There are eight DSPIx_CTARs in the device DSPI implementation. Note: Use in SPI master mode only. | | | | | | | | | CTAS | Use Clock and Transfer<br>Attributes from | | | | 1–3<br>CTAS | | 000 | DSPIx_CTAR0 | | | | [0:2] | | 001 | DSPIx_CTAR1 | | | | | | 010 | DSPIx_CTAR2 | | | | | | 011 | DSPIx_CTAR3 | | | | | | 100 | DSPIx_CTAR4 | | | | | | 101 | DSPIx_CTAR5 | | | | | | 110 | DSPIx_CTAR6 | | | | | | 111 | DSPIx_CTAR7 | | | | 4<br>EOQ | End of queue Provides a means for host software to signal to the DSPI that the current SPI transfer is the last in a queue. At the end of the transfer the EOQF bit in the DSPIx_SR is set. O The SPI data is not the last data to transfer. 1 The SPI data is the last data to transfer. Note: Use in SPI master mode only. | | | | | | 5<br>CTCNT | Note: Use in SPI master mode only. Clear SPI_TCNT Provides a means for host software to clear the SPI transfer counter. The CTCNT bit clears the SPI_TCNT field in the DSPIx_TCR. The SPI_TCNT field is cleared before transmission of the current SPI frame begins. 0 Do not clear SPI_TCNT field in the DSPIx_TCR. 1 Clear SPI_TCNT field in the DSPIx_TCR. Note: Use in SPI master mode only. | | | | | | 6–7 | Reserved | | | | | Field Peripheral chip select x Selects which CSx signals are asserted for the transfer. 0 Negate the CSx signal. 1 Assert the CSx signal. Note: Use in SPI master mode only. Transmit data TXDATA [0:15] Note: Use TXDATA in master and slave modes. Table 378. DSPIx PUSHR field descriptions(Continued) #### 22.7.2.7 DSPI POP RX FIFO Register (DSPIx\_POPR) The DSPIx\_POPR allows you to read the RX FIFO. Refer to Section 22.8.3.5: Receive First In First Out (RX FIFO) buffering mechanism for a description of the RX FIFO operations. Eight or 16-bit read accesses to the DSPIx\_POPR fetch the RX FIFO data, and update the counter and pointer. Note: Reading the RX FIFO field fetches data from the RX FIFO. Once the RX FIFO is read, the read data pointer is moved to the next entry in the RX FIFO. Therefore, read DSPIx\_POPR only when you need the data. For compatibility, configure the TLB (MMU table) entry for DSPIx\_POPR as guarded. Figure 395. DSPI POP RX FIFO Register (DSPIx\_POPR) Field Description 0–15 Reserved, must be cleared. 16–31 Received data RXDATA The RXDATA field contains the SPI data from the RX FIFO entry pointed to by the pop next data pointer (POPNXTPTR). Table 379. DSPIx POPR field descriptions ## 22.7.2.8 DSPI Transmit FIFO Registers 0–4 (DSPIx\_TXFRn) The DSPIx\_TXFR*n* registers provide visibility into the TX FIFO for debugging purposes. Each register is an entry in the TX FIFO. The registers are read-only and cannot be modified. Reading the DSPIx\_TXFR*n* registers does not alter the state of the TX FIFO. The MCU uses five registers to implement the TX FIFO, that is DSPIx\_TXFR0-DSPIx\_TXFR4 are used. Figure 396. DSPI Transmit FIFO Register 0-4 (DSPIx\_TXFRn) Field O-15 TXCMD [0:15] Transmit command Contains the command that sets the transfer attributes for the SPI data. Refer to Section 22.7.2.6: DSPI PUSH TX FIFO Register (DSPIx\_PUSHR) for details on the command field. Table 380. DSPIx\_TXFRn field descriptions #### 22.7.2.9 DSPI Receive FIFO Registers 0–4 (DSPIx\_RXFRn) Contains the SPI data to be shifted out. Transmit data **TXDATA** [0:15] The DSPIx\_RXFR*n* registers provide visibility into the RX FIFO for debugging purposes. Each register is an entry in the RX FIFO. The DSPIx\_RXFR registers are read-only. Reading the DSPIx\_RXFR*n* registers does not alter the state of the RX FIFO. The device uses five registers to implement the RX FIFO, that is DSPIx\_RXFR0-DSPIx\_RXFR4 are used. Figure 397. DSPI Receive FIFO Registers 0-4 (DSPIx\_RXFRn) Table 381. DSPIx\_RXFRn field description | Field | Description | |---------------------------|----------------------------------------------| | 0–15 | Reserved, must be cleared. | | 16–31<br>RXDATA<br>[15:0] | Receive data Contains the received SPI data. | ## 22.8 Functional description The DSPI supports full-duplex, synchronous serial communications between the MCU and peripheral devices. All communications are through an SPI-like protocol. The DSPI supports only the serial peripheral interface (SPI) configuration in which the DSPI operates as a basic SPI or a queued SPI. The DCONF field in the DSPIx\_MCR determines the DSPI configuration. Refer to *Table 367* for the DSPI configuration values. The DSPIx\_CTAR0-DSPIx\_CTAR7 registers hold clock and transfer attributes. The SPI configuration can select which CTAR to use on a frame by frame basis by setting the CTAS field in the DSPIx\_PUSHR. The 16-bit shift register in the master and the 16-bit shift register in the slave are linked by the SOUT\_x and SIN\_x signals to form a distributed 32-bit register. When a data transfer operation is performed, data is serially shifted a pre-determined number of bit positions. Because the registers are linked, data is exchanged between the master and the slave; the data that was in the master's shift register is now in the shift register of the slave, and vice versa. At the end of a transfer, the TCF bit in the DSPIx\_SR is set to indicate a completed transfer. *Figure 398* illustrates how master and slave data is exchanged. Figure 398. SPI serial protocol overview Each DSPI has four peripheral chip select $(\overline{CSx})$ signals that select the slaves with which to communicate (DSPI 0 and DSPI 1 have eight CSx signals.) Transfer protocols and timing properties are shared by the three DSPI configurations; these properties are described independently of the configuration in Section 22.8.5: Transfer formats. The transfer rate and delay settings are described in Section 22.8.4: DSPI baud rate and clock delay generation. Refer to Section 22.8.8: Power saving features for information on the power-saving features of the DSPI. ### 22.8.1 Modes of operation The DSPI modules have four available distinct modes: - Master mode - Slave mode - Module disable mode - Debug mode Master, slave, and module disable modes are module-specific modes while debug mode is a device-specific mode. All four modes are implemented on this device. The module-specific modes are determined by bits in the DSPIx\_MCR. Debug mode is a mode that the entire device can enter in parallel with the DSPI being configured in one of its module-specific modes. #### 22.8.1.1 Master mode In master mode the DSPI can initiate communications with peripheral devices. The DSPI operates as bus master when the MSTR bit in the DSPIx\_MCR is set. The serial communications clock (SCK) is controlled by the master DSPI. All three DSPI configurations are valid in master mode. In SPI configuration, master mode transfer attributes are controlled by the SPI command in the current TX FIFO entry. The CTAS field in the SPI command selects which of the eight DSPIx\_CTARs set the transfer attributes. Transfer attribute control is on a frame by frame basis. Refer to Section 22.8.3: Serial Peripheral Interface (SPI) configuration for more details. #### 22.8.1.2 Slave mode In slave mode the DSPI responds to transfers initiated by an SPI master. The DSPI operates as bus slave when the MSTR bit in the <u>DSPIx\_MCR</u> is negated. The DSPI slave is selected by a bus master by having the slave's <u>CSO\_x</u> asserted. In slave mode, the SCK is provided by the bus master. All transfer attributes are controlled by the bus master, except the clock polarity, clock phase, and the number of bits to transfer. These must be configured in the DSPI slave for correct communications. #### 22.8.1.3 Module disable mode The module disable mode is used for MCU power management. The clock to the non-memory mapped logic in the DSPI is stopped while in module disable mode. The DSPI enters the module disable mode when the MDIS bit in DSPIx MCR is set. Refer to Section 22.8.8: Power saving features for more details on the module disable mode. #### 22.8.1.4 Debug mode The debug mode is used for system development and debugging. If the MCU enters debug mode while the FRZ bit in the DSPIx\_MCR is set, the DSPI stops all serial transfers and enters a stopped state. If the MCU enters debug mode while the FRZ bit is cleared, the DSPI behavior is unaffected and remains dictated by the module-specific mode and configuration of the DSPI. The DSPI enters debug mode when a debug request is asserted by an external controller. Refer to Figure 399 for a state diagram. ### 22.8.2 Start and stop of DSPI transfers The DSPI has two operating states: STOPPED and RUNNING. The states are independent of DSPI configuration. The default state of the DSPI is STOPPED. In the STOPPED state no serial transfers are initiated in master mode and no transfers are responded to in slave mode. The STOPPED state is also a safe state for writing the various configuration registers of the DSPI without causing undetermined results. The TXRXS bit in the DSPIx\_SR is cleared in this state. In the RUNNING state, serial transfers take place. The TXRXS bit in the DSPIx SR is set in the RUNNING state. Figure 399 shows a state diagram of the start and stop mechanism. Figure 399. DSPI start and stop state diagram The transitions are described in *Table 382*. | Transition # | Current State | Next State | Description | | |--------------|---------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | RESET | STOPPED | Generic power-on-reset transition | | | 1 | STOPPED | RUNNING | The DSPI starts (transitions from STOPPED to RUNNING) when all of the following conditions are true: - EOQF bit is clear - Debug mode is unselected or the FRZ bit is clear - HALT bit is clear | | | 2 | RUNNING | STOPPED | The DSPI stops (transitions from RUNNING to STOPPED) after the current frame for any one of the following conditions: - EOQF bit is set - Debug mode is selected and the FRZ bit is set - HALT bit is set | | Table 382. State transitions for start and stop of DSPI transfers State transitions from RUNNING to STOPPED occur on the next frame boundary if a transfer is in progress, or on the next system clock cycle if no transfers are in progress. ### 22.8.3 Serial Peripheral Interface (SPI) configuration The SPI configuration transfers data serially using a shift register and a selection of programmable transfer attributes. The DSPI is in SPI configuration when the DCONF field in the DSPIx\_MCR is 0b00. The SPI frames can be from 4 to 16 bits long. The data to be transmitted can come from queues stored in RAM external to the DSPI. Host software or an eDMA controller can transfer the SPI data from the queues to a first-in first-out (FIFO) buffer. The received data is stored in entries in the receive FIFO (RX FIFO) buffer. Host software or an eDMA controller transfers the received data from the RX FIFO to memory external to the DSPI. The FIFO buffer operations are described in Section 22.8.3.4: Transmit First In First Out (TX FIFO) buffering mechanism and Section 22.8.3.5: Receive First In First Out (RX FIFO) buffering mechanism. The interrupt and DMA request conditions are described in *Section 22.8.7: Interrupts/DMA requests*. The SPI configuration supports two module-specific modes; master mode and slave mode. The FIFO operations are similar for the master mode and slave mode. The main difference is that in master mode the DSPI initiates and controls the transfer according to the fields in the SPI command field of the TX FIFO entry. In slave mode the DSPI only responds to transfers initiated by a bus master external to the DSPI and the SPI command field of the TX FIFO entry is ignored. ## 22.8.3.1 SPI master mode In SPI master mode the DSPI initiates the serial transfers by controlling the serial communications clock (SCK\_x) and the peripheral chip select (CSx) signals. The SPI command field in the executing TX FIFO entry determines which CTARs set the transfer attributes and which CSx signals to assert. The command field also contains various bits that help with queue management and transfer protocol. The data field in the executing TX FIFO entry is loaded into the shift register and shifted out on the serial out (SOUT\_x) pin. In SPI master mode, each SPI frame to be transmitted has a command associated with it allowing for transfer attribute control on a frame by frame basis. Refer to Section 22.7.2.6: DSPI PUSH TX FIFO Register (DSPIx\_PUSHR) for details on the SPI command fields. #### 22.8.3.2 SPI slave mode In SPI slave mode the DSPI responds to transfers initiated by an SPI bus master. The DSPI does not initiate transfers. Certain transfer attributes such as clock polarity, clock phase and frame size must be set for successful communication with an SPI master. The SPI slave mode transfer attributes are set in the DSPIx\_CTAR0. #### 22.8.3.3 FIFO disable operation The FIFO disable mechanisms allow SPI transfers without using the TX FIFO or RX FIFO. The DSPI operates as a double-buffered simplified SPI when the FIFOs are disabled. The TX and RX FIFOs are disabled separately. The TX FIFO is disabled by writing a 1 to the DIS\_TXF bit in the DSPIx\_MCR. The RX FIFO is disabled by writing a 1 to the DIS\_RXF bit in the DSPIx MCR. The FIFO disable mechanisms are transparent to the user and to host software; transmit data and commands are written to the DSPIx\_PUSHR and received data is read from the DSPIx\_POPR. When the TX FIFO is disabled, the TFFF, TFUF, and TXCTR fields in DSPIx\_SR behave as if there is a one-entry FIFO but the contents of the DSPIx\_TXFRs and TXNXTPTR are undefined. When the RX FIFO is disabled, the RFDF, RFOF, and RXCTR fields in the DSPIx\_SR behave as if there is a one-entry FIFO but the contents of the DSPIx RXFRs and POPNXTPTR are undefined. Disable the TX and RX FIFOs only if the FIFO must be disabled as a requirement of the application's operating mode. A FIFO must be disabled before it is accessed. Failure to disable a FIFO prior to a first FIFO access is not supported, and can result in incorrect results. #### 22.8.3.4 Transmit First In First Out (TX FIFO) buffering mechanism The TX FIFO functions as a buffer of SPI data and SPI commands for transmission. The TX FIFO holds five entries, each consisting of a command field and a data field. SPI commands and data are added to the TX FIFO by writing to the DSPI push TX FIFO register (DSPIx\_PUSHR). For more information on DSPIx\_PUSHR refer to Section 22.7.2.6: DSPI PUSH TX FIFO Register (DSPIx\_PUSHR). TX FIFO entries can only be removed from the TX FIFO by being shifted out or by flushing the TX FIFO. The TX FIFO counter field (TXCTR) in the DSPI status register (DSPIx\_SR) indicates the number of valid entries in the TX FIFO. The TXCTR is updated every time the DSPI \_PUSHR is written or SPI data is transferred into the shift register from the TX FIFO. Refer to Section 22.7.2.4: DSPI Status Register (DSPIx\_SR) for more information on DSPIx\_SR. The TXNXTPTR field indicates which TX FIFO entry is transmitted during the next transfer. The TXNXTPTR contains the positive offset from DSPIx\_TXFR0 in number of 32-bit registers. For example, TXNXTPTR equal to two means that the DSPIx\_TXFR2 contains the SPI data and command for the next transfer. The TXNXTPTR field is incremented every time SPI data is transferred from the TX FIFO to the shift register. ### 22.8.3.4.1 Filling the TX FIFO Host software or the eDMA controller can add (push) entries to the TX FIFO by writing to the DSPIx\_PUSHR. When the TX FIFO is not full, the TX FIFO fill flag (TFFF) in the DSPIx\_SR is set. The TFFF bit is cleared when the TX FIFO is full and the eDMA controller indicates that a write to DSPIx\_PUSHR is complete or alternatively by host software writing a 1 to the TFFF in the DSPIx\_SR. The TFFF can generate a DMA request or an interrupt request. Refer to Section 22.8.7.2: Transmit FIFO fill interrupt or DMA request (TFFF) for details. The DSPI ignores attempts to push data to a full TX FIFO; that is, the state of the TX FIFO is unchanged. No error condition is indicated. ## 22.8.3.4.2 Draining the TX FIFO The TX FIFO entries are removed (drained) by shifting SPI data out through the shift register. Entries are transferred from the TX FIFO to the shift register and shifted out as long as there are valid entries in the TX FIFO. Every time an entry is transferred from the TX FIFO to the shift register, the TX FIFO counter is decremented by one. At the end of a transfer, the TCF bit in the DSPIx\_SR is set to indicate the completion of a transfer. The TX FIFO is flushed by writing a 1 to the CLR TXF bit in DSPIx MCR. If an external SPI bus master initiates a transfer with a DSPI slave while the slave's DSPI TX FIFO is empty, the transmit FIFO underflow flag (TFUF) in the slave's DSPIx\_SR is set. Refer to Section 22.8.7.4: Transmit FIFO underflow interrupt request (TFUF) for details. #### 22.8.3.5 Receive First In First Out (RX FIFO) buffering mechanism The RX FIFO functions as a buffer for data received on the SIN pin. The RX FIFO holds five received SPI data frames. SPI data is added to the RX FIFO at the completion of a transfer when the received data in the shift register is transferred into the RX FIFO. SPI data is removed (popped) from the RX FIFO by reading the DSPIx\_POPR. RX FIFO entries can only be removed from the RX FIFO by reading the DSPIx\_POPR or by flushing the RX FIFO. Refer to Section 22.7.2.7: DSPI POP RX FIFO Register (DSPIx\_POPR) for more information on the DSPIx\_POPR. The RX FIFO counter field (RXCTR) in the DSPI status register (DSPIx\_SR) indicates the number of valid entries in the RX FIFO. The RXCTR is updated every time the DSPI\_POPR is read or SPI data is copied from the shift register to the RX FIFO. The POPNXTPTR field in the DSPIx\_SR points to the RX FIFO entry that is returned when the DSPIx\_POPR is read. The POPNXTPTR contains the positive, 32-bit word offset from DSPIx\_RXFR0. For example, POPNXTPTR equal to two means that the DSPIx\_RXFR2 contains the received SPI data that is returned when DSPIx\_POPR is read. The POPNXTPTR field is incremented every time the DSPIx\_POPR is read. POPNXTPTR rolls over every four frames on the MCU. #### 22.8.3.5.1 Filling the RX FIFO The RX FIFO is filled with the received SPI data from the shift register. While the RX FIFO is not full, SPI frames from the shift register are transferred to the RX FIFO. Every time an SPI frame is transferred to the RX FIFO the RX FIFO counter is incremented by one. If the RX FIFO and shift register are full and a transfer is initiated, the RFOF bit in the DSPIx\_SR is set indicating an overflow condition. Depending on the state of the ROOE bit in the DSPIx\_MCR, the data from the transfer that generated the overflow is ignored or put in the shift register. If the ROOE bit is set, the incoming data is put in the shift register. If the ROOE bit is cleared, the incoming data is ignored. ### 22.8.3.5.2 Draining the RX FIFO Host software or the eDMA can remove (pop) entries from the RX FIFO by reading the DSPIx\_POPR. A read of the DSPIx\_POPR decrements the RX FIFO counter by one. Attempts to pop data from an empty RX FIFO are ignored, the RX FIFO counter remains unchanged. The data returned from reading an empty RX FIFO is undetermined. Refer to Section 22.7.2.7: DSPI POP RX FIFO Register (DSPIx\_POPR) for more information on DSPIx\_POPR. When the RX FIFO is not empty, the RX FIFO drain flag (RFDF) in the DSPIx\_SR is set. The RFDF bit is cleared when the RX\_FIFO is empty and the eDMA controller indicates that a read from DSPIx\_POPR is complete; alternatively the RFDF bit can be cleared by the host writing a 1 to it. ## 22.8.4 DSPI baud rate and clock delay generation The SCK\_x frequency and the delay values for serial transfer are generated by dividing the system clock frequency by a prescaler and a scaler with the option of doubling the baud rate. Figure 400 shows conceptually how the SCK signal is generated. Figure 400. Communications clock prescalers and scalers ### 22.8.4.1 Baud rate generator The baud rate is the frequency of the serial communication clock (SCK\_x). The system clock is divided by a baud rate prescaler (defined by DSPIx\_CTAR[PBR]) and baud rate scaler (defined by DSPIx\_CTAR[BR]) to produce SCK\_x with the possibility of doubling the baud rate. The DBR, PBR, and BR fields in the DSPIx\_CTARs select the frequency of SCK\_x using the following formula: #### **Equation 55** SCK baud rate = $$\frac{f_{SYS}}{PBRPrescalerValue} \times \frac{1 + DBR}{BRScalerValue}$$ Table 383 shows an example of a computed baud rate. Table 383. Baud rate computation example | f <sub>SYS</sub> | PBR | Prescaler value | BR | Scaler value | DBR value | Baud rate | |------------------|------|-----------------|--------|--------------|-----------|-----------| | 100 MHz | 0b00 | 2 | 0b0000 | 2 | 0 | 25 Mbit/s | | 20 MHz | 0b00 | 2 | 0b0000 | 2 | 1 | 10 Mbit/s | ### 22.8.4.2 CS to SCK delay (t<sub>CSC</sub>) The $\overline{\text{CS}_X}$ to $\overline{\text{SCK}_X}$ delay is the length of time from assertion of the $\overline{\text{CS}_X}$ signal to the first $\overline{\text{SCK}_X}$ edge. Refer to $\overline{\text{Figure 402}}$ for an illustration of the $\overline{\text{CS}_X}$ to $\overline{\text{SCK}_X}$ delay. The PCSSCK and CSSCK fields in the DSPIx\_CTARn registers select the $\overline{\text{CS}_X}$ to $\overline{\text{SCK}_X}$ delay, and the relationship is expressed by the following formula: #### **Equation 56** $$t_{CSC}$$ = $\frac{1}{f_{SYS}}$ × PCSSCK × CSSCK Table 384 shows an example of the computed $\overline{CS}$ to SCK x delay. Table 384. CS to SCK delay computation example | PCSSCK | Prescaler value | сѕѕск | Scaler value | f <sub>SYS</sub> | CS to SCK delay | |--------|-----------------|--------|--------------|------------------|-----------------| | 0b01 | 3 | 0b0100 | 32 | 100 MHz | 0.96 μs | #### 22.8.4.3 After SCK delay (t<sub>ASC</sub>) The after SCK\_x delay is the length of time between the last edge of SCK\_x and the deassertion of CS\_x. Refer to Figure 402 and Figure 403 for illustrations of the after SCK\_x delay. The PASC and ASC fields in the DSPIx\_CTARn registers select the after SCK delay. The relationship between these variables is given in the following formula: #### **Equation 57** $$t_{ASC} = \frac{1}{f_{SYS}} \times PASC \times ASC$$ Table 385 shows an example of the computed after SCK delay. Table 385. After SCK delay computation example | PASC | Prescaler value | ASC | Scaler value | f <sub>SYS</sub> | After SCK delay | |------|-----------------|--------|--------------|------------------|-----------------| | 0b01 | 3 | 0b0100 | 32 | 100 MHz | 0.96 μs | #### 22.8.4.4 Delay after transfer (t<sub>DT</sub>) The delay after transfer is the length of time between negation of the $\overline{CSx}$ signal for a frame and the assertion of the $\overline{CSx}$ signal for the next frame. The PDT and DT fields in the DSPIx\_CTARn registers select the delay after transfer. Refer to Figure 402 for an illustration of the delay after transfer. The following formula expresses the PDT/DT/delay after transfer relationship: #### **Equation 58** $$t_{DT} = \frac{1}{f_{SYS}} \times PDT \times DT$$ Table 386 shows an example of the computed delay after transfer. Table 386. Delay after transfer computation example | | PDT | Prescaler value | DT | Scaler value | f <sub>SYS</sub> | Delay after transfer | |---|------|-----------------|--------|--------------|------------------|----------------------| | Ī | 0b01 | 3 | 0b1110 | 32768 | 100 MHz | 0.98 ms | ## 22.8.4.5 Peripheral Chip Select strobe enable $(\overline{CS5}_x)$ The CS5\_x signal provides a delay to allow the CSx signals to settle after transitioning, thereby avoiding glitches. When the DSPI is in master mode and PCSSE bit is set in the DSPIx\_MCR, CS5\_x provides a signal for an external demultiplexer to decode the CS4\_x signals into as many as 32 glitch-free CSx signals. *Figure 401* shows the timing of the CS5\_*x* signal relative to CS signals. Figure 401. Peripheral Chip Select strobe timing The delay between the assertion of the CSx signals and the assertion of CS5\_x signal is selected by the PCSSCK field in the DSPIx\_CTAR based on the following formula: #### **Equation 59** $$t_{PCSSCK} = \frac{1}{f_{SYS}} \times PCSSCK$$ At the end of the transfer the delay between CS5\_x negation and CSx negation is selected by the PASC field in the DSPIx\_CTAR based on the following formula: #### **Equation 60** $$t_{PASC} = \frac{1}{f_{SYS}} \times PASC$$ Table 387 shows an example of the computed tpcssck delay. Table 387. Peripheral Chip Select strobe assert computation example | PCSSCK | Prescaler | f <sub>SYS</sub> | Delay before transfer | |--------|-----------|------------------|-----------------------| | 0b11 | 7 | 100 MHz | 70.0 ns | Table 388 shows an example of the computed the t<sub>PASC</sub> delay. Table 388. Peripheral Chip Select strobe negate computation example | PASC | Prescaler | f <sub>SYS</sub> | Delay after transfer | |------|-----------|------------------|----------------------| | 0b11 | 7 | 100 MHz | 70.0 ns | #### 22.8.5 Transfer formats The SPI serial communication is controlled by the serial communications clock (SCK\_x) signal and the CSx signals. The SCK\_x signal provided by the master device synchronizes shifting and sampling of the data by the SIN\_x and SOUT\_x pins. The CSx signals serve as enable signals for the slave devices. When the DSPI is the bus master, the CPOL and CPHA bits in the DSPI clock and transfer attributes registers (DSPIx\_CTARn) select the polarity and phase of the serial clock, SCK\_x. The polarity bit selects the idle state of the SCK\_x. The clock phase bit selects if the data on SOUT x is valid before or on the first SCK x edge. When the DSPI is the bus slave, CPOL and CPHA bits in the DSPIx\_CTAR0 (SPI slave mode) select the polarity and phase of the serial clock. Even though the bus slave does not control the SCK signal, clock polarity, clock phase and number of bits to transfer must be identical for the master device and the slave device to ensure proper transmission. The DSPI supports four different transfer formats: - Classic SPI with CPHA = 0 - Classic SPI with CPHA = 1 - Modified transfer format with CPHA = 0 - Modified transfer format with CPHA = 1 A modified transfer format is supported to allow for high-speed communication with peripherals that require longer setup times. The DSPI can sample the incoming data later than halfway through the cycle to give the peripheral more setup time. The MTFE bit in the DSPIx\_MCR selects between classic SPI format and modified transfer format. The classic SPI formats are described in Section 22.8.5.1: Classic SPI transfer format (CPHA = 0) and Section 22.8.5.2: Classic SPI transfer format (CPHA = 1)." The modified transfer formats are described in Section 22.8.5.3: Modified SPI transfer format (MTFE = 1, CPHA = 0) and Section 22.8.5.4: Modified SPI transfer format (MTFE = 1, CPHA = 1)." In the SPI configuration, the DSPI provides the option of keeping the CS signals asserted between frames. Refer to Section 22.8.5.5: Continuous selection format for details. #### 22.8.5.1 Classic SPI transfer format (CPHA = 0) The transfer format shown in *Figure 402* is used to communicate with peripheral SPI slave devices where the first data bit is available on the first clock edge. In this format, the master and slave sample their SIN\_x pins on the odd-numbered SCK\_x edges and change the data on their SOUT\_x pins on the even-numbered SCK\_x edges. Figure 402. DSPI transfer timing diagram (MTFE = 0, CPHA = 0, FMSZ = 8) The master initiates the transfer by placing its first data bit on the SOUT\_x pin and asserting the appropriate peripheral chip select signals to the slave device. The slave responds by placing its first data bit on its SOUT\_x pin. After the $t_{CSC}$ delay has elapsed, the master outputs the first edge of SCK\_x. This is the edge used by the master and slave devices to sample the first input data bit on their serial data input signals. At the second edge of the SCK\_x the master and slave devices place their second data bit on their serial data output signals. For the rest of the frame the master and the slave sample their SIN\_x pins on the odd-numbered clock edges and changes the data on their SOUT\_x pins on the even-numbered clock edges. After the last clock edge occurs a delay of $t_{ASC}$ is inserted before the master negates the CS signals. A delay of $t_{DT}$ is inserted before a new frame transfer can be initiated by the master. For the CPHA = 0 condition of the master, TCF and EOQF are set and the RXCTR counter is updated at the next to last serial clock edge of the frame (edge 15) of *Figure 402*. For the CPHA = 0 condition of the slave, TCF is set and the RXCTR counter is updated at the last serial clock edge of the frame (edge 16) of *Figure 402*. #### 22.8.5.2 Classic SPI transfer format (CPHA = 1) The transfer format shown in *Figure 403* is used to communicate with peripheral SPI slave devices that require the first SCK\_x edge before the first data bit becomes available on the slave SOUT\_x pin. In this format the master and slave devices change the data on their SOUT\_x pins on the odd-numbered SCK\_x edges and sample the data on their SIN\_x pins on the even-numbered SCK\_x edges. Figure 403. DSPI transfer timing diagram (MTFE = 0, CPHA = 1, FMSZ = 8) The master initiates the transfer by asserting the CSx signal to the slave. After the $t_{CSC}$ delay has elapsed, the master generates the first SCK $_x$ edge and at the same time places valid data on the master SOUT $_x$ pin. The slave responds to the first SCK $_x$ edge by placing its first data bit on its slave SOUT $_x$ pin. At the second edge of the SCK\_x the master and slave sample their SIN\_x pins. For the rest of the frame the master and the slave change the data on their SOUT\_x pins on the odd-numbered clock edges and sample their SIN\_x pins on the even-numbered clock edges. After the last clock edge occurs a delay of $t_{ASC}$ is inserted before the master negates the CSx signal. A delay of $t_{DT}$ is inserted before a new frame transfer can be initiated by the master. For CPHA = 1 the master EOQF and TCF and slave TCF are set at the last serial clock edge (edge 16) of *Figure 403*. For CPHA = 1 the master and slave RXCTR counters are updated on the same clock edge. #### 22.8.5.3 Modified SPI transfer format (MTFE = 1, CPHA = 0) In this modified transfer format both the master and the slave sample later in the SCK period than in classic SPI mode to allow for delays in device pads and board traces. These delays become a more significant fraction of the SCK period as the SCK period decreases with increasing baud rates. Note: For the modified transfer format to operate correctly, you must thoroughly analyze the SPI link timing budget. The master and the slave place data on the SOUT\_x pins at the assertion of the CSx signal. After the CSx to SCK\_x delay has elapsed the first SCK\_x edge is generated. The slave samples the master SOUT\_x signal on every odd numbered SCK\_x edge. The slave also places new data on the slave SOUT\_x on every odd numbered clock edge. The master places its second data bit on the SOUT\_x line one system clock after odd numbered SCK\_x edge. The point where the master samples the slave SOUT\_x is selected by writing to the SMPL\_PT field in the DSPIx\_MCR. *Table 389* lists the number of system clock cycles between the active edge of SCK\_x and the master sample point for different values of the SMPL\_PT bit field. The master sample point can be delayed by one or two system clock cycles. SMPL\_PT Number of system clock cycles between odd-numbered edge of SCK and sampling of SIN 00 01 1 10 2 Invalid value Table 389. Delayed master sample point *Figure 404* shows the modified transfer format for CPHA = 0. Only the condition where CPOL = 0 is illustrated. The delayed master sample points are indicated with a lighter shaded arrow. Figure 404. DSPI modified transfer format (MTFE = 1, CPHA = 0, $f_{SCK} = f_{SYS} / 4$ ) #### 22.8.5.4 Modified SPI transfer format (MTFE = 1, CPHA = 1) At the start of a transfer the DSPI asserts the CS signal to the slave device. After the CS to SCK delay has elapsed the master and the slave put data on their SOUT pins at the first edge of SCK. The slave samples the master SOUT signal on the even numbered edges of SCK. The master samples the slave SOUT signal on the odd numbered SCK edges starting with the 3rd SCK edge. The slave samples the last bit on the last edge of the SCK. The master samples the last slave SOUT bit one half SCK cycle after the last edge of SCK. No clock edge is visible on the master SCK pin during the sampling of the last bit. The SCK to CS delay must be programmed to be greater than or equal to half the SCK period. Note: For the modified transfer format to operate correctly, you must thoroughly analyze the SPI link timing budget. *Figure 405* shows the modified transfer format for CPHA = 1. Only the condition where CPOL = 0 is shown. Figure 405. DSPI modified transfer format (MTFE = 1, CPHA = 1, $f_{SCK} = f_{SYS} / 4$ ) #### 22.8.5.5 Continuous selection format Some peripherals must be deselected between every transfer. Other peripherals must remain selected between several sequential serial transfers. The continuous selection format provides the flexibility to handle both cases. The continuous selection format is enabled for the SPI configuration by setting the CONT bit in the SPI command. When the CONT bit = 0, the DSPI drives the asserted chip select signals to their idle states in between frames. The idle states of the chip select signals are selected by the PCSIS field in the DSPIx MCR. Figure 406 shows the timing diagram for two 4-bit transfers with CPHA = 1 and CONT = 0. When the CONT = 1 and the CS signal for the next transfer is the same as for the current transfer, the CS signal remains asserted for the duration of the two transfers. The delay between transfers ( $t_{\rm DT}$ ) is not inserted between the transfers. Figure 407 shows the timing diagram for two 4-bit transfers with CPHA = 1 and CONT = 1. In *Figure 407*, the period length at the start of the next transfer is the sum of $t_{ASC}$ and $t_{CSC}$ ; i.e., it does not include a half-clock period. The default settings for these provide a total of four system clocks. In many situations, $t_{ASC}$ and $t_{CSC}$ must be increased if a full half-clock period is required. Switching CTARs between frames while using continuous selection can cause errors in the transfer. The CS signal must be negated before CTAR is switched. When the CONT bit = 1 and the CS signals for the next transfer are different from the present transfer, the CS signals behave as if the CONT bit was not set. Note: It is mandatory to fill the TXFIFO with the number of entries that will be concatenated together under one PCS assertion for both master and slave before the TXFIFO becomes empty. For example; while transmitting in master mode, it should be ensured that the last entry in the TXFIFO, after which TXFIFO becomes empty, must have the CONT bit in command frame as deasserted (i.e. CONT bit = 0). While operating in slave mode, it should be ensured that when the last-entry in the TXFIFO is completely transmitted (i.e. the corresponding TCF flag is asserted and TXFIFO is empty) the slave should be de-selected for any further serial communication; else an underflow error occurs ### 22.8.5.6 Clock polarity switching between DSPI transfers If it is desired to switch polarity between non-continuous DSPI frames, the edge generated by the change in the idle state of the clock occurs one system clock before the assertion of the chip select for the next frame. Refer to Section 22.7.2.3: DSPI Clock and Transfer Attributes Registers 0–7 (DSPIx\_CTARn). In *Figure 408*, time 'A' shows the one clock interval. Time 'B' is user programmable from a minimum of two system clocks. Figure 408. Polarity switching between frames ## 22.8.6 Continuous Serial communications clock The DSPI provides the option of generating a continuous SCK signal for slave peripherals that require a continuous clock. Continuous SCK is enabled by setting the CONT\_SCKE bit in the DSPIx\_MCR. Continuous SCK is valid in all configurations. Continuous SCK is only supported for CPHA = 1. Setting CPHA = 0 is ignored if the CONT SCKE bit is set. Continuous SCK is supported for modified transfer format. Clock and transfer attributes for the continuous SCK mode are set according to the following rules: - When the DSPI is in SPI configuration, CTAR0 is used initially. At the start of each SPI frame transfer, the CTAR specified by the CTAS for the frame is used. - In all configurations, the currently selected CTAR remains in use until the start of a frame with a different CTAR specified, or the continuous SCK mode is terminated. The device is designed to use the same baud rate for all transfers made while using the continuous SCK. Switching clock polarity between frames while using continuous SCK can cause errors in the transfer. Continuous SCK operation is not guaranteed if the DSPI is put into module disable mode. Enabling continuous SCK disables the CS to SCK delay and the After SCK delay. The delay after transfer is fixed at one SCK cycle. *Figure 409* shows timing diagram for continuous SCK format with continuous selection disabled. Note: When in Continuous SCK mode, for the SPI transfer CTAR0 should always be used, and the TX-FIFO must be clear using the MCR.CLR TXF field before initiating transfer. Figure 409. Continuous SCK timing diagram (CONT = 0) If the CONT bit in the TX FIFO entry is set, CS remains asserted between the transfers when the CS signal for the next transfer is the same as for the current transfer. *Figure 410* shows timing diagram for continuous SCK format with continuous selection enabled. Figure 410. Continuous SCK timing diagram (CONT = 1) ## 22.8.7 Interrupts/DMA requests The DSPI has conditions that can generate interrupt requests only, and conditions that can generate interrupts or DMA requests. *Table 390* lists these conditions. | Condition | Flag | Interrupt | DMA | |----------------------------------------------|---------------------|-----------|-----| | End of transfer queue has been reached (EOQ) | EOQF | Х | | | TX FIFO is not full | TFFF | Х | Х | | Current frame transfer is complete | TCF | Х | | | TX FIFO underflow has occurred | TFUF | Х | | | RX FIFO is not empty | RFDF | X | Х | | RX FIFO overflow occurred | RFOF | Х | | | A FIFO overrun occurred <sup>(1)</sup> | TFUF ORed with RFOF | Х | | Table 390. Interrupt and DMA request conditions Each condition has a flag bit and a request enable bit. The flag bits are described in the Section 22.7.2.4: DSPI Status Register (DSPIx\_SR) and the request enable bits are described in the Section 22.7.2.5: DSPI DMA / Interrupt Request Select and Enable Register (DSPIx\_RSER). The TX FIFO fill flag (TFFF) and RX FIFO drain flag (RFDF) generate interrupt requests or DMA requests depending on the TFFF\_DIRS and RFDF DIRS bits in the DSPIx RSER. #### 22.8.7.1 End of queue interrupt request (EOQF) The end of queue request indicates that the end of a transmit queue is reached. The end of queue request is generated when the EOQ bit in the executing SPI command is asserted and the EOQF\_RE bit in the DSPIx\_RSER is set. Refer to the EOQ bit description in Section 22.7.2.4: DSPI Status Register (DSPIx\_SR). Refer to Figure 402 and Figure 403 that illustrate when EOQF is set. #### 22.8.7.2 Transmit FIFO fill interrupt or DMA request (TFFF) The transmit FIFO fill request indicates that the TX FIFO is not full. The transmit FIFO fill request is generated when the number of entries in the TX FIFO is less than the maximum number of possible entries, and the TFFF\_RE bit in the DSPIx\_RSER is set. The TFFF\_DIRS bit in the DSPIx\_RSER selects whether a DMA request or an interrupt request is generated. #### 22.8.7.3 Transfer complete interrupt request (TCF) The transfer complete request indicates the end of the transfer of a serial frame. The transfer complete request is generated at the end of each frame transfer when the TCF\_RE bit is set in the DSPIx\_RSER. Refer to the TCF bit description in *Section 22.7.2.4: DSPI Status Register (DSPIx\_SR)*. Refer to *Figure 402* and *Figure 403*, which show when TCF is set. <sup>1.</sup> The FIFO overrun condition is created by ORing the TFUF and RFOF flags together. #### 22.8.7.4 Transmit FIFO underflow interrupt request (TFUF) The transmit FIFO underflow request indicates that an underflow condition in the TX FIFO has occurred. The transmit underflow condition is detected only for DSPI modules operating in slave mode and SPI configuration. The TFUF bit is set when the TX FIFO of a DSPI operating in slave mode and SPI configuration is empty, and a transfer is initiated from an external SPI master. If the TFUF bit is set while the TFUF\_RE bit in the DSPIx\_RSER is set, an interrupt request is generated. #### 22.8.7.5 Receive FIFO drain interrupt or DMA request (RFDF) The receive FIFO drain request indicates that the RX FIFO is not empty. The receive FIFO drain request is generated when the number of entries in the RX FIFO is not zero, and the RFDF\_RE bit in the DSPIx\_RSER is set. The RFDF\_DIRS bit in the DSPIx\_RSER selects whether a DMA request or an interrupt request is generated. #### 22.8.7.6 Receive FIFO overflow interrupt request (RFOF) The receive FIFO overflow request indicates that an overflow condition in the RX FIFO has occurred. A receive FIFO overflow request is generated when RX FIFO and shift register are full and a transfer is initiated. The RFOF\_RE bit in the DSPIx\_RSER must be set for the interrupt request to be generated. Depending on the state of the ROOE bit in the DSPIx\_MCR, the data from the transfer that generated the overflow is either ignored or shifted in to the shift register. If the ROOE bit is set, the incoming data is shifted in to the shift register. If the ROOE bit is negated, the incoming data is ignored. #### 22.8.7.7 FIFO overrun request (TFUF) or (RFOF) The FIFO overrun request indicates that at least one of the FIFOs in the DSPI has exceeded its capacity. The FIFO overrun request is generated by logically OR'ing together the RX FIFO overflow and TX FIFO underflow signals. #### 22.8.8 Power saving features The DSPI supports two power-saving strategies: - Module disable mode—clock gating of non-memory mapped logic - Clock gating of slave interface signals and clock to memory-mapped logic #### 22.8.8.1 Module disable mode Module disable mode is a module-specific mode that the DSPI can enter to save power. Host software can initiate the module disable mode by writing a 1 to the MDIS bit in the DSPIx\_MCR.In module disable mode, the DSPI is in a dormant state, but the memory mapped registers are still accessible. Certain read or write operations have a different affect when the DSPI is in the module disable mode. Reading the RX FIFO pop register does not change the state of the RX FIFO. Likewise, writing to the TX FIFO push register does not change the state of the TX FIFO. Clearing either of the FIFOs does not have any effect in the module disable mode. Changes to the DIS\_TXF and DIS\_RXF fields of the DSPIx\_MCR does not have any affect in the module disable mode. In the module disable mode, all status bits and register flags in the DSPI return the correct values when read, but writing to them has no affect. Writing to the DSPIx\_TCR during module disable mode does not have an effect. Interrupt and DMA request signals cannot be cleared while in the module disable mode. ## 22.9 Initialization and application information ## 22.9.1 Managing queues DSPI queues are not part of the DSPI module, but the DSPI includes features in support of queue management. Queues are primarily supported in SPI configuration. This section presents an example of how to manage queues for the DSPI. - 1. The last command word from a queue is executed. The EOQ bit in the command word is set to indicate to the DSPI that this is the last entry in the queue. - 2. At the end of the transfer, corresponding to the command word with EOQ set is sampled, the EOQ flag (EOQF) in the DSPIx SR is set. - The setting of the EOQF flag disables both serial transmission, and serial reception of data, putting the DSPI in the STOPPED state. The TXRXS bit is negated to indicate the STOPPED state. - 4. The eDMA continues to fill TX FIFO until it is full or step 5 occurs. - Disable DSPI DMA transfers by disabling the DMA enable request for the DMA channel assigned to TX FIFO and RX FIFO. This is done by clearing the corresponding DMA enable request bits in the eDMA controller. - 6. Ensure all received data in RX FIFO has been transferred to memory receive queue by reading the RXCNT in DSPIx\_SR or by checking RFDF in the DSPIx\_SR after each read operation of the DSPIx\_POPR. - 7. Modify DMA descriptor of TX and RX channels for "new" queues. - 8. Flush TX FIFO by writing a 1 to the CLR\_TXF bit in the DSPIx\_MCR and flush the RX FIFO by writing a 1 to the CLR\_RXF bit in the DSPIx\_MCR. - 9. Clear transfer count either by setting CTCNT bit in the command word of the first entry in the new queue or via CPU writing directly to SPI\_TCNT field in the DSPIx\_TCR. - Enable DMA channel by enabling the DMA enable request for the DMA channel assigned to the DSPI TX FIFO, and RX FIFO by setting the corresponding DMA set enable request bit. - 11. Enable serial transmission and serial reception of data by clearing the EOQF bit. ## 22.9.2 Baud rate settings *Table 391* shows the baud rate that is generated based on the combination of the baud rate prescaler PBR and the baud rate scaler BR in the DSPIx\_CTARs. The values are calculated at a 100 MHz system frequency. Table 391. Baud rate values | | | Baud Rate divider prescaler values (DSPI_CTAR[PBR]) | | | | | | |-----------------------------------------|-------|-----------------------------------------------------|----------|----------|----------|--|--| | | | 2 | 3 | 5 | 7 | | | | | 2 | 25.0 MHz | 16.7 MHz | 10.0 MHz | 7.14 MHz | | | | | 4 | 12.5 MHz | 8.33 MHz | 5.00 MHz | 3.57 MHz | | | | | 6 | 8.33 MHz | 5.56 MHz | 3.33 MHz | 2.38 MHz | | | | | 8 | 6.25 MHz | 4.17 MHz | 2.50 MHz | 1.79 MHz | | | | Z[BR] | 16 | 3.12 MHz | 2.08 MHz | 1.25 MHz | 893 kHz | | | | CTAF | 32 | 1.56 MHz | 1.04 MHz | 625 kHz | 446 kHz | | | | SPI | 64 | 781 kHz | 521 kHz | 312 kHz | 223 kHz | | | | es (D | 128 | 391 kHz | 260 kHz | 156 kHz | 112 kHz | | | | valu | 256 | 195 kHz | 130 kHz | 78.1 kHz | 55.8 kHz | | | | caleı | 512 | 97.7 kHz | 65.1 kHz | 39.1 kHz | 27.9 kHz | | | | rate s | 1024 | 48.8 kHz | 32.6 kHz | 19.5 kHz | 14.0 kHz | | | | Baud rate scaler values (DSPI_CTAR[BR]) | 2048 | 24.4 kHz | 16.3 kHz | 9.77 kHz | 6.98 kHz | | | | | 4096 | 12.2 kHz | 8.14 kHz | 4.88 kHz | 3.49 kHz | | | | | 8192 | 6.10 kHz | 4.07 kHz | 2.44 kHz | 1.74 kHz | | | | | 16384 | 3.05 kHz | 2.04 kHz | 1.22 kHz | 872 Hz | | | | | 32768 | 1.53 kHz | 1.02 kHz | 610 Hz | 436 Hz | | | ## 22.9.3 Delay settings *Table 392* shows the values for the delay after transfer ( $t_{DT}$ ) and CS to SCK delay ( $t_{CSC}$ ) that can be generated based on the prescaler values and the scaler values set in the DSPIx\_CTARs. The values calculated assume a 100 MHz system frequency. **Delay prescaler values** (DSPI\_CTAR[PBR]) 1 3 5 7 60.0 ns 2 20.0 ns 100.0 ns 140.0 ns 4 40.0 ns 120.0 ns 200.0 ns 280.0 ns 8 80.0 ns 240.0 ns 400.0 ns 560.0 ns 16 160.0 ns 480.0 ns 800.0 ns $1.1 \mu s$ 32 960.0 ns Delay scaler values (DSPI\_CTAR[DT]) 320.0 ns 1.6 μs $2.2~\mu s$ 64 640.0 ns $1.9 \mu s$ $3.2 \mu s$ $4.5 \mu s$ 128 9.0 μs 1.3 μs $3.8 \mu s$ 6.4 μs 256 $2.6 \mu s$ $7.7 \mu s$ 12.8 µs 17.9 μs 512 $5.1 \,\mu s$ $15.4 \mu s$ $25.6 \mu s$ $35.8 \mu s$ 1024 $10.2 \mu s$ $30.7 \mu s$ 51.2 μs $71.7 \mu s$ 2048 $20.5 \mu s$ 102.4 μs 143.4 μs $61.4 \mu s$ 4096 $41.0 \mu s$ 122.9 μs 204.8 μs 286.7 μs 8192 409.6 μs 573.4 μs $81.9 \mu s$ 245.8 μs 16384 163.8 μs $491.5 \mu s$ 819.2 μs 1.1 ms 32768 983.0 μs 1.6 ms 2.3 ms $327.7 \mu s$ 65536 655.4 μs 2.0 ms 3.3 ms 4.6 ms Table 392. Delay values #### 22.9.4 Calculation of FIFO pointer addresses The user has complete visibility of the TX and RX FIFO contents through the FIFO registers, and valid entries can be identified through a memory mapped pointer and a memory mapped counter for each FIFO. The pointer to the first-in entry in each FIFO is memory mapped. For the TX FIFO the first-in pointer is the transmit next pointer (TXNXTPTR). For the RX FIFO the first-in pointer is the pop next pointer (POPNXTPTR). Refer to Section 22.8.3.4: Transmit First In First Out (TX FIFO) buffering mechanism and Section 22.8.3.5: Receive First In First Out (RX FIFO) buffering mechanism for details on the FIFO operation. The TX FIFO is chosen for the illustration, but the concepts carry over to the RX FIFO. *Figure 411* illustrates the concept of first-in and last-in FIFO entries along with the FIFO counter. Figure 411. TX FIFO pointers and counter #### 22.9.4.1 Address calculation for first-in entry and last-in entry in TX FIFO The memory address of the first-in entry in the TX FIFO is computed by the following equation: #### **Equation 61** First-in entry address = TXFIFO base + 4 (TXNXTPTR) The memory address of the last-in entry in the TX FIFO is computed by the following equation: #### **Equation 62** Last-in entry address = TXFIFO base + 4 × [(TXCTR + TXNXTPTR - 1) modulo TXFIFO depth] #### where: TXFIFO base = base address of transmit FIFO TXCTR = transmit FIFO counter TXNXTPTR = transmit next pointer TX FIFO depth = transmit FIFO depth (depth is 5) #### 22.9.4.2 Address calculation for first-in entry and last-in entry in RX FIFO The memory address of the first-in entry in the RX FIFO is computed by the following equation: ## **Equation 63** First-in entry address = RXFIFO base + 4 × (POPNXTPTR) The memory address of the last-in entry in the RX FIFO is computed by the following equation: #### **Equation 64** Last-in entry address = RXFIFO base + 4 × [(RXCTR + POPNXTPTR – 1) modulo RXFIFO depth] #### where: RXFIFO base = base address of receive FIFO RXCTR = receive FIFO counter POPNXTPTR = pop next pointer RX FIFO depth = receive FIFO depth (depth is 5) # 23 LIN Controller (LINFlex) #### 23.1 Introduction The LINFlex (Local Interconnect Network Flexible) controller interfaces the LIN network and supports the LIN protocol versions 1.3 and 2.0 in both Master and Slave modes. LINFlex includes a LIN mode that provides additional features (compared to standard UART) to ease LIN implementation, improve system robustness, minimize CPU load and allow slave node resynchronization. ### 23.2 Main features #### 23.2.1 LIN mode features - Supports LIN protocol versions 1.3 and 2.0 - Master mode with autonomous message handling - Classic and enhanced checksum calculation and check - Single 8-byte buffer for transmission/reception - Extended frame mode for In-Application Programming (IAP) purposes - Wake-up event on dominant bit detection - True LIN field state machine - Advanced LIN error detection - Header, response and frame timeout - Slave mode - Autonomous header handling - Autonomous transmit/receive data handling - LIN automatic resynchronization, allowing operation with 16 MHz fast internal RC oscillator as clock source - 16 identifier filters for autonomous message handling in Slave mode #### 23.2.2 UART mode features - Full duplex communication - 8- or 9-bit with parity - 4-byte buffer for reception, 4-byte buffer for transmission - 8-bit counter for timeout management #### 23.2.3 Features common to LIN and UART - Fractional baud rate generator - 3 operating modes for power saving and configuration registers lock: - Initialization - Normal - Sleep - 2 test modes: - Loop Back - Self Test - Maskable interrupts ## 23.3 General description The increasing number of communication peripherals embedded on microcontrollers, for example CAN, LIN and SPI, requires more and more CPU resources for communication management. Even a 32-bit microcontroller is overloaded if its peripherals do not provide high-level features to autonomously handle the communication. Even though the LIN protocol with a maximum baud rate of 20 Kbit/s is relatively slow, it still generates a non-negligible load on the CPU if the LIN is implemented on a standard UART, as usually the case. To minimize the CPU load in Master mode, LINFlex handles the LIN messages autonomously. In Master mode, once the software has triggered the header transmission, LINFlex does not request any software intervention until the next header transmission request in transmission mode or until the checksum reception in reception mode. To minimize the CPU load in Slave mode, LINFlex requires software intervention only to: - Trigger transmission or reception or data discard depending on the identifier - Write data into the buffer (transmission mode) or read data from the buffer (reception mode) after checksum reception If filter mode is activated for Slave mode, LINFlex requires software intervention only to write data into the buffer (transmission mode) or read data from the buffer (reception mode) The software uses the control, status and configuration registers to: - Configure LIN parameters (for example, baud rate or mode) - Request transmissions - Handle receptions - Manage interrupts - Configure LIN error and timeout detection - Process diagnostic information The message buffer stores transmitted or received LIN frames. Depot Application LINFlex Controller LIN Transceiver LIN Transceiver LIN Bus Figure 412. LIN topology network Figure 413. LINFlex block diagram # 23.4 Fractional baud rate generation The baud rates for the receiver and transmitter are both set to the same value as programmed in the Mantissa (LINIBRR) and Fraction (LINFBRR) registers. #### **Equation 65** Tx/ Rx baud = $$\frac{f_{periph\_set\_1\_clk}}{(16 \times LFDIV)}$$ LFDIV is an unsigned fixed point number. The 12-bit mantissa is coded in the LINIBRR and the fraction is coded in the LINFBRR. The following examples show how to derive LFDIV from LINIBRR and LINFBRR register values: **Example 11** Deriving LFDIV from LINIBRR and LINFBRR register values If LINIBRR = 27d and LINFBRR = 12d, then Mantissa (LFDIV) = 27d Fraction (LFDIV) = 12/16 = 0.75d Therefore LFDIV = 27.75d Example 12 Programming LFDIV from LINIBRR and LINFBRR register values To program LFDIV = 25.62d, LINFBRR = $16 \times 0.62 = 9.92$ , nearest real number 10d = 0xA LINIBRR = mantissa (25.620d) = 25d = 0x19 Note: The baud counters are updated with the new value of the baud registers after a write to LINIBRR. Hence the baud register value must not be changed during a transaction. The LINFBRR (containing the Fraction bits) must be programmed before the LINIBRR. Note: LFDIV must be greater than or equal to 1.5d, i.e. LINIBRR = 1 and LINFBRR = 8. Therefore, the maximum possible baudrate is fperiph\_set\_1\_clk / 24. Table 393. Error calculation for programmed baud rates | Baud<br>rate | f <sub>periph_set_1_clk</sub> = 64 MHz | | | | f <sub>periph_set_1_clk</sub> = 16 MHz | | | | |--------------|----------------------------------------|-----------------------------------------------------|---------|------------------------------------------------------|----------------------------------------|--------------------------------------------|---------|------------------------------------------------------| | | Actual | Value programmed<br>in<br>the baud rate<br>register | | % Error = (Calculated – Desired) baud rate / Desired | Actual | Value programmed in the baud rate register | | % Error = (Calculated – Desired) baud rate / Desired | | | | LINIBRR | LINFBRR | baud rate | | LINIBRR | LINFBRR | baud rate | | 2400 | 2399.97 | 1666 | 11 | -0.001 | 2399.88 | 416 | 11 | -0.005 | | 9600 | 9599.52 | 416 | 11 | -0.005 | 9598.08 | 104 | 3 | -0.02 | | 10417 | 10416.7 | 384 | 0 | -0.003 | 10416.7 | 96 | 0 | -0.003 | | 19200 | 19201.9 | 208 | 5 | 0.01 | 19207.7 | 52 | 1 | 0.04 | | 57600 | 57605.8 | 69 | 7 | 0.01 | 57554 | 17 | 6 | -0.08 | | 115200 | 115108 | 34 | 12 | -0.08 | 115108 | 8 | 11 | -0.08 | | 230400 | 230216 | 17 | 6 | -0.08 | 231884 | 4 | 5 | 0.644 | | 460800 | 460432 | 8 | 11 | -0.08 | 457143 | 2 | 3 | -0.794 | | 921600 | 927536 | 4 | 5 | 0.644 | 941176 | 1 | 1 | 2.124 | ## 23.5 Operating modes LINFlex has three main operating modes: Initialization, Normal and Sleep. After a hardware reset, LINFlex is in Sleep mode to reduce power consumption. The software instructs LINFlex to enter Initialization mode or Sleep mode by setting the INIT bit or SLEEP bit in the LINCR1. SLEEP SLEEP INITIALIZATION NORMAL SLEEP INIT Figure 414. LINFlex operating modes #### 23.5.1 Initialization mode The software can be initialized while the hardware is in Initialization mode. To enter this mode the software sets the INIT bit in the LINCR1. To exit Initialization mode, the software clears the INIT bit. While in Initialization mode, all message transfers to and from the LIN bus are stopped and the status of the LIN bus output LINTX is recessive (high). Entering Initialization mode does not change any of the configuration registers. To initialize the LINFlex controller, the software selects the mode (LIN Master, LIN Slave or UART), sets up the baud rate register and, if LIN Slave mode with filter activation is selected, initializes the identifier list. #### 23.5.2 Normal mode Once initialization is complete, software clears the INIT bit in the LINCR1 to put the hardware into Normal mode. #### 23.5.3 Low power mode (Sleep) To reduce power consumption, LINFlex has a low power mode called Sleep mode. To enter Sleep mode, software sets the SLEEP bit in the LINCR1. In this mode, the LINFlex clock is stopped. Consequently, the LINFlex will not update the status bits but software can still access the LINFlex registers. LINFlex can be awakened (exit Sleep mode) either by software clearing the SLEEP bit or on detection of LIN bus activity if automatic wake-up mode is enabled (AWUM bit is set). On LIN bus activity detection, hardware automatically performs the wake-up sequence by clearing the SLEEP bit if the AWUM bit in the LINCR1 is set. To exit from Sleep mode if the AWUM bit is cleared, software clears the SLEEP bit when a wake-up event occurs. #### 23.6 Test modes Two test modes are available to the user: Loop Back mode and Self Test mode. They can be selected by the LBKM and SFTM bits in the LINCR1. These bits must be configured while LINFlex is in Initialization mode. Once one of the two test modes has been selected, LINFlex must be started in Normal mode. ## 23.6.1 Loop Back mode LINFlex can be put in Loop Back mode by setting the LBKM bit in the LINCR. In Loop Back mode, the LINFlex treats its own transmitted messages as received messages. Figure 415. LINFlex in loop back mode This mode is provided for self test functions. To be independent of external events, the LIN core ignores the LINRX signal. In this mode, the LINFlex performs an internal feedback from its Tx output to its Rx input. The actual value of the **LINRX** input pin is disregarded by the LINFlex. The transmitted messages can be monitored on the **LINTX** pin. #### 23.6.2 Self Test mode LINFlex can be put in Self Test mode by setting the LBKM and SFTM bits in the LINCR. This mode can be used for a "Hot Self Test", meaning the LINFlex can be tested as in Loop Back mode but without affecting a running LIN system connected to the LINTX and LINRX pins. In this mode, the LINRX pin is disconnected from the LINFlex and the LINTX pin is held recessive. LINFlex Tx Rx Tx Rx LINTX LINRX Figure 416. LINFlex in self test mode # 23.7 Memory map and registers description # 23.7.1 Memory map See the "Memory map" chapter of this reference manual for the base addresses for the LINFlex modules. Table 394 shows the LINFlex memory map. Table 394. LINFlex memory map | Address offset | Register | Location | | | | | |----------------|------------------------------------------------|-------------|--|--|--|--| | 0x0000 | LIN control register 1 (LINCR1) | on page 722 | | | | | | 0x0004 | 0x0004 LIN interrupt enable register (LINIER) | | | | | | | 0x0008 | LIN status register (LINSR) | on page 727 | | | | | | 0x000C | LIN error status register (LINESR) | on page 730 | | | | | | 0x0010 | UART mode control register (UARTCR) | on page 731 | | | | | | 0x0014 | UART mode status register (UARTSR) | on page 733 | | | | | | 0x0018 | LIN timeout control status register (LINTCSR) | on page 735 | | | | | | 0x001C | LIN output compare register (LINOCR) | on page 736 | | | | | | 0x0020 | LIN timeout control register (LINTOCR) | on page 736 | | | | | | 0x0024 | LIN fractional baud rate register (LINFBRR) | on page 737 | | | | | | 0x0028 | LIN integer baud rate register (LINIBRR) | on page 737 | | | | | | 0x002C | LIN checksum field register (LINCFR) | on page 738 | | | | | | 0x0030 | LIN control register 2 (LINCR2) | on page 739 | | | | | | 0x0034 | Buffer identifier register (BIDR) | on page 740 | | | | | | 0x0038 | Buffer data register LSB (BDRL) <sup>(1)</sup> | on page 741 | | | | | | 0x003C | Buffer data register MSB (BDRM) <sup>(2)</sup> | on page 741 | | | | | | 0x0040 | Identifier filter enable register (IFER) | on page 742 | | | | | | 0x0044 | Identifier filter match index (IFMI) | on page 743 | | | | | | Address offset | Register | Location | |----------------|------------------------------------------------|-------------| | 0x0048 | Identifier filter mode register (IFMR) | on page 743 | | 0x004C | Identifier filter control register 0 (IFCR0) | on page 744 | | 0x0050 | Identifier filter control register 1 (IFCR1) | on page 745 | | 0x0054 | Identifier filter control register 2 (IFCR2) | on page 745 | | 0x0058 | Identifier filter control register 3 (IFCR3) | on page 745 | | 0x005C | Identifier filter control register 4 (IFCR4) | on page 745 | | 0x0060 | Identifier filter control register 5 (IFCR5) | on page 745 | | 0x0064 | Identifier filter control register 6 (IFCR6) | on page 745 | | 0x0068 | Identifier filter control register 7 (IFCR7) | on page 745 | | 0x006C | Identifier filter control register 8 (IFCR8) | on page 745 | | 0x0070 | Identifier filter control register 9 (IFCR9) | on page 745 | | 0x0074 | Identifier filter control register 10 (IFCR10) | on page 745 | | 0x0078 | Identifier filter control register 11 (IFCR11) | on page 745 | | 0x007C | Identifier filter control register 12 (IFCR12) | on page 745 | | 0x0080 | Identifier filter control register 13 (IFCR13) | on page 745 | | 0x0084 | Identifier filter control register 14 (IFCR14) | on page 745 | | 0x0088 | Identifier filter control register 15 (IFCR15) | on page 745 | | 0x008C-0x3FFF | Reserved | • | Table 394. LINFlex memory map(Continued) # 23.7.1.1 LIN control register 1 (LINCR1) Figure 417. LIN control register 1 (LINCR1) <sup>1.</sup> LSB: Least significant byte <sup>2.</sup> MSB: Most significant byte # Table 395. LINCR1 field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CCD | Checksum calculation disable This bit disables the checksum calculation (see <i>Table 396</i> ). 0 Checksum calculation is done by hardware. When this bit is 0, the LINCFR is read-only. 1 Checksum calculation is disabled. When this bit is set the LINCFR is read/write. User can program this register to send a software-calculated CRC (provided CFD is 0). Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | CFD | Checksum field disable This bit disables the checksum field transmission (see <i>Table 396</i> ). 0 Checksum field is sent after the required number of data bytes is sent. 1 No checksum field is sent. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | LASE | LIN Slave Automatic Resynchronization Enable 0 Automatic resynchronization disable. 1 Automatic resynchronization enable. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | AWUM | Automatic Wake-Up Mode This bit controls the behavior of the LINFlex hardware during Sleep mode. O The Sleep mode is exited on software request by clearing the SLEEP bit of the LINCR. The Sleep mode is exited automatically by hardware on LINRX dominant state detection. The SLEEP bit of the LINCR is cleared by hardware whenever WUF bit in the LINSR is set. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | MBL | LIN Master Break Length This field indicates the Break length in Master mode (see <i>Table 397</i> ). <b>Note:</b> This field can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | BF | Bypass filter 0 No interrupt if identifier does not match any filter. 1 An RX interrupt is generated on identifier not matching any filter. Note: - If no filter is activated, this bit is reserved. - This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | SFTM | Self Test Mode This bit controls the Self Test mode. For more details, see Section 23.6.2: Self Test mode. 0 Self Test mode disable. 1 Self Test mode enable. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | LBKM | Loop Back Mode This bit controls the Loop Back mode. For more details see Section 23.6.1: Loop Back mode. 0 Loop Back mode disable. 1 Loop Back mode enable. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode | | MME | Master Mode Enable O Slave mode enable. Master mode enable. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | Table 395. LINCR1 field descriptions(Continued) | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SBDT | Slave Mode Break Detection Threshold 0 11-bit break. 1 10-bit break. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | RBLM | Receive Buffer Locked Mode Receive Buffer not locked on overrun. Once the Slave Receive Buffer is full the next incoming message overwrites the previous one. Receive Buffer locked against overrun. Once the Receive Buffer is full the next incoming message is discarded. Note: This bit can be written in Initialization mode only. It is read-only in Normal or Sleep mode. | | SLEEP | Sleep Mode Request This bit is set by software to request LINFlex to enter Sleep mode. This bit is cleared by software to exit Sleep mode or by hardware if the AWUM bit in LINCR1 and the WUF bit in LINSR are set (see <i>Table 398</i> ). | | INIT | Initialization Request The software sets this bit to switch hardware into Initialization mode. If the SLEEP bit is reset, LINFlex enters Normal mode when clearing the INIT bit (see <i>Table 398</i> ). | Table 396. Checksum bits configuration | CFD | CCD | LINCFR | Checksum sent | |-----|-----|------------|--------------------------------------| | 1 | 1 | Read/Write | None | | 1 | 0 | Read-only | None | | 0 | 1 | Read/Write | Programmed in LINCFR by bits CF[0:7] | | 0 | 0 | Read-only | Hardware calculated | Table 397. LIN master break length selection | MBL | Length | |------|--------| | 0000 | 10-bit | | 0001 | 11-bit | | 0010 | 12-bit | | 0011 | 13-bit | | 0100 | 14-bit | | 0101 | 15-bit | | 0110 | 16-bit | | 0111 | 17-bit | | 1000 | 18-bit | | 1001 | 19-bit | | 1010 | 20-bit | Table 397. LIN master break length selection(Continued) | MBL | Length | |------|--------| | 1011 | 21-bit | | 1100 | 22-bit | | 1101 | 23-bit | | 1110 | 36-bit | | 1111 | 50-bit | Table 398. Operating mode selection | SLEEP | INIT | Operating mode | | | | | | |-------|------|---------------------|--|--|--|--|--| | 1 | 0 | Sleep (reset value) | | | | | | | х | 1 | Initialization | | | | | | | 0 | 0 | Normal | | | | | | # 23.7.1.2 LIN interrupt enable register (LINIER) Figure 418. LIN interrupt enable register (LINIER) Table 399. LINIER field descriptions | Field | Description | | | | | | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | SZIE | Stuck at Zero Interrupt Enable 0 No interrupt when SZF bit in LINESR or UARTSR is set. 1 Interrupt generated when SZF bit in LINESR or UARTSR is set. | | | | | | | | OCIE | Output Compare Interrupt Enable 0 No interrupt when OCF bit in LINESR or UARTSR is set. 1 Interrupt generated when OCF bit in LINESR or UARTSR is set. | | | | | | | | BEIE | Bit Error Interrupt Enable 0 No interrupt when BEF bit in LINESR is set. 1 Interrupt generated when BEF bit in LINESR is set. | | | | | | | Table 399. LINIER field descriptions(Continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CEIE | Checksum Error Interrupt Enable 0 No interrupt on Checksum error. 1 Interrupt generated when checksum error flag (CEF) in LINESR is set. | | HEIE | Header Error Interrupt Enable 0 No interrupt on Break Delimiter error, Synch Field error, Identifier field error. 1 Interrupt generated on Break Delimiter error, Synch Field error, Identifier field error. | | FEIE | Framing Error Interrupt Enable 0 No interrupt on Framing error. 1 Interrupt generated on Framing error. | | BOIE | Buffer Overrun Interrupt Enable 0 No interrupt on Buffer overrun. 1 Interrupt generated on Buffer overrun. | | LSIE | LIN State Interrupt Enable 0 No interrupt on LIN state change. 1 Interrupt generated on LIN state change. This interrupt can be used for debugging purposes. It has no status flag but is reset when writing '1111' into LINS[0:3] in the LINSR. | | WUIE | Wake-up Interrupt Enable 0 No interrupt when WUF bit in LINSR or UARTSR is set. 1 Interrupt generated when WUF bit in LINSR or UARTSR is set. | | DBFIE | Data Buffer Full Interrupt Enable 0 No interrupt when buffer data register is full. 1 Interrupt generated when data buffer register is full. | | DBEIE | Data Buffer Empty Interrupt Enable 0 No interrupt when buffer data register is empty. 1 Interrupt generated when data buffer register is empty. | | DRIE | Data Reception Complete Interrupt Enable 0 No interrupt when data reception is completed. 1 Interrupt generated when data received flag (DRF) in LINSR or UARTSR is set. | | DTIE | Data Transmitted Interrupt Enable 0 No interrupt when data transmission is completed. 1 Interrupt generated when data transmitted flag (DTF) is set in LINSR or UARTSR. | | HRIE | Header Received Interrupt Enable 0 No interrupt when a valid LIN header has been received. 1 Interrupt generated when a valid LIN header has been received, that is, HRF bit in LINSR is set. | # 23.7.1.3 LIN status register (LINSR) | Offset: | Offset: 0x0008 Access: User read/write | | | | | | | d/write | | | | | | | | | |---------|----------------------------------------|-----|----|----|----|----|-----|---------|------|-----|-----|------|------|-----|-----|-----| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | I | | | | I | | | | I | | | | | _ | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | | LII | NS | | 0 | 0 | RMB | 0 | RBSY | RPS | WUF | DBFF | JBBG | DRF | DTF | HRF | | W | | | | | | | w1c | | w1c | | w1c | w1c | w1c | w1c | w1c | w1c | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 419. LIN status register (LINSR) Table 400. LINSR field descriptions | Field | Description | | | | | | | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | LIN modes / normal mode states | | | | | | | | | | | | | | | | | | | | 0000: Sleep mode | | | | | | | | | | LINFlex is in Sleep mode to save power consumption. | | | | | | | | | | 0001: Initialization mode LINFlex is in Initialization mode. | | | | | | | | | | LINFIEX IS IN INITIALIZATION Mode. | | | | | | | | | | Normal mode states | | | | | | | | | | 0010: Idle | | | | | | | | | | This state is entered on several events: | | | | | | | | | | <ul> <li>SLEEP bit and INIT bit in LINCR1 have been cleared by software,</li> </ul> | | | | | | | | | | <ul> <li>A falling edge has been received on RX pin and AWUM bit is set,</li> </ul> | | | | | | | | | | The previous frame reception or transmission has been completed or <b>aborted</b> . | | | | | | | | | | 0011: Break | | | | | | | | | | In Slave mode, a falling edge followed by a dominant state has been detected. Receiving Break. | | | | | | | | | | <b>Note:</b> In Slave mode, in case of error new LIN state can be either Idle or Break depending on last bit state. If last bit is dominant new LIN state is Break, otherwise Idle. | | | | | | | | | | In Master mode, Break transmission ongoing. | | | | | | | | | | 0100: Break Delimiter | | | | | | | | | LINS | In Slave mode, a valid Break has been detected. See Section 23.7.1.1: LIN control register 1 (LINCR1) for break length configuration (10-bit or 11-bit). Waiting for a rising edge. | | | | | | | | | | In Master mode, Break transmission has been completed. Break Delimiter transmission is ongoing. | | | | | | | | | | 0101: Synch Field | | | | | | | | | | In Slave mode, a valid Break Delimiter has been detected (recessive state for at least one bit time). Receiving Synch Field. | | | | | | | | | | In Master mode, Synch Field transmission is ongoing. | | | | | | | | | | 0110: Identifier Field | | | | | | | | | | In Slave mode, a valid Synch Field has been received. Receiving Identifier Field. | | | | | | | | | | In Master mode, identifier transmission is ongoing. | | | | | | | | | | 0111: Header reception/transmission completed | | | | | | | | | | In Slave mode, a valid header has been received and identifier field is available in the BIDR. | | | | | | | | | | In Master mode, header transmission is completed. | | | | | | | | | | 1000: Data reception/transmission | | | | | | | | | | Response reception/transmission is ongoing. 1001: Checksum | | | | | | | | | | Data reception/transmission completed. Checksum reception/transmission ongoing. | | | | | | | | | | In UART mode, only the following states are flagged by the LIN state bits: | | | | | | | | | | - Init | | | | | | | | | | - Sleep | | | | | | | | | | – Idle | | | | | | | | | | - Data transmission/reception | | | | | | | | Table 400. LINSR field descriptions(Continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RMB | Release Message Buffer 0 Buffer is free. 1 Buffer ready to be read by software. This bit must be cleared by software after reading data received in the buffer. This bit is cleared by hardware in Initialization mode. | | RBSY | Receiver Busy Flag 0 Receiver is idle 1 Reception ongoing Note: In Slave mode, after header reception, if BIDR[DIR] = 0 and reception starts then this bit is set. In this case, user cannot program LINCR2[DTRQ] = 1. | | RPS | LIN receive pin state This bit reflects the current status of LINRX pin for diagnostic purposes. | | WUF | Wake-up Flag This bit is set by hardware and indicates to the software that LINFlex has detected a falling edge on the LINRX pin when: - Slave is in Sleep mode - Master is in Sleep mode or idle state This bit must be cleared by software. It is reset by hardware in Initialization mode. An interrupt is generated if WUIE bit in LINIER is set. | | DBFF | Data Buffer Full Flag This bit is set by hardware and indicates the buffer is full. It is set only when receiving extended frames (DFL > 7). This bit must be cleared by software. It is reset by hardware in Initialization mode. | | DBEF | Data Buffer Empty Flag This bit is set by hardware and indicates the buffer is empty. It is set only when transmitting extended frames (DFL > 7). This bit must be cleared by software, once buffer has been filled again, in order to start transmission. This bit is reset by hardware in Initialization mode. | | DRF | Data Reception Completed Flag This bit is set by hardware and indicates the data reception is completed. This bit must be cleared by software. It is reset by hardware in Initialization mode. Note: This flag is not set in case of bit error or framing error. | | DTF | Data Transmission Completed Flag This bit is set by hardware and indicates the data transmission is completed. This bit must be cleared by software. It is reset by hardware in Initialization mode. Note: This flag is not set in case of bit error if IOBE bit is reset. | Table 400. LINSR field descriptions(Continued) | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HRF | Header Reception Flag This bit is set by hardware and indicates a valid header reception is completed. This bit must be cleared by software. This bit is reset by hardware in Initialization mode and at end of completed or aborted frame. Note: If filters are enabled, this bit is set only when identifier software filtering is required, that is to say: - All filters are inactive and BF bit in LINCR1 is set - No match in any filter and BF bit in LINCR1 is set - TX filter match | ## 23.7.1.4 LIN error status register (LINESR) Figure 420. LIN error status register (LINESR) Table 401. LINESR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SZF | Stuck at Zero Flag This bit is set by hardware when the bus is dominant for more than a 100-bit time. If the dominant state continues, SZF flag is set again after 87-bit time. It is cleared by software. | | OCF | Output Compare Flag 0 No output compare event occurred 1 The content of the counter has matched the content of OC1[0:7] or OC2[0:7] in LINOCR. If this bit is set and IOT bit in LINTCSR is set, LINFlex moves to Idle state. If LTOM bit in LINTCSR is set, then OCF is cleared by hardware in Initialization mode. If LTOM bit is cleared, then OCF maintains its status whatever the mode is. | | BEF | Bit Error Flag This bit is set by hardware and indicates to the software that LINFlex has detected a bit error. This error can occur during response field transmission (Slave and Master modes) or during header transmission (in Master mode). This bit is cleared by software. | Table 401. LINESR field descriptions(Continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CEF | Checksum Error Flag This bit is set by hardware and indicates that the received checksum does not match the hardware calculated checksum. This bit is cleared by software. Note: This bit is never set if CCD or CFD bit in LINCR1 is set. | | SFEF | Synch Field Error Flag This bit is set by hardware and indicates that a Synch Field error occurred (inconsistent Synch Field). | | BDEF | Break Delimiter Error Flag This bit is set by hardware and indicates that the received Break Delimiter is too short (less than one bit time). | | IDPEF | Identifier Parity Error Flag This bit is set by hardware and indicates that a Identifier Parity error occurred. Note: Header interrupt is triggered when SFEF or BDEF or IDPEF bit is set and HEIE bit in LINIER is set. | | FEF | Framing Error Flag This bit is set by hardware and indicates to the software that LINFlex has detected a framing error (invalid stop bit). This error can occur during reception of any data in the response field (Master or Slave mode) or during reception of Synch Field or Identifier Field in Slave mode. | | BOF | Buffer Overrun Flag This bit is set by hardware when a new data byte is received and the buffer full flag is not cleared. If RBLM in LINCR1 is set then the new byte received is discarded. If RBLM is reset then the new byte overwrites the buffer. It can be cleared by software. | | NF | Noise Flag This bit is set by hardware when noise is detected on a received character. This bit is cleared by software. | # 23.7.1.5 UART mode control register (UARTCR) Figure 421. UART mode control register (UARTCR) Table 402. UARTCR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TDFL | Transmitter Data Field length This field sets the number of bytes to be transmitted in UART mode. It can be programmed only when the UART bit is set. TDFL[0:1] = Transmit buffer size – 1. 00 Transmit buffer size = 1. 01 Transmit buffer size = 2. 10 Transmit buffer size = 3. 11 Transmit buffer size = 4. | | RDFL | Receiver Data Field length This field sets the number of bytes to be received in UART mode. It can be programmed only when the UART bit is set. RDFL[0:1] = Receive buffer size – 1. 00 Receive buffer size = 1. 01 Receive buffer size = 2. 10 Receive buffer size = 3. 11 Receive buffer size = 4. | | RXEN | Receiver Enable 0 Receiver disable. 1 Receiver enable. This bit can be programmed only when the UART bit is set. | | TXEN | Transmitter Enable 0 Transmitter disable. 1 Transmitter enable. This bit can be programmed only when the UART bit is set. Note: Transmission starts when this bit is set and when writing DATA0 in the BDRL register. | | OP | Odd Parity 0 Sent parity is even. 1 Sent parity is odd. This bit can be programmed in Initialization mode only when the UART bit is set. | | PCE | Parity Control Enable 0 Parity transmit/check disable. 1 Parity transmit/check enable. This bit can be programmed in Initialization mode only when the UART bit is set. | | WL | Word Length in UART mode 0 7-bit data + parity bit. 1 8-bit data (or 9-bit if PCE is set). This bit can be programmed in Initialization mode only when the UART bit is set. | | UART | UART mode enable 0 LIN mode. 1 UART mode. This bit can be programmed in Initialization mode only. | # 23.7.1.6 UART mode status register (UARTSR) Figure 422. UART mode status register (UARTSR) Table 403. UARTSR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SZF | Stuck at Zero Flag This bit is set by hardware when the bus is dominant for more than a 100-bit time. It is cleared by software. | | OCF | OCF Output Compare Flag 0 No output compare event occurred. 1 The content of the counter has matched the content of OC1[0:7] or OC2[0:7] in LINOCR. An interrupt is generated if the OCIE bit in LINIER is set. | | PE3 | Parity Error Flag Rx3 This bit indicates if there is a parity error in the corresponding received byte (Rx3). See Section 23.8.1.1: Buffer in UART mode. No interrupt is generated if this error occurs. 0 No parity error. 1 Parity error. | | PE2 | Parity Error Flag Rx2 This bit indicates if there is a parity error in the corresponding received byte (Rx2). See Section 23.8.1.1: Buffer in UART mode. No interrupt is generated if this error occurs. 0 No parity error. 1 Parity error. | | PE1 | Parity Error Flag Rx1 This bit indicates if there is a parity error in the corresponding received byte (Rx1). See Section 23.8.1.1: Buffer in UART mode. No interrupt is generated if this error occurs. 0 No parity error. 1 Parity error. | | PE0 | Parity Error Flag Rx0 This bit indicates if there is a parity error in the corresponding received byte (Rx0). See Section 23.8.1.1: Buffer in UART mode. No interrupt is generated if this error occurs. 0 No parity error. 1 Parity error. | Table 403. UARTSR field descriptions(Continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RMB | Release Message Buffer 0 Buffer is free. 1 Buffer ready to be read by software. This bit must be cleared by software after reading data received in the buffer. This bit is cleared by hardware in Initialization mode. | | FEF | Framing Error Flag This bit is set by hardware and indicates to the software that LINFlex has detected a framing error (invalid stop bit). | | BOF | Buffer Overrun Flag This bit is set by hardware when a new data byte is received and the buffer full flag is not cleared. If RBLM in LINCR1 is set then the new byte received is discarded. If RBLM is reset then the new byte overwrites buffer. it can be cleared by software. | | RPS | LIN Receive Pin State This bit reflects the current status of LINRX pin for diagnostic purposes. | | WUF | Wake-up Flag This bit is set by hardware and indicates to the software that LINFlex has detected a falling edge on the LINRX pin in Sleep mode. This bit must be cleared by software. It is reset by hardware in Initialization mode. An interrupt i generated if WUIE bit in LINIER is set. | | DRF | Data Reception Completed Flag This bit is set by hardware and indicates the data reception is completed, that is, the number of bytes programmed in RDFL[0:1] in UARTCR have been received. This bit must be cleared by software. It is reset by hardware in Initialization mode. An interrupt is generated if DRIE bit in LINIER is set. Note: In UART mode, this flag is set in case of framing error, parity error or overrun. | | DTF | Data Transmission Completed Flag This bit is set by hardware and indicates the data transmission is completed, that is, the number of bytes programmed in TDFL[0:1] have been transmitted. This bit must be cleared by software. It is reset by hardware in Initialization mode. An interrupt is generated if DTIE bit in LINIER is set. | | NF | Noise Flag This bit is set by hardware when noise is detected on a received character. This bit is cleared by software. | # 23.7.1.7 LIN timeout control status register (LINTCSR) Figure 423. LIN timeout control status register (LINTCSR) Table 404. LINTCSR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LTOM | LIN timeout mode 0 LIN timeout mode (header, response and frame timeout detection). 1 Output compare mode. This bit can be set/cleared in Initialization mode only. | | ЮТ | Idle on Timeout 0 LIN state machine not reset to Idle on timeout event. 1 LIN state machine reset to Idle on timeout event. This bit can be set/cleared in Initialization mode only. | | TOCE | Timeout counter enable 0 Timeout counter disable. OCF bit in LINESR or UARTSR is not set on an output compare event. 1 Timeout counter enable. OCF bit is set if an output compare event occurs. TOCE bit is configurable by software in Initialization mode. If LIN state is not Init and if timer is in LIN timeout mode, then hardware takes control of TOCE bit. | | CNT | Counter Value This field indicates the LIN timeout counter value. | ## 23.7.1.8 LIN output compare register (LINOCR) Figure 424. LIN output compare register (LINOCR) Table 405. LINOCR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------| | OC2 | Output compare 2 value These bits contain the value to be compared to the value of bits CNT[0:7] in LINTCSR. | | OC1 | Output compare 1 value These bits contain the value to be compared to the value of bits CNT[0:7] in LINTCSR. | # 23.7.1.9 LIN timeout control register (LINTOCR) Figure 425. LIN timeout control register (LINTOCR) Table 406. LINTOCR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RTO | Response timeout value This field contains the response timeout duration (in bit time) for 1 byte. The reset value is $0xE = 14$ , corresponding to $T_{Response\_Maximum} = 1.4 \times T_{Response\_Nominal}$ | Table 406. LINTOCR field descriptions(Continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | нто | Header timeout value This field contains the header timeout duration (in bit time). This value does not include the Break and the Break Delimiter. The reset value is the 0x2C = 44, corresponding to THeader_Maximum. Programming LINSR[MME] = 1 changes the HTO value to 0x1C = 28. This field can be written only in Slave mode. | ### 23.7.1.10 LIN fractional baud rate register (LINFBRR) Figure 426. LIN fractional baud rate register (LINFBRR) Table 407. LINFBRR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DIV_F | Fraction bits of LFDIV The 4 fraction bits define the value of the fraction of the LINFlex divider (LFDIV). Fraction (LFDIV) = Decimal value of DIV_F / 16. This field can be written in Initialization mode only. | ## 23.7.1.11 LIN integer baud rate register (LINIBRR) Figure 427. LIN integer baud rate register (LINIBRR) ## Table 408. LINIBRR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | DIV_M | LFDIV mantissa This field defines the LINFlex divider (LFDIV) mantissa value (see <i>Table 409</i> ). This field can be written in Initialization mode only. | Table 409. Integer baud rate selection | DIV_M[0:12] | Mantissa | |-------------|--------------------| | 0x0000 | LIN clock disabled | | 0x0001 | 1 | | | | | 0x1FFE | 8190 | | ox1FFF | 8191 | # 23.7.1.12 LIN checksum field register (LINCFR) Figure 428. LIN checksum field register (LINCFR) ### Table 410. LINCFR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------| | CF | Checksum bits When LINCR1[CCD] = 0, this field is read-only. When LINCR1[CCD] = 1, this field is read/write. See <i>Table 396</i> . | # 23.7.1.13 LIN control register 2 (LINCR2) Figure 429. LIN control register 2 (LINCR2) Table 411. LINCR2 field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOBE | Idle on Bit Error 0 Bit error does not reset LIN state machine. 1 Bit error reset LIN state machine. This bit can be set/cleared in Initialization mode only. | | IOPE | Idle on Identifier Parity Error 0 Identifier Parity error does not reset LIN state machine. 1 Identifier Parity error reset LIN state machine. This bit can be set/cleared in Initialization mode only. | | WURQ | Wake-up Generation Request Setting this bit generates a wake-up pulse. It is reset by hardware when the wake-up character has been transmitted. The character sent is copied from DATA0 in BDRL buffer. Note that this bit cannot be set in Sleep mode. Software has to exit Sleep mode before requesting a wake-up. Bit error is not checked when transmitting the wake-up request. | | DDRQ | Data Discard Request Set by software to stop data reception if the frame does not concern the node. This bit is reset by hardware once LINFlex has moved to idle state. In Slave mode, this bit can be set only when HRF bit in LINSR is set and identifier did not match any filter. | | DTRQ | Data Transmission Request Set by software in Slave mode to request the transmission of the LIN Data field stored in the Buffer data register. This bit can be set only when HRF bit in LINSR is set. Cleared by hardware when the request has been completed or aborted or on an error condition. In Master mode, this bit is set by hardware when BIDR[DIR] = 1 and header transmission is completed. | | ABRQ | Abort Request Set by software to abort the current transmission. Cleared by hardware when the transmission has been aborted. LINFlex aborts the transmission at the end of the current bit. This bit can also abort a wake-up request. It can also be used in UART mode. | Table 411. LINCR2 field descriptions(Continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HTRQ | Header Transmission Request Set by software to request the transmission of the LIN header. Cleared by hardware when the request has been completed or aborted. This bit has no effect in UART mode. | # 23.7.1.14 Buffer identifier register (BIDR) Figure 430. Buffer identifier register (BIDR) Table 412. BIDR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DFL | Data Field Length This field defines the number of data bytes in the response part of the frame. DFL = Number of data bytes – 1. Normally, LIN uses only DFL[2:0] to manage frames with a maximum of 8 bytes of data. Identifier filters are compatible with DFL[2:0] only. DFL[5:3] are provided to manage extended frames. | | DIR | Direction This bit controls the direction of the data field. 0 LINFlex receives the data and copies them in the BDRs. 1 LINFlex transmits the data from the BDRs. | | ccs | Classic Checksum This bit controls the type of checksum applied on the current message. 0 Enhanced Checksum covering Identifier and Data fields. This is compatible with LIN specification 2.0 and higher. 1 Classic Checksum covering Data fields only. This is compatible with LIN specification 1.3 and earlier. In LIN slave mode (MME bit cleared in LINCR1), this bit must be configured before the header reception. If the slave has to manage frames with 2 types of checksum, filters must be configured. | | ID | Identifier Identifier part of the identifier field without the identifier parity. | # 23.7.1.15 Buffer data register LSB (BDRL) Figure 431. Buffer data register LSB (BDRL) Table 413. BDRL field descriptions | Field | Description | |-------|--------------------------------------------| | DATA3 | Data Byte 3 Data byte 3 of the data field. | | DATA2 | Data Byte 2 Data byte 2 of the data field. | | DATA1 | Data Byte 1 Data byte 1 of the data field. | | DATA0 | Data Byte 0 Data byte 0 of the data field. | # 23.7.1.16 Buffer data register MSB (BDRM) Figure 432. Buffer data register MSB (BDRM) **Table 414. BDRM field descriptions** | Field | Description | |-------|--------------------------------------------| | ΠΔΤΔ7 | Data Byte 7 Data byte 7 of the data field. | Table 414. BDRM field descriptions(Continued) | Field | Description | |-------|--------------------------------------------| | DATA6 | Data Byte 6 Data byte 6 of the data field. | | DATA5 | Data Byte 5 Data byte 5 of the data field. | | DATA4 | Data Byte 4 Data byte 4 of the data field. | # 23.7.1.17 Identifier filter enable register (IFER) Figure 433. Identifier filter enable register (IFER) Table 415. IFER field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FACT | Filter activation The software sets the bit FACT[x] to activate the filters x in identifier list mode. In identifier mask mode bits FACT(2n + 1) have no effect on the corresponding filters as they act as masks for the Identifiers 2n. 0 Filter x is deactivated. 1 Filter x is activated. This field can be set/cleared in Initialization mode only. | # 23.7.1.18 Identifier filter match index (IFMI) Figure 434. Identifier filter match index (IFMI) Table 416. IFMI field descriptions | Field | Description | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:26 | Reserved | | IFMI[0:4]<br>27:31 | Filter match index This register contains the index corresponding to the received identifier. It can be used to directly write or read the data in SRAM (see Section 23.8.2.2: Slave mode for more details). When no filter matches, IFMI[0:4] = 0. When Filter $n$ is matching, IFMI[0:4] = $n + 1$ . | # 23.7.1.19 Identifier filter mode register (IFMR) Figure 435. Identifier filter mode register (IFMR) Table 417. IFMR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IFM | Filter mode (see <i>Table 418</i> ). 0 Filters 2 <i>n</i> and 2 <i>n</i> + 1 are in identifier list mode. 1 Filters 2 <i>n</i> and 2 <i>n</i> + 1 are in mask mode (filter 2 <i>n</i> + 1 is the mask for the filter 2 <i>n</i> ). | Table 418. IFMR[IFM] configuration | Bit | Value | Result | | |-----------|-------|-------------------------------------------------------------------------------|--| | IEMIOI | 0 | Filters 0 and 1 are in identifier list mode. | | | IFM[0] | 1 | Filters 0 and 1 are in mask mode (filter 1 is the mask for the filter 0). | | | IEM[4] | 0 | Filters 2 and 3 are in identifier list mode. | | | IFM[1] | 1 | Filters 2 and 3 are in mask mode (filter 3 is the mask for the filter 2). | | | IEMIOI | 0 | Filters 4 and 5 are in identifier list mode. | | | IFM[2] | 1 | Filters 4 and 5 are in mask mode (filter 5 is the mask for the filter 4). | | | IFM[3] | 0 | Filters 6 and 7 are in identifier list mode. | | | II-IVI[3] | 1 | Filters 6 and 7 are in mask mode (filter 7 is the mask for the filter 6). | | | IEM[4] | 0 | Filters 8 and 9 are in identifier list mode. | | | IFM[4] | 1 | Filters 8 and 9 are in mask mode (filter 9 is the mask for the filter 8). | | | IEMI61 | 0 | Filters 10 and 11 are in identifier list mode. | | | IFM[5] | 1 | Filters 10 and 11 are in mask mode (filter 11 is the mask for the filter 10). | | | IEMI61 | 0 | Filters 12 and 13 are in identifier list mode. | | | IFM[6] | 1 | Filters 12 and 13 are in mask mode (filter 13 is the mask for the filter 12). | | | IFM[7] | 0 | Filters 14 and 15 are in identifier list mode. | | | 11 141[7] | 1 | Filters 14 and 15 are in mask mode (filter 15 is the mask for the filter 14). | | # 23.7.1.20 Identifier filter control register (IFCR2n) Figure 436. Identifier filter control register (IFCR2n) Note: Register bit can be read in any mode, written only in Initialization mode Table 419. IFCR2*n* field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------| | DFL | Data Field Length This field defines the number of data bytes in the response part of the frame. | Table 419. IFCR2n field descriptions(Continued) | Field | Description | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | DIR | Direction This bit controls the direction of the data field. 0 LINFlex receives the data and copies them in the BDRL and BDRM registers. 1 LINFlex transmits the data from the BDRL and BDRM registers. | | | ccs | Classic Checksum This bit controls the type of checksum applied on the current message. 0 Enhanced Checksum covering Identifier and Data fields. This is compatible with LIN specification 2.0 and higher. 1 Classic Checksum covering Data fields only. This is compatible with LIN specification 1.3 and earlier. | | | ID | Identifier Identifier part of the identifier field without the identifier parity. | | # 23.7.1.21 Identifier filter control register (IFCR2n + 1) Figure 437. Identifier filter control register (IFCR2n + 1) Note: Register bit can be read in any mode, written only in Initialization mode Table 420. IFCR2n + 1 field descriptions | Field | Description | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | DFL | Data Field Length This field defines the number of data bytes in the response part of the frame. DFL = Number of data bytes – 1. | | | DIR | Direction This bit controls the direction of the data field. 0 LINFlex receives the data and copies them in the BDRL and BDRM registers. 1 LINFlex transmits the data from the BDRL and BDRM registers. | | | Field | Description | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | ccs | Classic Checksum This bit controls the type of checksum applied on the current message. 0 Enhanced Checksum covering Identifier and Data fields. This is compatible with LIN specification 2.0 and higher. 1 Classic Checksum covering Data field only. This is compatible with LIN specification 1.3 and earlier. | | | ID | Identifier Identifier part of the identifier field without the identifier parity | | Table 420. IFCR2n + 1 field descriptions(Continued) # 23.8 Functional description ## 23.8.1 **UART** mode The main features in the UART mode are - Full duplex communication - 8- or 9-bit data with parity - 4-byte buffer for reception, 4-byte buffer for transmission - 8-bit counter for timeout management **8-bit data frames**: The 8th bit can be a data or a parity bit. Even/Odd Parity can be selected by the Odd Parity bit in the UARTCR. An even parity is set if the modulo-2 sum of the 7 data bits is 1. An odd parity is cleared in this case. Figure 438. UART mode 8-bit data frame **9-bit frames**: The 9th bit is a parity bit. Even/Odd Parity can be selected by the Odd Parity bit in the UARTCR. An even parity is set if the modulo-2 sum of the 8 data bits is 1. An odd parity is cleared in this case. Figure 439. UART mode 9-bit data frame #### 23.8.1.1 Buffer in UART mode The 8-byte buffer is divided into two parts: one for receiver and one for transmitter as shown in *Table 421*. | Buffer data register | register LIN mode | | UART mode | | |----------------------|----------------------------|------------|-----------------|-----| | | Transmit/Receive<br>buffer | DATA0[0:7] | Transmit buffer | Tx0 | | BDRL[0:31] | | DATA1[0:7] | | Tx1 | | BDRL[0.31] | | DATA2[0:7] | | Tx2 | | | | DATA3[0:7] | | Tx3 | | | | DATA4[0:7] | Receive buffer | Rx0 | | BDRM[0:31] | | DATA5[0:7] | | Rx1 | | BDRIVI[0.31] | | DATA6[0:7] | | Rx2 | | | | DATA7[0:7] | | Rx3 | Table 421. Message buffer #### 23.8.1.2 UART transmitter In order to start transmission in UART mode, you must program the UART bit and the transmitter enable (TXEN) bit in the UARTCR to 1. Transmission starts when DATA0 (least significant data byte) is programmed. The number of bytes transmitted is equal to the value configured by UARTCR[TDFL] (see *Table 402*). The Transmit buffer is 4 bytes, hence a 4-byte maximum transmission can be triggered. Once the programmed number of bytes has been transmitted, the UARTSR[DTF] bit is set. If UARTCR[TXEN] is reset during a transmission then the current transmission is completed and no further transmission can be invoked. ### 23.8.1.3 UART receiver The UART receiver is active as soon as the user exits Initialization mode and programs UARTCR[RXEN] = 1. There is a dedicated 4-byte data buffer for received data bytes. Once the programmed number (RDFL bits) of bytes has been received, the UARTSR[DRF] bit is set. If the RXEN bit is reset during a reception then the current reception is completed and no further reception can be invoked until RXEN is set. If a parity error occurs during reception of any byte, then the corresponding PEx bit in the UARTSR is set. No interrupt is generated in this case. If a framing error occurs in any byte (UARTSR[FE] = 1) then an interrupt is generated if the LINIER[FEIE] bit is set. If the last received frame has not been read from the buffer (that is, RMB bit is not reset by the user) then upon reception of the next byte an overrun error occurs (UARTSR[BOF] = 1) and one message will be lost. Which message is lost depends on the configuration of LINCR1[RBLM]. - If the buffer lock function is disabled (LINCR1[RBLM] = 0) the last message stored in the buffer is overwritten by the new incoming message. In this case the latest message is always available to the application. - If the buffer lock function is enabled (LINCR1[RBLM] = 1) the most recent message is discarded and the previous message is available in the buffer. An interrupt is generated if the LINIER[BOIE] bit is set. ### 23.8.1.4 Clock gating The LINFlex clock can be gated from the Mode Entry module (MC\_ME). In UART mode, the LINFlex controller acknowledges a clock gating request once the data transmission and data reception are completed, that is, once the Transmit buffer is empty and the Receive buffer is full. #### 23.8.2 LIN mode LIN mode comprises four submodes: - Master mode - Slave mode - · Slave mode with identifier filtering - Slave mode with automatic resynchronization These submodes are described in the following pages. #### 23.8.2.1 Master mode In Master mode the application uses the message buffer to handle the LIN messages. Master mode is selected when the LINCR1[MME] bit is set. #### 23.8.2.1.1 LIN header transmission According to the LIN protocol any communication on the LIN bus is triggered by the Master sending a header. The header is transmitted by the Master task while the data is transmitted by the Slave task of a node. To transmit a header with LINFlex the application must set up the identifier, the data field length and configure the message (direction and checksum type) in the BIDR before requesting the header transmission by setting LINCR2[HTRQ]. ### 23.8.2.1.2 Data transmission (transceiver as publisher) When the master node is publisher of the data corresponding to the identifier sent in the header, then the slave task of the master has to send the data in the Response part of the LIN frame. Therefore, the application must provide the data to LINFlex before requesting the header transmission. The application stores the data in the message buffer BDR. According to the data field length, LINFlex transmits the data and the checksum. The application uses the BDR[CCS] bit to configure the checksum type (classic or enhanced) for each message. If the response has been sent successfully, the LINSR[DTF] bit is set. In case of error, the DTF flag is not set and the corresponding error flag is set in the LINESR (see Section 23.8.2.1.6: Error handling). It is possible to handle frames with a Response size larger than 8 bytes of data (extended frames). If the data field length in the BIDR is configured with a value higher than 8 data bytes, the LINSR[DBEF] bit is set after the first 8 bytes have been transmitted. The application has to update the buffer BDR before resetting the DBEF bit. The transmission of the next bytes starts when the DBEF bit is reset. After the last data byte (or the checksum byte) has been sent, the DTF flag is set. The direction of the message buffer is controlled by the BIDR[DIR] bit. When the application sets this bit the response is sent by LINFlex (publisher). Resetting this bit configures the message buffer as subscriber. ### 23.8.2.1.3 Data reception (transceiver as subscriber) To receive data from a slave node, the master sends a header with the corresponding identifier. LINFlex stores the data received from the slave in the message buffer and stores the message status in the LINSR. If the response has been received successfully, the LINSR[DRF] is set. In case of error, the DRF flag is not set and the corresponding error flag is set in the LINESR (see *Section 23.8.2.1.6: Error handling*). It is possible to handle frames with a Response size larger than 8 bytes of data (extended frames). If the data field length in the BIDR is configured with a value higher than 8 data bytes, the LINSR[DBFF] bit is set once the first 8 bytes have been received. The application has to read the buffer BDR before resetting the DBFF bit. Once the last data byte (or the checksum byte) has been received, the DRF flag is set. #### 23.8.2.1.4 Data discard To discard data from a slave, the BIDR[DIR] bit must be reset and the LINCR2[DDRQ] bit must be set before starting the header transmission. #### 23.8.2.1.5 Error detection LINFlex is able to detect and handle LIN communication errors. A code stored in the LIN error status register (LINESR) signals the errors to the software. In Master mode, the following errors are detected: - **Bit error**: During transmission, the value read back from the bus differs from the transmitted value. - **Framing error**: A dominant state has been sampled on the stop bit of the currently received character (synch field, identifier field or data field). - **Checksum error**: The computed checksum does not match the received one. - Response and Frame timeout: See Section 23.8.3: 8-bit timeout counter, for more details. ### 23.8.2.1.6 Error handling In case of Bit Error detection during transmission, LINFlex stops the transmission of the frame after the corrupted bit. LINFlex returns to idle state and an interrupt is generated if LINIER[BEIE] = 1. During reception, a Framing Error leads LINFlex to discard the current frame. LINFlex returns immediately to idle state. An interrupt is generated if LINIER[FEIE] = 1. During reception, a Checksum Error leads LINFlex to discard the received frame. LINFlex returns to idle state. An interrupt is generated if LINIER[CEIE] = 1. #### 23.8.2.1.7 Overrun Once the messages buffer is full (LINSR[RMB] = 1) the next valid message reception leads to an overrun and message is lost. The hardware signals the overrun condition by setting the BOF bit in the LINESR. Which message is lost depends on the buffer lock function control bit RBLM. - If the buffer lock function control bit is cleared (LINCR1[RBLM] = 0) the old message in the buffer is overwritten by the most recent message. - If buffer lock function control bit is set (LINCR1[RBLM] = 1) the most recent message is discarded, and the oldest message is available in the buffer. ## 23.8.2.2 Slave mode In Slave mode the application uses the message buffer to handle the LIN messages. Slave mode is selected when LINCR1[MME] = 0. ### 23.8.2.2.1 Data transmission (transceiver as publisher) When LINFlex receives the identifier, the LINSR[HRF] is set and, if LINIER[HRIE] = 1, an RX interrupt is generated. The software must read the received identifier in the BIDR, fill the BDRs, specify the data field length using the BIDR[DFL] and trigger the data transmission by setting the LINCR2[DTRQ] bit. One or several identifier filters can be configured for transmission by setting the IFCRx[DIR] bit and activated by setting one or several bits in the IFER. When at least one identifier filter is configured in transmission and activated, and if the received identifier matches the filter, a specific TX interrupt (instead of an RX interrupt) is generated. Typically, the application has to copy the data from SRAM locations to the BDR. To copy the data to the right location, the application has to identify the data by means of the identifier. To avoid this and to ease the access to the SRAM locations, the LINFlex controller provides a Filter Match Index. This index value is the number of the filter that matched the received identifier. The software can use the index in the IFMI register to directly access the pointer that points to the right data array in the SRAM area and copy this data to the BDR (see *Figure 441*). Using a filter avoids the software having to configure the direction, the data field length and the checksum type in the BIDR. The software fills the BDR and triggers the data transmission by programming LINCR2[DTRQ] = 1. If LINFlex cannot provide enough TX identifier filters to handle all identifiers the software has to transmit data for, then a filter can be configured in mask mode (see Section 23.8.2.3: Slave mode with identifier filtering) in order to manage several identifiers with one filter only. ### 23.8.2.2.2 Data reception (transceiver as subscriber) When LINFlex receives the identifier, the LINSR[HRF] bit is set and, if LINIER[HRIE] = 1, an RX interrupt is generated. The software must read the received identifier in the BIDR and specify the data field length using the BIDR[DFL] field before receiving the stop bit of the first byte of data field. When the checksum reception is completed, an RX interrupt is generated to allow the software to read the received data in the BDRs. One or several identifier filters can be configured for reception by programming IFCRx[DIR] = 0 and activated by setting one or several bits in the IFER. When at least one identifier filter is configured in reception and activated, and if the received identifier matches the filter, an RX interrupt is generated after the checksum reception only. Typically, the application has to copy the data from the BDR to SRAM locations. To copy the data to the right location, the application has to identify the data by means of the identifier. To avoid this and to ease the access to the SRAM locations, the LINFlex controller provides a Filter Match Index. This index value is the number of the filter that matched the received identifier. The software can use the index in the IFMI register to directly access the pointer that points to the right data array in the SRAM area and copy this data from the BDR to the SRAM (see *Figure 441*). Using a filter avoids the software reading the ID value in the BIDR, and configuring the direction, the data field length and the checksum type in the BIDR. If LINFlex cannot provide enough RX identifier filters to handle all identifiers the software has to receive the data for, then a filter can be configured in mask mode (see Section 23.8.2.3: Slave mode with identifier filtering) in order to manage several identifiers with one filter only. ### 23.8.2.2.3 Data discard When LINFlex receives the identifier, the LINSR[HRF] bit is set and, if LINIER[HRIE] = 1, an RX interrupt is generated. If the received identifier does not concern the node, you must program LINCR2[DDRQ] = 1. LINFlex returns to idle state after bit DDRQ is set. #### 23.8.2.2.4 Error detection In Slave mode, the following errors are detected: - **Header error**: An error occurred during header reception (Break Delimiter error, Inconsistent Synch Field, Header Timeout). - Bit error: During transmission, the value read back from the bus differs from the transmitted value. - **Framing error**: A dominant state has been sampled on the stop bit of the currently received character (synch field, identifier field or data field). - Checksum error: The computed checksum does not match the received one. #### 23.8.2.2.5 Error handling In case of Bit Error detection during transmission, LINFlex stops the transmission of the frame after the corrupted bit. LINFlex returns to idle state and an interrupt is generated if the BEIE bit in the LINIER is set. During reception, a Framing Error leads LINFlex to discard the current frame. LINFlex returns immediately to idle state. An interrupt is generated if LINIER[FEIE] = 1. During reception, a Checksum Error leads LINFlex to discard the received frame. LINFlex returns to idle state. An interrupt is generated if LINIER[CEIE] = 1. During header reception, a Break Delimiter error, an Inconsistent Synch Field or a Timeout error leads LINFlex to discard the header. An interrupt is generated if LINIER[HEIE] = 1. LINFlex returns to idle state. #### 23.8.2.2.6 Valid header A received header is considered as valid when it has been received correctly according to the LIN protocol. If a valid Break Field and Break Delimiter come before the end of the current header or at any time during a data field, the current header or data is discarded and the state machine synchronizes on this new break. ### 23.8.2.2.7 Valid message A received or transmitted message is considered as valid when the data has been received or transmitted without error according to the LIN protocol. #### 23.8.2.2.8 Overrun Once the messages buffer is full (LINSR[RMB] = 1) the next valid message reception leads to an overrun and message is lost. The hardware signals the overrun condition by setting the BOF bit in the LINESR. Which message is lost depends on the buffer lock function control bit RBLM. - If the buffer lock function control bit is cleared (LINCR1[RBLM] = 0) the old message in the buffer will be overwritten by the most recent message. - If buffer lock function control bit is set (LINCR1[RBLM] = 1) the most recent message is discarded, and the oldest message is available in the buffer. - If buffer is not released (LINSR[RMB] = 1) before reception of next Identifier and if RBLM is set then ID along with the data is discarded. ## 23.8.2.3 Slave mode with identifier filtering In the LIN protocol the identifier of a message is not associated with the address of a node but related to the content of the message. Consequently a transmitter broadcasts its message to all receivers. On header reception a slave node decides—depending on the identifier value—whether the software needs to receive or send a response. If the message does not target the node, it must be discarded without software intervention. To fulfill this requirement, the LINFlex controller provides configurable filters in order to request software intervention only if needed. This hardware filtering saves CPU resources that would otherwise be needed by software for filtering. #### 23.8.2.3.1 Filter mode Usually each of the sixteen IFCR registers filters one dedicated identifier, but this limits the number of identifiers LINFlex can handle to the number of IFCR registers implemented in the device. Therefore, in order to be able to handle more identifiers, the filters can be configured in mask mode. In **identifier list mode** (the default mode), both filter registers are used as identifier registers. All bits of the incoming identifier must match the bits specified in the filter register. In **mask mode**, the identifier registers are associated with mask registers specifying which bits of the identifier are handled as "must match" or as "don't care". For the bit mapping and registers organization, please see *Figure 440*. **Identifier Filter Register Organization** 15 0 IFCR<sub>n</sub> Identifier Bit Mapping DFL DIR CCS ID **Identifier Filter Configuration Identifier Filter Mode Identifier List Mode** IFCR2n Identifier IFM = 0IFCR2n + 1 Identifier Mask Mode Identifier IFCR2n IFM = 1 IFCR2n + 1 Mask Figure 440. Filter configuration—register organization ### 23.8.2.3.2 Identifier filter mode configuration The identifier filters are configured in the IFCRx registers. To configure an identifier filter the filter must first be activated by programming IFER[FACT] = 1. The **identifier list** or **identifier mask** mode for the corresponding IFCRx registers is configured by the IFMR[IFM] bit. For each filter, the IFCRx register configures the ID (or the mask), the direction (TX or RX), the data field length, and the checksum type. If no filter is active, an RX interrupt is generated on any received identifier event. If at least one active filter is configured as TX, all received identifiers matching this filter generate a TX interrupt. If at least one active filter is configured as RX, all received identifiers matching this filter generate an RX interrupt. If no active filter is configured as RX, all received identifiers not matching TX filter(s) generate an RX interrupt. Number of Number of active filters Number of active filters Interrupt vector active filters configured as TX configured as RX 0 0 0 RX interrupt on all identifiers - TX interrupt on identifiers matching the filters, - RX interrupt on all other а 0 (a > 0)identifiers if BF bit is set, no RX interrupt if BF bit is reset Table 422. Filter to interrupt vector correlation | Number of active filters | Number of active filters configured as TX | Number of active filters configured as RX | Interrupt vector | |--------------------------|-------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | n<br>(n = a + b) | a<br>(a > 0) | b<br>(b > 0) | TX interrupt on identifiers matching the TX filters, RX interrupt on identifiers matching the RX filters, all other identifiers discarded (no interrupt) | | b<br>(b > 0) | 0 | b | RX interrupt on identifiers matching the filters, TX interrupt on all other identifiers if BF bit is set, no TX interrupt if BF bit is reset | Table 422. Filter to interrupt vector correlation(Continued) Figure 441. Identifier match index ## 23.8.2.4 Slave mode with automatic resynchronization Automatic resynchronization must be enabled in Slave mode if $f_{periph\_set\_1\_clk}$ tolerance is greater than 1.5%. This feature compensates a $f_{periph\_set\_1\_clk}$ deviation up to 14%, as specified in LIN standard. This mode is similar to Slave mode as described in *Section 23.8.2.2: Slave mode*, with the addition of automatic resynchronization enabled by the LASE bit. In this mode LINFlex adjusts the fractional baud rate generator after each Synch Field reception. ### 23.8.2.4.1 Automatic resynchronization method When automatic resynchronization is enabled, after each LIN Break, the time duration between five falling edges on RDI is sampled on $f_{periph\_set\_1\_clk}$ and the result of this measurement is stored in an internal 19-bit register called SM (not user accessible) (see *Figure 442*). Then the LFDIV value (and its associated registers LINIBRR and LINFBRR) is automatically updated at the end of the fifth falling edge. During LIN Synch Field measurement, the LINFlex state machine is stopped and no data is transferred to the data register. Figure 442. LIN synch field measurement LFDIV is an unsigned fixed point number. The mantissa is coded on 12 bits in the LINIBRR and the fraction is coded on 4 bits in the LINFBRR. If LASE bit = 1 then LFDIV is automatically updated at the end of each LIN Synch Field. Three internal registers (not user-accessible) manage the auto-update of the LINFlex divider (LFDIV): - LFDIV\_NOM (nominal value written by software at LINIBRR and LINFBRR addresses) - LFDIV\_MEAS (results of the Field Synch measurement) - LFDIV (used to generate the local baud rate) On transition to idle, break or break delimiter state due to any error or on reception of a complete frame, hardware reloads LFDIV with LFDIV NOM. ## 23.8.2.4.2 Deviation error on the Synch Field The deviation error is checked by comparing the current baud rate (relative to the slave oscillator) with the received LIN Synch Field (relative to the master oscillator). Two checks are performed in parallel. The first check is based on a measurement between the first falling edge and the last falling edge of the Synch Field: - If D1 > 14.84%, LHE is set. - If D1 < 14.06%, LHE is not set.</li> - If 14.06% < D1 < 14.84%, LHE can be either set or reset depending on the dephasing between the signal on LINFlex\_RX pin the f<sub>periph\_set\_1\_clk</sub> clock. The second check is based on a measurement of time between each falling edge of the Synch Field: - If D2 > 18.75%, LHE is set. - If D2 < 15.62%, LHE is not set.</li> - If 15.62% < D2 < 18.75%, LHE can be either set or reset depending on the dephasing between the signal on LINFlex\_RX pin the f<sub>periph set 1 clk</sub> clock. Note that the LINFlex does not need to check if the next edge occurs slower than expected. This is covered by the check for deviation error on the full synch byte. # 23.8.2.5 Clock gating The LINFlex clock can be gated from the Mode Entry module (MC\_ME). In LIN mode, the LINFlex controller acknowledges a clock gating request once the frame transmission or reception is completed. ### 23.8.3 8-bit timeout counter ### 23.8.3.1 LIN timeout mode Resetting the LTOM bit in the LINTCSR enables the LIN timeout mode. The LINOCR becomes read-only, and OC1 and OC2 output compare values in the LINOCR are automatically updated by hardware. This configuration detects header timeout, response timeout, and frame timeout. Depending on the LIN mode (selected by the LINCR1[MME] bit), the 8-bit timeout counter will behave differently. LIN timeout mode must not be enabled during LIN extended frames transmission or reception (that is, if the data field length in the BIDR is configured with a value higher than 8 data bytes). ### 23.8.3.1.1 LIN Master mode The LINTOCR[RTO] field can be used to tune response timeout and frame timeout values. Header timeout value is fixed to HTO = 28-bit time. Field OC1 checks T<sub>Header</sub> and T<sub>Response</sub> and field OC2 checks T<sub>Frame</sub> (see *Figure 443*). When LINFlex moves from Break delimiter state to Synch Field state (see Section 23.7.1.3: LIN status register (LINSR)): - OC1 is updated with the value of OC<sub>Header</sub> (OC<sub>Header</sub> = CNT + 28), - OC2 is updated with the value of OC<sub>Frame</sub> (OC<sub>Frame</sub> = CNT + 28 + RTO × 9 (frame timeout value for an 8-byte frame), - the TOCE bit is set. On the start bit of the first response data byte (and if no error occurred during the header reception), OC1 is updated with the value of $OC_{Response}$ ( $OC_{Response}$ = CNT + RTO × 9 (response timeout value for an 8-byte frame)). On the first response byte is received, OC1 and OC2 are automatically updated to check $T_{Response}$ and $T_{Frame}$ according to RTO (tolerance) and DFL. On the checksum reception or in case of error in the header or response, the TOCE bit is reset. If there is no response, frame timeout value does not take into account the DFL value, and an 8-byte response (DFL = 7) is always assumed. #### 23.8.3.1.2 LIN Slave mode The LINTOCR[RTO] field can be used to tune response timeout and frame timeout values. Header timeout value is fixed to HTO. OC1 checks T<sub>Header</sub> and T<sub>Response</sub> and OC2 checks T<sub>Frame</sub> (see *Figure 443*). When LINFlex moves from Break state to Break Delimiter state (see Section 23.7.1.3: LIN status register (LINSR)): - OC1 is updated with the value of OC<sub>Header</sub> (OC<sub>Header</sub> = CNT + HTO), - OC2 is updated with the value of OC<sub>Frame</sub> (OC<sub>Frame</sub> = CNT + HTO + RTO × 9 (frame timeout value for an 8-byte frame)), - The TOCE bit is set. On the start bit of the first response data byte (and if no error occurred during the header reception), OC1 is updated with the value of $OC_{Response}$ ( $OC_{Response}$ = CNT + RTO × 9 (response timeout value for an 8-byte frame)). Once the first response byte is received, OC1 and OC2 are automatically updated to check $T_{Response}$ and $T_{Frame}$ according to RTO (tolerance) and DFL. On the checksum reception or in case of error in the header or data field, the TOCE bit is reset. Figure 443. Header and response timeout ### 23.8.3.2 Output compare mode Programming LINTCSR[LTOM] = 1 enables the output compare mode. This mode allows the user to fully customize the use of the counter. OC1 and OC2 output compare values can be updated in the LINTOCR by software. ## 23.8.4 Interrupts **Enable control bit** Interrupt event **Event flag bit** Interrupt vector RXI (1) Header Received interrupt **HRF HRIE** Data Transmitted interrupt DTF DTIE TXI **DRF DRIE** RXI Data Received interrupt Data Buffer Empty interrupt **DBEF DBEIE** TXI Data Buffer Full interrupt **DBFF DBFIE** RXI RXI Wake-up interrupt **WUPF WUPIE** **Table 423. LINFlex interrupt control** Table 423. LINFlex interrupt control(Continued) | Interrupt event | Event flag bit | Enable control bit | Interrupt vector | |--------------------------|----------------|--------------------|------------------| | LIN State interrupt (2) | LSF | LSIE | RXI | | Buffer Overrun interrupt | BOF | BOIE | ERR | | Framing Error interrupt | FEF | FEIE | ERR | | Header Error interrupt | HEF | HEIE | ERR | | Checksum Error interrupt | CEF | CEIE | ERR | | Bit Error interrupt | BEF | BEIE | ERR | | Output Compare interrupt | OCF | OCIE | ERR | | Stuck at Zero interrupt | SZF | SZIE | ERR | In Slave mode, if at least one filter is configured as TX and enabled, header received interrupt vector is RXI or TXI depending on the value of identifier received. <sup>2.</sup> For debug and validation purposes. # 24 FlexCAN # 24.1 Introduction The FlexCAN module is a communication controller implementing the CAN protocol according to the CAN 2.0B protocol specification. A general block diagram is shown in *Figure 444*, which describes the main subblocks implemented in the FlexCAN module, including two embedded memories, one for storing Message Buffers (MB) and another one for storing Rx Individual Mask Registers. Support for 32 MBs is provided. The functions of the submodules are described in subsequent sections. Figure 444. FlexCAN block diagram ### 24.1.1 Overview The CAN protocol was primarily, but not only, designed to be used as a vehicle serial data bus, meeting the specific requirements of this field: real-time processing, reliable operation in the EMI environment of a vehicle, cost-effectiveness and required bandwidth. The FlexCAN module is a full implementation of the CAN protocol specification, Version 2.0 B, which supports both standard and extended message frames. 32 Message Buffers are supported. The Message Buffers are stored in an embedded RAM dedicated to the FlexCAN module. The CAN Protocol Interface (CPI) submodule manages the serial communication on the CAN bus, requesting RAM access for receiving and transmitting message frames, validating received messages and performing error handling. The Message Buffer Management (MBM) submodule handles Message Buffer selection for reception and transmission, taking care of arbitration and ID matching algorithms. The Bus Interface Unit (BIU) submodule controls the access to and from the internal interface bus, in order to establish connection to the CPU and to other blocks. Clocks, address and data buses, interrupt outputs and test signals are accessed through the Bus Interface Unit. Three FlexCAN module are implemented on SPC56xP60x/54x device. Two are named as FlexCAN\_0 and FlexCAN\_1 and one is Safetyport. #### 24.1.2 FlexCAN module features The FlexCAN module includes these features: Full Implementation of the CAN protocol specification, Version 2.0B - Standard data and remote frames - Extended data and remote frames - 0 to 8 bytes data length - Programmable bit rate as high as 1 Mbit/s - Content-related addressing - 32 Flexible Message Buffers (MBs) of 0 to 8 bytes data length - Each MB configurable as Rx or Tx, all supporting standard and extended messages - Individual Rx Mask Registers per Message Buffer - Includes 544 bytes (32 MBs) of RAM used for MB storage - Includes 128 bytes (32 MBs) of RAM used for individual Rx Mask Registers - Full-featured Rx FIFO with storage capacity for 6 frames and internal pointer handling - Powerful Rx FIFO ID filtering, capable of matching incoming IDs against either 8 extended, 16 standard, or 32 partial (8-bit) IDs, with individual masking capability - Selectable backwards compatibility with previous FlexCAN version - Programmable clock source to the CAN Protocol Interface, either bus clock or crystal oscillator - Unused MB and Rx Mask Register space can be used as general purpose RAM space - Listen-only mode capability - Programmable loop-back mode supporting self-test operation - Programmable transmission priority scheme: lowest ID, lowest buffer number or highest priority - Time Stamp based on 16-bit free-running timer - Global network time, synchronized by a specific message - Maskable interrupts - Independent of the transmission medium (an external transceiver is assumed) - Short latency time due to an arbitration scheme for high-priority messages - Low power modes # 24.1.3 Modes of operation The FlexCAN module has four functional modes: Normal mode (User and Supervisor), Freeze mode, Listen-Only Mode, and Loop-Back mode. There are also these low power modes: Disable mode and Stop mode. - Normal mode (User or Supervisor) - In Normal mode, the module operates receiving and/or transmitting message frames, errors are handled normally and all the CAN Protocol functions are enabled. User and Supervisor modes differ in the access to some restricted control registers. - Freeze mode It is enabled when the FRZ bit in the Module Configuration Register (MCR) is asserted. If enabled, Freeze Mode is entered when the HALT bit in the MCR is set or when Debug Mode is requested at MCU level. In this mode, no transmission or reception of frames is done and synchronicity to the CAN bus is lost. See Section 24.4.9.1: Freeze mode for more information. #### Listen-Only mode The module enters this mode when the LOM bit in the Control Register is asserted. In this mode, transmission is disabled, all error counters are frozen and the module operates in a CAN Error Passive mode [Ref. 1]. Only messages acknowledged by another CAN station will be received. If FlexCAN detects a message that has not been acknowledged, it will flag a BIT0 error (without changing the REC), as if it was trying to acknowledge the message. #### Loop-Back mode The module enters this mode when the LPB bit in the Control Register is asserted. In this mode, FlexCAN performs an internal loop back that can be used for self test operation. The bit stream output of the transmitter is internally fed back to the receiver input. The Rx CAN input pin is ignored and the Tx CAN output goes to the recessive state (logic 1). FlexCAN behaves as it normally does when transmitting and treats its own transmitted message as a message received from a remote node. In this mode, FlexCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field to ensure proper reception of its own message. Both transmit and receive interrupts are generated. #### Module Disable mode This low power mode is entered when the MDIS bit in the MCR is asserted. When disabled, the module shuts down the clocks to the CAN Protocol Interface and Message Buffer Management submodules. Exit from this mode is done by negating the MDIS bit in the MCR. See Section 24.4.9.2: Module disable mode for more information. # 24.2 External signal description #### 24.2.1 Overview The FlexCAN module has two I/O signals connected to the external MCU pins. These signals are summarized in *Table 424* and described in more detail in the next subsections. | Signal name | Direction | Description | |-------------|-----------|------------------| | RXD | Input | CAN receive pin | | TXD Outpu | | CAN transmit pin | Table 424. FlexCAN signals # 24.2.2 Signal Descriptions #### 24.2.2.1 RXD This pin is the receive pin from the CAN bus transceiver. Dominant state is represented by logic level 0. Recessive state is represented by logic level 1. #### 24.2.2.2 TXD This pin is the transmit pin to the CAN bus transceiver. Dominant state is represented by logic level 0. Recessive state is represented by logic level 1. # 24.3 Memory map and registers description This section describes the registers and data structures in the FlexCAN module. The base address of the module depends on the particular memory map of the device. The addresses presented here are relative to the base address. The address space occupied by FlexCAN has 96 bytes for registers starting at the module base address, followed by MB storage space in embedded RAM starting at address 0x0060, and an extra ID Mask storage space in a separate embedded RAM starting at address 0x0880. # 24.3.1 FlexCAN memory mapping The complete memory map for a FlexCAN module with 32 MBs capability is shown in *Table 425*. The access type can be Supervisor (S) or Unrestricted (U), also called User access. Most of the registers can be configured to have either Supervisor or Unrestricted access by programming the SUPV bit in the MCR. The Rx Global Mask (RXGMASK), Rx Buffer 14 Mask (RX14MASK) and the Rx Buffer 15 Mask (RX15MASK) registers are provided for backwards compatibility, and are not used when the BCC bit in the MCR is asserted. The address ranges 0x0060–0x027F and 0x0880–0x08FF are occupied by two separate embedded memories of RAM, of 544 bytes and 128 bytes, respectively. When the FlexCAN is configured with 32 MBs, the memory sizes are 544 and 128 bytes, so the address ranges 0x0280–0x047F and 0x0900–0x097F are considered reserved space. Furthermore, if the BCC bit in the MCR is negated, then the whole Rx Individual Mask Registers address range (0x0880–0x097F) is considered reserved space. Note: The individual Rx Mask per Message Buffer feature may not be available in low cost MCUs. Please consult the specific MCU documentation to find out if this feature is supported. If not supported, the address range 0x0880–0x097F is considered reserved space, independent of the value of the BCC bit. Table 425. FlexCAN module memory map | Offset from FlexCAN_BASE 0xFFFC_0000 (CAN_0) 0x8FFC_4000 (CAN_1) | Register | Location | |------------------------------------------------------------------|---------------------------------------------|-------------| | 0x0000 | Module Configuration Register (MCR) | on page 770 | | 0x0004 | Control Register (CTRL) | on page 774 | | 0x0008 | Free Running Timer (TIMER) | on page 777 | | 0x000C | Reserved | | | 0x0010 | Rx Global Mask (RXGMASK) on page 778 | | | 0x0014 | Rx Buffer 14 Mask (RX14MASK) | on page 779 | | 0x0018 | Rx Buffer 15 Mask (RX15MASK) | on page 780 | | 0x001C | Error Counter Register (ECR) | on page 780 | | 0x0020 | Error and Status Register (ESR) on page 78. | | | 0x0024 | Reserved | | Table 425. FlexCAN module memory map(Continued) | Offset from FlexCAN_BASE 0xFFFC_0000 (CAN_0) 0x8FFC_4000 (CAN_1) | Register | Location | |------------------------------------------------------------------|---------------------------------------------------------|-------------| | 0x0028 | Interrupt Masks 1 (IMASK1) | on page 785 | | 0x002C | Reserved | | | 0x0030 | Interrupt Flags 1 (IFLAG1) | on page 785 | | 0x0034-0x005F | Reserved | • | | 0x0060-0x007F | Serial Message Buffers (SMB0–SMB1) – Reserved — | | | 0x0080-0x017F | Message Buffers MB0–MB15 on page 765 | | | 0x0180-0x027F | Message Buffers MB16–MB31 on page 76 | | | 0x0280-0x087F | Reserved | • | | 0x0880-0x08BF | Rx Individual Mask Registers RXIMR0–RXIMR15 on page 7 | | | 0x08C0-0x08FF | Rx Individual Mask Registers RXIMR16–RXIMR31 on page 78 | | | 0x0900-0x3FFF | Reserved | • | Table 426. FlexCAN register reset status | Register | Affected by hard reset | Affected by soft reset | |-----------------------------------------------|------------------------|------------------------| | Module Configuration Register (MCR) | Yes | Yes | | Control Register (CTRL) | Yes | No | | Free Running Timer (TIMER) | Yes | Yes | | Reserved | | | | Rx Global Mask (RXGMASK) | Yes | No | | Rx Buffer 14 Mask (RX14MASK) | Yes | No | | Rx Buffer 15 Mask (RX15MASK) | Yes | No | | Error Counter Register (ECR) | Yes | Yes | | Error and Status Register (ESR) | Yes | Yes | | Interrupt Masks 1 (IMASK1) | Yes | Yes | | Interrupt Flags 1 (IFLAG1) | Yes | Yes | | Serial Message Buffers (SMB0–SMB1) – Reserved | No | No | | Message Buffers MB0-MB15 | No | No | | Message Buffers MB16–MB31 | No | No | | Rx Individual Mask Registers RXIMR0–RXIMR15 | No | No | | Rx Individual Mask Registers RXIMR16–RXIMR31 | No | No | The FlexCAN module stores CAN messages for transmission and reception using a Message Buffer structure. Each individual MB is formed by 16 bytes mapped on memory as described in *Table 427*. The module also implements two additional Message Buffers called SMB0 and SMB1 (Serial Message Buffers), in the address ranges 0x60–0x6F and 0x70–0x7F, which are not accessible to the end user. They are used for temporary storage of frames during the reception and transmission processes. *Table 427* shows a Standard/Extended Message Buffer (MB0) memory map, using 16 bytes total (0x80–0x8F space). Table 427. Message Buffer MB0 memory mapping | Address offset | MB field | |----------------|-------------------------------------------| | 0x0080 | Control and Status (C/S) | | 0x0084 | Identifier Field | | 0x0088-0x008F | Data Field 0 - Data Field 7 (1 byte each) | # 24.3.2 Message buffer structure The Message Buffer structure used by the FlexCAN module is represented in *Table 445*. Both Extended and Standard Frames (29-bit Identifier and 11-bit Identifier, respectively) used in the CAN specification (Version 2.0 Part B) are represented. | 0x0 | | CODE | SRR<br>IDE<br>RTR | GTH | TIME S | STAMP | |-----|---------------------------------------------|------------|-------------------|-----|-------------|-------------| | 0x4 | 4 PRIO ID (Standard/Extended) ID (Extended) | | ed) | | | | | 0x8 | Da | nta Byte 0 | Data Byte 1 | | Data Byte 2 | Data Byte 3 | | 0xC | Data Byte 4 | | Data Byte 5 | | Data Byte 6 | Data Byte 7 | Figure 445. Message buffer structure Table 428. Message Buffer structure field description | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CODE | Message Buffer Code This 4-bit field can be accessed (read or write) by the CPU and by the FlexCAN module itself, as part of the message buffer matching and arbitration process. The encoding is shown in <i>Table 429</i> and <i>Table 430</i> . See <i>Section 24.4: Functional description</i> for additional information. | | SRR | Substitute Remote Request Fixed recessive bit, used only in extended format. It must be set to 1 by the user for transmission (Tx Buffers) and will be stored with the value received on the CAN bus for Rx receiving buffers. It can be received as either recessive or dominant. If FlexCAN receives this bit as dominant, then it is interpreted as arbitration loss. 0 Dominant is not a valid value for transmission in Extended Format frames. 1 Recessive value is compulsory for transmission in Extended Format frames. | | IDE | ID Extended Bit This bit identifies whether the frame format is standard or extended. 0 Frame format is standard 1 Frame format is extended | Table 428. Message Buffer structure field description(Continued) | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RTR | Remote Transmission Request This bit is used for requesting transmissions of a data frame. If FlexCAN transmits this bit as 1 (recessive) and receives it as 0 (dominant), it is interpreted as arbitration loss. If this bit is transmitted as 0 (dominant), then if it is received as 1 (recessive), the FlexCAN module treats it as bit error. If the value received matches the value transmitted, it is considered as a successful bit transmission. 0 Indicates the current MB has a Data Frame to be transmitted 1 Indicates the current MB has a Remote Frame to be transmitted | | LENGTH | Length of Data in Bytes This 4-bit field is the length (in bytes) of the Rx or Tx data, which is located in offset 0x8 through 0xF of the MB space (see <i>Figure 445</i> ). In reception, this field is written by the FlexCAN module, copied from the DLC (Data Length Code) field of the received frame. In transmission, this field is written by the CPU and corresponds to the DLC field value of the frame to be transmitted. When RTR=1, the Frame to be transmitted is a Remote Frame and does not include the data field, regardless of the Length field. | | TIME STAMP | Free-Running Counter Time Stamp This 16-bit field is a copy of the Free-Running Timer, captured for Tx and Rx frames at the time when the beginning of the Identifier field appears on the CAN bus. | | PRIO | Local priority This 3-bit field is only used when LPRIO_EN bit is set in MCR and it only makes sense for Tx buffers. These bits are not transmitted. They are appended to the regular ID to define the transmission priority. See Section 24.4.3: Arbitration process. | | ID | Frame Identifier In Standard Frame format, only the 11 most significant bits (3 to 13) are used for frame identification in both receive and transmit cases. The 18 least significant bits are ignored. In Extended Frame format, all bits are used for frame identification in both receive and transmit cases. | | DATA | Data Field As many as 8 bytes can be used for a data frame. For Rx frames, the data is stored as it is received from the CAN bus. For Tx frames, the CPU prepares the data field to be transmitted within the frame. | Table 429. Message buffer code for Rx buffers | Rx Code<br>BEFORE<br>Rx New Frame | Description | Rx Code<br>AFTER<br>Rx New Frame | Comment | |-----------------------------------|--------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------| | 0000 | INACTIVE: MB is not active. | _ | MB does not participate in the matching process. | | 0100 | EMPTY: MB is active and empty. | 0010 | MB participates in the matching process. When a frame is received successfully, the code is automatically updated to FULL. | Table 429. Message buffer code for Rx buffers(Continued) | Rx Code<br>BEFORE<br>Rx New Frame | Description | Rx Code<br>AFTER<br>Rx New Frame | Comment | |-----------------------------------|-------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0010 | FULL: MB is full. | 0010 | The act of reading the C/S word followed by unlocking the MB does not make the code return to EMPTY. It remains FULL. If a new frame is written to the MB after the C/S word was read and the MB was unlocked, the code still remains FULL. | | 0010 | | 0110 | If the MB is FULL and a new frame is overwritten to this MB before the CPU had time to read it, the code is automatically updated to OVERRUN. Refer to Section 24.4.5: Matching process for details about overrun behavior. | | 0110 | OVERRUN: a frame was overwritten into a full buffer. | 0010 | If the code indicates OVERRUN but the CPU reads the C/S word and then unlocks the MB, when a new frame is written to the MB the code returns to FULL. | | | | 0110 | If the code already indicates OVERRUN, and yet another new frame must be written, the MB will be overwritten again, and the code will remain OVERRUN. Refer to Section 24.4.5: Matching process for details about overrun behavior. | | 0XY1 <sup>(1)</sup> | BUSY: FlexCAN is updating the contents of the MB. The | 0010 | An EMPTY buffer was written with a new frame (XY was 01). | | | CPU must not access the MB. | 0110 | A FULL/OVERRUN buffer was overwritten (XY was 11). | <sup>1.</sup> Note that for Tx MBs (see Table 430), the BUSY bit should be ignored upon read, except when AEN bit is set in the MCR. Table 430. Message Buffer code for Tx buffers | RTR | Initial Tx<br>code | Code after successful transmission | Description | |-----|--------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Х | 1000 | - | INACTIVE: MB does not participate in the arbitration process. | | х | 1001 | - | ABORT: MB was configured as Tx and CPU aborted the transmission. This code is only valid when AEN bit in MCR is asserted. MB does not participate in the arbitration process. | | 0 | 1100 | 1000 | Transmit data frame unconditionally once. After transmission, the MB automatically returns to the INACTIVE state. | | 1 | 1100 | 0100 | Transmit remote frame unconditionally once. After transmission, the MB automatically becomes an Rx MB with the same ID. | Table 430. Message Buffer code for Tx buffers(Continued) | RTR | Initial Tx<br>code | Code after successful transmission | Description | |-----|--------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 1010 | 1010 | Transmit a data frame whenever a remote request frame with the same ID is received. This MB participates simultaneously in both the matching and arbitration processes. The matching process compares the ID of the incoming remote request frame with the ID of the MB. If a match occurs this MB is allowed to participate in the current arbitration process and the Code field is automatically updated to '1110' to allow the MB to participate in future arbitration runs. When the frame is eventually transmitted successfully, the Code automatically returns to '1010' to restart the process again. | | 0 | 1110 | 1010 | This is an intermediate code that is automatically written to the MB by the MBM as a result of match to a remote request frame. The data frame will be transmitted unconditionally once and then the code will automatically return to '1010'. The CPU can also write this code with the same effect. | Table 431. MB0-MB31 addresses | Address | Register | Address | Register | |---------------|----------|---------------|----------| | Base + 0x0080 | MB0 | Base + 0x0180 | MB16 | | Base + 0x0090 | MB1 | Base + 0x0190 | MB17 | | Base + 0x00A0 | MB2 | Base + 0x01A0 | MB18 | | Base + 0x00B0 | MB3 | Base + 0x01B0 | MB19 | | Base + 0x00C0 | MB4 | Base + 0x01C0 | MB20 | | Base + 0x00D0 | MB5 | Base + 0x01D0 | MB21 | | Base + 0x00E0 | MB6 | Base + 0x01E0 | MB22 | | Base + 0x00F0 | MB7 | Base + 0x01F0 | MB23 | | Base + 0x0100 | MB8 | Base + 0x0200 | MB24 | | Base + 0x0110 | MB9 | Base + 0x0210 | MB25 | | Base + 0x0120 | MB10 | Base + 0x0220 | MB26 | | Base + 0x0130 | MB11 | Base + 0x0230 | MB27 | | Base + 0x0140 | MB12 | Base + 0x0240 | MB28 | | Base + 0x0150 | MB13 | Base + 0x0250 | MB29 | | Base + 0x0160 | MB14 | Base + 0x0260 | MB30 | | Base + 0x0170 | MB15 | Base + 0x0270 | MB31 | # 24.3.3 Rx FIFO structure When the FEN bit is set in the MCR, the memory area from 0x80 to 0xFF (which is normally occupied by MBs 0 to 7) is used by the reception FIFO engine. *Figure 446* shows the Rx FIFO data structure. The region 0x80–0x8F contains an MB structure that is the port through which the CPU reads data from the FIFO (the oldest frame received and not read yet). The region 0x90–0xDF is reserved for internal use of the FIFO engine. The region 0xE0–0xFF contains an 8-entry ID table that specifies filtering criteria for accepting frames into the FIFO. *Figure 446* shows the three different formats that the elements of the ID table can assume, depending on the IDAM field of the MCR. Note that all elements of the table must have the same format. See *Section 24.4.7: Rx FIFO* for more information. $0 \quad 1 \quad 2 \quad 3 \quad 4 \quad 5 \quad 6 \quad 7 \quad 8 \quad 9 \quad 10 \quad 11 \quad 12 \quad 13 \quad 14 \quad 15 \quad 16 \quad 17 \quad 18 \quad 19 \quad 20 \quad 21 \quad 22 \quad 23 \quad 24 \quad 25 \quad 26 \quad 27 \quad 28 \quad 29 \quad 30 \quad 31$ 믭 0x80 **LENGTH** TIME STAMP 0x84 ID (Standard/Extended) ID (Extended) 0x88 Data Byte 0 Data Byte 1 Data Byte 2 Data Byte 3 0x8C Data Byte 4 Data Byte 5 Data Byte 6 Data Byte 7 0x90 Reserved to 0xDC 0xE0 ID Table 0 ID Table 1 0xE4 ID Table 2 0xE8 ID Table 3 0xEC 0xF0 ID Table 4 ID Table 5 0xF4 = Unimplemented or Reserved ID Table 6 ID Table 7 Figure 446. Rx FIFO structure 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 REM **RXIDA** (Standard = 2-12, Extended = 2-31) RXIDB 0 RXIDB\_1 REMREM EXT В (Standard =2-12, Extended = 2-15) (Standard = 18-28, Extended = 18-31) RXIDC 0 RXIDC 1 RXIDC 2 RXIDC 3 С (Std/Ext = 16-23)(Std/Ext = 24-31)(Std/Ext = 0-7)(Std/Ext = 8-15) Figure 447. ID Table 0 - 7 = Unimplemented or Reserved 0xF8 0xFC Table 432. Rx FIFO Structure field description | Field | Description | |------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | REM | Remote Frame This bit specifies if Remote Frames are accepted into the FIFO if they match the target ID. Remote Frames are rejected and data frames can be accepted. Remote Frames can be accepted and data frames are rejected. | | EXT | Extended Frame Specifies whether extended or standard frames are accepted into the FIFO if they match the target ID. 0 Extended frames are rejected and standard frames can be accepted. 1 Extended frames can be accepted and standard frames are rejected. | | RXIDA | Rx Frame Identifier (Format A) Specifies an ID to be used as acceptance criteria for the FIFO. In the standard frame format, only the 11 most significant bits (3 to 13) are used for frame identification. In the extended frame format, all bits are used. | | RXIDB_0<br>RXIDB_1 | Rx Frame Identifier (Format B) Specifies an ID to be used as acceptance criteria for the FIFO. In the standard frame format, the 11 most significant bits (a full standard ID) (3 to 13) are used for frame identification. In the extended frame format, all 14 bits of the field are compared to the 14 most significant bits of the received ID. | | RXIDC_0<br>RXIDC_1<br>RXIDC_2<br>RXIDC_3 | Rx Frame Identifier (Format C) Specifies an ID to be used as acceptance criteria for the FIFO. In both standard and extended frame formats, all 8 bits of the field are compared to the 8 most significant bits of the received ID. | # 24.3.4 Registers description The FlexCAN registers are described in this section in ascending address order. ## 24.3.4.1 Module Configuration Register (MCR) This register defines global system configurations, such as the module operation mode (e.g., low power) and maximum message buffer configuration. Most of the fields in this register can be accessed at any time, except the MAXMB field, which should only be changed while the module is in Freeze Mode. Figure 448. Module Configuration Register (MCR) Table 433. MCR field descriptions | Field | Description | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>MDIS | Module Disable This bit controls whether FlexCAN is enabled or not. When disabled, FlexCAN shuts down the clocks to the CAN Protocol Interface and Message Buffer Management submodules. This is the only bit in MCR not affected by soft reset. See Section 24.4.9.2: Module disable mode for more information. 0 Enable the FlexCAN module. 1 Disable the FlexCAN module. | | 1<br>FRZ | Freeze Enable The FRZ bit specifies the FlexCAN behavior when the HALT bit in the MCR is set or when Debug Mode is requested at MCU level. When FRZ is asserted, FlexCAN is able to enter Freeze Mode. Negation of this bit field causes FlexCAN to exit from Freeze Mode. 0 Not able to enter Freeze Mode. 1 Able to enter Freeze Mode. | | 2<br>FEN | FIFO Enable This bit controls whether the FIFO feature is enabled or not. When FEN is set, MBs 0 to 7 cannot be used for normal reception and transmission because the corresponding memory region (0x80–0xFF) is used by the FIFO engine. See Section 24.3.3: Rx FIFO structure and Section 24.4.7: Rx FIFO for more information. 0 FIFO disabled. 1 FIFO enabled. | | 3<br>HALT | Halt FlexCAN Assertion of this bit puts the FlexCAN module into Freeze Mode. The CPU should clear it after initializing the Message Buffers and Control Register. No reception or transmission is performed by FlexCAN before this bit is cleared. While in Freeze Mode, the CPU has write access to the Error Counter Register, that is otherwise read-only. Freeze Mode can not be entered while FlexCAN is in any of the low power modes. See Section 24.4.9.1: Freeze mode for more information. 0 No Freeze Mode request. 1 Enters Freeze Mode if the FRZ bit is asserted. | Table 433. MCR field descriptions(Continued) | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4<br>NOT_RDY | FlexCAN Not Ready This read-only bit indicates that FlexCAN is either in Disable Mode, Stop Mode or Freeze Mode. It is negated once FlexCAN has exited these modes. 0 FlexCAN module is either in Normal Mode, Listen-Only Mode or Loop-Back Mode. 1 FlexCAN module is either in Disable Mode, Stop Mode or Freeze Mode. | | 6<br>SOFT_RST | Soft Reset When this bit is asserted, FlexCAN resets its internal state machines and some of the memory mapped registers. The following registers are reset: MCR (except the MDIS bit), TIMER, ECR, ESR, IMASK1, IFLAG1. Configuration registers that control the interface to the CAN bus are not affected by soft reset. The following registers are unaffected: - CTRL - RXIMR0-RXIMR31 - RXGMASK, RX14MASK, RX15MASK | | | <ul> <li>all Message Buffers</li> <li>The SOFT_RST bit can be asserted directly by the CPU when it writes to the MCR. Since soft reset is synchronous and has to follow a request/acknowledge procedure across clock domains, it may take some time to fully propagate its effect. The SOFT_RST bit remains asserted while reset is pending, and is automatically negated when reset completes. Therefore, software can poll this bit to know when the soft reset has completed.</li> <li>Soft reset cannot be applied while clocks are shut down in any of the low power modes. The module should be first removed from low power mode, and then soft reset can be applied.</li> <li>No reset request.</li> </ul> | | | 1 Resets the registers marked as "affected by soft reset" in <i>Table 425</i> . | | 7<br>FRZ_ACK | Freeze Mode Acknowledge This read-only bit indicates that FlexCAN is in Freeze mode and its prescaler is stopped. The Freeze mode request cannot be granted until current transmission or reception processes have finished. Therefore the software can poll the FRZ_ACK bit to know when FlexCAN has actually entered Freeze Mode. If Freeze mode request is negated, then this bit is negated once the FlexCAN prescaler is running again. If Freeze mode is requested while FlexCAN is in any of the low power modes, then the FRZ_ACK bit will only be set when the low power mode is exited. See Section 24.4.9.1: Freeze mode for more information. O FlexCAN not in Freeze mode, prescaler running. 1 FlexCAN in Freeze mode, prescaler stopped. | | 8<br>SUPV | Supervisor Mode This bit configures some of the FlexCAN registers to be either in Supervisor or Unrestricted memory space. The registers affected by this bit are marked as S/U in the Access Type column of <i>Table 425</i> . The reset value of this bit is 1, so the affected registers start with Supervisor access restrictions. 0 Affected registers are in Unrestricted memory space. 1 Affected registers are in Supervisor memory space. Any access without supervisor permission behaves as though the access was done to an unimplemented register location. | Table 433. MCR field descriptions(Continued) | Field | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10<br>WRN_EN | Warning Interrupt Enable When asserted, this bit enables the generation of the TWRN_INT and RWRN_INT flags in the Error and Status Register. If WRN_EN is negated, the TWRN_INT and RWRN_INT flags will always be zero, independent of the values of the error counters, and no warning interrupt will ever be generated. 0 TWRN_INT and RWRN_INT bits are zero, independent of the values in the error counters. 1 TWRN_INT and RWRN_INT bits are set when the respective error counter transition from <96 to ≥ 96. | | 11<br>LPM_ACK | Low Power Mode Acknowledge This read-only bit indicates that FlexCAN is either in Disable Mode or Stop Mode. Either of these low power modes can not be entered until all current transmission or reception processes have finished, so the CPU can poll the LPM_ACK bit to know when FlexCAN has actually entered low power mode. See Section 24.4.9.2: Module disable mode and Section 24.4.9.3: Stop mode for more information. 0 FlexCAN not in any of the low power modes. 1 FlexCAN is either in Disable Mode or Stop mode. | | 14<br>SRX_DIS | Self Reception Disable This bit defines whether FlexCAN is allowed to receive frames transmitted by itself. If this bit is asserted, frames transmitted by the module will not be stored in any MB, regardless if the MB is programmed with an ID that matches the transmitted frame, and no interrupt flag or interrupt signal will be generated due to the frame reception. O Self reception enabled Self reception disabled | | 15<br>BCC | Backwards Compatibility Configuration This bit is provided to support Backwards Compatibility with previous FlexCAN versions. When this bit is negated, the following configuration is applied: - For MCUs supporting individual Rx ID masking, this feature is disabled. Instead of individual ID masking per MB, FlexCAN uses its previous masking scheme with RXGMASK, RX14MASK and RX15MASK. - The reception queue feature is disabled. Upon receiving a message, if the first MB with a matching ID that is found is still occupied by a previous unread message, FlexCAN will not look for another matching MB. It will override this MB with the new message and set the CODE field to '0110' (overrun). Upon reset this bit is negated, allowing legacy software to work without modification. 0 Individual Rx masking and queue feature are disabled. 1 Individual Rx masking and queue feature are enabled. | | 18<br>LPRIO_EN | Local Priority Enable This bit is provided for backwards compatibility reasons. It controls whether the local priority feature is enabled or not. It extends the ID used during the arbitration process. With this extended ID concept, the arbitration process is done based on the full 32-bit word, but the actual transmitted ID still has 11-bit for standard frames and 29-bit for extended frames. 0 Local Priority disabled 1 Local Priority enabled | Table 433. MCR field descriptions(Continued) | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19<br>AEN | Abort Enable This bit is supplied for backwards compatibility reasons. When asserted, it enables the Tx abort feature. This feature guarantees a safe procedure for aborting a pending transmission, so that no frame is sent in the CAN bus without notification. O Abort disabled Abort enabled | | 22–23<br>IDAM | ID Acceptance Mode This 2-bit field identifies the format of the elements of the Rx FIFO filter table, as shown in Table 434. Note that all elements of the table are configured at the same time by this field (they are all the same format). See Section 24.3.3: Rx FIFO structure. | | 26–31 | Maximum Number of Message Buffers This 6-bit field defines the maximum number of message buffers that will take part in the matching and arbitration processes. The reset value (0x0F) is equivalent to 16 MB configuration. This field should be changed only while the module is in Freeze Mode. | | MAXMB | Maximum MBs in use = MAXMB + 1 | | | Note: MAXMB has to be programmed with a value smaller or equal to the number of available Message Buffers, otherwise FlexCAN will not transmit or receive frames. | Table 434. IDAM coding | IDAM | Format | Explanation | |------|--------|------------------------------------------------------------------------------| | 00 | Α | One full ID (standard or extended) per filter element. | | 01 | В | Two full standard IDs or two partial 14-bit extended IDs per filter element. | | 10 | С | Four partial 8-bit IDs (standard or extended) per filter element. | | 11 | D | All frames rejected. | # 24.3.4.2 Control Register (CTRL) This register is defined for specific FlexCAN control features related to the CAN bus, such as bit-rate, programmable sampling point within an Rx bit, Loop Back Mode, Listen Only Mode, Bus Off recovery behavior and interrupt enabling (Bus-Off, Error, Warning). It also determines the Division Factor for the clock prescaler. Most of the fields in this register should only be changed while the module is in Disable Mode or in Freeze Mode. Exceptions are the BOFF\_MSK, ERR\_MSK, TWRN\_MSK, RWRN\_MSK and BOFF\_REC bits, that can be accessed at any time. Figure 449. Control Register (CTRL) Table 435. CTRL field descriptions | Field | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–7<br>PRESDIV | Prescaler Division Factor This 8-bit field defines the ratio between the CPI clock frequency and the Serial Clock (Sclock) frequency. The Sclock period defines the time quantum of the CAN protocol. For the reset value, the Sclock frequency is equal to the CPI clock frequency. The Maximum value of this register is 0xFF, that gives a minimum Sclock frequency equal to the CPI clock frequency divided by 256. For more information refer to Section 24.4.8.4: Protocol timing. | | | Sclock frequency = CPI clock frequency / (PRESDIV + 1). | | 8–9<br>RJW | Resync Jump Width This 2-bit field defines the maximum number of time quanta <sup>(1)</sup> that a bit time can be changed by one resynchronization. The valid programmable values are 0–3. | | | Resync Jump Width = RJW + 1. | | 10–12<br>PSEG1 | PSEG1 — Phase Segment 1 This 3-bit field defines the length of Phase Buffer Segment 1 in the bit time. The valid programmable values are 0–7. Phase Buffer Segment 1(PSEG1 + 1) x Time-Quanta. | | 13–15<br>PSEG2 | PSEG2 — Phase Segment 2 This 3-bit field defines the length of Phase Buffer Segment 2 in the bit time. The valid programmable values are 1–7. Phase Buffer Segment 2 = (PSEG2 + 1) x Time-Quanta. | | 16<br>BOFF_MSK | Bus Off Mask This bit provides a mask for the Bus Off Interrupt. 0 Bus Off interrupt disabled. 1 Bus Off interrupt enabled. | | 17<br>ERR_MSK | Error Mask This bit provides a mask for the Error Interrupt. 0 Error interrupt disabled. 1 Error interrupt enabled. | Table 435. CTRL field descriptions(Continued) | Field | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18<br>CLK_SRC | CAN Engine Clock Source This bit selects the clock source to the CAN Protocol Interface (CPI) to be either the peripheral clock (driven by the PLL) or the crystal oscillator clock. The selected clock is the one fed to the prescaler to generate the Serial Clock (Sclock). In order to guarantee reliable operation, this bit should only be changed while the module is in Disable Mode. See Section 24.4.8.4: Protocol timing for more information. O The CAN engine clock source is the oscillator clock. The CAN engine clock source is the bus clock. Note: This clock selection feature may not be available in all MCUs. A particular MCU may not have a PLL, in which case it would have only the oscillator clock, or it may use only the PLL clock feeding the FlexCAN module. In these cases, this bit has no effect on the module operation. | | 19<br>TWRN_MSK | Tx Warning Interrupt Mask This bit provides a mask for the Tx Warning Interrupt associated with the TWRN_INT flag in the Error and Status Register. This bit has no effect if the WRN_EN bit in MCR is negated and it is read as zero when WRN_EN is negated. 0 Tx Warning Interrupt disabled. 1 Tx Warning Interrupt enabled. | | 20<br>RWRN_MSK | Rx Warning Interrupt Mask This bit provides a mask for the Rx Warning Interrupt associated with the RWRN_INT flag in the Error and Status Register. This bit has no effect if the WRN_EN bit in MCR is negated and it is read as zero when WRN_EN is negated. 0 Rx Warning Interrupt disabled. 1 Rx Warning Interrupt enabled. | | 21<br>LPB | Loop Back This bit configures FlexCAN to operate in Loop-Back Mode. In this mode, FlexCAN performs an internal loop back that can be used for self test operation. The bit stream output of the transmitter is fed back internally to the receiver input. The Rx CAN input pin is ignored and the Tx CAN output goes to the recessive state (logic 1). FlexCAN behaves as it normally does when transmitting, and treats its own transmitted message as a message received from a remote node. In this mode, FlexCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field, generating an internal acknowledge bit to ensure proper reception of its own message. Both transmit and receive interrupts are generated. 0 Loop Back disabled. 1 Loop Back enabled. | | 24<br>SMP | Sampling Mode This bit defines the sampling mode of CAN bits at the Rx input. 0 Just one sample determines the bit value. 1 Three samples are used to determine the value of the received bit: the regular one (sample point) and two preceding samples, a majority rule is used. | Table 435. CTRL field descriptions(Continued) | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 25<br>BOFF_REC | Bus Off Recovery Mode This bit defines how FlexCAN recovers from Bus Off state. If this bit is negated, automatic recovering from Bus Off state occurs according to the CAN Specification 2.0B. If the bit is asserted, automatic recovering from Bus Off is disabled and the module remains in Bus Off state until the bit is negated by the user. If the negation occurs before 128 sequences of 11 recessive bits are detected on the CAN bus, then Bus Off recovery happens as if the BOFF_REC bit had never been asserted. If the negation occurs after 128 sequences of 11 recessive bits occurred, then FlexCAN will resynchronize to the bus by waiting for 11 recessive bits before joining the bus. After negation, the BOFF_REC bit can be re-asserted again during Bus Off, but it will only be effective the next time the module enters Bus Off. If BOFF_REC was negated when the module entered Bus Off, asserting it during Bus Off will not be effective for the current Bus Off recovery. O Automatic recovering from Bus Off state enabled, according to CAN Spec 2.0 part B. 1 Automatic recovering from Bus Off state disabled. | | 26<br>TSYN | Timer Sync Mode This bit enables a mechanism that resets the free-running timer each time a message is received in Message Buffer 0. This feature provides means to synchronize multiple FlexCAN stations with a special "SYNC" message (that is, global network time). If the FEN bit in MCR is set (FIFO enabled), MB8 is used for timer synchronization instead of MB0. 0 Timer Sync feature disabled 1 Timer Sync feature enabled | | 27<br>LBUF | Lowest Buffer Transmitted First This bit defines the ordering mechanism for Message Buffer transmission. When asserted, the LPRIO_EN bit does not affect the priority arbitration. 0 Buffer with highest priority is transmitted first. 1 Lowest number buffer is transmitted first. | | 28<br>LOM | Listen-Only Mode This bit configures FlexCAN to operate in Listen Only Mode. In this mode, transmission is disabled, all error counters are frozen and the module operates in a CAN Error Passive mode [Ref. 1]. Only messages acknowledged by another CAN station will be received. If FlexCAN detects a message that has not been acknowledged, it will flag a BIT0 error (without changing the REC), as if it was trying to acknowledge the message. 0 Listen Only Mode is deactivated. 1 FlexCAN module operates in Listen Only Mode. | | 29–31<br>PROPSEG | Propagation Segment This 3-bit field defines the length of the Propagation Segment in the bit time. The valid programmable values are 0–7. Propagation Segment Time = (PROPSEG + 1) × Time-Quanta. Time-Quantum = one Sclock period. | <sup>1.</sup> One time quantum is equal to the Sclock period. ## 24.3.4.3 Free Running Timer (TIMER) This register represents a 16-bit free running counter that can be read and written by the CPU. The timer starts from 0x0000 after Reset, counts linearly to 0xFFFF, and wraps around. The timer is clocked by the FlexCAN bit-clock (which defines the baud rate on the CAN bus). During a message transmission/reception, it increments by one for each bit that is received or transmitted. When there is no message on the bus, it counts using the previously programmed baud rate. During Freeze Mode, the timer is not incremented. The timer value is captured at the beginning of the identifier field of any frame on the CAN bus. This captured value is written into the Time Stamp entry in a message buffer after a successful reception or transmission of a message. Writing to the timer is an indirect operation. The data is first written to an auxiliary register and then an internal request/acknowledge procedure across clock domains is executed. All this is transparent to the user, except for the fact that the data will take some time to be actually written to the register. If desired, software can poll the register to discover when the data was actually written. Figure 450. Free Running Timer (TIMER) Table 436. TIMER field descriptions | Field | Description | |-------|---------------------------------| | TIMER | Holds the value for this timer. | ### 24.3.4.4 Rx Global Mask register (RXGMASK) This register is provided for legacy support and for low cost MCUs that do not have the individual masking per Message Buffer feature. For MCUs supporting individual masks per MB, setting the BCC bit in the MCR causes the RXGMASK register to have no effect on the module operation. For MCUs not supporting individual masks per MB, this register is always effective. RXGMASK is used as an acceptance mask for all Rx MBs, excluding MBs 14–15, which have individual mask registers. When the FEN bit in the MCR is set (FIFO enabled), the RXGMASK also applies to all elements of the ID filter table, except elements 6–7, which have individual masks. The contents of this register must be programmed while the module is in Freeze Mode, and must not be modified when the module is transmitting or receiving frames. Figure 451. Rx Global Mask register (RXGMASK) Table 437. RXGMASK field description | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–31<br>MI31–MI0 | Mask Bits For normal Rx MBs, the mask bits affect the ID filter programmed on the MB. For the Rx FIFO, the mask bits affect all bits programmed in the filter table (ID, IDE, RTR). O The corresponding bit in the filter is "don't care." 1 The corresponding bit in the filter is checked against the one received. | ## 24.3.4.5 Rx 14 Mask (RX14MASK) This register is provided for legacy support and for low cost MCUs that do not have the individual masking per Message Buffer feature. For MCUs supporting individual masks per MB, setting the BCC bit in the MCR causes the RX14MASK register to have no effect on the module operation. RX14MASK is used as an acceptance mask for the Identifier in Message Buffer 14. When the FEN bit in the MCR is set (FIFO enabled), the RX14MASK also applies to element 6 of the ID filter table. This register has the same structure as the Rx Global Mask Register. It must be programmed while the module is in Freeze Mode, and must not be modified when the module is transmitting or receiving frames. Figure 452. Rx Buffer 14 Mask register (RX14MASK) | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–31<br>MI31–MI0 | Mask Bits For normal Rx MBs, the mask bits affect the ID filter programmed on the MB. For the Rx FIFO, the mask bits affect all bits programmed in the filter table (ID, IDE, RTR). O The corresponding bit in the filter is "don't care." 1 The corresponding bit in the filter is checked against the one received. | Table 438. RX14MASK field description ## 24.3.4.6 Rx 15 Mask (RX15MASK) This register is provided for legacy support and for low cost MCUs that do not have the individual masking per Message Buffer feature. For MCUs supporting individual masks per MB, setting the BCC bit in the MCR causes the RX15MASK register to have no effect on the module operation. When the BCC bit is negated, RX15MASK is used as acceptance mask for the Identifier in Message Buffer 15. When the FEN bit in the MCR is set (FIFO enabled), the RX15MASK also applies to element 7 of the ID filter table. This register has the same structure as the Rx Global Mask Register. It must be programmed while the module is in Freeze Mode, and must not be modified when the module is transmitting or receiving frames. Figure 453. Rx Buffer 15 Mask register (RX15MASK) | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0–31<br>MI31–MI0 | Mask Bits For normal Rx MBs, the mask bits affect the ID filter programmed on the MB. For the Rx FIFO, the mask bits affect all bits programmed in the filter table (ID, IDE, RTR). 0 The corresponding bit in the filter is "don't care." 1 The corresponding bit in the filter is checked against the one received. | Table 439. RX15MASK field description # 24.3.4.7 Error Counter Register (ECR) This register has two 8-bit fields that reflect the value of two FlexCAN error counters: - Transmit Error Counter (Tx\_Err\_Counter field) - Receive Error Counter (Rx\_Err\_Counter field) The rules for increasing and decreasing these counters are described in the CAN protocol and are completely implemented in the FlexCAN module. Both counters are read only except in Freeze Mode, where they can be written by the CPU. Writing to the Error Counter Register while in Freeze Mode is an indirect operation. The data is first written to an auxiliary register and then an internal request/acknowledge procedure across clock domains is executed. All this is transparent to the user, except for the fact that the data will take some time to be actually written to the register. If desired, software can poll the register to discover when the data was actually written. FlexCAN responds to any bus state as described in the protocol, e.g., transmit 'Error Active' or 'Error Passive' flag, delay its transmission start time ('Error Passive') and avoid any influence on the bus when in 'Bus Off' state. The following are the basic rules for FlexCAN bus state transitions. - If the value of Tx\_Err\_Counter or Rx\_Err\_Counter increases to be greater than or equal to 128, the FLT\_CONF field in the Error and Status Register is updated to reflect 'Error Passive' state. - If the FlexCAN state is 'Error Passive', and either Tx\_Err\_Counter or Rx\_Err\_Counter decrements to a value less than or equal to 127 while the other already satisfies this condition, the FLT\_CONF field in the Error and Status Register is updated to reflect 'Error Active' state. - If the value of Tx\_Err\_Counter increases to be greater than 255, the FLT\_CONF field in the Error and Status Register is updated to reflect 'Bus Off' state, and an interrupt may be issued. The value of Tx\_Err\_Counter is then reset to 0. - If FlexCAN is in 'Bus Off' state, then Tx\_Err\_Counter is cascaded together with another internal counter to count the 128th occurrences of 11 consecutive recessive bits on the bus. Hence, Tx\_Err\_Counter is reset to 0 and counts in a manner where the internal counter counts 11 such bits and then wraps around while incrementing the Tx\_Err\_Counter. When Tx\_Err\_Counter reaches the value of 128, the FLT\_CONF field in the Error and Status Register is updated to be 'Error Active' and both error counters are reset to zero. At any instance of dominant bit following a stream of less than 11 consecutive recessive bits, the internal counter resets itself to zero without affecting the Tx\_Err\_Counter value. - If during system start-up, only one node is operating, then its Tx\_Err\_Counter increases in each message it is trying to transmit, as a result of acknowledge errors (indicated by the ACK\_ERR bit in the Error and Status Register). After the transition to 'Error Passive' state, the Tx\_Err\_Counter does not increment anymore by acknowledge errors. Therefore the device never goes to the 'Bus Off' state. - If the Rx\_Err\_Counter increases to a value greater than 127, it is not incremented further, even if more errors are detected while being a receiver. At the next successful message reception, the counter is set to a value between 119 and 127 to resume to 'Error Active' state. Figure 454. Error Counter Register (ECR) ### 24.3.4.8 Error and Status Register (ESR) This register reflects various error conditions, some general status of the device and it is the source of four interrupts to the CPU. The reported error conditions (bits 16–21) are those that occurred since the last time the CPU read this register. The CPU read action clears bits 16–21. Bits 22–28 are status bits. Most bits in this register are read only, except TWRN\_INT, RWRN\_INT, BOFF\_INT and ERR\_INT, that are interrupt flags that can be cleared by writing 1 to them (writing 0 has no effect). See *Section 24.4.10: Interrupts* for more details. Figure 455. Error and Status Register (ESR) Table 440. Error and Status Register (ESR) field description | Field | Field Description | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 14<br>TWRN_INT | Tx Warning Interrupt Flag If the WRN_EN bit in MCR is asserted, the TWRN_INT bit is set when the TX_WRN flag transition from 0 to 1, meaning that the Tx error counter reached 96. If the corresponding mask bit in the Control Register (TWRN_MSK) is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1. Writing 0 has no effect. 0 No such occurrence. 1 The Tx error counter transitioned from < 96 to ≥ 96. | | | | | 15<br>RWRN_INT | Rx Warning Interrupt Flag If the WRN_EN bit in MCR is asserted, the RWRN_INT bit is set when the RX_WRN flag transition from 0 to 1, meaning that the Rx error counters reached 96. If the corresponding mask bit in the Control Register (RWRN_MSK) is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1. Writing 0 has no effect. 0 No such occurrence. 1 The Rx error counter transitioned from < 96 to ≥ 96. | | | | | 16<br>BIT1_ERR | Bit1 Error This bit indicates when an inconsistency occurs between the transmitted and the received bit in a message. O No such occurrence. At least one bit sent as recessive is received as dominant. Note: This bit is not set by a transmitter in case of arbitration field or ACK slot, or in case of a node sending a passive error flag that detects dominant bits. | | | | | 17<br>BIT0_ERR | Bit0 Error This bit indicates when an inconsistency occurs between the transmitted and the received bit in a message. 0 No such occurrence. 1 At least one bit sent as dominant is received as recessive. | | | | | Acknowledge Error This bit indicates that an Acknowledge Error has been detected by the transmitter node, the dominant bit has not been detected during the ACK SLOT. No such occurrence. Acknowledge Error This bit indicates that an Acknowledge Error has been detected by the transmitter node, the dominant bit has not been detected during the ACK SLOT. No such occurrence. Acknowledge Error This bit indicates that an Acknowledge Error has been detected by the transmitter node, the dominant bit has not been detected during the ACK SLOT. | | | | | | 19<br>CRC_ERR | Cyclic Redundancy Check Error This bit indicates that a CRC Error has been detected by the receiver node, that is, the calculated CRC is different from the received. 0 No such occurrence. 1 A CRC error occurred since last read of this register. | | | | | 20<br>FRM_ERR | Form Error This bit indicates that a Form Error has been detected by the receiver node, that is, a fixed-form bit field contains at least one illegal bit. 0 No such occurrence. 1 A Form Error occurred since last read of this register. | | | | | 21<br>STF_ERR | Stuffing Error This bit indicates that a Stuffing Error has been detected. 0 No such occurrence. 1 A Stuffing Error occurred since last read of this register. | | | | Table 440. Error and Status Register (ESR) field description(Continued) | Field | Description | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 22<br>TX_WRN | TX Error Counter This bit indicates when repetitive errors are occurring during message transmission. 0 No such occurrence. 1 TX_Err_Counter ≥ 96. | | | | 23<br>RX_WRN | Rx Error Counter This bit indicates when repetitive errors are occurring during message reception. 0 No such occurrence. 1 Rx_Err_Counter ≥ 96. | | | | 24<br>IDLE | CAN bus IDLE state This bit indicates when the CAN bus is in IDLE state. 0 No such occurrence. 1 CAN bus is now IDLE. | | | | 25<br>TXRX | Current FlexCAN status (transmitting/receiving) This bit indicates if FlexCAN is transmitting or receiving a message when the CAN bus is not IDLE state. This bit has no meaning when IDLE is asserted. 0 FlexCAN is receiving a message (IDLE = 0). 1 FlexCAN is transmitting a message (IDLE = 0). | | | | 26–27<br>FLT_CONF | Fault Confinement State This 2-bit field indicates the Confinement State of the FlexCAN module, as shown in <i>Table 441</i> . If the LOM bit in the Control Register is asserted, the FLT_CONF field will indicate "Error Passive". Since the Control Register is not affected by soft reset, the FLT_CONF field will not be affected by soft reset if the LOM bit is asserted. | | | | 29<br>BOFF_INT | Bus Off Interrupt This bit is set when FlexCAN enters 'Bus Off' state. If the corresponding mask bit in the Control Register (BOFF_MSK) is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1. Writing 0 has no effect. 0 No such occurrence. 1 FlexCAN module entered 'Bus Off' state. | | | | 30<br>ERR_INT | Error Interrupt This bit indicates that at least one of the Error Bits (bits 16–21) is set. If the corresponding mask bit in the Control Register (ERR_MSK) is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1.Writing 0 has no effect. O No such occurrence. Indicates setting of any Error Bit in the Error and Status Register. | | | Table 441. Fault confinement state | Value | Meaning | |-------|---------------| | 00 | Error Active | | 01 | Error Passive | | 1X | Bus Off | ## 24.3.4.9 Interrupt Masks 1 Register (IMASK1) This register allows to enable or disable any number of a range of 32 Message Buffer Interrupts. It contains one interrupt mask bit per buffer, enabling the CPU to determine which buffer generates an interrupt after a successful transmission or reception (that is, when the corresponding IFLAG1 bit is set). Figure 456. Interrupt Masks 1 Register (IMASK1) | Table 442. IMASK1 | field | descrip | otions | |-------------------|-------|---------|--------| | | | | | | Field | Description | | | | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0–31<br>BUF31M –<br>BUF0M | BUF31M–BUF0M — Buffer MB <sub>i</sub> Mask Each bit enables or disables the respective FlexCAN Message Buffer (MB0 to MB31) Interrupt. | | | | | | O The corresponding buffer Interrupt is disabled. 1 The corresponding buffer Interrupt is enabled. | | | | | | <b>Note:</b> Setting or clearing a bit in the IMASK1 Register can assert or negate an interrupt request, if the corresponding IFLAG1 bit is set. | | | | ### 24.3.4.10 Interrupt Flags 1 Register (IFLAG1) This register defines the flags for 32 Message Buffer interrupts and FIFO interrupts. It contains one interrupt flag bit per buffer. Each successful transmission or reception sets the corresponding IFLAG1 bit. If the corresponding IMASK1 bit is set, an interrupt will be generated. The Interrupt flag must be cleared by writing it to 1. Writing 0 has no effect. When the AEN bit in the MCR is set (Abort enabled), while the IFLAG1 bit is set for a MB configured as Tx, the writing access done by CPU into the corresponding MB will be blocked. When the FEN bit in the MCR is set (FIFO enabled), the function of the eight least significant interrupt flags (BUF7I – BUF0I) is changed to support the FIFO operation. BUF7I, BUF6I and BUF5I indicate operating conditions of the FIFO, while BUF4I to BUF0I are not used. Figure 457. Interrupt Flags 1 Register (IFLAG1) Table 443. IFLAG1 field descriptions | Field | Description | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0–23<br>BUF31I – BUF8I | Buffer MB <sub>i</sub> Interrupt Each bit flags the respective FlexCAN Message Buffer (MB8 to MB31) interrupt. 0 No such occurrence. 1 The corresponding MB has successfully completed transmission or reception. | | | | Buffer MB7 Interrupt or "FIFO Overflow" If the FIFO is not enabled, this bit flags the interrupt for MB7. If the FIFO is enabled, th indicates an overflow condition in the FIFO (frame lost because FIFO is full). No such occurrence. MB7 completed transmission/reception or FIFO overflow. | | | | | 25<br>BUF61 | Lindicates that 4 out of 6 buffers of the FIFO are already occupied (FIFO almost full). | | | | Buffer MB5 Interrupt or "Frames available in FIFO" If the FIFO is not enabled, this bit flags the interrupt for MB5. If the FIFO is enabled, the indicates that at least one frame is available to be read from the FIFO. No such occurrence. MB5 completed transmission/reception or frames available in the FIFO. | | | | | 27–31<br>BUF4I – BUF0I | Buffer MB <sub>i</sub> Interrupt or "reserved" If the FIFO is not enabled, these bits flag the interrupts for MB0 to MB4. If the FIFO is enabled, these flags are not used and must be considered as reserved locations. O No such occurrence. Corresponding MB completed transmission/reception. | | | ## 24.3.4.11 Rx Individual Mask Registers (RXIMR0-RXIMR31) These registers are used as acceptance masks for ID filtering in Rx MBs and the FIFO. If the FIFO is not enabled, one mask register is provided for each available Message Buffer, providing ID masking capability on a per Message Buffer basis. When the FIFO is enabled (FEN bit in MCR is set), the first 8 Mask Registers apply to the 8 elements of the FIFO filter table (on a one-to-one correspondence), while the rest of the registers apply to the regular MBs, starting from MB8. The Individual Rx Mask Registers are implemented in RAM, so they are not affected by reset and must be explicitly initialized prior to any reception. Furthermore, they can only be accessed by the CPU while the module is in Freeze Mode. Out of Freeze Mode, write accesses are blocked and read accesses will return "all zeros". Furthermore, if the BCC bit in the MCR is negated, any read or write operation to these registers results in access error. Note: The individual Rx Mask per Message Buffer feature may not be available in low cost MCUs. Please consult the specific MCU documentation to find out if this feature is supported. If not supported, the RXGMASK, RX14MASK and RX15MASK registers are available, regardless of the value of the BCC bit. Figure 458. Rx Individual Mask Registers (RXIMR0-RXIMR31) Table 444. RXIMR0-RXIMR31 field descriptions | Field | Description | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0–31<br>MI31–MI0 | Mask Bits For normal Rx MBs, the mask bits affect the ID filter programmed on the MB. For the Rx FIFO, the mask bits affect all bits programmed in the filter table (ID, IDE, RTR). 0 The corresponding bit in the filter is "don't care." 1 The corresponding bit in the filter is checked against the one received. | | Table 445. RXIMR0-RXIMR31 addresses | Address | Register | Address | Register | |---------------|----------|---------------|----------| | Base + 0x0880 | RXIMR0 | Base + 0x08C0 | RXIMR16 | | Base + 0x0884 | RXIMR1 | Base + 0x08C4 | RXIMR17 | | Base + 0x0888 | RXIMR2 | Base + 0x08C8 | RXIMR18 | | Base + 0x088C | RXIMR3 | Base + 0x08CC | RXIMR19 | | Base + 0x0890 | RXIMR4 | Base + 0x08D0 | RXIMR20 | | Base + 0x0894 | RXIMR5 | Base + 0x08D4 | RXIMR21 | | Base + 0x0898 | RXIMR6 | Base + 0x08D8 | RXIMR22 | | Base + 0x089C | RXIMR7 | Base + 0x08DC | RXIMR23 | | Base + 0x08A0 | RXIMR8 | Base + 0x08E0 | RXIMR24 | | Base + 0x08A4 | RXIMR9 | Base + 0x08E4 | RXIMR25 | Table 445. RXIMR0-RXIMR31 addresses(Continued) | Address | Register | Add | |---------------|----------|--------| | Base + 0x08A8 | RXIMR10 | Base + | | Base + 0x08AC | RXIMR11 | Base + | | Base + 0x08B0 | RXIMR12 | Base + | | Base + 0x08B4 | RXIMR13 | Base + | | Base + 0x08B8 | RXIMR14 | Base + | | Base + 0x08BC | RXIMR15 | Base + | | Address | Register | |---------------|----------| | Base + 0x08E8 | RXIMR26 | | Base + 0x08EC | RXIMR27 | | Base + 0x08F0 | RXIMR28 | | Base + 0x08F4 | RXIMR29 | | Base + 0x08F8 | RXIMR30 | | Base + 0x08FC | RXIMR31 | # 24.4 Functional description ### 24.4.1 Overview The FlexCAN module is a CAN protocol engine with a very flexible mailbox system for transmitting and receiving CAN frames. The mailbox system is composed by a set of as many as 32 Message Buffers (MB) that store configuration and control data, time stamp, message ID and data (see Section 24.3.2: Message buffer structure). The memory corresponding to the first eight Message Buffers can be configured to support a FIFO reception scheme with a powerful ID filtering mechanism, capable of checking incoming frames against a table of IDs (as many as 8 extended IDs or 16 standard IDs or 32 eight-bit ID slices), each one with its own individual mask register. Simultaneous reception through FIFO and mailbox is supported. For mailbox reception, a matching algorithm makes it possible to store received frames only into MBs that have the same ID programmed on its ID field. A masking scheme makes it possible to match the ID programmed on the MB with a range of IDs on received CAN frames. For transmission, an arbitration algorithm decides the prioritization of MBs to be transmitted based on the message ID (optionally augmented by 3 local priority bits) or the MB ordering. Before proceeding with the functional description, an important concept must be explained. A Message Buffer is said to be "active" at a given time if it can participate in the matching and arbitration algorithms that are happening at that time. An Rx MB with a 0000 code is inactive (refer to *Table 429*). Similarly, a Tx MB with a 1000 or 1001 code is also inactive (refer to *Table 430*). An MB not programmed with 0000, 1000, or 1001 will be temporarily deactivated (will not participate in the current arbitration or matching run) when the CPU writes to the C/S field of that MB (see *Section 24.4.6.2: Message Buffer deactivation*). ## 24.4.2 Transmit process In order to transmit a CAN frame, the CPU must prepare a Message Buffer for transmission by executing the following procedure: - 1. If the MB is active (transmission pending), write an ABORT code ('1001') to the Code field of the Control and Status word to request an abortion of the transmission, then read back the Code field and the IFLAG register to check if the transmission was aborted (see Section 24.4.6.1: Transmission abort mechanism). If backwards compatibility is desired (AEN in MCR negated), just write '1000' to the Code field to inactivate the MB but then the pending frame may be transmitted without notification (see Section 24.4.6.2: Message Buffer deactivation). - 2. Write the ID word. - Write the data bytes. - Write the Length, Control and Code fields of the Control and Status word to activate the MB. Once the MB is activated in the fourth step, it will participate into the arbitration process and eventually be transmitted according to its priority. At the end of the successful transmission, the value of the Free Running Timer is written into the Time Stamp field, the Code field in the Control and Status word is updated, a status flag is set in the Interrupt Flag Register and an interrupt is generated if allowed by the corresponding Interrupt Mask Register bit. The new Code field after transmission depends on the code that was used to activate the MB in step 4 (see *Table 429* and *Table 430* in *Section 24.3.2: Message buffer structure*). When the Abort feature is enabled (AEN in MCR is asserted), after the Interrupt Flag is asserted for a MB configured as transmit buffer, the MB is blocked, therefore the CPU is not able to update it until the Interrupt Flag be negated by CPU. It means that the CPU must clear the corresponding IFLAG before starting to prepare this MB for a new transmission or reception. ## 24.4.3 Arbitration process The arbitration process is an algorithm executed by the MBM that scans the whole MB memory looking for the highest priority message to be transmitted. All MBs programmed as transmit buffers will be scanned to find the lowest ID<sup>(j)</sup> or the lowest MB number or the highest priority, depending on the LBUF and LPRIO\_EN bits on the Control Register. The arbitration process is triggered in the following events: - During the CRC field of the CAN frame - During the error delimiter field of the CAN frame - During Intermission, if the winner MB defined in a previous arbitration was deactivated, or if there was no MB to transmit, but the CPU wrote to the C/S word of any MB after the previous arbitration finished - When MBM is in Idle or Bus Off state and the CPU writes to the C/S word of any MB - Upon leaving Freeze Mode When LBUF is asserted, the LPRIO\_EN bit has no effect and the lowest number buffer is transmitted first. When LBUF and LPRIO\_EN are both negated, the MB with the lowest ID is transmitted first but. If LBUF is negated and LPRIO\_EN is asserted, the PRIO bits augment the ID used during the arbitration process. With this extended ID concept, arbitration is done based on the full 32-bit ID and the PRIO bits define which MB should be transmitted first, therefore MBs with PRIO = 000 have higher priority. If two or more MBs have the same priority, the regular ID will determine the priority of transmission. If two or more MBs have the same priority (3 extra bits) and the same regular ID, the lowest MB will be transmitted first Once the highest priority MB is selected, it is transferred to a temporary storage space called Serial Message Buffer (SMB), which has the same structure as a normal MB but is not user accessible. This operation is called "move-out" and after it is done, write access to the corresponding MB is blocked (if the AEN bit in the MCR is asserted). The write access is released in the following events: - After the MB is transmitted - FlexCAN enters in HALT or BUS OFF - FlexCAN loses the bus arbitration or there is an error during the transmission At the first opportunity window on the CAN bus, the message on the SMB is transmitted according to the CAN protocol rules. FlexCAN transmits as many as 8 data bytes, even if the DLC (Data Length Code) value is bigger. ## 24.4.4 Receive process To be able to receive CAN frames into the mailbox MBs, the CPU must prepare one or more Message Buffers for reception by executing the following steps: If the MB has a pending transmission, write an ABORT code ('1001') to the Code field of the Control and Status word to request an abortion of the transmission, then read back the Code field and the IFLAG register to check if the transmission was aborted j. Actually, if LBUF is negated, the arbitration considers not only the ID, but also the RTR and IDE bits placed inside the ID at the same positions they are transmitted in the CAN frame. (see Section 24.4.6.1: Transmission abort mechanism). If backwards compatibility is desired (AEN in MCR negated), just write '1000' to the Code field to inactivate the MB, but then the pending frame may be transmitted without notification (see Section 24.4.6.2: Message Buffer deactivation). If the MB already programmed as a receiver, just write '0000' to the Code field of the Control and Status word to keep the MB inactive. - 2. Write the ID word - Write '0100' to the Code field of the Control and Status word to activate the MB Once the MB is activated in the third step, it will be able to receive frames that match the programmed ID. At the end of a successful reception, the MB is updated by the MBM as follows: - The value of the Free Running Timer is written into the Time Stamp field - The received ID, Data (8 bytes at most) and Length fields are stored - The Code field in the Control and Status word is updated (see Table 429 and Table 430 in Section 24.3.2: Message buffer structure) - A status flag is set in the Interrupt Flag Register and an interrupt is generated if allowed by the corresponding Interrupt Mask Register bit Upon receiving the MB interrupt, the CPU should service the received frame using the following procedure: - Read the Control and Status word (mandatory activates an internal lock for this buffer) - 2. Read the ID field (optional needed only if a mask was used) - Read the Data field - 4. Read the Free Running Timer (optional releases the internal lock) Upon reading the Control and Status word, if the BUSY bit is set in the Code field, then the CPU should defer the access to the MB until this bit is negated. Reading the Free Running Timer is not mandatory. If not executed the MB remains locked, unless the CPU reads the C/S word of another MB. Note that only a single MB is locked at a time. The only mandatory CPU read operation is the one on the Control and Status word to assure data coherency (see Section 24.4.6: Data coherence). The CPU should synchronize to frame reception by the status flag bit for the specific MB in one of the IFLAG Registers and not by the Code field of that MB. Polling the Code field does not work because once a frame was received and the CPU services the MB (by reading the C/S word followed by unlocking the MB), the Code field will not return to EMPTY. It will remain FULL, as explained in *Table 429*. If the CPU tries to work around this behavior by writing to the C/S word to force an EMPTY code after reading the MB, the MB is actually deactivated from any currently ongoing matching process. As a result, a newly received frame matching the ID of that MB may be lost. In summary: **never perform polling by directly reading the C/S word of the MBs. Instead, read the IFLAG registers**. Note that the received ID field is always stored in the matching MB, thus the contents of the ID field in an MB may change if the match was due to masking. Note also that FlexCAN does receive frames transmitted by itself if there exists an Rx matching MB, provided the SRX\_DIS bit in the MCR is not asserted. If SRX\_DIS is asserted, FlexCAN will not store frames transmitted by itself in any MB, even if it contains a matching MB, and no interrupt flag or interrupt signal will be generated due to the frame reception. To be able to receive CAN frames through the FIFO, the CPU must enable and configure the FIFO during Freeze Mode (see Section 24.4.7: Rx FIFO). Upon receiving the frames available interrupt from FIFO, the CPU should service the received frame using the following procedure: - Read the Control and Status word (optional needed only if a mask was used for IDE and RTR bits) - 2. Read the ID field (optional needed only if a mask was used) - 3. Read the Data field - 4. Clear the frames available interrupt (mandatory release the buffer and allow the CPU to read the next FIFO entry) ## 24.4.5 Matching process The matching process is an algorithm executed by the MBM that scans the MB memory looking for Rx MBs programmed with the same ID as the one received from the CAN bus. If the FIFO is enabled, the 8-entry ID table from FIFO is scanned first and then, if a match is not found within the FIFO table, the other MBs are scanned. In the event that the FIFO is full, the matching algorithm will always look for a matching MB outside the FIFO region. When the frame is received, it is temporarily stored in a hidden auxiliary MB called Serial Message Buffer (SMB). The matching process takes place during the CRC field of the received frame. If a matching ID is found in the FIFO table or in one of the regular MBs, the contents of the SMB will be transferred to the FIFO or to the matched MB during the 6th bit of the End-Of-Frame field of the CAN protocol. This operation is called "move-in". If any protocol error (CRC, ACK, etc.) is detected, than the move-in operation does not happen. For the regular mailbox MBs, an MB is said to be "free to receive" a new frame if the following conditions are satisfied: - The MB is not locked (see Section 24.4.6.3: Message Buffer lock mechanism) - The Code field is either EMPTY or else it is FULL or OVERRUN but the CPU has already serviced the MB (read the C/S word and then unlocked the MB) If the first MB with a matching ID is not "free to receive" the new frame, then the matching algorithm keeps looking for another free MB until it finds one. If it can not find one that is free, then it will overwrite the last matching MB (unless it is locked) and set the Code field to OVERRUN (refer to *Table 429* and *Table 430*). If the last matching MB is locked, then the new message remains in the SMB, waiting for the MB to be unlocked (see *Section 24.4.6.3: Message Buffer lock mechanism*). Suppose, for example, that the FIFO is disabled and there are two MBs with the same ID, and FlexCAN starts receiving messages with that ID. Let us say that these MBs are the second and the fifth in the array. When the first message arrives, the matching algorithm will find the first match in MB number 2. The code of this MB is EMPTY, so the message is stored there. When the second message arrives, the matching algorithm will find MB number 2 again, but it is not "free to receive", so it will keep looking and find MB number 5 and store the message there. If yet another message with the same ID arrives, the matching algorithm finds out that there are no matching MBs that are "free to receive", so it decides to overwrite the last matched MB, which is number 5. In doing so, it sets the Code field of the MB to indicate OVERRUN. The ability to match the same ID in more than one MB can be exploited to implement a reception queue (in addition to the full featured FIFO) to allow more time for the CPU to service the MBs. By programming more than one MB with the same ID, received messages will be queued into the MBs. The CPU can examine the Time Stamp field of the MBs to determine the order in which the messages arrived. RM0083 FlexCAN The matching algorithm described above can be changed to be the same one used in previous versions of the FlexCAN module. When the BCC bit in the MCR is negated, the matching algorithm stops at the first MB with a matching ID that it founds, whether this MB is free or not. As a result, the message queueing feature does not work if the BCC bit is negated. Matching to a range of IDs is possible by using ID Acceptance Masks. FlexCAN supports individual masking per MB. Please refer to *Section 24.3.4.11: Rx Individual Mask Registers (RXIMR0–RXIMR31)*. During the matching algorithm, if a mask bit is asserted, then the corresponding ID bit is compared. If the mask bit is negated, the corresponding ID bit is "don't care". Please note that the Individual Mask Registers are implemented in RAM, so they are not initialized out of reset. Also, they can only be programmed if the BCC bit is asserted and while the module is in Freeze Mode. FlexCAN also supports an alternate masking scheme with only three mask registers (RGXMASK, RX14MASK and RX15MASK) for backwards compatibility. This alternate masking scheme is enabled when the BCC bit in the MCR is negated. Note: The individual Rx Mask per Message Buffer feature may not be available in low cost MCUs. Please consult the specific MCU documentation to find out if this feature is supported. If not supported, the RXGMASK, RX14MASK, and RX15MASK registers are available, regardless of the value of the BCC bit. #### 24.4.6 Data coherence In order to maintain data coherency and FlexCAN proper operation, the CPU must obey the rules described in Transmit process and *Section 24.4.4: Receive process*. Any form of CPU accessing an MB structure within FlexCAN other than those specified may cause FlexCAN to behave in an unpredictable way. #### 24.4.6.1 Transmission abort mechanism The abort mechanism provides a safe way to request the abortion of a pending transmission. A feedback mechanism is provided to inform the CPU if the transmission was aborted or if the frame could not be aborted and was transmitted instead. In order to maintain backwards compatibility, the abort mechanism must be explicitly enabled by asserting the AEN bit in the MCR. In order to abort a transmission, the CPU must write a specific abort code (1001) to the Code field of the Control and Status word. When the abort mechanism is enabled, the active MBs configured as transmission must be aborted first and then they may be updated. If the abort code is written to an MB that is currently being transmitted, or to an MB that was already loaded into the SMB for transmission, the write operation is blocked and the MB is not deactivated, but the abort request is captured and kept pending until one of the following conditions are satisfied: - The module loses the bus arbitration - There is an error during the transmission - The module is put into Freeze Mode If none of conditions above are reached, the MB is transmitted correctly, the interrupt flag is set in the IFLAG register and an interrupt to the CPU is generated (if enabled). The abort request is automatically cleared when the interrupt flag is set. In the other hand, if one of the above conditions is reached, the frame is not transmitted, therefore the abort code is written FlexCAN RM0083 into the Code field, the interrupt flag is set in the IFLAG and an interrupt is (optionally) generated to the CPU. If the CPU writes the abort code before the transmission begins internally, then the write operation is not blocked, therefore the MB is updated and no interrupt flag is set. In this way the CPU just needs to read the abort code to make sure the active MB was deactivated. Although the AEN bit is asserted and the CPU wrote the abort code, in this case the MB is deactivated and not aborted, because the transmission did not start yet. One MB is only aborted when the abort request is captured and kept pending until one of the previous conditions are satisfied. The abort procedure can be summarized as follows: - CPU writes 1001 into the code field of the C/S word. - 2. CPU reads the CODE field and compares it to the value that was written. - 3. If the CODE field that was read is different from the value that was written, the CPU must read the corresponding IFLAG to check if the frame was transmitted or it is being currently transmitted. If the corresponding IFLAG is set, the frame was transmitted. If the corresponding IFLAG is reset, the CPU must wait for it to be set, and then the CPU must read the CODE field to check if the MB was aborted (CODE = 1001) or it was transmitted (CODE = 1000). ### 24.4.6.2 Message Buffer deactivation Deactivation is mechanism provided to maintain data coherence when the CPU writes to the Control and Status word of active MBs out of Freeze Mode. Any CPU write access to the Control and Status word of an MB causes that MB to be excluded from the transmit or receive processes during the current matching or arbitration round. The deactivation is temporary, affecting only for the current match/arbitration round. The purpose of deactivation is data coherency. The match/arbitration process scans the MBs to decide which MB to transmit or receive. If the CPU updates the MB in the middle of a match or arbitration process, the data of that MB may no longer be coherent, therefore deactivation of that MB is done. Even with the coherence mechanism described above, writing to the Control and Status word of active MBs when not in Freeze Mode may produce undesirable results. Examples are: - Matching and arbitration are one-pass processes. If MBs are deactivated after they are scanned, no re-evaluation is done to determine a new match/winner. If an Rx MB with a matching ID is deactivated during the matching process after it was scanned, then this MB is marked as invalid to receive the frame, and FlexCAN will keep looking for another matching MB within the ones it has not scanned yet. If it can not find one, then the message will be lost. Suppose, for example, that two MBs have a matching ID to a received frame, and the user deactivated the first matching MB after FlexCAN has scanned the second. The received frame will be lost even if the second matching MB was "free to receive". - If a Tx MB containing the lowest ID is deactivated after FlexCAN has scanned it, then FlexCAN will look for another winner within the MBs that it has not scanned yet. Therefore, it may transmit an MB with ID that may not be the lowest at the time because a lower ID might be present in one of the MBs that it had already scanned before the deactivation. - There is a point in time until which the deactivation of a Tx MB causes it not to be transmitted (end of move-out). After this point, it is transmitted but no interrupt is issued RM0083 FlexCAN and the Code field is not updated. In order to avoid this situation, the abort procedures described in *Section 24.4.6.1: Transmission abort mechanism* should be used. ### 24.4.6.3 Message Buffer lock mechanism Besides MB deactivation, FlexCAN has another data coherence mechanism for the receive process. When the CPU reads the Control and Status word of an "active not empty" Rx MB, FlexCAN assumes that the CPU wants to read the whole MB in an atomic operation, and thus it sets an internal lock flag for that MB. The lock is released when the CPU reads the Free Running Timer (global unlock operation), or when it reads the Control and Status word of another MB. The MB locking is done to prevent a new frame to be written into the MB while the CPU is reading it. Note: The locking mechanism only applies to Rx MBs that have a code different than INACTIVE ('0000') or EMPTY<sup>(k)</sup> ('0100'). Also, Tx MBs can not be locked. Suppose, for example, that the FIFO is disabled and the second and the fifth MBs of the array are programmed with the same ID, and FlexCAN has already received and stored messages into these two MBs. Suppose now that the CPU decides to read MB number 5 and at the same time another message with the same ID is arriving. When the CPU reads the Control and Status word of MB number 5, this MB is locked. The new message arrives and the matching algorithm finds out that there are no "free to receive" MBs, so it decides to override MB number 5. However, this MB is locked, so the new message can not be written there. It will remain in the SMB waiting for the MB to be unlocked, and only then will be written to the MB. If the MB is not unlocked in time and yet another new message with the same ID arrives, then the new message overwrites the one on the SMB and there will be no indication of lost messages either in the Code field of the MB or in the Error and Status Register. While the message is being moved-in from the SMB to the MB, the BUSY bit on the Code field is asserted. If the CPU reads the Control and Status word and finds out that the BUSY bit is set, it should defer accessing the MB until the BUSY bit is negated. Note: If the BUSY bit is asserted or if the MB is empty, then reading the Control and Status word does not lock the MB. Deactivation takes precedence over locking. If the CPU deactivates a locked Rx MB, then its lock status is negated and the MB is marked as invalid for the current matching round. Any pending message on the SMB will not be transferred anymore to the MB. ## 24.4.7 Rx FIFO The receive-only FIFO is enabled by asserting the FEN bit in the MCR. The reset value of this bit is zero to maintain software backwards compatibility with previous versions of the module that did not have the FIFO feature. When the FIFO is enabled, the memory region normally occupied by the first 8 MBs (0x80-0xFF) is now reserved for use of the FIFO engine (see Section 24.3.3: Rx FIFO structure). Management of read and write pointers is done internally by the FIFO engine. The CPU can read the received frames sequentially, in the order they were received, by repeatedly accessing a Message Buffer structure at the beginning of the memory. k. In previous FlexCAN versions, reading the C/S word locked the MB even if it was EMPTY. In current FlexCAN versions, this behavior is maintained when the BCC bit is negated. DocID018714 Rev 5 FlexCAN RM0083 The FIFO can store as many as six frames pending service by the CPU. An interrupt is sent to the CPU when new frames are available in the FIFO. Upon receiving the interrupt, the CPU must read the frame (accessing an MB in the 0x80 address) and then clear the interrupt. The act of clearing the interrupt triggers the FIFO engine to replace the MB in 0x80 with the next frame in the queue, and then issue another interrupt to the CPU. If the FIFO is full and more frames continue to be received, an OVERFLOW interrupt is issued to the CPU and subsequent frames are not accepted until the CPU creates space in the FIFO by reading one or more frames. A warning interrupt is also generated when 4frames are accumulated in the FIFO. A powerful filtering scheme is provided to accept only frames intended for the target application, thus reducing the interrupt servicing work load. The filtering criteria is specified by programming a table of 8 32-bit registers that can be configured to one of the following formats (see also *Section 24.3.3: Rx FIFO structure*): - Format A: 8 extended or standard IDs (including IDE and RTR) - Format B: 16 standard IDs or 16 extended 14-bit ID slices (including IDE and RTR) - Format C: 32 standard or extended 8-bit ID slices Note: A chosen format is applied to all 8 registers of the filter table. It is not possible to mix formats within the table. The eight elements of the filter table are individually affected by the first eight Individual Mask Registers (RXIMR0–RXIMR7), allowing very powerful filtering criteria to be defined. The rest of the RXIMR, starting from RXIM8, continue to affect the regular MBs, starting from MB8. If the BCC bit is negated (or if the RXIMR are not available for the particular MCU), then the FIFO filter table is affected by the legacy mask registers as follows: element 6 is affected by RX14MASK, element 7 is affected by RX15MASK and the other elements (0 to 5) are affected by RXGMASK. #### 24.4.8 CAN protocol related features #### 24.4.8.1 Remote frames Remote frame is a special kind of frame. The user can program a MB to be a Request Remote Frame by writing the MB as Transmit with the RTR bit set to 1. After the Remote Request frame is transmitted successfully, the MB becomes a Receive Message Buffer, with the same ID as before. When a Remote Request frame is received by FlexCAN, its ID is compared to the IDs of the transmit message buffers with the Code field '1010'. If there is a matching ID, then this MB frame will be transmitted. Note that if the matching MB has the RTR bit set, then FlexCAN will transmit a Remote Frame as a response. A received Remote Request Frame is not stored in a receive buffer. It is only used to trigger a transmission of a frame in response. The mask registers are not used in remote frame matching, and all ID bits (except RTR) of the incoming received frame should match. In the case that a Remote Request Frame was received and matched an MB, this message buffer immediately enters the internal arbitration process, but is considered as normal Tx MB, with no higher priority. The data length of this frame is independent of the DLC field in the remote frame that initiated its transmission. If the Rx FIFO is enabled (bit FEN set in MCR), FlexCAN will not generate an automatic response for Remote Request Frames that match the FIFO filtering criteria. If the remote frame matches one of the target IDs, it will be stored in the FIFO and presented to the CPU. RM0083 FlexCAN Note that for filtering formats A and B, it is possible to select whether remote frames are accepted or not. For format C, remote frames are always accepted (if they match the ID). #### 24.4.8.2 Overload frames FlexCAN does transmit overload frames due to detection of following conditions on CAN bus: - Detection of a dominant bit in the first/second bit of Intermission - Detection of a dominant bit at the 7th bit (last) of End of Frame field (Rx frames) - Detection of a dominant bit at the 8th bit (last) of Error Frame Delimiter or Overload Frame Delimiter #### 24.4.8.3 Time stamp The value of the Free Running Timer is sampled at the beginning of the Identifier field on the CAN bus, and is stored at the end of "move-in" in the TIME STAMP field, providing network behavior with respect to time. Note that the Free Running Timer can be reset upon a specific frame reception, enabling network time synchronization. Refer to TSYN description in *Section 24.3.4.2: Control Register (CTRL)*. ## 24.4.8.4 Protocol timing Figure 459 shows the structure of the clock generation circuitry that feeds the CAN Protocol Interface (CPI) sub-module. The clock source bit (CLK\_SRC) in the CTRL Register defines whether the internal clock is connected to the output of a crystal oscillator (Oscillator Clock) or to the Peripheral Clock (generally from a PLL). In order to guarantee reliable operation, the clock source should be selected while the module is in Disable Mode (bit MDIS set in the Module Configuration Register). Peripheral Clock (PLL) CPI Clock Prescaler (1...256) Oscillator Clock (Xtal) CLK\_SRC Figure 459. CAN engine clocking scheme The crystal oscillator clock should be selected whenever a tight tolerance (to 0.1%) is required in the CAN bus timing. The crystal oscillator clock has better jitter performance than PLL generated clocks. This clock selection feature may not be available in all MCUs. A particular MCU may not have a PLL, in which case it would have only the oscillator clock, or it may use only the PLL clock feeding the FlexCAN module. In these cases, the CLK\_SRC bit in the CTRL Register has no effect on the module operation. The FlexCAN module supports a variety of means to setup bit timing parameters that are required by the CAN protocol. The Control Register has various fields used to control bit timing parameters: PRESDIV, PROPSEG, PSEG1, PSEG2 and RJW. See Section 24.3.4.2: Control Register (CTRL). Note: FlexCAN RM0083 The PRESDIV field controls a prescaler that generates the Serial Clock (Sclock), whose period defines the 'time quantum' used to compose the CAN waveform. A time quantum is the atomic unit of time handled by the CAN engine. #### **Equation 66** $$f_{Tq} = \frac{f_{CANCLK}}{(Prescaler value)}$$ A bit time is subdivided into three segments<sup>(I)</sup> (reference *Figure 460* and *Table 446*): - SYNC\_SEG: This segment has a fixed length of one time quantum. Signal edges are expected to happen within this section. - Time Segment 1: This segment includes the Propagation Segment and the Phase Segment 1 of the CAN standard. It can be programmed by setting the PROPSEG and the PSEG1 fields of the CTRL Register so that their sum (plus 2) is in the range of 4 to 16 time quanta. - Time Segment 2: This segment represents the Phase Segment 2 of the CAN standard. It can be programmed by setting the PSEG2 field of the CTRL Register (plus 1) to be 2 to 8 time quanta long. #### **Equation 67** Transmit Point Bit Rate= $$\frac{f_{Tq}}{(number of Time Quanta)}$$ Figure 460. Segments within the bit time Sample Point (single or triple sampling) <sup>.</sup> For further explanation of the underlying concepts please refer to ISO/DIS 11519–1, Section 10.3. Reference also the Bosch CAN 2.0A/B protocol specification dated September 1991 for bit timing. RM0083 FlexCAN Table 446. Time segment syntax | Syntax | Description | | | | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | SYNC_SEG | System expects transitions to occur on the bus during this period. | | | | | Transmit Point | A node in transmit mode transfers a new value to the CAN bus at this point. | | | | | Sample Point | A node samples the bus at this point. If the three samples per bit option is selected, then this point marks the position of the third sample. | | | | *Table 447* gives an overview of the CAN compliant segment settings and the related parameter values. Table 447. CAN standard compliant bit time segment settings | Time Segment 1 | Time Segment 2 | Resynchronization Jump<br>Width | |----------------|----------------|---------------------------------| | 510 | 2 | 12 | | 4 11 | 3 | 13 | | 512 | 4 | 14 | | 613 | 5 | 14 | | 714 | 6 | 14 | | 815 | 7 | 14 | | 916 | 8 | 14 | Note: It is the user's responsibility to ensure the bit time settings are in compliance with the CAN standard. For bit time calculations, use an IPT (Information Processing Time) of 2, which is the value implemented in the FlexCAN module. ## 24.4.8.5 Arbitration and matching timing During normal transmission or reception of frames, the arbitration, matching, move-in and move-out processes are executed during certain time windows inside the CAN frame, as shown in *Figure 461*. Figure 461. Arbitration, match, and move time windows FlexCAN RM0083 When doing matching and arbitration, FlexCAN needs to scan the whole Message Buffer memory during the available time slot. In order to have sufficient time to do that, the following requirements must be observed: - A valid CAN bit timing must be programmed, as indicated in Table 447 - The peripheral clock frequency can not be smaller than the oscillator clock frequency, that is, the PLL can not be programmed to divide down the oscillator clock - There must be a minimum ratio between the peripheral clock frequency and the CAN bit rate, as specified in *Table 448* | Number of message buffers | Minimum ratio | |---------------------------|---------------| | 16 | 8 | | 32 | 8 | A direct consequence of the first requirement is that the minimum number of time quanta per CAN bit must be 8, so the oscillator clock frequency should be at least 8 times the CAN bit rate. The minimum frequency ratio specified in *Table 448* can be achieved by choosing a high enough peripheral clock frequency when compared to the oscillator clock frequency, or by adjusting one or more of the bit timing parameters (PRESDIV, PROPSEG, PSEG1, PSEG2). As an example, taking the case of 32 MBs, if the oscillator and peripheral clock frequencies are equal and the CAN bit timing is programmed to have 8 time quanta per bit, then the prescaler factor (PRESDIV + 1) should be at least 2. For prescaler factor equal to 1 and CAN bit timing with 8 time quanta per bit, the ratio between peripheral and oscillator clock frequencies should be at least 2. ## 24.4.9 Modes of operation details #### 24.4.9.1 Freeze mode This mode is entered by asserting the HALT bit in the MCR or when the MCU is put into Debug Mode. In both cases it is also necessary that the FRZ bit is asserted in the MCR and the module is not in any of the low power modes. When Freeze Mode is requested during transmission or reception, FlexCAN does the following: - · Waits to be in either Intermission, Passive Error, Bus Off or Idle state - Waits for all internal activities like arbitration, matching, move-in and move-out to finish - Ignores the Rx input pin and drives the Tx pin as recessive - Stops the prescaler, thus halting all CAN protocol activities - Grants write access to the Error Counters Register, which is read-only in other modes - Sets the NOT RDY and FRZ ACK bits in MCR After requesting Freeze Mode, the user must wait for the FRZ\_ACK bit to be asserted in the MCR before executing any other action, otherwise FlexCAN may operate in an unpredictable way. In Freeze mode, all memory mapped registers are accessible. Exiting Freeze Mode is done in one of the following ways: - CPU negates the FRZ bit in the MCR - The MCU is removed from Debug Mode and/or the HALT bit is negated RM0083 FlexCAN Once out of Freeze Mode, FlexCAN tries to resynchronize to the CAN bus by waiting for 11 consecutive recessive bits. #### 24.4.9.2 Module disable mode This low power mode is entered when the MDIS bit in the MCR is asserted. If the module is disabled during Freeze Mode, it shuts down the clocks to the CPI and MBM sub-modules, sets the LPM\_ACK bit and negates the FRZ\_ACK bit. If the module is disabled during transmission or reception, FlexCAN does the following: - Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and then checks it to be recessive - Waits for all internal activities like arbitration, matching, move-in and move-out to finish - Ignores its Rx input pin and drives its Tx pin as recessive - Shuts down the clocks to the CPI and MBM sub-modules - Sets the NOT RDY and LPM ACK bits in MCR The Bus Interface Unit continues to operate, enabling the CPU to access memory mapped registers, except the Free Running Timer, the Error Counter Register, and the Message Buffers, which cannot be accessed when the module is in Disable Mode. Exiting from this mode is done by negating the MDIS bit, which will resume the clocks and negate the LPM\_ACK bit. ### 24.4.9.3 Stop mode This is a system low power mode in which all MCU clocks are stopped for maximum power savings. If FlexCAN receives the global Stop Mode request during Freeze Mode, it sets the LPM\_ACK bit, negates the FRZ\_ACK bit and then sends a Stop Acknowledge signal to the CPU, in order to shut down the clocks globally. If Stop Mode is requested during transmission or reception, FlexCAN does the following: - Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and checks it to be recessive - Waits for all internal activities like arbitration, matching, move-in and move-out to finish - Ignores its Rx input pin and drives its Tx pin as recessive - Sets the NOT RDY and LPM ACK bits in MCR - Sends a Stop Acknowledge signal to the CPU, so that it can shut down the clocks globally Stop Mode is exited by the CPU resuming the clocks and removing the Stop Mode request. ### 24.4.10 Interrupts The module can generate as many as 38 interrupt sources (32 interrupts due to message buffers and 6 interrupts due to ORed interrupts from MBs, Bus Off, Error, Tx Warning, Rx Warning, and Wake Up<sup>(m)</sup>). The number of actual sources depends on the configured number of Message Buffers. Each one of the message buffers can be an interrupt source if its corresponding IMASK bit is set. There is no distinction between Tx and Rx interrupts for a particular buffer, under the assumption that the buffer is initialized for either transmission or reception. Each of the m. Wakeup interrupt never occurs because self-wakeup mechanism is not implemented. FlexCAN RM0083 buffers has assigned a flag bit in the IFLAG Registers. The bit is set when the corresponding buffer completes a successful transmission/reception and is cleared when the CPU writes it to 1 (unless another interrupt is generated at the same time). Note: It must be guaranteed that the CPU only clears the bit causing the current interrupt. For this reason, bit manipulation instructions (BSET) must not be used to clear interrupt flags. These instructions may cause accidental clearing of interrupt flags that are set after entering the current interrupt service routine. If the Rx FIFO is enabled (bit FEN on MCR set), the interrupts corresponding to MBs 0 to 7 have a different behavior. Bit 7 of the IFLAG1 becomes the FIFO Overflow flag; bit 6 becomes the FIFO Warning flag, bit 5 becomes the Frames Available in FIFO flag and bits 4:0 are unused. See Section 24.3.4.10: Interrupt Flags 1 Register (IFLAG1) for more information. A combined interrupt for all MBs is also generated by an OR of all the interrupt sources from MBs. This interrupt gets generated when any of the MBs generates an interrupt. In this case the CPU must read the IFLAG Registers to determine which MB caused the interrupt. The other five interrupt sources (Bus Off, Error, Tx Warning, Rx Warning, and Wakeup<sup>(m)</sup>) generate interrupts like the MB ones, and can be read from the ESR register. The Bus Off, Error, Tx Warning, and Rx Warning interrupt mask bits are located in the CTRL register, and the Wake-Up interrupt mask bit is located in the MCR. #### 24.4.11 Bus interface The CPU access to FlexCAN registers is subject to the following rules: - Read and write access to supervisor registers in User Mode results in access error. - Read and write access to unimplemented or reserved address space also results in access error. Any access to unimplemented MB or Rx Individual Mask Register locations results in access error. Any access to the Rx Individual Mask Register space when the BCC bit in the MCR is negated results in access error. - If MAXMB is programmed with a value smaller than the available number of MBs, then the unused memory space can be used as general purpose RAM space. Note that the Rx Individual Mask Registers can only be accessed in Freeze Mode, and this is still true for unused space within this memory. Note also that reserved words within RAM cannot be used. As an example, suppose FlexCAN is configured with 32 MBs and MAXMB is programmed with 0. The maximum number of MBs in this case becomes 1. The MB memory starts at 0x0060, but the space from 0x0060 to 0x007F is reserved (for SMB usage), and the space from 0x0080 to 0x008F is used by the one MB. This leaves us with the available space from 0x0090 to 0x027F. The available memory in the Mask Registers space would be from 0x0884 to 0x08FF. Note: Unused MB space must not be used as general purpose RAM while FlexCAN is transmitting and receiving CAN frames. # 24.5 Initialization/application information This section provide instructions for initializing the FlexCAN module. 577 RM0083 FlexCAN ## 24.5.1 FlexCAN initialization sequence The FlexCAN module may be reset in three ways: MCU level hard reset, which resets all memory mapped registers asynchronously SOFT RST bit in MCR, which has the same effect as the MCU level soft reset The clock source (CLK\_SRC bit) should be selected while the module is in Disable Mode. After the clock source is selected and the module is enabled (MDIS bit negated), FlexCAN automatically goes to Freeze Mode. In Freeze Mode, FlexCAN is unsynchronized to the CAN bus, the HALT and FRZ bits in the MCR are set, the internal state machines are disabled and the FRZ\_ACK and NOT\_RDY bits in the MCR are set. The Tx pin is in recessive state and FlexCAN does not initiate any transmission or reception of CAN frames. Note that the Message Buffers and the Rx Individual Mask Registers are not affected by reset, so they are not automatically initialized. For any configuration change/initialization it is required that FlexCAN is put into Freeze Mode (see *Section 24.4.9.1: Freeze mode*). The following is a generic initialization sequence applicable to the FlexCAN module: - Initialize the Module Configuration Register - Enable the individual filtering per MB and reception queue features by setting the BCC bit - Enable the warning interrupts by setting the WRN EN bit - If required, disable frame self reception by setting the SRX\_DIS bit - Enable the FIFO by setting the FEN bit - Enable the abort mechanism by setting the AEN bit - Enable the local priority feature by setting the LPRIO\_EN bit - Initialize the Control Register - Determine the bit timing parameters: PROPSEG, PSEG1, PSEG2, RJW - Determine the bit rate by programming the PRESDIV field - Determine the internal arbitration mode (LBUF bit) - Initialize the Message Buffers - The Control and Status word of all Message Buffers must be initialized - If FIFO was enabled, the 8-entry ID table must be initialized - Other entries in each Message Buffer should be initialized as required - Initialize the Rx Individual Mask Registers - Set required interrupt mask bits in the IMASK Registers (for all MB interrupts), in CTRL Register (for Bus Off and Error interrupts) and in MCR for Wake-Up interrupt - Negate the HALT bit in MCR Starting with the last event, FlexCAN attempts to synchronize to the CAN bus. # 25 Analog-to-Digital Converter (ADC) ### 25.1 Overview ## 25.1.1 Device-specific features - 1 ADC unit - 10-bit resolution - 27 input channels - 26 channels on 144-pin LQFP; 16 channels on 100-pin LQFP - There are two types of channels: as many as 15 precision channels (CH0 to CH14) as many as 11 standard channels (CH16 to CH26) - Channel 15 dedicated to the internal 1.2 V rail - Conversion time of 500 ns without sampling time - Cross triggering unit (CTU) - 4 analog watchdogs with interrupt capability for continuous hardware monitoring of as many as 4 analog input channels - Clock stretching (with CTU pulse) - Sampling and conversion time register CTR0 (internal channels) - Left-aligned result format - Right-aligned result format - One Shot/Scan Modes - Chain Injection Mode - Power-down mode - 2 different Abort functions allow aborting either single-channel conversion or chain conversion - As many as 27 data registers for storing converted data. Conversion information, such as mode of operation (normal, injected or CTU), is associated to data value. - Auto-clock-off - 2 modes of operation, each with DMA compatible interface - Normal Mode - CTU Control Mode - External channels not supported ## 25.1.2 Device-specific pin configuration features For Section 25.3.3: ADC sampling and conversion timing, f<sub>ck</sub> = (1/2) PLL\_CLK is true where the bit ADCLKSEL would be always 0 (default value), meaning that AD\_clk is half of PLL\_CLK. A clock prescaler (1 or 2) can be configured. The AD\_clk has the same frequency of PLL\_CLK or is half of PLL\_CLK, depending on the value of the bit ADCLKSEL. - CTUEN field in the MCR: Enables or disables CTU control mode - Registers CDR[27...95] not used - ADC channel 15 is internally connected to the core voltage ## 25.1.3 Device-specific implementation ADC\_EOC DMA ADC\_WD TRIGGER 0 ADC\_CMD\_0 **ADC** NEXT\_CMD\_0 Analog **ADC Digital** ADC\_DATA\_0 Interface ADC unit 0 Cross CTU/ADC Triggering IP Interface Unit TRIGGER\_1 Figure 462. ADC implementation diagram ## 25.2 Introduction ADC\_CMD\_1 NEXT\_CMD\_1 ADC\_DATA\_1 The analog-to-digital converter (ADC) block provides accurate and fast conversions for a wide range of applications. The ADC contains advanced features for normal or injected conversion. A conversion can be triggered by software or hardware (PIT). The mask registers present within the ADC can be programmed to configure the channel to be converted. A conversion timing register for configuring different sampling and conversion times is associated to each channel type. Analog watchdogs allow continuous hardware monitoring. ## 25.3 Functional description ## 25.3.1 Analog channel conversion Two conversion modes are available within the ADC: - Normal conversion - Injected conversion #### 25.3.1.1 Normal conversion This is the normal conversion that the user programs by configuring the normal conversion mask registers (NCMR). Each channel can be individually enabled by setting '1' in the corresponding field of NCMRs. Mask registers must be programmed before starting the conversion and cannot be changed until the conversion of all the selected channels ends (NSTART bit in the Main Status Register (MSR) is reset). #### 25.3.1.2 Start of normal conversion By programming the configuration bits in the Main Configuration Register (MCR), the normal conversion can be started in two ways: - By software The conversion chain starts when the MCR[NSTART] bit is set. - By trigger An on-chip internal signal triggers an ADC conversion. The settings in the MCR select how conversions are triggered based on these internal signals: - A rising/falling edge detected in the signal sets the MSR[NSTART] bit and starts the programmed conversion. - The conversion is started if and only if the MCR[NSTART] bit is set and the programmed level on the trigger signal is detected. | Type of conversion start | NSTART<br>(in MCR) | NSTART<br>(in MSR) | Result | |--------------------------|--------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | Software | 1 | 1 | Conversion chain starts | | | _ | 1 | A falling or rising edge detected in a trigger signal sets the NSTART bit in the MSR and starts the programmed conversion. | | Trigger 1 | | 1 | The conversion is started if the programmed level on the trigger signal is detected: the start of conversion is enabled if the external pin is low or high. | Table 449. Configurations for starting normal conversion The MSR[NSTART] status bit is automatically set when the normal conversion starts. At the same time the MCR[NSTART] bit is reset, allowing the software to program a new start of conversion. In that case the new requested conversion starts after the running conversion is completed. If the content of all the normal conversion mask registers is zero (that is, no channel is selected) the conversion operation is considered completed and the interrupt ECH (see interrupt controller chapter for further details) is immediately issued after the start of conversion. #### 25.3.1.3 Normal conversion operating modes Two operating modes are available for the normal conversion: - One Shot - Scan To enter one of these modes, it is necessary to program the MCR[MODE] bit. The first phase of the conversion process involves sampling the analog channel and the next phase involves the conversion phase when the sampled analog value is converted to digital as shown in *Figure 463*. Figure 463. Normal conversion flow In **One Shot Mode** (MODE = 0) a sequential conversion specified in the NCMRs is performed only once. At the end of each conversion, the digital result of the conversion is stored in the corresponding data register. #### Example 13 One Shot Mode (MODE = 0) Channels A-B-C-D-E-F-G-H are present in the device where channels B-D-E are to be converted in the One Shot Mode. MODE = 0 is set for One Shot mode. Conversion starts from the channel B followed by conversion of channels D-E. At the end of conversion of channel E the scanning of channels stops. The NSTART status bit in the MSR is automatically set when the Normal conversion starts. At the same time the MCR[NSTART] bit is reset, allowing the software to program a new start of conversion. In that case the new requested conversion starts after the running conversion is completed. In **Scan Mode** (MODE = 1), a sequential conversion of N channels specified in the NCMRs is continuously performed. As in the previous case, at the end of each conversion the digital result of the conversion is stored into the corresponding data register. The MSR[NSTART] status bit is automatically set when the Normal conversion starts. Unlike One Shot Mode, the MCR[NSTART] bit is not reset. It can be reset by software when the user needs to stop scan mode. In that case, the ADC completes the current scan conversion and, after the last conversion, also resets the MSR[NSTART] bit. #### Example 14 Scan Mode (MODE = 1) Channels A-B-C-D-E-F-G-H are present in the device where channels B-D-E are to be converted in the Scan Mode. MODE = 1 is set for Scan Mode. Conversion starts from the channel B followed by conversion of the channels D-E. At the end of conversion of channel E the scanning of channel B starts followed by conversion of the channels D-E. This sequence repeats itself till the MCR[NSTART] bit is cleared by software. At the end of each conversion an End Of Conversion interrupt is issued (if enabled by the corresponding mask bit) and at the end of the conversion sequence an End Of Chain interrupt is issued (if enabled by the corresponding mask bit in the IMR). ## 25.3.1.4 Injected channel conversion A conversion chain can be injected into the ongoing normal conversion by configuring the Injected Conversion Mask Registers (JCMR). As with normal conversion, each channel can be selected individually. This injected conversion (which can occur only in One Shot mode) interrupts the normal conversion (which can be in One Shot or Scan mode). When an injected conversion is inserted, ongoing normal channel conversion is aborted and the injected channel request is processed. After the last channel in the injected chain is converted, normal conversion resumes from the channel at which the normal conversion was aborted, as shown in *Figure 464*. Convert B Sample C Convert C Convert D Convert E Injected conversion of channels Convert I Abort C Sample I Sample J Convert J Sample C Sample C Convert C The ongoing channel conversion is interrupted Normal conversion and the injected conversion chain is processed first. After the injected chain is converted the Figure 464. Injected sample/conversion sequence The injected conversion can be started using two options: - By software setting the MCR[JSTART]; the current conversion is suspended and the injected chain is converted. At the end of the chain, the JSTART bit in the MSR is reset and the normal chain conversion is resumed. - By an internal trigger signal from the ETIMER when MCR[JTRGEN] is set; a programmed event (rising/falling edge depending on MCR[JEDGE]) on the signal coming from ETIMER starts the injected conversion by setting the MSR[JSTART]. At the end of the chain, the MSR[JSTART] is cleared and the normal conversion chain is resumed. The MSR[JSTART] is automatically set when the Injected conversion starts. At the same time the MCR[JSTART] is reset, allowing the software to program a new start of conversion. In that case the new requested conversion starts after the running injected conversion is completed. At the end of each injected conversion, an End Of Injected Conversion (JEOC) interrupt is issued (if enabled by the IMR[MSKJEOC]) and at the end of the sequence an End Of Injected Chain (JECH) interrupt is issued (if enabled by the IMR[MSKJEOC]). If the content of all the injected conversion mask registers (JCMR) is zero (that is, no channel is selected) the JECH interrupt is immediately issued after the start of conversion. Once started, injected chain conversion cannot be interrupted by any other conversion type (it can, however, be aborted; see Section 25.3.1.5: Abort conversion). #### 25.3.1.5 Abort conversion Two different abort functions are provided. - The user can abort the ongoing conversion by setting the MCR[ABORT] bit. The current conversion is aborted and the conversion of the next channel of the chain is immediately started. In the case of an abort operation, the NSTART/JSTART bit remains set and the ABORT bit is reset after the conversion of the next channel starts. The EOC interrupt corresponding to the aborted channel is not generated. This behavior is true for normal or Injected conversion modes. If the last channel of a chain is aborted, the end of chain is reported generating an ECH interrupt. - It is also possible to abort the current chain conversion by setting the MCR[ABORTCHAIN] bit. In that case the behavior of the ADC depends on the MODE bit. If scan mode is disabled, the NSTART bit is automatically reset together with the MCR[ABORTCHAIN] bit. Otherwise, if the scan mode is enabled, a new chain conversion is started. The EOC interrupt of the current aborted conversion is not generated but an ECH interrupt is generated to signal the end of the chain. When a chain conversion abort is requested (ABORTCHAIN bit is set) while an injected conversion is running over a suspended Normal conversion, both injected chain and Normal conversion chain are aborted (both the NSTART and JSTART bits are also reset). ## 25.3.2 Analog clock generator and conversion timings The clock frequency can be selected by programming the MCR[ADCLKSEL]. When this bit is set to '1' the ADC clock has the same frequency as the PLL\_CLK. Otherwise, the ADC clock is half of the PLL\_CLK frequency. The ADCLKSEL bit can be written only in power-down mode. When the internal divider is not enabled (ADCCLKSEL = 1), it is important that the associated clock divider in the clock generation module is '1'. This is needed to ensure 50% clock duty cycle. The direct clock should basically be used only in low power mode when the device is using only the 16 MHz fast internal RC oscillator, but the conversion still requires a 16 MHz clock (an 8 MHz clock is not fast enough). In all other cases, the ADC should use the clock divided by two internally. Depending on the position of the rising edge of the signal internal trigger signal coming from the CTU, the ADC clock could also be stretched as illustrated in *Figure 465*. Figure 465. Prescaler simplified block diagram The clock stretching is implemented if and only if ADCLKSEL = 0 (and clock is half of the PLL CLK). ## 25.3.3 ADC sampling and conversion timing In order to support different loading and switching times, several different Conversion Timing registers (CTR) are present. There is one register per channel type. INPLATCH and INPCMP configurations are limited when the system clock frequency is greater than 20 MHz. When a conversion is started, the ADC connects the internal sampling capacitor to the respective analog input pin, allowing the capacitance to charge up to the input voltage value. The time to load the capacitor is referred to as sampling time. After completion of the sampling phase, the evaluation phase starts and all the bits corresponding to the resolution of the ADC are estimated to provide the conversion result. The conversion times are programmed via the bit fields of the CTR. Bit fields INPLATCH, INPCMP, and INPSAMP define the total conversion duration ( $T_{conv}$ ) and in particular the partition between sampling phase duration ( $T_{sample}$ ) and total evaluation phase duration ( $T_{eval}$ ). #### 25.3.3.1 ADC\_0 Figure 466 represents the sampling and conversion sequence. Figure 466. Sampling and conversion timings The sampling phase duration is: $$T_{sample} = (INPSAMP - ndelay) \cdot T_{ck}$$ $$INPSAMP \ge 3$$ where ndelay is equal to 0.5 if INPSAMP is less than or equal to 06h, otherwise it is 1. INPSAMP must be greater than or equal to 3 (hardware requirement). The total evaluation phase duration is: $$T_{eval} = 10 \bullet T_{biteval} = 10 \bullet (INPCMP \bullet T_{ck})$$ $$(INPCMP \ge 1) \quad and \quad (INPLATCH < INPCMP)$$ INPCMP must be greater than or equal to 1 and INPLATCH must be less than INCMP (hardware requirements). The total conversion duration is (not including external multiplexing): $$T_{conv} = T_{sample} + T_{eval} + (ndelay \bullet T_{ck})$$ The timings refer to the unit $T_{ck}$ , where $f_{ck} = (1/2 \text{ x ADC peripheral set clock})$ . Table 450. ADC sampling and conversion timing at 5 V / 3.3 V for ADC0 | Clock<br>(MHz) | T <sub>ck</sub><br>(μs) | INPSAMPLE <sup>(1)</sup> | Ndelay<br>(2) | T <sub>sample</sub> | T <sub>sample</sub> /T <sub>ck</sub> | INPCMP | T <sub>eval</sub><br>(μs) | INPLATCH | T <sub>conv</sub><br>(μs) | T <sub>conv</sub> /<br>T <sub>ck</sub> | |----------------|-------------------------|--------------------------|---------------|---------------------|--------------------------------------|--------|---------------------------|----------|---------------------------|----------------------------------------| | 6 | 0.167 | 4 | 0.5 | 0.583 | 3.500 | 1 | 1.667 | 0 | 2.333 | 14.000 | | 7 | 0.143 | 4 | 0.5 | 0.500 | 3.500 | 1 | 1.429 | 0 | 2.000 | 14.000 | | 8 | 0.125 | 5 | 0.5 | 0.563 | 4.500 | 1 | 1.250 | 0 | 1.875 | 15.000 | Table 450. ADC sampling and conversion timing at 5 V / 3.3 V for ADC0(Continued) | Clock<br>(MHz) | T <sub>ck</sub><br>(μs) | INPSAMPLE <sup>(1)</sup> | Ndelay<br>(2) | T <sub>sample</sub> | T <sub>sample</sub> /T <sub>ck</sub> | INPCMP | T <sub>eval</sub><br>(μs) | INPLATCH | T <sub>conv</sub><br>(μs) | T <sub>conv</sub> / | |----------------|-------------------------|--------------------------|---------------|---------------------|--------------------------------------|--------|---------------------------|----------|---------------------------|---------------------| | 16 | 0.063 | 9 | 1 | 0.500 | 8.000 | 1 | 0.625 | 0 | 1.188 | 19.000 | | 32 | 0.031 | 17 | 1 | 0.500 | 16.000 | 2 | 0.625 | 1 | 1.156 | 37.000 | - 1. Where: INPSAMPLE $\geq$ 3. - 2. Where: INPSAMP $\leq$ 6, N = 0.5; INPSAMP > 6, N = 1. - 3. Where: $T_{sample}$ = (INPSAMP-N) $T_{ck}$ ; Must be $\geq$ 500 ns. Table 451. Max/Min ADC clk frequency and related configuration settings at 5 V / 3.3 V for ADC0 | INPCMP | INPLATCH | Max f <sub>ADC_clk</sub> | Min f <sub>ADC_clk</sub> | |--------|----------|--------------------------|--------------------------| | 00/01 | 0 | 20+4% | 6 | | 00/01 | 1 | _ | _ | | 10 | 0 | _ | _ | | 10 | 1 | 32+4% | 6 | | 11 | 0 | _ | _ | | | 1 | 32+4% | 9 | ## 25.3.4 ADC CTU (Cross Triggering Unit) #### 25.3.4.1 Overview The ADC cross triggering unit (CTU) is added to enhance the injected conversion capability of the ADC. The CTU contains multiple event inputs that can be used to select the channels to be converted from the appropriate event configuration register. The CTU generates a trigger output pulse of one clock cycle and outputs onto an internal data bus the channel to be converted. A single channel is converted for each request. After performing the conversion, the ADC returns the result on internal bus. The conversion result is also saved in the corresponding data register and it is compared with watchdog thresholds if requested. The CTU can be enabled by setting MCR[CTUEN]. The CTU and the ADC are synchronous with the PLL CLK in both cases. #### 25.3.4.2 CTU in control mode In CTU control mode, the CPU is able to write in the ADC registers but it cannot start any conversion. Conversion requests can be generated only by the CTU trigger pulse. If a normal or injected conversion is requested, it is automatically discarded. When a CTU trigger pulse is received with the injected channel number, the conversion starts. The CTUSTART bit is set automatically at this point and it is also automatically reset when CTU Control mode is disabled (CTUEN = '0'). ## 25.3.5 Presampling #### 25.3.5.1 Introduction Presampling is used to precharge or discharge the ADC internal capacitor before it starts sampling of the analog input coming from the input pins. This is useful for resetting information regarding the last converted data or to have more accurate control of conversion speed. During presampling, the ADC samples the internally generated voltage. Presampling can be enabled/disabled on a channel basis by setting the corresponding bits in the PSRs. After enabling the presampling for a channel, the normal sequence of operation will be Presampling + Sampling + Conversion for that channel. Sampling of the channel can be bypassed by setting the PRECONV bit in the PSCR. When sampling of a channel is bypassed, the sampled data of internal voltage in the presampling state is converted (*Figure 467*, *Figure 468*). Figure 467. Presampling sequence Figure 468. Presampling sequence with PRECONV = 1 #### 25.3.5.2 Presampling channel enable signals It is possible to select between two internally generated voltages V0 and V1 depending on the value of the PSCR[PREVAL] as shown in *Table 452*. Table 452. Presampling voltage selection based on PREVALx fields | PSCR[PREVALx] | Presampling voltage | |---------------|-----------------------------| | 00 | V0 = V <sub>SS_HV_ADC</sub> | | 01 | $V1 = V_{DD\_HV\_ADC}$ | | 10 | Reserved | | 11 | Reserved | Three presampling value fields, one per channel type, in the PSCR make it possible to select different presampling values for each type. ## 25.3.6 Programmable analog watchdog #### 25.3.6.1 Introduction The analog watchdogs are used for determining whether the result of a channel conversion lies within a given guarded area (as shown in *Figure 469*) specified by an upper and a lower threshold value named THRH and THRL respectively. Analog voltage Upper threshold Guarded area THRH THRL Figure 469. Guarded area After the conversion of the selected channel, a comparison is performed between the converted value and the threshold values. If the converted value lies outside that guarded area then corresponding threshold violation interrupts are generated. The comparison result is stored as WTISR[WDGxH] and WTISR[WDGxL] as explained in *Table 453*. Depending on the mask bits WTIMR[MSKWDGxL] and WTIMR[MSKWDGxH], an interrupt is generated on threshold violation. WDGxH WDGxL Converted data 1 0 converted data > THRH 0 1 converted data < THRL</td> 0 0 THRL <= converted data <= THRH</td> Table 453. Values of WDGxH and WDGxL fields The TRC[THRCH] field specifies the channel on which the analog watchdog is applied. The analog watchdog is enabled by setting the corresponding TRC[THREN]. The lower and higher threshold values for the analog watchdog are programmed using the THRHLRs. For example, if channel number 3 is to be monitored with threshold values in THRHLR1, then the TRC[THRCH] field is programmed to select channel number 3. A set of threshold registers (THRHLRx and TRCx) can be linked only to a single channel for a particular THRCH value. If another channel is to be monitored with same threshold values, then the TRCx[THRCH] must be programmed again. Note: If the higher threshold for the analog watchdog is programmed lower than the lower threshold and the converted value is less than the lower threshold, then the WDGxL interrupt for the low threshold violation is set, else if the converted value is greater than the lower threshold (consequently also greater than the higher threshold) then the interrupt WDGxH for high threshold violation is set. Thus, the user should avoid that situation as it could lead to misinterpretation of the watchdog interrupts. ### 25.3.6.2 Analog watchdog functionality For each input channel the result of the comparison is reflected in the THROP bit in TRC register based on the converted analog values received by the analog watchdogs: - If the converted data value is lower than the lower threshold then the THROP bit in TRC register will be set to 1. - If the converted voltage is higher than the higher threshold then the THROP bit in TRC register will be set to 0. - If the converted voltage lies between the upper and the lower threshold guard window then THROP bit in TRC register will keep its logic value. The logic level of the THROP bit can be programmed by software. In fact, the user can decide to keep the behavior described or to invert the output logic level by setting the THRINV bit in the TRC register. An example of the operation is shown in Table 454. | Converted data watchdog[x] | Upper threshold watchdog[x] | Lower threshold watchdog[x] | THRINV<br>watchdog[x] | THROP[x] | |----------------------------|-----------------------------|-----------------------------|-----------------------|----------| | 155h | 055h | 000h | 0 | 0 | | 055h | 1ffh | 088h | 0 | 1 | | 155h | 055h | 000h | 1 | 1 | | 055h | 1ffh | 088h | 1 | 0 | Table 454. Example for Analog watchdog operation ## 25.3.7 DMA functionality A DMA request can be programmed after the conversion of every channel by setting the respective masking bit in the DMARs. The DMAR masking registers must be programmed before starting any conversion. There is one DMAR per channel type. The DMA transfers can be enabled using the DMAEN bit of DMAE register. When the DCLR bit of DMAE register is set, the DMA request is cleared the register enabled for DMA transfer has been read. ### 25.3.8 Interrupts The ADC generates the following maskable interrupt signals: - EOC (end of conversion) interrupt request - ECH (end of chain) interrupt request - JEOC (end of injected conversion) interrupt request - JECH (end of injected chain) interrupt request - EOCTU (end of CTU conversion) interrupt request - WDGxL and WDGxH (watchdog threshold) interrupt requests Interrupts are generated during the conversion process to signal events such as End Of Conversion as explained in register description for ISR and IMR. The analog watchdog interrupts are handled by two registers WTISR (Watchdog Threshold Interrupt Status Register) and WTIMR (Watchdog Threshold Interrupt Mask Register) in order to check and enable the interrupt request to the INTC module. The Watchdog interrupt source sets two pending bits WDGxH and WDGxL in the WTISR for each of the channels being monitored. #### 25.3.9 Power-down mode The analog part of the ADC can be put in low power mode by setting the MCR[PWDN]. After releasing the reset signal the ADC analog module is kept in power-down mode by default, so this state must be exited before starting any operation by resetting the appropriate bit in the MCR. The power-down mode can be requested at any time by setting the MCR[PWDN]. If a conversion is ongoing, the ADC must complete the conversion before entering the power down mode. In fact, the ADC enters power-down mode only after completing the ongoing conversion. Otherwise, the ongoing operation should be aborted manually by resetting the NSTART bit and using the ABORTCHAIN bit. MSR[ADCSTATUS] bit is set only when ADC enters power-down mode. After the power-down phase is completed the process ongoing before the power-down phase must be restarted manually by setting the appropriate MCR[START] bit. Resetting MCR[PWDN] bit and setting MCR[NSTART] or MCR[JSTART] bit during the same cycle is forbidden. If a CTU trigger pulse is received during power-down, it is discarded. If the CTU is enabled and the MSR[CTUSTART] bit is '1', then the MCR[PWDN] bit cannot be set. #### 25.3.10 Auto-clock-off mode To reduce power consumption during the IDLE mode of operation (without going into power-down mode), an "auto-clock-off" feature can be enabled by setting the MCR[ACKO] bit. When enabled, the analog clock is automatically switched off when no operation is ongoing, that is, no conversion is programmed by the user. Note: The auto-clock-off feature cannot operate when the digital interface runs at the same rate as the analog interface. This means that when MCR.ADCCLKSEL = 1, the analog clock will not shut down in IDLE mode. # 25.4 Register descriptions #### 25.4.1 Introduction Table 455 lists ADC registers with their address offsets and reset values. Table 455. ADC digital registers | Offset from base<br>address<br>0xFFE0_0000 | Register name | Location | |--------------------------------------------|-----------------------------------|-------------| | 0x0000 | Main Configuration Register (MCR) | on page 818 | | 0x0004 | Main Status Register (MSR) | on page 820 | Table 455. ADC digital registers(Continued) | Offset from base<br>address<br>0xFFE0_0000 | Register name | Location | |--------------------------------------------|------------------------------------------------------|-------------| | 0x0008-0x000F | Reserved | | | 0x0010 | Interrupt Status Register (ISR) | on page 821 | | 0x0014-0x001F | Reserved | · | | 0x0020 | Interrupt Mask Register (IMR) | on page 822 | | 0x0024-0x002F | Reserved | · | | 0x0030 | Watchdog Threshold Interrupt Status Register (WTISR) | on page 823 | | 0x0034 | Watchdog Threshold Interrupt Mask Register (WTIMR) | on page 823 | | 0x0038-0x003F | Reserved | | | 0x0040 | DMA Enable Register (DMAE) | on page 824 | | 0x0044 | DMA Channel Select Register 0 (DMAR0) | on page 825 | | 0x0048-0x004F | Reserved | · | | 0x0050 | Threshold Control Register 0 (TRC0) | on page 826 | | 0x0054 | Threshold Control Register 1 (TRC1) | on page 826 | | 0x0058 | Threshold Control Register 2 (TRC2) | on page 826 | | 0x005C | Threshold Control Register 3 (TRC3) | on page 826 | | 0x0060 | Threshold Register 0 (THRHLR0) | on page 827 | | 0x0064 | Threshold Register 1 (THRHLR1) | on page 827 | | 0x0068 | Threshold Register 2 (THRHLR2) | on page 827 | | 0x006C | Threshold Register 3 (THRHLR3) | on page 827 | | 0x0070-0x007F | Reserved | | | 0x0080 | Presampling Control Register (PSCR) | on page 827 | | 0x0084 | Presampling Register 0 (PSR0) | on page 827 | | 0x0088-0x0093 | Reserved | | | 0x0094 | Conversion Timing Register 0 (CTR0) | on page 829 | | 0x0098-0x00A3 | Reserved | | | 0x00A4 | Normal Conversion Mask Register 0 (NCMR0) | on page 829 | | 0x00A8-0x00B3 | Reserved | , | | 0x00B4 | Injected Conversion Mask Register 0 (JCMR0) | on page 830 | | 0x00B8-00C7 | Reserved | · | | 0x00C8 | Power-down Exit Delay Register (PDEDR) | on page 831 | | 0x00CC-0x00FF | Reserved | • | | 0x0100 | Channel 0 Data Register (CDR0) | on page 831 | | 0x0104 | Channel 1 Data Register (CDR1) | on page 831 | | | | | Table 455. ADC digital registers(Continued) | Offset from base<br>address<br>0xFFE0_0000 | Register name | Location | |--------------------------------------------|----------------------------------|-------------| | 0x0108 | Channel 2 Data Register (CDR2) | on page 831 | | 0x010C | Channel 3 Data Register (CDR3) | on page 831 | | 0x0110 | Channel 4 Data Register (CDR4) | on page 831 | | 0x0114 | Channel 5 Data Register (CDR5) | on page 831 | | 0x0118 | Channel 6 Data Register (CDR6) | on page 831 | | 0x011C | Channel 7 Data Register (CDR7) | on page 831 | | 0x0120 | Channel 8 Data Register (CDR8) | on page 831 | | 0x0124 | Channel 9 Data Register (CDR9) | on page 831 | | 0x0128 | Channel 10 Data Register (CDR10) | on page 831 | | 0x012C | Channel 11 Data Register (CDR11) | on page 831 | | 0x0130 | Channel 12 Data Register (CDR12) | on page 831 | | 0x0134 | Channel 13 Data Register (CDR13) | on page 831 | | 0x0138 | Channel 14 Data Register (CDR14) | on page 831 | | 0x013C | Channel 15 Data Register (CDR15) | on page 831 | | 0x0140 | Channel 16 Data Register (CDR16) | on page 831 | | 0x0144 | Channel 17 Data Register (CDR17) | on page 831 | | 0x0148 | Channel 18 Data Register (CDR18) | on page 831 | | 0x014C | Channel 19 Data Register (CDR19) | on page 831 | | 0x0150 | Channel 20 Data Register (CDR20) | on page 831 | | 0x0154 | Channel 21 Data Register (CDR21) | on page 831 | | 0x0158 | Channel 22 Data Register (CDR22) | on page 831 | | 0x015C | Channel 23 Data Register (CDR23) | on page 831 | | 0x0160 | Channel 24 Data Register (CDR24) | on page 831 | | 0x0164 | Channel 25 Data Register (CDR25) | on page 831 | | 0x0168 | Channel 26 Data Register (CDR26) | on page 831 | ## 25.4.2 Control logic registers ## 25.4.2.1 Main Configuration Register (MCR) The Main Configuration Register (MCR) provides configuration settings for the ADC. Figure 470. Main Configuration Register (MCR) Table 456. MCR field descriptions | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OWREN | Overwrite enable This bit enables or disables the functionality to overwrite unread converted data. O Prevents overwrite of unread converted data; new result is discarded Enables converted data to be overwritten by a new conversion | | WLSIDE | Write left/right-aligned 0 The conversion data is written right-aligned. 1 Data is left-aligned (from 15 to (15 – resolution + 1)). The WLSIDE bit affects all the CDR registers simultaneously. See <i>Figure 486</i> and <i>Table 472</i> . | | MODE | One Shot/Scan One Shot Mode—Configures the normal conversion of one chain. Scan Mode—Configures continuous chain conversion mode; when the programmed chain conversion is finished it restarts immediately. | | NSTART | Normal Start conversion Setting this bit starts the chain or scan conversion. Resetting this bit during scan mode causes the current chain conversion to finish, then stops the operation. This bit stays high while the conversion is ongoing (or pending during injection mode). Causes the current chain conversion to finish and stops the operation Starts the chain or scan conversion | | JTRGEN | Injection external trigger enable 0 External trigger disabled for channel injection 1 External trigger enabled for channel injection | | JEDGE | Injection trigger edge selection Edge selection for external trigger, if JTRGEN = 1. 0 Selects falling edge for the external trigger 1 Selects rising edge for the external trigger | | JSTART | Injection start Setting this bit will start the configured injected analog channels to be converted by software. Resetting this bit has no effect, as the injected chain conversion cannot be interrupted. | | CTUEN | Cross trigger unit conversion enable 0 CTU triggered conversion disabled 1 CTU triggered conversion enabled | Table 456. MCR field descriptions(Continued) | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADCLKSEL | Analog clock select This bit can only be written when ADC in Power-Down mode 0 ADC clock frequency is half Peripheral Set Clock frequency 1 ADC clock frequency is equal to Peripheral Set Clock frequency | | ABORTCHAIN | Abort Chain When this bit is set, the ongoing Chain Conversion is aborted. This bit is reset by hardware as soon as a new conversion is requested. O Conversion is not affected Aborts the ongoing chain conversion | | ABORT | Abort Conversion When this bit is set, the ongoing conversion is aborted and a new conversion is invoked. This bit is reset by hardware as soon as a new conversion is invoked. If it is set during a scan chain, only the ongoing conversion is aborted and the next conversion is performed as planned. O Conversion is not affected Aborts the ongoing conversion | | ACKO | Auto-clock-off enable If set, this bit enables the Auto clock off feature. O Auto clock off disabled 1 Auto clock off enabled | | PWDN | Power-down enable When this bit is set, the analog module is requested to enter Power Down mode. When ADC status is PWDN, resetting this bit starts ADC transition to IDLE mode. 0 ADC is in normal mode 1 ADC has been requested to power down | ## 25.4.2.2 Main Status Register (MSR) The Main Status Register (MSR) provides status bits for the ADC. Figure 471. Main Status Register (MSR) | Field | Description | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NSTART | This status bit is used to signal that a Normal conversion is ongoing. | | JABORT | This status bit is used to signal that an Injected conversion has been aborted. This bit is reset when a new injected conversion starts. | | JSTART | This status bit is used to signal that an Injected conversion is ongoing. | | CTUSTART | This status bit is used to signal that a CTU conversion is ongoing. | | CHADDR | Current conversion channel address This status field indicates current conversion channel address. | | ACKO | Auto-clock-off enable This status bit is used to signal if the Auto-clock-off feature is on. | | ADCSTATUS | The value of this parameter depends on ADC status: 000 IDLE — The ADC is powered up but idle. 001 Power-down — The ADC is powered down. 010 Wait state — The ADC is waiting for an external multiplexer. This occurs only when the DSDR is non-zero. 011 Reserved 100 Sample — The ADC is sampling the analog signal. 101 Reserved 110 Conversion — The ADC is converting the sampled signal. 111 Reserved | Table 457. MSR field descriptions Note: MSR[JSTART] is automatically set when the injected conversion starts. At the same time MCR[JSTART] is reset, allowing the software to program a new start of conversion. The JCMR registers do not change their values. ## 25.4.3 Interrupt registers ## 25.4.3.1 Interrupt Status Register (ISR) The Interrupt Status Register (ISR) contains interrupt status bits for the ADC. Figure 472. Interrupt Status Register (ISR) Table 458. ISR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------| | EOCTU | End of CTU Conversion interrupt flag When this bit is set, an EOCTU interrupt has occurred. | | JEOC | End of Injected Channel Conversion interrupt flag When this bit is set, a JEOC interrupt has occurred. | | JECH | End of Injected Chain Conversion interrupt flag When this bit is set, a JECH interrupt has occurred. | | EOC | End of Channel Conversion interrupt flag When this bit is set, an EOC interrupt has occurred. | | ECH | End of Chain Conversion interrupt flag When this bit is set, an ECH interrupt has occurred. | ## 25.4.3.2 Interrupt Mask Register (IMR) The Interrupt Mask Register (IMR) contains the interrupt enable bits for the ADC. Figure 473. Interrupt Mask Register (IMR) Table 459. IMR field descriptions | Field | Description | |----------|-------------------------------------------------------------------------------------------------------| | MSKEOCTU | Mask for end of CTU conversion (EOCTU) interrupt When set, the EOCTU interrupt is enabled. | | MSKJEOC | Mask for end of injected channel conversion (JEOC) interrupt When set, the JEOC interrupt is enabled. | | MSKJECH | Mask for end of injected chain conversion (JECH) interrupt When set, the JECH interrupt is enabled. | | MSKEOC | Mask for end of channel conversion (EOC) interrupt When set, the EOC interrupt is enabled. | | MSKECH | Mask for end of chain conversion (ECH) interrupt When set, the ECH interrupt is enabled. | ## 25.4.3.3 Watchdog Threshold Interrupt Status Register (WTISR) Figure 474. Watchdog Threshold Interrupt Status Register (WTISR) Table 460. WTISR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------| | WDGxH | This corresponds to the status flag generated on the converted value being higher than the programmed higher threshold (for $[x = 03]$ ). | | WDGxL | This corresponds to the status flag generated on the converted value being lower than the programmed lower threshold (for $[x = 03]$ ). | ### 25.4.3.4 Watchdog Threshold Interrupt Mask Register (WTIMR) Figure 475. Watchdog Threshold Interrupt Mask Register (WTIMR) Table 461. WTIMR field descriptions | Field | Description | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MSKWDGxH | This corresponds to the mask bit for the interrupt generated on the converted value being higher than the programmed higher threshold (for $[x = 03]$ ). When set the interrupt is enabled. | | MSKWDGxL | This corresponds to the mask bit for the interrupt generated on the converted value being lower than the programmed lower threshold (for $[x = 03]$ ). When set the interrupt is enabled. | ## 25.4.4 DMA registers ## 25.4.4.1 DMA Enable (DMAE) register The DMA Enable (DMAE) register sets up the DMA for use with the ADC. Figure 476. DMA Enable (DMAE) register Table 462. DMAE field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------| | DCLR | DMA clear sequence enable 0 DMA request cleared by Acknowledge from DMA controller 1 DMA request cleared on read of data registers | | DMAEN | DMA global enable 0 DMA feature disabled 1 DMA feature enabled | ## 25.4.4.2 DMA Channel Select Register (DMAR[0]) DMAR0 = Enable bits for channel 0 to 26 Address: Base + 0x0044 Access: User read/write R DMA Reset R DMA Reset Figure 477. DMA Channel Select Register 0 (DMAR0) Table 463. DMARx field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------| | DMAn | DMA enable When set (DMAn = 1), channel n is enabled to transfer data in DMA mode. | # 25.4.5 Threshold registers ### 25.4.5.1 Introduction The Threshold registers store the user programmable lower and upper thresholds' values. The inverter bit and the mask bit for mask the interrupt are stored in the TRC registers. ## 25.4.5.2 Threshold Control Register (TRCx, x = [0...3]) Figure 478. Threshold Control Register (TRCx, x = [0...3]) Table 464. TRCx field descriptions | Field | Description | |--------|-------------------------------------------------------------------------------------------------------| | THREN | Threshold enable When set, this bit enables the threshold detection feature for the selected channel. | | THRINV | Invert the output pin Setting this bit inverts the behavior of the threshold output pin. | | THROP | This bit reflects the output pin status. | | THRCH | Choose the channel for threshold comparison. | ## 25.4.5.3 Threshold Register (THRHLR[0:3]) The four THRHLR*n* registers store the user-programmable thresholds' 10-bit values. Figure 479. Threshold Register (THRHLR[0:3]) Table 465. THRHLRx field descriptions | Field | Description | |-------|---------------------------------------------| | THRH | High threshold value for channel <i>n</i> . | | THRL | Low threshold value for channel <i>n</i> . | ## 25.4.6 Presampling registers ## 25.4.6.1 Presampling Control Register (PSCR) Figure 480. Presampling Control Register (PSCR) ### Table 466. PSCR field descriptions | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PREVAL0 | Internal voltage selection for presampling 00 Select the V0 internal presampling voltage 01 Select the V1 internal presampling voltage 10 Reserved 11 Reserved | | PRECONV | Convert presampled value If bit PRECONV is set, presampling is followed by the conversion. Sampling will be bypassed and conversion of presampled data will be done. | ## 25.4.6.2 Presampling Register (PSR[0]) PSR0 = Enable bits of presampling for channel 0 to 26 Figure 481. Presampling Register 0 (PSR0) Table 467. PSR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------| | PRESn | Presampling enable When set (PRESn = 1), presampling is enabled for channel n. | # 25.4.7 Conversion Timing Registers CTR[0] CTR0 = associated to internal channels (from 0 to 26) Figure 482. Conversion Timing Registers CTR[0] Table 468. CTR field descriptions | Field | Description | | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | INPLATCH | Configuration bit for latching phase duration | | | OFFSHIFT | Configuration for offset shift characteristic 00 No shift (that is the transition between codes 000h and 001h) is reached when the A <sub>VIN</sub> (analog input voltage) is equal to 1 LSB. 01 Transition between code 000h and 001h is reached when the A <sub>VIN</sub> is equal to 1/2 LSB 10 Transition between code 00h and 001h is reached when the A <sub>VIN</sub> is equal to 0 11 Not used Note: Available only on CTR0 | | | INPCMP | Configuration bits for comparison phase duration | | | INPSAMP | Configuration bits for sampling phase duration | | # 25.4.8 Mask registers #### 25.4.8.1 Introduction The Mask registers are used to program the 27 input channels that are converted during Normal and Injected conversion. #### 25.4.8.2 Normal Conversion Mask Registers (NCMR[0]) NCMR0 = Enable bits of normal sampling for channel 0 to 26 Figure 483. Normal Conversion Mask Register 0 (NCMR0) #### Table 469. NCMR field descriptions | Field | Description | |-------|-------------------------------------------------------------| | CHn | Sampling enable When set Sampling is enabled for channel n. | #### 25.4.8.3 Injected Conversion Mask Registers (JCMR[0]) JCMR0 = Enable bits of injected sampling for channel 0 to 26 Figure 484. Injected Conversion Mask Register 0 (JCMR0) #### Table 470. JCMR field descriptions | Field | Description | |-------|--------------------------------------------------------------| | CHn | Sampling enable When set, sampling is enabled for channel n. | # 25.4.9 Delay registers ### 25.4.9.1 Power-Down Exit Delay Register (PDEDR) Figure 485. Power-Down Exit Delay Register (PDEDR) Table 471. PDEDR field descriptions | Field | Description | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | PDED | Delay between the power-down bit reset and the start of conversion. The delay is to allow time for the ADC power supply to settle before commencing conversions. The power down delay is calculated as: PDED x 1/frequency of ADC clock. | | ### 25.4.10 Data registers #### 25.4.10.1 Introduction ADC conversion results are stored in data registers. There is one register per channel. ### 25.4.10.2 Channel Data Registers (CDR[0...26]) CDR[0...26] = precision channels Each data register also gives information regarding the corresponding result as described below. Figure 486. Channel Data Registers (CDR[0...26]) Table 472. CDR field descriptions | Field | Description | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | VALID | Used to notify when the data is valid (a new value has been written). It is automatically cleared when data is read. | | | | | Overwrite data | | | | OVERW | This bit signals that the previous converted data has been overwritten by a new conversion. This functionality depends on the value of MCR[OWREN]: | | | | | <ul> <li>When OWREN = 0, then OVERW is frozen to 0 and CDATA field is protected against being<br/>overwritten until being read.</li> </ul> | | | | | – When OWREN = 1, then OVERW flags the CDATA field overwrite status. | | | | | 0 Converted data has not been overwritten | | | | | Previous converted data has been overwritten before having been read | | | | RESULT | This bit reflects the mode of conversion for the corresponding channel. 00 Data is a result of Normal conversion mode 01 Data is a result of Injected conversion mode 10 Data is a result of CTU conversion mode 11 Reserved | | | | CDATA | Channel 0- converted data. Depending on the value of the MCR[WLSIDE] bit, the position of this field can be changed as shown in <i>Figure 486</i> . | | | # **26** Cross Triggering Unit (CTU) #### 26.1 Introduction The cross triggering unit (CTU) is intended to completely avoid CPU involvement in the time acquisitions of state variables during the control cycle that can be the PWM cycle, the half PWM cycle or a number of PWM cycles. In such cases the pre-setting of the acquisition times needs to be completed during the previous control cycle, where the actual acquisitions are to be made, and a double-buffered structure for the CTU registers is used, in order to activate the new settings at the beginning of the next control cycle. Additionally, four FIFOs inside the CTU are available to store the ADC results. #### 26.2 CTU overview The CTU receives various incoming signals from different sources (timers, position decoder and/or external pins). These signals are then processed to generate as many as eight trigger events. An input can be a rising edge, a falling edge or both, edges of each incoming signal. The output can be a pulse or a command (or a stream of consecutive commands for over-sampling support) or both, to one or more peripherals (for example, ADC or timers). The CTU interfaces to the following peripherals: - Timers—2 inputs - GPIO—1 external input signal The 16 input signals are digital signals and the CTU must be able to detect a rising and/or a falling edge for each of them. The CTU comprises the following: - Input signals interface - User interface (such as configuration registers) - ADC interface - Timers interface The block diagram of the CTU is shown in Figure 487. Figure 487. Cross triggering unit diagram The CTU consists of two subunits: - Trigger generator - Scheduler The trigger generator subunit handles incoming signals, selecting for each signal, the active edges to generate the Master Reload signal, and generates as many as eight trigger events (signals). The scheduler subunit generates the trigger event output according to the occurred trigger event (signal). # 26.3 Functional description The following describes the functionality of the CTU. ### 26.3.1 Trigger events features The TGS has the capability to generate as many as eight trigger events. Each trigger event has the following characteristics: - Generation of the trigger event is sequential in time - The triggers list uses eight 16-bit double-buffered registers - On each Master Reload Signal (MRS), the new triggers list is loaded - The triggers list is reloaded on a MRS occurrence, only if the reload enable bit is set ### 26.3.2 Trigger generator subunit (TGS) The trigger generator subunit has the following two modes: Triggered mode—Each event source for the incoming signals can generate as many as eight trigger event outputs. For the ADC, a commands list is entered by the CPU, and - each event source can generate as many as eight commands or streams of commands. - Sequential mode—Each event source for the incoming signals can generate one trigger event output, the next event source generates the next trigger event output, and so on in a predefined sequence. For the ADC, a commands list is entered by the CPU and the sequence of the selected incoming trigger events generate commands or stream of commands. The TGS Mode is selected using the TGS\_M bit in the TGS Control Register. ### 26.3.3 TGS in triggered mode The structure of the TGS in Triggered mode is shown in *Figure 488*. Figure 488. TGS in triggered mode The TGS has 16 input signals, each of which is selected from the input selection register (TGSISR), selecting the states inactive, rising, falling or both. Depending on the selection, as many as 32 input events can be enabled. These signals are ORed in order to generate the MRS. The MRS, at the beginning of the control cycle n (defined by the MRS occurrence), preloads the TGS counter register, using the preload value written into the double-buffered register (TGSCRR), during the control cycle n-1 and reloads all the double-buffered registers (such as Trigger Compare registers, TGSCR, TGSCRR itself). The triggers list registers consist of eight compare registers. Each triggers list register is associated with a comparator. On reload (MRS occurrence), the comparators are disabled. One TGS clock cycle is necessary to enable them and to start the counting. The MRS is output together with individual trigger signals. The MRS can be performed by hardware or by software. The MRS SG bit in the CTU control register, if set to 1, generates equivalent software MRS (that is, resets/reloads TGS Counter and reloads all double-buffered registers). This bit is cleared by each hardware or software MRS occurrence. The TGS counter compare register and the TGS counter comparator are used to stop the TGS counter when it reaches the value stored in the TGS counter compare register before an MRS occurs. The prescaler for TGS and SU can be 1,2,3,4 (PRES bits in the TGS Control Register). An example timing for the TGS in Triggered Mode is shown in *Figure 489*. The red arrows indicate the MRS occurrences, while the black arrows indicate the trigger event occurrences, with the relevant delay in respect to the last MRS occurrence. Figure 489. Example timing for TGS in triggered mode #### 26.3.4 TGS in sequential mode The structure of the TGS in sequential mode is shown in Figure 490. The 32 input events (16 signals with two edges for signal), which can be individually enabled, are ORed in order to generate the event signal (ES). The ES enables the reload of the TGS counter register and pilots the 3-bit counter in order to select the next active trigger. One of the 32 input events can be selected, through the MRS SM (master reload selection sequential mode) bits in the TGS control register, to be the MRS, that enables the reload of the triggers list and resets the 3-bit counter (incoming events counter), that is, the MRS is the signal linked with the control cycle defined as the time window between two consecutive MRSs. In this mode, each incoming event sequentially enables only one trigger event through the 3-bit counter and the MUX. The MUX is a selection switch that enables, according to the number of event signals occurred, only one of the eight trigger signals to the scheduler subunit. Sequences of as many as eight trigger events can be supported within this control cycle. For the other features see the previous paragraphs. Figure 490. TGS in sequential mode An example timing diagram for TGS in sequential mode is shown in *Figure 491*. The red arrows indicate the MRS occurrences and ES occurrences, while the black arrows indicate the trigger event occurrences with the relevant delay in respect to the ES occurrence. The first red arrow indicates the first ES occurrence, which is also the MRS. Figure 491. Example timing for TGS in sequential mode #### 26.3.5 TGS counter The TGS counter is able to count from negative to positive, that is, from 0x8000 to 0x7FFF. *Figure 492* shows examples in order to explain the TGS counter counts. The compare operation to stop the TGS counter is not enabled during the first counting cycle, in order to allow the counting, if the value of the TGSCRR is the same as the value of the TGSCCR. Figure 492. TGS counter cases # 26.4 Scheduler subunit (SU) The structure of the SU is shown in Figure 493. The SU generates the trigger event output according to the occurred trigger event, and it has the same functionality in both TGS modes (triggered mode and sequential mode). Each of the four SU outputs: - ADC command or ADC stream of commands - eTimer1 pulse (ETIMER0\_TRG internally connected to eTimer\_0 AUX0) - eTimer2 pulse (ETIMER1\_TRG internally connected to eTimer\_1 AUX0 - External trigger pulse can be linked to any of eight trigger events by the Trigger Handler block. Each trigger event can be linked to one or more SU outputs. If two events at the same time are linked to the same output only one output is generated and an error is provided. The output is generated using the trigger with the lowest index. For example, if trigger 0 and trigger 1 are linked to the ADC output and they occur together, an error is generated and the output linked with the trigger 0 is generated. When a trigger is linked to the ADC, an associated ADC command (or stream of commands) is generated. The ADC Commands List Control Register (CLCRx) sets the assignment to an ADC command or to a stream of commands. When a trigger is linked to a timer or to the external trigger, a pulse with an active rising edge is generated. Additional features for the external triggers are available: The external trigger output has: - Pulse mode - Toggle mode In Toggle Mode, each trigger event is linked to the external trigger, the external trigger pin toggles. The ON-Time for both modes (Pulse mode and Toggle mode) of the triggers is defined from a COTR (Control On Time Register). A guard time is also defined from the same register at the same value of the ON-Time. A new trigger will be generated only if the ON time + Guard Time has past. The ON-Time and the Guard Time are only used for external Triggers. External signals can be asynchronous with motor control clock. For this reason a programmable digital filter is available. The external signal is considered at 1 if it is latched N time at 1, and is considered at 0 if it is latched N time at 0, where N is a value in the digital filter control register. Trigger events in the SU can be initiated by hardware or by software, and an additional software control is possible for each trigger event (as for the MRS), so 1 bit for each trigger event in the CTU Control Register is used to generate an equivalent software trigger event. Each of these bits is cleared by a respective hardware or software trigger event. Figure 493. Scheduler subunit #### 26.4.1 ADC commands list The ADC can be controlled by the CPU (CPU Control Mode) and by the CTU (CTU Control Mode). The CTU can control the ADC by sending an ADC command only when the ADC is in CTU control mode. During the CTU control mode, the CPU is able to write to the ADC registers but it can not start a new conversion. A control bit is allowed to select from the classic interface of the CTU control mode. Once selected, no change is possible unless a reset occurs. The SU uses a Commands List in order to select the command to send to the ADC when a trigger event occurs. The commands list can hold twenty-four 16-bit commands (see Section 26.4.2: ADC commands list format) and it is double-buffered, that is, the commands list can be updated at any time between two consecutive MRS, but the changes become workable only after the next MRS occurs, and a correct reload is performed. In order to manage the commands list, 5 bits are available in the CLCRx (ADC Commands List Control Register x), for the position of the first command in the list of commands for each trigger event. The number of commands piloted by the same trigger event is defined directly in the commands list. For each command, a bit defines whether or not it is the first command of a commands list. #### 26.4.2 ADC commands list format The CTU can be interfaced with two ADCs, supporting the Single Conversion Mode and the Dual Conversion Mode. In Single Conversion Mode only one ADC starts a conversion at a time. In Dual Conversion Mode both ADCs start a conversion at the same time; in particular both the ADC conversions are performed at the same time while the storage of the results is performed in series. In Dual Conversion Mode, 4 bits select each channel number, and the conversion mode selection bit selects the Dual Conversion Mode. If the Single Conversion Mode is selected, 5 of the 8 bits reserved to select the channels in Dual Conversion Mode are reused to select the channel (4 bits) and the ADC unit (1 bit). See Section 26.8.10: Commands list register x (x = 1,...,24) (CLRx). The result of each conversion is stored in one of the four available FIFOs. The interrupt request bit is used as an interrupt request when ADC will complete the command with this bit set and it is only for CTU internal use. Before the next command to the CTU controls is sent, the value of the first command (FC) bit is checked to see if it is the current command is the first command of a new stream of consecutive commands or not. If not, the CTU sends the command. According to the previous considerations, the commands in the list allow control on: - Channel 0: number of ADC channel to sample from ADC unit 0 (4 bits) - Channel 1: number of ADC channel to sample from ADC unit 1 (4 bits) - FIFO selection bits for the ADC unit 0/1 (2 bits) - Conversion Mode selection bit - First command bit (only for CTU internal use) - Interrupt request bit (only for CTU internal use) On this device, only ADC\_0 is implemented so a new CTU/ADC interface is implemented in order to interface the CTU and the only ADC\_0. This new CTU/ADC interface is a logic machine between the CTU outputs and the ADC\_0 inputs and it has no configuration registers. It is implemented to ensure software compatibility between SPC56xP60x/54x and the 512 Kbyte memory family device, in fact it is able to virtualize ADC\_1 on SPC56xP60x/54x, so, for example, the user can write on SPC56xP60x/54x a command to start a conversion on ADC\_1 channels 0 and the CTU/ADC interface will translate this command into a command for ADC\_0 channel 6. Moreover CTU/ADC interface will manage software programming mistakes for SPC56xP60x/54x as not allowed Dual Conversion Mode or wrong ADC\_0/1 channel number selection to ensure that the CTU does not go in a blocking status. Table 473. ADC commands translation. | Input command | Output command | |-------------------------------------------------------------------|----------------------------------| | Single sampling ADC_0 channel 0 | Single sampling ADC_0 channel 0 | | Single sampling ADC_0 channel 1 | Single sampling ADC_0 channel 1 | | Single sampling ADC_0 channel 2 | Single sampling ADC_0 channel 2 | | Single sampling ADC_0 channel 3 | Single sampling ADC_0 channel 3 | | Single sampling ADC_0 channel 4 | Single sampling ADC_0 channel 4 | | Single sampling ADC_0 channel 5 | Single sampling ADC_0 channel 5 | | Single sampling ADC_0 channel 6 | Single sampling ADC_0 channel 6 | | Single sampling ADC_0 channel 7 | Single sampling ADC_0 channel 7 | | Single sampling ADC_0 channel 8 | Single sampling ADC_0 channel 8 | | Single sampling ADC_0 channel 9 | Single sampling ADC_0 channel 9 | | Single sampling ADC_0 channel 10 | Single sampling ADC_0 channel 10 | | Single sampling ADC_0 channel 11 | Single sampling ADC_0 channel 11 | | Single sampling ADC_0 channel 12 | Single sampling ADC_0 channel 12 | | Single sampling ADC_0 channel 13 | Single sampling ADC_0 channel 13 | | Single sampling ADC_0 channel 14 Single sampling ADC_0 channel 14 | | | Single sampling ADC_0 channel 15 | Single sampling ADC_0 channel 15 | | Single sampling ADC_1 Channel 0 | Single sampling ADC_0 Channel 16 | | Single sampling ADC_1 Channel 1 Single sampling ADC_0 Channel 17 | | | Single sampling ADC_1 Channel 2 Single sampling ADC_0 Channel 18 | | | Single sampling ADC_1 Channel 3 | Single sampling ADC_0 Channel 19 | | Single sampling ADC_1 Channel 4 | Single sampling ADC_0 Channel 20 | | Single sampling ADC_1 Channel 5 | Single sampling ADC_0 Channel 21 | | Single sampling ADC_1 Channel 6 | Single sampling ADC_0 Channel 22 | | Single sampling ADC_1 Channel 7 | Single sampling ADC_0 Channel 23 | | Single sampling ADC_1 Channel 8 | Single sampling ADC_0 Channel 24 | | Single sampling ADC_1 Channel 9 Single sampling ADC_0 Channel 25 | | | Single sampling ADC_1 Channel 10 Single sampling ADC_0 Channel 26 | | | Single sampling ADC_1 Channel 11 Not valid - force EOC to CTU | | | Single sampling ADC_1 Channel 12 | Not valid - force EOC to CTU | | Input command | Output command | | | | |-------------------------------------------------|------------------------------|--|--|--| | Single sampling ADC_1 Channel 13 | Not valid - force EOC to CTU | | | | | Single sampling ADC_1 Channel 14 | Not valid - force EOC to CTU | | | | | Single sampling ADC_1 Channel 15 | Not valid - force EOC to CTU | | | | | Dual sampling ADC 0 channel x / ADC 1 channel y | Not valid - force EOC to CTU | | | | Table 473. ADC commands translation. #### 26.4.3 ADC results ADC results can be stored in the channel relevant standard result register and/or in one of the four FIFOs: the different FIFOs allow to dispatch ADC results according to their type of acquisition (for example phase currents, rotor position or ground-noise). Each FIFO has its own interrupt line and DMA request signal (plus an individual overflow error bit in the FIFO status register). The store location is specified in the ADC command, that is, the FIFOs are available only in CTU Control Mode. Each entry of a FIFO is 32-bits. The size of the FIFOs are the following: - FIFO1 and FIFO2—16 entries - FIFO3 and FIFO4—4 entries (low acquisition rate FIFOs) Results in each FIFO can be read by a 16-bit read transaction (only the result is read in order to minimize the CPU load before computing on results) or by a 32-bit read transaction (both the result and the channel number are read in order to avoid blind acquisitions), 5 bits in the upper 16 bits indicate the ADC unit (1 bit) and the channel number (4 bits). The result registers (only for the FIFOs) can be read from two different addresses in the ADC memory map. The format of the result depends on the address from which it is read. The available formats are: - Unsigned right-justified - Conversion result is unsigned right-justified data. Bits [9:0] are used for 10-bit resolution and bits [15:10] always return zero when read. - Signed left-justified Conversion result is signed left-justified data. Bit [15] is reserved for sign and is always read as zero for this ADC, bits [14:5] are used for 10-bit resolution, and bits [4:0] always return zero when read. ### 26.5 Reload mechanism Some CTU registers are double-buffered, and the reload is controlled by a reload enable bit, as the TGSISR\_RE bit or the DFE bit, but for the most of the double-buffered registers, the reload is controlled by the MRS occurrence, and it is synchronized with the beginning of the CTU control period. If the MRS occurs while the user is updating some double-buffered the new triggers list will be a mix of the old triggers list and the new triggers list, because the user has not ended the update of the triggers list before the MRS occurrence. In order to avoid this case, one bit enables the reload operation, that is, to inform the CTU that the user has ended updates to the double-buffered registers, and the reload can be performed without problems of mixed scenarios. In order to guarantee the coherency, the reload of all double-buffered registers is enabled by setting GRE (General Reload Enable) bit in the CTU Control Register. The user must ensure that all intended double-buffered registers are updated before a new MRS occurrence. If an MRS occurs before a GRE bit is set (for example, wrong application timing), the update is not performed, the previous values of all double-buffered registers remain active, the error flag is set (the MRS\_RE bit in the CTU Error Flag Register) and, if enabled, CTU performs an interrupt request. All the double-buffered registers use the General Reload Enable (GRE) bit to enable the reload when the MRS occurs. The GRE bit is R/S (Read/Set) and if this bit is 1, the reload can be performed, while if this bit is 0, the reload is not performed. A correct reload resets the GRE bit. None of the double-buffered registers can be written while the GRE bit remains set. The GRE bit can be reset by the occurrence of the next MRS (that is, a correct reload) or by software setting the CGRE bit. The CGRE is reset by hardware after that GRE bit is reset. If the user sets the CGRE bit and at the same time a MRS occurs, CGRE has the priority so GRE is reset and the reload is not performed. In the same way, the GRE has the priority when compared with the MRS occurrence, and the CGRE has the priority compared with the GRE (the two bits are in the same register so they can be set in the same time). MRS has the priority compared with the re-synchronization bit of the TGSISR. In order to verify if a reload error occurs, FGRE (Flag GRE bit in the CTU Control Register) bit is used. When one of the double-buffered registers is written, this flag is set to 1 and it is reset by a correct reload. When the MRS occurs while FGRE is 1 and GRE is 1, a correct reload is performed (because all intended registers have been updated before the MRS occurs). If FGRE is 1 and GRE is 0, a reload is not performed, the error flag (MRS\_RE) is set and (if enabled) an interrupt for an error is performed (in this case at least one register was written but the update has not ended before the MRS occurrence). If FGRE is 0 it is not necessary to perform a reload because all the double-buffered registers are unchanged (see *Figure 494*). Figure 494. Reload error scenario # 26.6 Power safety mode To reduce power consumption two mechanisms are implemented: - MDIS bit in the CTUPCR - STOP mode #### 26.6.1 MDIS bit The MDIS bit in the CTUPCR is used for stopping the clock to all non memory mapped registers. #### 26.6.2 STOP mode To reduce consumption, it is also possible to enable a stop request from the Mode Entry module. The FIFOs are considered a lot like memory mapped registers, otherwise there could be some problems if a read operation occurs during the MDIS bit set period. When the clock is started after an MDIS bit setting or a stop signal, some mistakes could occur. For example, a wrong trigger could be provided because it was programmed before the stop signal was performed, and some incorrect write operations into the FIFOs could happen. For this reason after a stop signal after a MDIS bit setting the FIFO have to be empty. In order to avoid the problems linked to a wrong trigger, the CTU output can be disabled by the CTU\_ODIS bit and the ADC interface state machine can be reset by the CRU\_ADC\_R (see Section 26.8.21: Cross triggering unit control register (CTUCR)). # 26.7 Interrupts and DMA requests #### 26.7.1 DMA support The DMA can be used to configure the CTU registers. One DMA channel is reserved for performing a block transfer, and the MRS can be used as an optional DMA request signal (MRS\_DMAE bit in the CTU Interrupt/DMA Register). Note: If enabled, the DMA request on the MRS occurrence is performed only if a reload is performed, that is, only if the GRE bit is set. Moreover, this CTU implementation requires DMA support for reading the data from the FIFOs. One DMA channel is available for each FIFO. Each FIFO can perform a DMA request when the number of words stored in the FIFO reaches the threshold value. #### 26.7.2 CTU faults and errors Faults and errors that could occur during the programming include: - An MRS occurs while user is updating the double-buffered registers and the MRS\_RE bit is set. - Receiving more than eight EVs before that the next MRS occurs in TGS sequential mode and the SM\_TO bit is set. - A trigger event occurs during the time when the actions of the previous trigger event are not completed (user ensures no trigger event occurs during another one is processed, but if user makes a mistake and a trigger event occurs when another one is processed, the incoming trigger event will be lost and an error occurs). There are four overrun flags (one for each type of output). The general mechanism shall be as in *Figure 493*. The Trigger Handler, when a trigger event occurs, and the corresponding Ready signal is high, presents the respective trigger signal (one cycle high time + one cycle low time) to the respective generator sub-block (ADC Command Generator, eT0 Trigger Generator, eT1 Trigger Generator or Ext. Trigger Generator). This generator sub-block 577 then generates the requested signal. Until this real signal is generated (including guard time) the Ready signal is kept low. In the case of ADC command generator, the Ready signal shall be kept low until the last conversion in the batch is finished. The respective overrun flag is set at the following conditions: - Ready signal is low. - The rising edge of the respective trigger signal (from Trigger Handler to generator sub-block) occurs. This architecture allows the user to pre-set a trigger to the eTimer0 in the middle of an ADC conversion, that is, the SU will be considered busy only if a request to perform the same action that the SU is already performing occurs. One of the following bits is set: ADC\_OE, T0\_OE, T1\_OE, or ET\_OE. - Invalid (unrecognized) ADC command and the ICE bit is set. - The MRS occurs before the enabled trigger events occur and the MRS\_O bit is set. - TGS overrun in sequential mode: a new incoming EV occurs before than the trigger event selected by the previous EV occurs. The incoming EV sets an internal busy flag. The outgoing trigger event (all line are ORed) resets this flag to 0. TGS Overrun in the sequential mode shall be generated under the following conditions: - TGS is in sequential mode - there is an incoming EV while the busy flag is high, the TGS OSM bit is set. The faults/errors flags in the CTU error flag register and in the CTU interrupt flag register can be cleared by writing a 1 while writing a 0 has no effect. The CTU does not support a write-protection mechanism. # 26.7.3 CTU interrupt/DMA requests The CTU can perform the following interrupt/DMA requests (15 interrupt lines): - Error interrupt request (see Section 26.7.2: CTU faults and errors) (1 interrupt line) - ADC command interrupt request (1 interrupt line) - Interrupt request on MRS occurrence (1 interrupt line) - Interrupt request on each trigger event occurrence (1 interrupt line for each trigger event) - FIFOs interrupt requests and/or DMA transfer request (1 interrupt line for each FIFO) - DMA transfer request on the MRS occurrence if GRE bit is set The interrupt flags are shown in Table 474. Table 474. CTU interrupts | Category | Interrupt Interrupt function | | |-------------------------------|------------------------------|---------------------------------------------------------------------------------------------| | | MRS_I | MRS Interrupt flag (IRQ193) | | | T0_I | Trigger 0 interrupt flag (IRQ194) | | | T1_I | Trigger 1 interrupt flag (IRQ195) | | | T2_I | Trigger 2 interrupt flag (IRQ196) | | Managed | T3_I | Trigger 3 interrupt flag (IRQ197) | | individually | T4_I | Trigger 4 interrupt flag (IRQ198) | | | T5_I | Trigger 5 interrupt flag (IRQ199) | | | T6_I | Trigger 6 interrupt flag (IRQ200) | | | T7_I | Trigger 7 interrupt flag (IRQ201) | | | ADC_I | ADC command interrupt flag (IRQ206) | | | FIFO_FULL0 | This bit is set to 1 if the FIFO 0 is full. | | | FIFO_EMPTY0 | This bit is set to 1 if the FIFO 0 is empty. | | ORed onto FIFO0_I<br>(IRQ202) | FIFO_OVERFLOW0 | This bit is set to 1 if the number of words exceeds the value set in the threshold 0. | | | FIFO_OVERRUN0 | This bit is set to 1 if a write operation occurs when corresponding FIFO_FULL0 flag is set. | | | FIFO_FULL1 | This bit is set to 1 if the FIFO 1 is full. | | | FIFO_EMPTY1 | This bit is set to 1 if the FIFO 1 is empty. | | ORed onto FIFO1_I<br>(IRQ203) | FIFO_OVERFLOW1 | This bit is set to 1 if the number of words exceeds the value set in the threshold 1. | | | FIFO_OVERRUN1 | This bit is set to 1 if a write operation occurs when corresponding FIFO_FULL1 flag is set. | | | FIFO_FULL2 | This bit is set to 1 if the FIFO 2 is full. | | | FIFO_EMPTY2 | This bit is set to 1 if the FIFO 2 is empty. | | ORed onto FIFO2_I<br>(IRQ204) | FIFO_OVERFLOW2 | This bit is set to 1 if the number of words exceeds the value set in the threshold 2. | | | FIFO_OVERRUN2 | This bit is set to 1 if a write operation occurs when corresponding FIFO_FULL2 flag is set. | | | FIFO_FULL3 | This bit is set to 1 if the FIFO 3 is full. | | | FIFO_EMPTY3 | This bit is set to 1 if the FIFO 3 is empty. | | ORed onto FIFO3_I<br>(IRQ205) | FIFO_OVERFLOW3 | This bit is set to 1 if the number of words exceeds the value set in the threshold 3. | | | FIFO_OVERRUN3 | This bit is set to 1 if a write operation occurs when corresponding FIFO_FULL3 flag is set. | Table 474. CTU interrupts(Continued) | Category | Interrupt | Interrupt function | |-----------------------------|-----------|---------------------------------------------------------| | | MRS_RE | Master Reload Signal Reload Error | | | SM_TO | Trigger Overrun (more than 8 EV) in TGS Sequential Mode | | | ICE | Invalid Command Error | | | MRS_O | Master Reload Signal Overrun | | ORed onto ERR_I<br>(IRQ207) | TGS_OSM | TGS Overrun in Sequential Mode | | ( , , , , | ADC_OE | ADC command generation Overrun Error | | | T0_OE | Timer 0 trigger generation Overrun Error | | | T1_OE | Timer 1 trigger generation Overrun Error | | | ET_OE | External Trigger generation Overrun Error | # 26.8 Memory map Table 475. CTU memory map | Offset from<br>CTU_BASE<br>(0xFFE0_C000) | Register | Location | |------------------------------------------|-------------------------------------------------------------|-------------| | 0x0000 | TGSISR — Trigger Generator Subunit Input Selection Register | on page 851 | | 0x0004 | TGSCRR — Trigger Generator Subunit Control Register | on page 853 | | 0x0006 | T0CR — Trigger 0 Compare Register | on page 854 | | 0x0008 | T1CR — Trigger 1 Compare Register | on page 854 | | 0x000A | T2CR — Trigger 2 Compare Register | on page 854 | | 0x000C | T3CR — Trigger 3 Compare Register | on page 854 | | 0x000E | T4CR — Trigger 4 Compare Register | on page 854 | | 0x0010 | T5CR — Trigger 5 Compare Register | on page 854 | | 0x0012 | T6CR — Trigger 6 Compare Register | on page 854 | | 0x0014 | T7CR — Trigger 7 Compare Register | on page 854 | | 0x0016 | TGSCCR — TGS Counter Compare Register | on page 854 | | 0x0018 | TGSCRR — TGS Counter Reload Register | on page 855 | | 0x001A | Reserved | | | 0x001C | CLCR1 — Commands List Control Register 1 | on page 855 | | 0x0020 | CLCR2 — Commands List Control Register 2 | on page 856 | | 0x0024 | THCR1 — Trigger Handler Control Register 1 | on page 856 | | 0x0028 | THCR2 — Trigger Handler Control Register 2 | on page 858 | | 0x002C | CLR1—Commands List Register 1 | on page 860 | | 0x002E | CLR2—Commands List Register 2 | on page 860 | Table 475. CTU memory map(Continued) | Offset from<br>CTU_BASE<br>(0xFFE0_C000) | Register | Location | | |------------------------------------------|------------------------------------------|-------------|--| | 0x0030 | CLR3—Commands List Register 3 | on page 860 | | | 0x0032 | CLR4—Commands List Register 4 | on page 860 | | | 0x0034 | CLR5—Commands List Register 5 | on page 860 | | | 0x0036 | CLR6—Commands List Register 6 | on page 860 | | | 0x0038 | CLR7—Commands List Register 7 | on page 860 | | | 0x003A | CLR8—Commands List Register 8 | on page 860 | | | 0x003C | CLR9—Commands List Register 9 | on page 860 | | | 0x003E | CLR10—Commands List Register 10 | on page 860 | | | 0x0040 | CLR11—Commands List Register 11 | on page 860 | | | 0x0042 | CLR12—Commands List Register 12 | on page 860 | | | 0x0044 | CLR13—Commands List Register 13 | on page 860 | | | 0x0046 | CLR14—Commands List Register 14 | on page 860 | | | 0x0048 | CLR15—Commands List Register 15 | on page 860 | | | 0x004A | CLR16—Commands List Register 16 | on page 860 | | | 0x004C | CLR17—Commands List Register 17 | on page 860 | | | 0x004E | CLR18—Commands List Register 18 | on page 860 | | | 0x0050 | CLR19—Commands List Register 19 | on page 860 | | | 0x0052 | CLR20—Commands List Register 20 | on page 860 | | | 0x0054 | CLR21—Commands List Register 21 | on page 860 | | | 0x0056 | CLR22—Commands List Register 22 | on page 860 | | | 0x0058 | CLR23—Commands List Register 23 | on page 860 | | | 0x005A | CLR24—Commands List Register 24 | on page 860 | | | 0x005C—0x006B | Reserved | | | | 0x006C | FDCR — FIFO DMA Control Register | on page 861 | | | 0x0070 | FCR — FIFO Control Register | on page 862 | | | 0x0074 | FTH — FIFO Threshold Register | on page 864 | | | 0x0078-0x007B | Reserved | · | | | 0x007C | FST — FIFO Status Register | on page 864 | | | 0x0080 | FR0 — FIFO Right aligned data register 0 | on page 866 | | | 0x0084 | FR1 — FIFO Right aligned data register 1 | on page 866 | | | 0x0088 | FR2 — FIFO Right aligned data register 2 | on page 866 | | | 0x008C | FR3 — FIFO Right aligned data register 3 | on page 866 | | | 0x0090-0x009F | Reserved | | | Table 475. CTU memory map(Continued) | Offset from<br>CTU_BASE<br>(0xFFE0_C000) | Register | Location | | |------------------------------------------|--------------------------------------------------------|-------------|--| | 0x00A0 | FL0 — FIFO Left aligned data register 0 | on page 867 | | | 0x00A4 | FL1 — FIFO Left aligned data register 1 | on page 867 | | | 0x00A8 | FL2 — FIFO Left aligned data register 2 | on page 867 | | | 0x00AC | FL3 — FIFO Left aligned data register 3 | on page 867 | | | 0x00B0-0x00BF | Reserved | | | | 0x00C0 | CTUEFR — Cross Triggering Unit Error Flag Register | on page 867 | | | 0x00C2 | CTUIFR — Cross Triggering Unit Interrupt Flag Register | on page 868 | | | 0x00C4 | CTUIR — Cross Triggering Unit Interrupt Register | on page 869 | | | 0x00C6 | COTR — Control ON-Time Register | on page 870 | | | 0x00C8 | CTUCR — Cross triggering unit control register | on page 871 | | | 0x00CA | CTUDF — Cross Triggering Unit Digital Filter register | on page 872 | | | 0x00CC | CTUPCR — Cross Triggering Unit Power Control Register | on page 872 | | | 0x00CE-0x3FFF | Reserved | | | Table 476. TGS registers | Offset from CTU_BASE | Register | Double-<br>buffered | Synchronization | Reset value | |----------------------|-------------------------------------------------------------|---------------------|-----------------|-------------| | 0x0000 | TGSISR — Trigger Generator Subunit Input Selection Register | Yes | TGSISR_RE | 0x0000_0000 | | 0x0004 | TGSCRR — Trigger Generator Subunit Control Register | Yes | MRS | 0x0000 | | 0x0006 | T0CR — Trigger 0 Compare Register | Yes | MRS | 0x0000 | | 0x0008 | T1CR — Trigger 1 Compare Register | Yes | MRS | 0x0000 | | 0x000A | T2CR — Trigger 2 Compare Register | Yes | MRS | 0x0000 | | 0x000C | T3CR — Trigger 3 Compare Register | Yes | MRS | 0x0000 | | 0x000E | T4CR — Trigger 4 Compare Register | Yes | MRS | 0x0000 | | 0x0010 | T5CR — Trigger 5 Compare Register | Yes | MRS | 0x0000 | | 0x0012 | T6CR — Trigger 6 Compare Register | Yes | MRS | 0x0000 | | 0x0014 | T7CR — Trigger 7 Compare Register | Yes | MRS | 0x0000 | | 0x0016 | TGSCCR — TGS Counter Compare Register | Yes | MRS | 0x0000 | | 0x0018 | TGSCRR — TGS Counter Reload Register | Yes | MRS | 0x0000 | # Table 477. SU registers | Offset from | Register | Double-<br>buffered | Synchronization | Reset value | |--------------------|---------------------------------------------|---------------------|-----------------|-------------| | 0x001C | CLCR1 — Commands List Control Register 1 | Yes | MRS | 0x0000_0000 | | 0x0020 | CLCR2 — Commands List Control Register 2 | Yes | MRS | 0x0000_0000 | | 0x0024 | THCR1 — Trigger Handler Control Register 1 | Yes | MRS | 0x0000_0000 | | 0x0028 | THCR2 — Trigger Handler Control Register 2 | Yes | MRS | 0x0000_0000 | | 0x002C -<br>0x005A | CLRx — Commands List Register x (x = 1,,24) | Yes | MRS | 0x0000 | # Table 478. CTU registers | Offset from CTU_BASE | Register | Double-<br>buffered | Synchronization | Reset<br>value | |----------------------|-----------------------------------------------------------|---------------------|-----------------|----------------| | 0x00C0 | CTUEFR — Cross Triggering Unit Error Flag<br>Register | No | _ | 0x0000 | | 0x00C2 | CTUIFR — Cross Triggering Unit Interrupt Flag<br>Register | No | _ | 0x0000 | | 0x00C4 | CTUIR — Cross Triggering Unit Interrupt Register | No | _ | 0x0000 | | 0x00C6 | COTR — Control ON-Time Register | Yes | MRS | 0x0000 | | 0x00C8 | CTUCR — Cross triggering unit control register | No | _ | 0x0000 | | 0x00CA | CTUDF — Cross Triggering Unit Digital Filter | Yes | DFE | 0x0000 | | 0x00CC | CTUPCR — Cross Triggering Unit Power Control Register | No | _ | 0x0000 | ### Table 479. FIFO registers | Offset from CTU_BASE | Register | Double-<br>buffered | Synchronization | Reset value | |----------------------|----------------------------------|---------------------|-----------------|-------------| | 0x006C | FDCR — FIFO DMA Control Register | No | _ | 0x0000 | | 0x0070 | FCR — FIFO Control Register | No | _ | 0x0000_0000 | | 0x0074 | FTH — FIFO Threshold Register | No | _ | 0x0000_0000 | | 0x007C | FST — FIFO Status Register | No | _ | 0x0000_0000 | | 0x0080 | FR0 — FIFO Right aligned data 0 | No | _ | 0x0000_0000 | | 0x0084 | FR1 — FIFO Right aligned data 1 | No | _ | 0x0000_0000 | | 0x0088 | FR2 — FIFO Right aligned data 2 | No | _ | 0x0000_0000 | | 0x008C | FR3 — FIFO Right aligned data 3 | No | _ | 0x0000_0000 | | 0x00A0 | FL0 — FIFO Left aligned data 0 | No | _ | 0x0000_0000 | | 0x00A4 | FL1 — FIFO Left aligned data 1 | No | _ | 0x0000_0000 | | 0x00A8 | FL2 — FIFO Left aligned data 2 | No | _ | 0x0000_0000 | | 0x00AC | FL3 — FIFO Left aligned data 3 | No | _ | 0x0000_0000 | # 26.8.1 Trigger Generator Sub-unit Input Selection Register (TGSISR) Figure 495. Trigger Generator Sub-unit Input Selection Register (TGSISR) Table 480. TGSISR field descriptions | Field | Description | |--------|----------------------------------------------------------------------| | I15_FE | Input 15 — ext_signals Falling edge Enable 0 Disabled 1 Enabled | | I15_RE | Input 15 — ext_signals Rising edge Enable 0 Disabled 1 Enabled | | I14_FE | Input 14 — eTimer1 [ETC2] Falling edge Enable 0 Disabled 1 Enabled | | I14_RE | Input 14 — eTimer1 [ETC2] Rising edge Enable 0 Disabled 1 Enabled | | I13_FE | Input 13 — eTimer0 [ETC2] Falling edge Enable 0 Disabled 1 Enabled | | I13_RE | Input 13 — eTimer0 [ETC2] Rising edge Enable 0 Disabled 1 Enabled | | I12_FE | Input 12 —PWM X[3] Falling edge Enable 0 Disabled 1 Enabled | | I12_RE | Input 12 — PWM X[3] Rising edge Enable 0Disabled 1 Enabled | | I11_FE | Input 11 — PWM X[2] Falling edge Enable 0 Disabled 1 Enabled | Table 480. TGSISR field descriptions(Continued) | Field | Description | |--------|-----------------------------------------------------------------------| | I11_RE | Input 11 — PWM X[2] Rising edge Enable 0 Disabled 1 Enabled | | I10_FE | Input 10 — PWM X[1] Falling edge Enable 0Disabled 1 Enabled | | I10_RE | Input 10 — PWM X[1] Rising edge Enable 0 Disabled 1 Enabled | | 19_FE | Input 9 — PWM X[0] Falling edge Enable 0Disabled 1 Enabled | | 19_RE | Input 9 — PWM X[0] Rising edge Enable 0 Disabled 1 Enabled | | I8_FE | Input 8 — PWM OUT_TRIG 1 [3] Falling edge Enable 0 Disabled 1 Enabled | | I8_RE | Input 8 — PWM OUT_TRIG 1 [3] Rising edge Enable 0 Disabled 1 Enabled | | I7_FE | Input 7 — PWM OUT_TRIG 1 [2] Falling edge Enable 0 Disabled 1 Enabled | | I7_RE | Input 7 — PWM OUT_TRIG 1 [2] Rising edge Enable 0 Disabled 1 Enabled | | I6_FE | Input 6 — PWM OUT_TRIG 1 [1] Falling edge Enable 0 Disabled 1 Enabled | | I6_RE | Input 6 — PWM OUT_TRIG 1 [1] Rising edge Enable 0 Disabled 1 Enabled | | I5_FE | Input 5 — PWM OUT_TRIG 1 [0] Falling edge Enable 0 Disabled 1 Enabled | | I5_RE | Input 5 — PWM OUT_TRIG 1 [0] Rising edge Enable 0 Disabled 1 Enabled | | I4_FE | Input 4 — PWM OUT_TRIG 0 [3] Falling edge Enable 0 Disabled 1 Enabled | Table 480. TGSISR field descriptions(Continued) | Field | Description | |-------|------------------------------------------------------------------------| | I4_RE | Input 4 — PWM OUT_TRIG 0 [3] Rising edge Enable 0 Disabled 1 Enabled | | I3_FE | Input 3 — PWM OUT_TRIG 0 [2] Falling edge Enable 0 Disabled 1 Enabled | | I3_RE | Input 3 — PWM OUT_TRIG 0 [2] Rising edge Enable 0 Disabled 1 Enabled | | I2_FE | Input 2 — PWM OUT_TRIG 0 [1] Falling edge Enable 0 Disabled 1 Enabled | | I2_RE | Input 2 — PWM OUT_TRIG 0 [1] Rising edge Enable 0 Disabled 1 Enabled h | | I1_FE | Input 1 — PWM OUT_TRIG 0 [0] Falling edge Enable 0 Disabled 1 Enabled | | I1_RE | Input 1 — PWM OUT_TRIG 0 [0] Rising edge Enable 0 Disabled 1 Enabled | | I0_FE | Input 0 — PWM Reload Falling edge Enable 0 Disabled 1 Enabled | | I0_RE | Input 0 — PWM Reload Rising edge Enable 0 Disabled 1 Enabled | # 26.8.2 Trigger Generator Sub-unit Control Register (TGSCR) Figure 496. Trigger Generator Sub-unit Control Register (TGSCR) Table 481. TGSCR field descriptions | Field | Description | |--------|--------------------------------------------------------------------------------| | ET_TM | This bit enables toggle mode for external triggers. | | PRES | TGS and SU prescaler selection bits 00 1 01 2 10 3 11 4 | | MRS_SM | Master Reload Selection in Sequential Mode (5 bits to select one of 32 inputs) | | TGS_M | Trigger Generator Subunit Mode 0 Triggered Mode 1 Sequential Mode | # 26.8.3 Trigger x Compare Register (TxCR, x = 0...7) Figure 497. Trigger x Compare Register (TxCR, x = 0...7) Table 482. TxCR field descriptions | Field | Description | |-------|----------------------------------| | TxCRV | Trigger x Compare Register Value | # 26.8.4 TGS Counter Compare Register (TGSCCR) Figure 498. TGS Counter Compare Register (TGSCCR) #### Table 483, TGSCCR field format | Field | Description | |--------|---------------------------| | TGSCCV | TGS Counter Compare Value | # 26.8.5 TGS Counter Reload Register (TGSCRR) Figure 499. TGS Counter Reload Register (TGSCRR) ### Table 484. TGSCRR field descriptions | Field | Description | |--------|--------------------------| | TGSCRV | TGS Counter Reload Value | # 26.8.6 Commands list control register 1 (CLCR1) Figure 500. Commands list control register 1 (CLCR1) Table 485. CLCR1 field descriptions | Field | Description | |----------|-----------------------------------------------| | T3_INDEX | Trigger 3 Commands List first command address | | T2_INDEX | Trigger 2 Commands List first command address | | T1_INDEX | Trigger 1 Commands List first command address | | T0_INDEX | Trigger 0 Commands List first command address | # 26.8.7 Commands list control register 2 (CLCR2) Figure 501. Commands list control register 2 (CLCR2) #### Table 486. CLCR2 field descriptions | Field | Description | |----------|-----------------------------------------------| | T7_INDEX | Trigger 7 Commands List first command address | | T6_INDEX | Trigger 6 Commands List first command address | | T5_INDEX | Trigger 5 Commands List first command address | | T4_INDEX | Trigger 4 Commands List first command address | # 26.8.8 Trigger handler control register 1 (THCR1) Figure 502. Trigger handler control register 1 (THCR1) Table 487. THCR1 field descriptions | Field | Description | |---------|---------------------------------------------------------------| | T3_E | Trigger 3 enable 0 Disabled 1 Enabled | | T3_ETE | Trigger 3 External Trigger output enable 0 Disabled 1 Enabled | | T3_T1E | Trigger 3 Timer 1 output enable 0 Disabled 1 Enabled | | T3_T0E | Trigger 3 Timer 0 output enable 0 Disabled 1 Enabled | | T3_ADCE | Trigger 3 ADC command output enable 0 Disabled 1 Enabled | | T2_E | Trigger 2 enable 0 Disabled 1 Enabled | | T2_ETE | Trigger 2 External Trigger output enable 0 Disabled 1 Enabled | | T2_T1E | Trigger 2 Timer 1 output enable 0 Disabled 1 Enabled | | T2_T0E | Trigger 2 Timer 0 output enable 0 Disabled 1 Enabled | | T2_ADCE | Trigger 2 ADC command output enable 0 Disabled 1 Enabled | | T1_E | Trigger 1 enable 0 Disabled 1 Enabled | | T1_ETE | Trigger 1 External Trigger output enable 0 Disabled 1 Enabled | | T1_T1E | Trigger 1 Timer 1 output enable 0 Disabled 1 Enabled | | T1_T0E | Trigger 1 Timer 0 output enable 0 Disabled 1 Enabled | Table 487. THCR1 field descriptions(Continued) | Field | Description | |---------|---------------------------------------------------------------| | T1_ADCE | Trigger 1 ADC command output enable 0 Disabled 1 Enabled | | T0_E | Trigger 0 enable 0 Disabled 1 Enabled | | T0_ETE | Trigger 0 External Trigger output enable 0 Disabled 1 Enabled | | T0_T1E | Trigger 0 Timer 1 output enable 0 Disabled 1 Enabled | | T0_T0E | Trigger 0 Timer 0 output enable 0 Disabled 1 Enabled | | T0_ADCE | Trigger 0 ADC command output enable 0 Disabled 1 Enabled | # 26.8.9 Trigger handler control register 2 (THCR2) Figure 503. Trigger handler control register 2 (THCR2) Table 488. THCR2 field descriptions | Field | Description | |--------|---------------------------------------------------------------| | T7_E | Trigger 7 enable 0 Disabled 1 Enabled | | T7_ETE | Trigger 7 External Trigger output enable 0 Disabled 1 Enabled | Table 488. THCR2 field descriptions(Continued) | Field | Description | |---------|---------------------------------------------------------------| | T7_T1E | Trigger 7 Timer 1 output enable 0 Disabled 1 Enabled | | T7_T0E | Trigger 7 Timer 0 output enable 0 Disabled 1 Enabled | | T7_ADCE | Trigger 7 ADC command output enable 0 Disabled 1 Enabled | | T6_E | Trigger 6 enable 0 Disabled 1 Enabled | | T6_ETE | Trigger 6 External Trigger output enable 0 Disabled 1 Enabled | | T6_T1E | Trigger 6 Timer 1 output enable 0 Disabled 1 Enabled | | T6_T0E | Trigger 6 Timer 0 output enable 0 Disabled 1 Enabled | | T6_ADCE | Trigger 6 ADC command output enable 0 Disabled 1 Enabled | | T5_E | Trigger 5 enable 0 Disabled 1 Enabled | | T5_ETE | Trigger 5 External Trigger output enable 0 Disabled 1 Enabled | | T5_T1E | Trigger 5 Timer 1 output enable 0 Disabled 1 Enabled | | T5_T0E | Trigger 5 Timer 0 output enable 0 Disabled 1 Enabled | | T5_ADCE | Trigger 5 ADC command output enable 0 Disabled 1 Enabled | | T4_E | Trigger 4 enable 0 Disabled 1 Enabled | Table 488. THCR2 field descriptions(Continued) | Field | Description | |---------|---------------------------------------------------------------| | T4_ETE | Trigger 4 External Trigger output enable 0 Disabled 1 Enabled | | T4_T1E | Trigger 4 Timer 1 output enable 0 Disabled 1 Enabled | | T4_T0E | Trigger 4 Timer 0 output enable 0 Disabled 1 Enabled | | T4_ADCE | Trigger 4 ADC command output enable 0 Disabled 1 Enabled | # 26.8.10 Commands list register x (x = 1,...,24) (CLRx) Figure 504 and Table 489 show the register configured for ADC command format in single conversion mode (CMS = 0) (CLRx). Figure 504. Commands list register x (x = 1,...,24) (CMS = 0) Table 489. CLRx (CMS = 0) field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------| | CIR | Command Interrupt Request bit 0 Disabled 1 Enabled | | FC | First command bit 0 Not first command 1 First command | | CMS | Conversion mode selection bit 0 Single conversion mode 1 Dual conversion mode | | FIFO | FIFO for ADC unit 0/1 00 FIFO 0 selected 01 FIFO 1 selected 10 FIFO 2 selected 11 FIFO 3 selected | Table 489. CLRx (CMS = 0) field descriptions(Continued) | Field | Description | |-------|----------------------------------------------------------------| | SU | Selection Unit bit 0 ADC unit 0 selected 1 ADC unit 1 selected | | СН | ADC unit channel number | *Figure 504* and *Table 490* show the register configured for ADC command format in dual conversion mode (CMS = 1). Table 490. CLRx (CMS = 1) field descriptions | Field | Description | |-------|---------------------------------------------------------------------------| | CIR | Command Interrupt Request bit 0 Disabled 1 Enabled | | FC | First command bit 0 Not first command 1 First command | | CMS | Conversion mode selection 0 Single conversion mode 1 Dual conversion mode | | FIFO | FIFO for ADC unit A/B | | CH_B | ADC unit B channel number | | CH_A | ADC unit A channel number | # 26.8.11 FIFO DMA control register (FDCR) Figure 506. FIFO DMA control register (FDCR) Table 491. FDCR field descriptions | Name | Description | |------|-----------------------------------------------------------| | DEx | This bit enables DMA for the FIFOx 0 Disabled 1 Enabled | # 26.8.12 FIFO control register (FCR) Figure 507. FIFO control register (FCR) Table 492. FCR field descriptions | Field | Description | |-----------|-----------------------------------------------------------------| | OR_EN3 | FIFO 3 Overrun interrupt enable 0 Disabled 1 Enabled | | OF_EN3 | FIFO 3 threshold Overflow interrupt enable 0 Disabled 1 Enabled | | EMPTY_EN3 | FIFO 3 Empty interrupt enable 0 Disabled 1 Enabled | | FULL_EN3 | FIFO 3 Full interrupt enable 0 Disabled 1 Enabled | | OR_EN2 | FIFO 2 Overrun interrupt enable 0 Disabled 1 Enabled | | OF_EN2 | FIFO 2 threshold Overflow interrupt enable 0 Disabled 1 Enabled | Table 492. FCR field descriptions(Continued) | Field | Description | |-----------|-----------------------------------------------------------------| | EMPTY_EN2 | FIFO 2 Empty interrupt enable 0 Disabled 1 Enabled | | FULL_EN2 | FIFO 2 Full interrupt enable 0 Disabled 1 Enabled | | OR_EN1 | FIFO 1 Overrun interrupt enable 0 Disabled 1 Enabled | | OF_EN1 | FIFO 1 threshold Overflow interrupt enable 0 Disabled 1 Enabled | | EMPTY_EN1 | FIFO 1 Empty interrupt enable 0 Disabled 1 Enabled | | FULL_EN1 | FIFO 1 Full interrupt enable 0 Disabled 1 Enabled | | OR_EN0 | FIFO 0 Overrun interrupt enable 0 Disabled 1 Enabled | | OF_EN0 | FIFO 0 threshold Overflow interrupt enable 0 Disabled 1 Enabled | | EMPTY_EN0 | FIFO 0 Empty interrupt enable 0 Disabled 1 Enabled | | FULL_EN0 | FIFO 0 Full interrupt enable 0 Disabled 1 Enabled | # 26.8.13 FIFO threshold register (FTH) Figure 508. FIFO threshold register (FTH) Table 493. FTH field descriptions | Field | Description | |-------|------------------| | TH3 | FIFO 3 Threshold | | TH2 | FIFO 2 Threshold | | TH1 | FIFO 1 Threshold | | TH0 | FIFO 0 Threshold | # 26.8.14 FIFO status register (FST) Figure 509. FIFO status register (FST) Table 494. FST field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------| | OR3 | FIFO 3 Overrun interrupt flag A read of this bit clears it. 0 Interrupt has not occurred. 1 Interrupt has occurred. | | OF3 | FIFO 3 threshold Overflow interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | EMP3 | FIFO 3 Empty interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | FULL3 | FIFO 3 Full interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | OR2 | FIFO 2 Overrun interrupt flag A read of this bit clears it. 0 Interrupt has not occurred. 1 Interrupt has occurred. | | OF2 | FIFO 2 threshold Overflow interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | EMP2 | FIFO 2 Empty interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | FULL2 | FIFO 2 Full interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | OR1 | FIFO 1 Overrun interrupt flag A read of this bit clears it. OInterrupt has not occurred. 1 Interrupt has occurred. | | OF1 | FIFO 1 threshold Overflow interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | EMP1 | FIFO 1 Empty interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | FULL1 | FIFO 1 Full interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | OR0 | FIFO 0 Overrun interrupt flag A read of this bit clears it. 0 Interrupt has not occurred. 1 Interrupt has occurred. | Table 494. FST field descriptions(Continued) | Field | Description | |-------|--------------------------------------------------------------------------------------------------| | OF0 | FIFO 0 threshold Overflow interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | EMP0 | FIFO 0 Empty interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | FULL0 | FIFO 0 Full interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | # 26.8.15 FIFO Right aligned data x (x = 0,...,3) (FRx) Figure 510. FIFO Right aligned data x (x = 0,...,3) (FRx) Table 495. FRx field descriptions | Field | Description | |-----------|--------------------------------------------------------------------------------------------------------------| | N_CH[4:0] | Number of stored channel 0xxxx: Result comes from an ADC_1 channel 1xxxx: Result comes from an ADC_0 channel | | DATA | Data of stored channel | # 26.8.16 FIFO signed Left aligned data x (x = 0,...,3) (FLx) Figure 511. FIFO signed Left aligned data x (x = 0,...,3) (FLx) Table 496. FLx field descriptions | Field | Description | |-----------|--------------------------------------------------------------------------------------------------------------| | N_CH[4:0] | Number of stored channel 0xxxx: Result comes from an ADC_1 channel 1xxxx: Result comes from an ADC_0 channel | | DATA | Data of stored channel | # 26.8.17 Cross triggering unit error flag register (CTUEFR) Figure 512. Cross triggering unit error flag register (CTUEFR) Table 497. CTUEFR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------| | ET_OE | External Trigger generation Overrun Error 0 Error has not occurred. 1 Error has occurred. | | T1_OE | Timer 1 trigger generation Overrun Error 0 Error has not occurred. 1 Error has occurred. | | T0_OE | Timer 0 trigger generation Overrun Error 0 Error has not occurred. 1 Error has occurred. | Table 497. CTUEFR field descriptions(Continued) | Field | Description | |---------|---------------------------------------------------------------------------------------------------------| | ADC_OE | ADC command generation Overrun Error 0 Error has not occurred. 1 Error has occurred. | | TGS_OSM | TGS Overrun in Sequential Mode 0 Error has not occurred. 1 Error has occurred. | | MRS_O | Master Reload Signal Overrun 0 Error has not occurred. 1 Error has occurred. | | ICE | Invalid Command Error 0 Error has not occurred. 1 Error has occurred. | | SM_TO | Trigger Overrun (more than 8 EV) in TGS Sequential Mode 0 Error has not occurred. 1 Error has occurred. | | MRS_RE | Master Reload Signal Reload Error 0 Error has not occurred. 1 Error has occurred. | # 26.8.18 Cross triggering unit interrupt flag register (CTUIFR) Figure 513. Cross triggering unit interrupt flag register (CTUIFR) Table 498. CTUIFR field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------| | ADC_I | ADC command interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T7_I | Trigger 7 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T6_I | Trigger 6 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T5_I | Trigger 5 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | Table 498. CTUIFR field descriptions(Continued) | Field | Description | |-------|------------------------------------------------------------------------------------| | T4_I | Trigger 4 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T3_I | Trigger 3 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T2_I | Trigger 2 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | T1_I | Trigger 1 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | Т0_I | Trigger 0 interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | | MRS_I | MRS Interrupt flag 0 Interrupt has not occurred. 1 Interrupt has occurred. | # 26.8.19 Cross triggering unit interrupt/DMA register (CTUIR) Figure 514. Cross triggering unit interrupt/DMA register (CTUIR) Table 499. CTUIR field descriptions | Field | Description | |-------|---------------------------------------------------------------------| | T7_IE | Trigger 7 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T6_IE | Trigger 6 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T5_IE | Trigger 5 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | Table 499. CTUIR field descriptions(Continued) | Field | Description | |----------|--------------------------------------------------------------------------------------------------| | T4_IE | Trigger 4 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T3_IE | Trigger 3 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T2_IE | Trigger 2 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T1_IE | Trigger 1 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | T0_IE | Trigger 0 Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | MRS_DMAE | DMA transfer Enable on MRS occurrence if GRE bit is set 0 Interrupt disabled 1 Interrupt enabled | | MRS_IE | MRS Interrupt Enable 0 Interrupt disabled 1 Interrupt enabled | | IEE | Interrupt Error Enable 0 Interrupt disabled 1 Interrupt enabled | # 26.8.20 Control ON time register (COTR) Figure 515. Control ON time register (COTR) #### Table 500. COTR field descriptions | Field | Description | |-------|-----------------------------------------------------| | COTR | Control ON-Time and Guard Time for external trigger | # 26.8.21 Cross triggering unit control register (CTUCR) Figure 516. Cross triggering unit control register (CTUCR) Table 501. CTUCR field descriptions | Field | Description | |-----------|-----------------------------------------------------------------------------------------------------| | T7_SG | Trigger 7 Software Generated 0 Trigger has not been generated. 1 Trigger has been generated. | | T6_SG | Trigger 6 Software Generated Trigger has not been generated. Trigger has been generated. | | T5_SG | Trigger 5 Software Generated Trigger has not been generated. Trigger has been generated. | | T4_SG | Trigger 4 Software Generated Trigger has not been generated. Trigger has been generated. | | T3_SG | Trigger 3 Software Generated Trigger has not been generated. Trigger has been generated. | | T2_SG | Trigger 2 Software Generated 0 Trigger has not been generated. 1 Trigger has been generated. | | T1_SG | Trigger 1 Software Generated Trigger has not been generated. Trigger has been generated. | | T0_SG | Trigger 0 Software Generated Trigger has not been generated. Trigger has been generated. | | CTU_ADC_R | CTU/ADC state machine Reset | | CTU_ODIS | CTU Output Disable | | DFE | Digital Filter Enable Note: This bit can be read by software and can only be set to 1 by software. | | CGRE | Clear GRE Note: This bit can only be set to 1 by software. | Table 501. CTUCR field descriptions(Continued) | Field | Description | | | |-----------|--------------------------------------------------------------------------------------------------------------------------|--|--| | FGRE | Flag GRE | | | | MRS_SG | MRS Software Generated | | | | GRE | General Reload Enable Note: This bit can be read by software and can only be set to 1 by software. | | | | TGSISR_RE | TGS Input Selection Register Reload Enable Note: This bit can be read by software and can only be set to 1 by software. | | | ### 26.8.22 Cross triggering unit digital filter (CTUDF) Figure 517. Cross triggering unit digital filter (CTUDF) Table 502. CTUDF field descriptions | Field | Description | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------| | 0-7 | Reserved | | 8-15<br>N | Digital Filter value (the external signal is considered at 1 if it is latched N time at 1 and is considered at 0 if it is latched N time at 0) | ### 26.8.23 Cross triggering unit power control register (CTUPCR) Figure 518. Cross triggering unit power control register (CTUPCR) Table 503. CTUPCR field descriptions | Field | Description | |------------|----------------| | 0-14 | Reserved | | 15<br>MDIS | Module Disable | # 27 Semaphore Unit (SEMA4) ### 27.1 Introduction SPC56xP60x/54x contains two SEMA4 units. In a dual-processor chip, semaphores are used to let each processor know who has control of common memory. Before a core can update or read memory coherently, it has to check the semaphore to see if the other core is not already updating the memory. If the semaphore is clear, it can write common memory, but if it is set, it has to wait for the other core to finish and clear the semaphore. The semaphore unit (SEMA4) provides the hardware support needed in multi-core systems for implementing semaphores and provide a simple mechanism to achieve lock/unlock operations via a single write access. This approach eliminates architecture-specific implementations like atomic (indivisible) read-modify-write instructions or reservation mechanisms. The result is an architecture-neutral solution that provides hardware-enforced gates as well as other useful system functions related to the gating mechanisms. In this chapter, the two instantiations of the e200z0h core on SPC56xP60x/54x are referred to as e200z0h\_0 and e200z0h\_1. (The e200z0h\_0 instantiation runs from reset in dual processor mode.) ### 27.1.1 Block diagram *Figure 519* is a simplified block diagram of the SEMA4 unit that illustrates the functionality and interdependence of major blocks. In the diagram, the register blocks named gate0, gate1, ..., gate 15 include the finite state machines implementing the semaphore gates plus the interrupt notification logic. aips\_master ips\_wdata master\_eq\_cp{0,1} wdata\_eq\_{unlock, cp[0-1]\_lock} ips\_addr decode gate1 gate2 control gate12 gate13 gate14 gate15 ips\_rdata cp0\_semaphore\_int cp1\_semaphore\_int 31 IPS Bus Figure 519. SEMA4 block diagram #### 27.1.2 Features The SEMA4 unit implements hardware-enforced semaphores as a peripheral device and has these major features: - Support for 16 hardware-enforced gates in a dual-processor configuration - Each hardware gate appears as a three-state, 2-bit state machine, with all 16 gates mapped as an array of bytes - Three-state implementation - if gate = 0b00, then state = unlocked - if gate = 0b01, then state = locked by e200z0h 0 (master ID = 0) - if gate = 0b10, then state = locked by e200z0h 1 (master ID = 1) - Uses the bus master ID number as a reference attribute plus the specified data patterns to validate all write operations - After it is locked, the gate must be unlocked by a write of zeroes from the locking processor - Optionally enabled interrupt notification after a failed lock write provides a mechanism to indicate the gate is unlocked - Secure reset mechanisms are supported to clear the contents of individual semaphore gates or notification logic, and clear all capability Note: Semaphore gates that are locked when entering sleep mode are cleared by the internal reset generated when exiting sleep mode. #### 27.1.3 Modes of operation The SEMA4 unit does not support any special modes of operation. # 27.2 Signal description The SEMA4 unit does not include any external signals. # 27.3 Memory map and register description The SEMA4 programming model map is shown in *Table 504*. The address of each register is given as an offset to the SEMA4 base address. Registers are listed in address order, identified by complete name and mnemonic, and list the type of accesses allowed. Table 504. SEMA4 memory map | Offset from<br>SEMA4_BASE<br>0xFFF2_4000 (SEMA4_0)<br>0x8FF2_4000 (SEMA4_1) | SEMA4_BASE<br>0xFFF2_4000 (SEMA4_0) | | |-----------------------------------------------------------------------------|-------------------------------------|-------------| | 0x0000 | SEMA4_Gate00—Semaphores gate 0 | on page 876 | | 0x0001 | SEMA4_Gate01—Semaphores gate 1 | on page 876 | | 0x0002 | SEMA4_Gate02—Semaphores gate 2 | on page 876 | | 0x0003 | SEMA4_Gate03—Semaphores gate 3 | on page 876 | Table 504. SEMA4 memory map(Continued) | Offset from<br>SEMA4_BASE<br>0xFFF2_4000 (SEMA4_0)<br>0x8FF2_4000 (SEMA4_1) | Register | Location | |-----------------------------------------------------------------------------|-----------------------------------------------------|-------------| | 0x0004 | SEMA4_Gate04—Semaphores gate 4 | on page 876 | | 0x0005 | SEMA4_Gate05—Semaphores gate 5 | on page 876 | | 0x0006 | SEMA4_Gate06—Semaphores gate 6 | on page 876 | | 0x0007 | SEMA4_Gate07—Semaphores gate 7 | on page 876 | | 0x0008 | SEMA4_Gate08—Semaphores gate 8 | on page 876 | | 0x0009 | SEMA4_Gate09—Semaphores gate 9 | on page 876 | | 0x000A | SEMA4_Gate10—Semaphores gate 10 | on page 876 | | 0x000B | SEMA4_Gate11—Semaphores gate 11 | on page 876 | | 0x000C | SEMA4_Gate12—Semaphores gate 12 | on page 876 | | 0x000D | SEMA4_Gate13—Semaphores gate 13 | on page 876 | | 0x000E | SEMA4_Gate14—Semaphores gate 14 | on page 876 | | 0x000F | SEMA4_Gate15—Semaphores gate 15 | on page 876 | | 0x0010-0x003F | Reserved | | | 00x040 | SEMA4_CP0INE—Semaphores CP0 IRQ notification enable | on page 877 | | 0x0042-0x0047 | Reserved | | | 0x0048 | SEMA4_CP1INE—Semaphores CP1 IRQ notification enable | on page 877 | | 0x004A-0x07F | Reserved | | | 0x0080 | SEMA4_CP0NTF—Semaphores CP0 IRQ notification | on page 878 | | 0x0082-00x087 | Reserved | | | 0x0088 | SEMA4_CP1NTF—Semaphores CP1 IRQ notification | on page 877 | | 0x008A-0x00FF | Reserved | | | 0x0100 | SEMA4_RSTGT—Semaphores reset gate | on page 878 | | 0x0102-0x0103 | Reserved | | | 0x0104 | SEMA4_RSTNTF—Semaphores reset IRQ notification | on page 880 | | 0x0106–0x3FFF | Reserved | | # 27.3.1 Semaphores gate *n* register (SEMA4\_GATE*n*) Each semaphore gate is implemented in a 2-bit finite state machine, right-justified in a byte data structure. The hardware uses the bus master number in conjunction with the data patterns to validate all attempted write operations. Only processor bus masters can modify the gate registers. After it is locked, a gate must be opened (unlocked) by the locking processor core. Multiple gate values can be read in a single access, but only a single gate at a time can be updated via a write operation. 16- and 32-bit writes to multiple gates are allowed, but the write data operand must update the state of a single gate only. A byte write data value of 0x03 is defined as no operation and does not affect the state of the corresponding gate register. Attempts to write multiple gates in a single-aligned access with a size larger than an 8-bit (byte) reference generate an error termination and do not allow any gate state changes. Figure 520. SEMA4 gate *n* register (SEMA4\_GATE*n*) Table 505. SEMA4\_GATEn field descriptions | Field | Description | | | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | GTFSM | Gate Finite State Machine. The hardware gate is maintained in a three-state implementation, defined as: 00 The gate is unlocked (free). 01 The gate has been locked by processor 0. 10 The gate has been locked by processor 1. 11 This state encoding is never used and therefore reserved. Attempted writes of 0x03 are treated as no operation and do not affect the gate state machine. Note: The state of the gate reflects the last processor that locked it, which can be useful during system debug. | | | | ### 27.3.2 Semaphores processor n IRQ notification enable (SEMA4\_CP $\{0,1\}$ INE) The application of a hardware semaphore module provides an opportunity for implementation of helpful system-level features. An example is an optional mechanism to generate a processor interrupt after a failed lock attempt. Traditional software gate functions execute a spin-wait loop in an effort to obtain and lock the referenced gate. With this module, the processor that fails in the lock attempt could continue with other tasks and allow a properly-enabled notification interrupt to return its execution to the original lock function. The optional notification interrupt function consists of two registers for each processor: an interrupt notification enable register (SEMA4\_CPnINE) and the interrupt request register (SEMA4\_CPnNTF). To support implementations with more than 16 gates, these registers can be referenced with aligned 16- or 32-bit accesses. For the SEMA4\_CPnINE registers, unimplemented bits read as zeroes and writes are ignored. Figure 521. Semaphores processor n IRQ notification enable (SEMA4 CP{0,1}INE) | Table 506. SEMA4 | CP{0.1 | NTF field | descriptions | |------------------|--------|-----------|--------------| |------------------|--------|-----------|--------------| | Field | Description | | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | INE <i>n</i> | Interrupt Request Notification Enable $n$ . This field is a bitmap to enable the generation of an interrupt notification from a failed attempt to lock gate $n$ . | | | IIVE// | <ul><li>0 The generation of the notification interrupt is disabled.</li><li>1 The generation of the notification interrupt is enabled.</li></ul> | | ### 27.3.3 Semaphores processor *n* IRQ notification (SEMA4\_CP{0,1}NTF) The notification interrupt is generated via a unique finite state machine, one per hardware gate. This machine operates in the following manner: - When an attempted lock fails, the FSM enters a first state where it waits until the gate is unlocked. - After it is unlocked, the FSM enters a second state where it generates an interrupt request to the failed lock processor. - When the failed lock processor succeeds in locking the gate, the IRQ is automatically negated and the FSM returns to the idle state. However, if the other processor locks the gate again, the FSM returns to the first state, negates the interrupt request, and waits for the gate to be unlocked again. The notification interrupt request is implemented in a 3-bit, five-state machine, where two specific states are encoded and program-visible as SEMA4\_CP0NTF[GNn] and SEMA4\_CP1NTF[GNn]. Figure 522. Semaphores processor *n* IRQ notification (SEMA4\_CP{0,1}NTF) Table 507. SEMA4\_CP{0,1}NTF field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GNn | Gate <i>n</i> Notification. This read-only field is a bitmap of the interrupt request notification from a failed attempt to lock gate <i>n</i> . 0 No notification interrupt generated. 1 Notification interrupt generated. | ### 27.3.4 Semaphores (secure) reset gate *n* (SEMA4\_RSTGT) Although the intent of the hardware gate implementation specifies a protocol where the locking processor must unlock the gate, it is recognized that system operation may require a reset function to re-initialize the state of any gate(s) without requiring a system-level reset. To support this special gate reset requirement, the SEMA4 unit implements a secure reset mechanism which allows a hardware gate (or all the gates) to be initialized by following a specific dual-write access pattern. Using a technique similar to that required for the servicing of a software watchdog timer, the secure gate reset requires two consecutive writes with predefined data patterns from the same processor to force the clearing of the specified gate(s). The required access pattern is: - A processor performs a 16-bit write to the SEMA4\_RSTGT memory location. The most significant byte (SEMA4\_RSTGT[RSTGDP]) must be 0xE2; the least significant byte is a "don't care" for this reference. - 2. The same processor then performs a second 16-bit write to the SEMA4\_RSTGT location. For this write, the upper byte (SEMA4\_RSTGT[RSTGDP]) is the logical complement of the first data pattern (0x1D) and the lower byte (SEMA4\_RSTGT[RSTGTN]) specifies the gate(s) to be reset. This gate field can specify a single gate be cleared or that all gates are cleared. - 3. Reads of the SEMA4\_RSTGT location return information on the 2-bit state machine (SEMA4\_RSTGT[RSTGSM]) which implements this function, the bus master performing the reset (SEMA4\_RSTGT[RSTGMS]) and the gate number(s) last cleared (SEMA4\_RSTGT[RSTGTN]). Reads of the SEMA4\_RSTGT register do not affect the secure reset finite state machine in any manner. Figure 523. Semaphores (secure) reset gate n (SEMA4\_RSTGT) Table 508. SEMA4\_RSTGT field descriptions | Field | Description | | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | RSTGSM | Reset Gate Finite State Machine. The reset state machine is maintained in a 2-bit, three-state implementation, defined as: 00 Idle, waiting for the first data pattern write. 01 Waiting for the second data pattern write. 10 The 2-write sequence has completed. Generate the specified gate reset(s). After the reset is performed, this machine returns to the idle (waiting for first data pattern write) state. 11 This state encoding is never used and therefore reserved. Reads of the SEMA4_RSTGT register return the encoded state machine value. Note the RSTGSM = 0b10 state is valid for a single machine cycle only, so it is impossible for a read to return this value. | | | | Table 508. SEMA4 RSTGT field descriptions(Continued) | Field | Description | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|--| | | Reset Gate Bus Master. This 3-bit read-only field records the logical number of the bus master performing the gate reset function. The reset function requires that the two consecutive writes to this register be initiated by the same bus master to succeed. This field is updated each time a write to this register occurs. | | | | | | | Master | Master ID | | | | | e200z0h_0 | 0 | | | RSTGMS | | e200z0h_1 | 1 | | | | | eDMA | 2 | | | | | FlexRay | 3 | | | | | _ | 4 | | | | | _ | 5 | | | | | _ | 6 | | | | | _ | 7 | | | RSTGTN | Reset Gate Number. This 8-bit field specifies the specific hardware gate to be reset. This field is updated by the second write. If RSTGTN < 64, then reset the single gate defined by RSTGTN, else reset all the gates. The corresponding secure IRQ notification state machine(s) are also reset. | | | | | RSTGDP | Reset Gate Data Pattern. This write-only field is accessed with the specified data patterns on the two consecutive writes to enable the gate reset mechanism. For the first write, RSTGDP = 0xe2 while the second write requires RSTGDP = 0x1d. | | | | #### 27.3.5 Semaphores (secure) Reset IRQ notification (SEMA4 RSTNTF) As with the case of the secure reset function and the hardware gates, it is recognized that system operation may require a reset function to re-initialize the state of the IRQ notification logic without requiring a system-level reset. To support this special notification reset requirement, the SEMA4 unit implements a secure reset mechanism which allows an IRQ notification (or all the notifications) to be initialized by following a specific dual-write access pattern. When successful, the specified IRQ notification state machine(s) are reset. Using a technique similar to that required for the servicing of a software watchdog timer, the secure reset mechanism requires two consecutive writes with predefined data patterns from the same processor to force the clearing of the IRQ notification(s). The required access pattern is: - 1. A processor performs a 16-bit write to the SEMA4\_RSTNTF memory location. The most significant byte (SEMA4\_RSTNTF[RSTNDP]) must be 0x47; the least significant byte is a "don't care" for this reference. - The same processor performs a second 16-bit write to the SEMA4\_RSTNTF location. For this write, the upper byte (SEMA4\_RSTNTF[RSTNDP]) is the logical complement of the first data pattern (0xb8) and the lower byte (SEMA4\_RSTNTF[RSTNTN]) - specifies the notification(s) to be reset. This field can specify a single notification be cleared or that all notifications are cleared. - Reads of the SEMA4\_RSTNTF location return information on the 2-bit state machine (SEMA4\_RSTNTF[RSTNSM]) that implements this function, the bus master performing the reset (SEMA4\_RSTNTF[RSTNMS]) and the notification number(s) last cleared (SEMA4\_RSTNTF[RSTNTN]). Reads of the SEMA4\_RSTNTF register do not affect the secure reset finite state machine in any manner. Figure 524. Semaphores (secure) Reset IRQ notification (SEMA4\_RSTNTF) #### Table 509. SEMA4\_RSTNTF field descriptions | Field | Description | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|--------------------------------------| | RSTNSM | Reset Notification Finite State Machine. The reset state machine is maintained in a 2-bit, three-state implementation, defined as: 00 Idle, waiting for the first data pattern write. 01 Waiting for the second data pattern write. 10 The two-write sequence has completed. Generate the specified notification reset(s). After the reset is performed, this machine returns to the idle (waiting for first data pattern write) state. 11 This state encoding is never used and therefore reserved. Reads of the SEMA4_RSTNTF register return the encoded state machine value. Note the RSTNSM = 0b10 state is valid for a single machine cycle only, so it is impossible for a read to return this value. | | | | | Reset Notification Bus Master. This 3-bit read-only field records the logical number of the b performing the notification reset function. The reset function requires that the two consecutor to this register be initiated by the same bus master to succeed. This field is updated eawrite to this register occurs. | | | | ires that the two consecutive writes | | | | Master | Master ID | | | | | e200z0h_0 | 0 | | | RSTNMS | | e200z0h_1 | 1 | | | ROTIVIO | | eDMA | 2 | | | | | FlexRay | 3 | | | | | _ | 4 | | | | | _ | 5 | | | | | _ | 6 | | | | | _ | 7 | | | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RSTNTN | Reset Notification Number. This 8-bit field specifies the specific IRQ notification state machine to be reset. This field is updated by the second write. If RSTNTN < 64, then reset the single IRQ notification machine defined by RSTNTN, else reset all the notifications. | | RSTNDP | Reset Notification Data Pattern. This write-only field is accessed with the specified data patterns on the two consecutive writes to enable the notification reset mechanism. For the first write, RSTNDP = 0x47 while the second write requires RSTNDP = 0xb8. | Table 509. SEMA4 RSTNTF field descriptions(Continued) # 27.4 Functional description Multi-processor systems require a function that can be used to safely and easily provide a locking mechanism that is then used by system software to control access to shared data structures, shared hardware resources, and etc. These gating mechanisms are used by the software to serialize (and synchronize) writes to shared data and/or resources to prevent race conditions and preserve memory coherency between processes and processors. For example, if processor X enters a section of code where shared data values are to be updated or read coherently, it must first acquire a semaphore. This locks, or closes, a software gate. After the gate has been locked, a properly architected software system does not allow other processes (or processors) to execute the same code segment or modify the shared data structure protected by the gate, that is, other processes/processors are locked out. Many software implementations include a spin-wait loop within the lock function until the locking of the gate is accomplished. After the lock has been obtained, processor X continues execution and updates the data values protected by the particular lock. After the updates are complete, processor X unlocks (or opens) the software gate, allowing other processes/processors access to the updated data values. There are three important rules that must be followed for a correctly implemented system solution: - All writes to shared data values or shared hardware resources must be protected by a gate variable. - After a processor locks a gate, accesses to the shared data or resources by other processes/processors must be blocked. This is enforced by software conventions. - The processor that locks a particular gate is the only processor that can unlock, or open, that gate. Information in the hardware gate identifying the locking processor can be useful for system-level debugging. The Hennessy/Patterson text on computer architecture offers this description of software gating: "One of the major requirements of a shared-memory architecture multiprocessor is being able to coordinate processes that are working on a common task. Typically, a programmer will use *lock variables* to synchronize the processes. The difficulty for the architect of a multiprocessor is to provide a mechanism to decide which processor gets the lock and to provide the operation that locks a variable. Arbitration is easy for shared-bus multiprocessors, since the bus is the only path to memory. The processor that gets the bus locks out all the other processors from memory. If the CPU and bus provide an atomic swap operation, programmers can create locks with the proper semantics. The adjective *atomic* is key, for it means that a processor can both read a location **and** set it to the locked value in the same bus operation, preventing any other processor from reading or writing memory." [Hennessy/Patterson, *Computer Architecture: A Quantitative Approach*, ppg. 471-472] The classic text continues with a description of the steps required to lock/unlock a variable using an atomic swap instruction. "Assume that 0 means unlocked and 1 means locked. A processor first reads the lock variable to test its state. A processor keeps reading and testing until the value indicates that the lock is unlocked. The processor then races against all other processes that were similarly "spin waiting" to see who can lock the variable first. All processes use a swap instruction that reads the old value and stores a 1 into the lock variable. The single winner will see the 0, and the losers will see a 1 that was placed there by the winner. (The losers will continue to set the variable to the locked value, but that doesn't matter.) The winning processor executes the code after the lock and then stores a 0 into the lock when it exits, starting the race all over again. Testing the old value and then setting to a new value is why the atomic swap instruction is called *test and set* in some instruction sets." [Hennessy/Patterson, *Computer Architecture: A Quantitative Approach*, ppg. 472-473] The sole drawback to a hardware-based semaphore module is the limited number of semaphores versus the infinite number that can be supported with Power Architecture reservation instructions. #### 27.4.1 Semaphore usage Example 1: Inter-processor communication done with software interrupts and semaphores - The e200z0h\_1 uses software interrupts to tell the e200z0h\_0 that new data is available, or the e200z0h\_0 does the same to tell the e200z0h\_1 that there is new data available for transmission. - Because only eight software interrupts are available, the user may need RAM locations or general-purpose registers in the SIU to refine the meaning of the software interrupt. - Messages are passed between cores in a defined section of system RAM. - Before a core updates a message, it must check the associated semaphore to see if the other core is in the process of updating the same message. If the RAM not being updated, then the semaphore must first be locked, then the message can be updated. A software interrupt can be sent to the other core and the semaphore can be unlocked. If the RAM is being updated, the CPU must wait for the other core to unlock the semaphore before proceeding with update. - Using the same memory location for bidirectional communication might be difficult, so two one-way message areas might work better. - For example, if both cores want to update the same location, then the following sequence may occur. - 1. The e200z0h\_1 locks the semaphore, updates the memory, unlocks the semaphore, and generates a software interrupt to the e200z0h 0. - 2. Before the e200z0h\_0 takes the software interrupt request, it finds the semaphore to be unlocked, so it writes new data to the memory. - 3. The e200z0h\_0 software interrupt ISR reads the data sent to the e200z0h\_1, not the data sent from the e200z0h\_1, and performs an incorrect operation. - Semaphores do not prevent this situation from occurring. Example 2: Coherent read done with semaphores - The e200z0h\_0 wants to coherently read a section of shared memory. - The e200z0h\_0 should check that the semaphore for the shared memory is not currently set. - The e200z0h\_0 should set the semaphore for the shared memory to prevent the e200z0h\_1 from updating the shared memory. - The e200z0h 0 reads the required data, then unlock the semaphore. #### 27.5 Initialization information The reset state of the SEMA4 unit allows it to begin operation without the need for any further initialization. All the internal state machines are cleared by any reset event, allowing the unit to immediately begin operation. # 27.6 Application information In an operational multi-core system, most interactions involving the SEMA4 unit involves reads and writes to the SEMA4\_GATE*n* registers for implementation of the hardware-enforced software gate functions. Typical code segments for gate functions perform the following operations: - To lock (close) a gate - The processor performs a byte write of logical\_processor\_number + 1 to gate[i] - The processor reads back gate[i] and checks for a value of logical processor number + 1 If the compare indicates the expected value then the gate is locked; proceed with the protected code segment else lock operation failed; repeat process beginning with byte write to gate[i] in spin-wait loop, or proceed with another execution path and wait for failed lock interrupt notification A simple C-language example of a gatelock function is shown in *Example 15*. This function follows the Hennessy/Patterson example. #### **Example 15** Sample Gatelock Function ``` #define UNLOCK 0 #define CP0_LOCK 1 #define CP1_LOCK 2 void gateLock (n) int n; /* gate number to lock */ { int i; int current_value; int locked value; ``` ``` i = processor_number(); /* obtain logical CPU number */ if (i == 0) locked_value = CP0_LOCK; else locked_value = CP1_LOCK; /* read the current value of the gate and wait until the state == UNLOCK */ do { current_value = gate[n]; } while (current_value != UNLOCK); /* the current value of the gate == UNLOCK. attempt to lock the gate for this processor. spin-wait in this loop until gate ownership is obtained */ do { gate[n] = locked_value; /* write gate with processor_number + 1 */ current_value = gate[n]; /* read gate to verify ownership was obtained */ } while (current_value != locked_value); } ``` - To unlock (open) a gate - After completing the protected code segment, the locking processor performs a byte write of zeroes to gate[i], unlocking (opening) the gate In this example, a reference to <code>processor\_number()</code> is used to retrieve this hardware configuration value. Typically, the logical processor numbers are defined by a hardwired input vector to the individual cores. For PowerPC cores, there is a processor ID register (PIR) which is SPR 286 and contains this value. A single instruction can be used to move the contents of the PIR into a general-purpose register: <code>mfspr rx,286</code> where <code>rx</code> is the destination GPRn. Other architectures may support a specific instruction to move the contents of the logical processor number into a general-purpose register, e.g., <code>rdcpn rx</code> for a read CPU number instruction. If the optional failed lock IRQ notification mechanisms are used, then accesses to the related registers (SEMA4\_CPnINE, SEMA4\_CPnNTF) are required. There is no required negation of the failed lock write notification interrupt as the request is automatically negated by the SEMA4 unit once the gate has been successfully locked by the failing processor. Finally, in the event a system state requires a software-controlled reset of a gate or IRQ notification register(s), accesses to the secure reset control registers (SEMA4\_RSTGT, SEMA4\_RSTNTF) are required. For these situations, it is recommended that the appropriate IRQ notification enable(s) (SEMA4\_CPnINE) bits be disabled before initiating the secure reset 2-write sequence to avoid any race conditions involving spurious notification interrupt requests. # 27.7 DMA requests There are no DMA requests associated with the SEMA4 unit. ### 28 eTimer #### 28.1 Introduction The eTimer module contains six identical counter/timer channels and one watchdog timer function only for eTimer\_0. Each 16-bit counter/timer channel contains a prescaler, a counter, a load register, a hold register, two queued capture registers, two compare registers, two compare preload registers, and four control registers. The Load register provides the initialization value to the counter when the counter's terminal value has been reached. For true modulo counting the counter can also be initialized by the CMPLD1 or CMPLD2 registers. The Hold register captures the counter's value when other counters are being read. This feature supports the reading of cascaded counters coherently. The Capture registers enable an external signal to take a "snapshot" of the counter's current value. The COMP1 and COMP2 registers provide the values to which the counter is compared. If a match occurs, the OFLAG signal can be set, cleared, or toggled. At match time, an interrupt is generated if enabled, and the new compare value is loaded into the COMP1 or COMP2 registers from CMPLD1 and CMPLD2 if enabled. The Prescaler provides different time bases useful for clocking the counter/timer. The Counter provides the ability to count internal or external events. Within the eTimer module (set of six timer/counter channels) the input pins are shareable. 577 #### 28.2 Features The eTimer module design includes these features: - Six 16-bit counters/timers - Count up/down - Cascadeable counters - Enhanced programmable up/down modulo counting - Max count rate equals peripheral clock/2 for external clocks - Max count rate equals peripheral clock for internal clocks - Count once or repeatedly - Preloadable counters - Preloadable compare registers - Counters can share available input pins - Separate prescaler for each counter - Each counter has capture and compare capability - Continuous and single shot capture for enhanced speed measurement - DMA support of capture registers and compare registers - 32-bit watchdog capability to detect stalled quadrature counting (implemented only on eTimer\_0) - OFLAG comparison for safety critical applications - Programmable operation during debug mode and stop mode - Programmable input filter - Counting start can be synchronized across counters # 28.3 Module block diagram Filter The eTimer block diagram is shown in Figure 525. IPBus**⋖** Clock Reset DMA Count OFLAG 0 Inp 0 Filter Channel 0 Aux Inp 0 Filter OFLAG 1 Inp 1 Watchdog Filter Channel 1 Timer Aux Inp 1 Filter WDF Inp 2 OFLAG 2 Filter Channel 2 Aux Inp 2 Channel n Figure 525. eTimer block diagram OFLAG n ➤ Error signal # 28.4 Channel block diagram Each of the timer/counter channels within the eTimer are shown in Figure 526. Figure 526. eTimer channel block diagram # 28.5 External signal descriptions The eTimer module has six external signals that can be used as either inputs or outputs. ### 28.5.1 ETC[5:0]—eTimer input/outputs These pins can be independently configured to be either timer input sources or output flags. # 28.6 Memory map and registers #### 28.6.1 Overview Table 510 shows the memory map for the eTimer modules. Table 510, eTimer memory map | Offset from<br>eTIMER0_BASE<br>(FFE1_8000)<br>eTIMER1_BASE<br>(FFE1_C000) | Register | Location | |---------------------------------------------------------------------------|---------------------------------------------|-------------| | | eTimer Channel 0 | | | 0x0000 | COMP1—Compare Register 1 | on page 893 | | 0x0002 | COMP2—Compare Register 2 | on page 894 | | 0x0004 | CAPT1—Capture Register 1 | on page 894 | | 0x0006 | CAPT2—Capture Register 2 | on page 895 | | 0x0008 | LOAD—Load Register | on page 895 | | 0x000A | HOLD—Hold Register | on page 896 | | 0x000C | CNTR—Counter Register | on page 896 | | 0x000E | CTRL1—Control Register 1 | on page 897 | | 0x0010 | CTRL2—Control Register 2 | on page 899 | | 0x0012 | CTRL3—Control Register 3 | on page 901 | | 0x0014 | STS—Status Register | on page 902 | | 0x0016 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | 0x0018 | CMPLD1—Comparator Load Register 1 | on page 905 | | 0x001A | CMPLD2—Comparator Load Register 2 | on page 905 | | 0x001C | CCCTRL—Compare and Capture Control Register | on page 906 | | 0x001E | FILT—Input Filter Register | on page 908 | | | eTimer Channel 1 | | | 0x0020 | COMP1—Compare Register 1 | on page 893 | | 0x0022 | COMP2—Compare Register 2 | on page 894 | | 0x0024 | CAPT1—Capture Register 1 | on page 894 | | 0x0026 | CAPT2—Capture Register 2 | on page 895 | | 0x0028 | LOAD—Load Register | on page 895 | | 0x002A | HOLD—Hold Register | on page 896 | | 0x002C | CNTR—Counter Register | on page 896 | | 0x002E | CTRL1—Control Register 1 | on page 897 | | 0x0030 | CTRL2—Control Register 2 | on page 899 | | 0x0032 | CTRL3—Control Register 3 | on page 901 | | 0x0034 | STS—Status Register | on page 902 | | 0x0036 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | 0x0038 | CMPLD1—Comparator Load Register 1 | on page 905 | | 0x003A | CMPLD2—Comparator Load Register 2 | on page 905 | Table 510. eTimer memory map(Continued) | 000 | Table 510. etimer memory map(continued) | | | | |---------------------------------------------------------------------------|---------------------------------------------|-------------|--|--| | Offset from<br>eTIMER0_BASE<br>(FFE1_8000)<br>eTIMER1_BASE<br>(FFE1_C000) | Register | Location | | | | 0x003C | CCCTRL—Compare and Capture Control Register | on page 906 | | | | 0x003E | FILT—Input Filter Register | on page 908 | | | | | eTimer Channel 2 | | | | | 0x0040 | COMP1—Compare Register 1 | on page 893 | | | | 0x0042 | COMP2—Compare Register 2 | on page 894 | | | | 0x0044 | CAPT1—Capture Register 1 | on page 894 | | | | 0x0046 | CAPT2—Capture Register 2 | on page 895 | | | | 0x0048 | LOAD—Load Register | on page 895 | | | | 0x004A | HOLD—Hold Register | on page 896 | | | | 0x004C | CNTR—Counter Register | on page 896 | | | | 0x004E | CTRL1—Control Register 1 | on page 897 | | | | 0x0050 | CTRL2—Control Register 2 | on page 899 | | | | 0x0052 | CTRL3—Control Register 3 | on page 901 | | | | 0x0054 | STS—Status Register | on page 902 | | | | 0x0056 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | | | 0x0058 | CMPLD1—Comparator Load Register 1 | on page 905 | | | | 0x005A | CMPLD2—Comparator Load Register 2 | on page 905 | | | | 0x005C | CCCTRL—Compare and Capture Control Register | on page 906 | | | | 0x005E | FILT—Input Filter Register | on page 908 | | | | eTimer Channel 3 | | | | | | 0x0060 | COMP1—Compare Register 1 | on page 893 | | | | 0x0062 | COMP2—Compare Register 2 | on page 894 | | | | 0x0064 | CAPT1—Capture Register 1 | on page 894 | | | | 0x0066 | CAPT2—Capture Register 2 | on page 895 | | | | 0x00068 | LOAD—Load Register | on page 895 | | | | 0x006A | HOLD—Hold Register | on page 896 | | | | 0x006C | CNTR—Counter Register | on page 896 | | | | 0x006E | CTRL1—Control Register 1 | on page 897 | | | | 0x0070 | CTRL2—Control Register 2 | on page 899 | | | | 0x0072 | CTRL3—Control Register 3 | on page 901 | | | | 0x0074 | STS—Status Register | on page 902 | | | | 0x0076 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | | Table 510. eTimer memory map(Continued) | Table 510. etimer memory map(Continued) | | | | |---------------------------------------------------------------------------|---------------------------------------------|-------------|--| | Offset from<br>eTIMER0_BASE<br>(FFE1_8000)<br>eTIMER1_BASE<br>(FFE1_C000) | Register | Location | | | 0x0078 | CMPLD1—Comparator Load Register 1 | on page 905 | | | 0x007A | CMPLD2—Comparator Load Register 2 | on page 905 | | | 0x007C | CCCTRL—Compare and Capture Control Register | on page 906 | | | 0x007E | FILT—Input Filter Register | on page 908 | | | | eTimer Channel 4 | | | | 0x0080 | COMP1—Compare Register 1 | on page 893 | | | 0x0082 | COMP2—Compare Register 2 | on page 894 | | | 0x0084 | CAPT1—Capture Register 1 | on page 894 | | | 0x0086 | CAPT2—Capture Register 2 | on page 895 | | | 0x0088 | LOAD—Load Register | on page 895 | | | 0x008A | HOLD—Hold Register | on page 896 | | | 0x008C | CNTR—Counter Register | on page 896 | | | 0x008E | CTRL1—Control Register 1 | on page 897 | | | 0x0090 | CTRL2—Control Register 2 | on page 899 | | | 0x0092 | CTRL3—Control Register 3 | on page 901 | | | 0x0094 | STS—Status Register | on page 902 | | | 0x0096 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | | 0x0098 | CMPLD1—Comparator Load Register 1 | on page 905 | | | 0x009A | CMPLD2—Comparator Load Register 2 | on page 905 | | | 0x009C | CCCTRL—Compare and Capture Control Register | on page 906 | | | 0x009E | FILT—Input Filter Register | on page 908 | | | | eTimer Channel 5 | | | | 0x00A0 | COMP1—Compare Register 1 | on page 893 | | | 0x00A2 | COMP2—Compare Register 2 | on page 894 | | | 0x00A4 | CAPT1—Capture Register 1 | on page 894 | | | 0x00A6 | CAPT2—Capture Register 2 | on page 895 | | | 0x00A8 | LOAD—Load Register | on page 895 | | | 0x00AA | HOLD—Hold Register | on page 896 | | | 0x00AC | CNTR—Counter Register | on page 896 | | | 0x00AE | CTRL1—Control Register 1 | on page 897 | | | 0x00B0 | CTRL2—Control Register 2 | on page 899 | | | 0x00B2 | CTRL3—Control Register 3 | on page 901 | | Table 510. eTimer memory map(Continued) | Offset from<br>eTIMER0_BASE<br>(FFE1_8000)<br>eTIMER1_BASE<br>(FFE1_C000) | Register | Location | |---------------------------------------------------------------------------|---------------------------------------------|-------------| | 0x00B4 | STS—Status Register | on page 902 | | 0x00B6 | INTDMA—Interrupt and DMA Enable Register | on page 904 | | 0x00B8 | CMPLD1—Comparator Load Register 1 | on page 905 | | 0x00BA | CMPLD2—Comparator Load Register 2 | on page 905 | | 0x00BC | CCCTRL—Compare and Capture Control Register | on page 906 | | 0x00BE | FILT—Input Filter Register | on page 908 | | 0x00C0-0x00FF | Reserved | | | 0x0100 | WDTOL—Watchdog Time-out Low Register | on page 909 | | 0x0102 | WDTOH—Watchdog Time-out High Register | on page 909 | | 0x0104-0x010B | Reserved | • | | Watchdog and Configuration registers | | | | 0x010C | ENBL—Channel Enable Register | on page 909 | | 0x0110 | DREQ0—DMA Request 0 Select Register | on page 910 | | 0x0112 | DREQ1—DMA Request 1 Select Register | on page 910 | | 0x0114-0x3FFF | Reserved | • | ### 28.6.2 Timer channel registers These registers are repeated for each timer channel. The base address of channel 0 is the same as the base address of the eTimer module as a whole. The base address of channel 1 is 0x20. This is the base address of the eTimer module plus an offset based on the number of bytes of registers in a timer channel. The base address of each subsequent timer channel is equal to the base address of the previous channel plus this same offset of 0x20. ### 28.6.2.1 Compare register 1 (COMP1) The COMP1 register stores the value used for comparison with the counter value. More explanation on the use of COMP1 can be found in *Section 28.7.2.11: Usage of compare registers*. Table 511. COMP1 field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------------------------| | COMP1[15:0] | Compare 1 Stores the value used for comparison with the counter value. Note: This register is not byte accessible. | #### 28.6.2.2 Compare register 2 (COMP2) The COMP2 register stores the value used for comparison with the counter value. More explanation on the use of COMP2 can be found in *Section 28.7.2.11: Usage of compare registers*. Figure 528. Compare register 2 (COMP2) Table 512. COMP2 field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------------------------| | COMP2[15:0] | Compare 2 Stores the value used for comparison with the counter value. Note: This register is not byte accessible. | ### 28.6.2.3 Capture register 1 (CAPT1) The CAPT1 register stores the value captured from the counter while the counter is enabled. Exactly when a capture occurs is defined by the CPT1MODE bits in the Compare and Capture Control (CCCTRL) register. This is actually a -deep FIFO and not a single register. Figure 529. Capture register 1 (CAPT1) Table 513. CAPT1 field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------| | CAPT1[15:0] | Capture 1 Stores the value captured from the counter. Note: This register is not byte accessible. | #### 28.6.2.4 Capture register 2 (CAPT2) This read only register stores the value captured from the counter while the counter is enabled. Exactly when a capture occurs is defined by the CPT2MODE bits. This is actually a 2-deep FIFO and not a single register. This register is not byte accessible. Figure 530. Capture register 2 (CAPT2) Table 514. CAPT2 field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------| | CAPT2[15:0] | Capture 2 Stores the value captured from the counter. Note: This register is not byte accessible. | #### 28.6.2.5 Load register (LOAD) This read/write register stores the value used to initialize the counter. This register is not byte accessible. Table 515. LOAD field descriptions | Field | Description | |------------|----------------------------------------------------------------------------------------------------| | LOAD[15:0] | Load Stores the value used to initialize the counter. Note: This register is not byte accessible. | #### 28.6.2.6 Hold register (HOLD) This read-only register stores the counter's value whenever any of the other counters within a module are read. This supports coherent reading of cascaded counters. Table 516. HOLD field descriptions | Field | Description | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HOLD[15:0] | Stores the counter's value whenever any of the other counters within a module are read. Note: The hardware request status reflects the state of the request as seen by the arbitration logic. Therefore, this status is affected by the EDMA_ERQRL[ERQn] bit. | #### 28.6.2.7 Counter register (CNTR) This read/write register is the counter for this channel of the timer module. This register is not byte accessible. Table 517. CNTR field descriptions | Field | Description | |------------|-----------------------------------------------------------------| | CNTR[15:0] | Contains the count value for this channel of the eTimer module. | | | Note: This register is not byte accessible. | #### 28.6.2.8 Control register 1 (CTRL1) Table 518. CTRL1 field descriptions | Field | Description | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | CNTMODE[2:0] | Count Mode These bits control the basic counting and behavior of the counter. 000 No Operation. 001 Count rising edges of primary source. Rising edges counted only when PIPS = 0. Falling edges counted when PIPS = 1. If primary count source is IP bus clock, only rising edges are counted regardless of PIPS value. 010 Count rising and falling edges of primary source. IP Bus clock divide by 1 can not be used as a primary count source in edge count mode. 011 Count rising edges of primary source while secondary input high active. 100 Quadrature count mode, uses primary and secondary sources. 101 Count primary source rising edges, secondary source specifies direction (1 = minus). Rising edges counted only when PIPS = 0. Falling edges counted when PIPS = 1. 110 Edge of secondary source triggers primary count till compare. 111 Cascaded counter mode, up/down. Primary count source must be set to one of the counter outputs. | | Table 518. CTRL1 field descriptions(Continued) | Field | Description | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | PRISRC | Primary Count Source These bits select the primary count source. See <i>Table 519</i> . <b>Note:</b> A timer cannot select its own output as its primary count source. If this is done, the timer will not count. | | | ONCE | Count Once This bit selects continuous or one-shot counting mode. 0 Count repeatedly. 1 Count until compare and then stop. When output mode 0x4 is used, the counter reinitializes after reaching the COMP1 value and continues to count to the COMP2 value, then stops. | | | LENGTH | Count Length This bit determines whether the counter counts to the compare value and then reinitializes itself to the value specified in the LOAD, CMPLD1, or CMPLD2 registers, or the counter continues counting past the compare value, to the binary roll over. O Continue counting to roll over. Count until compare, then reinitialize. The value that the counter is reinitialized with depends on the settings of CLC1 and CLC2. If neither of these indicates the counter is to be loaded from one of the CMPLD registers, then the LOAD register reinitializes the counter upon matching either COMP register. If one of CLC1 or CLC2 indicates that the counter is to be loaded from one of the CMPLD registers, then the counter will reinitialize to the value in the appropriate CMPLD register upon a match with the appropriate COMP register. If both of the CLC1 and CLC2 fields indicate that the counter is to be loaded from the CMPLD registers, then CMPLD1 will have priority if both compares happen at the same value. When output mode 0x4 is used, alternating values of COMP1 and COMP2 are used to generate successful comparisons. For example, the counter counts until COMP1 value is reached, reinitializes, then counts until COMP2 value is reached, reinitializes, then counts until COMP1 value is reached, etc. | | | DIR | Count Direction This bit selects either the normal count direction up, or the reverse direction, down. 0 Count up. 1 Count down. | | | SECSRC | Secondary Count Source These bits identify the source to be used as a count command or timer command. The selected input can trigger the timer to capture the current value of the CNTR register. The selected input can also be used to specify the count direction. The polarity of the signal can be inverted by the SIPS bit of the CTRL2 register. | | Table 519. Count source values | Value | Meaning | Value | Meaning | |-------|----------------------|-------|-------------------| | 00000 | Counter #0 input pin | 10000 | Counter #0 output | | 00001 | Counter #1 input pin | 10001 | Counter #1 output | | 00010 | Counter #2 input pin | 10010 | Counter #2 output | | 00011 | Counter #3 input pin | 10011 | Counter #3 output | | 00100 | Counter #4 input pin | 10100 | Counter #4 output | Table 519. Count source values(Continued) | Value | Meaning | Value | Meaning | |-------|------------------------|-------|--------------------------------------| | 00101 | Counter #5 input pin | 10101 | Counter #5 output | | 00110 | Reserved | 10110 | Reserved | | 00111 | Reserved | 10111 | Reserved | | 01000 | Auxiliary input #0 pin | 11000 | IP Bus clock divide by 1 prescaler | | 01001 | Auxiliary input #1 pin | 11001 | IP Bus clock divide by 2 prescaler | | 01010 | Auxiliary input #2 pin | 11010 | IP Bus clock divide by 4 prescaler | | 01011 | Reserved | 11011 | IP Bus clock divide by 8 prescaler | | 01100 | Reserved | 11100 | IP Bus clock divide by 16 prescaler | | 01101 | Reserved | 11101 | IP Bus clock divide by 32 prescaler | | 01110 | Reserved | 11110 | IP Bus clock divide by 64 prescaler | | 01111 | Reserved | 11111 | IP Bus clock divide by 128 prescaler | ### 28.6.2.9 Control register 2 (CTRL2) Figure 535. Control register 2 (CTRL2) Table 520. CTRL2 field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OEN | Output Enable This bit determines the direction of the external pin. The external pin is configured as an input. OFLAG output signal is driven on the external pin. Other timer channels using this external pin as their input will see the driven value. The polarity of the signal will be determined by the OPS bit. | | RDNT | Redundant Channel Enable This bit enables redundant channel checking between adjacent channels (0 and 1, 2 and 3, 4 and 5). When this bit is cleared, the RCF bit in this channel cannot be set. When this bit is set, the RCF bit is set by a miscompare between the OFLAG of this channel and the OFLAG of its redundant adjacent channel, which causes the output of this channel to go inactive (logic 0 prior to consideration of the OPS bit). O Disable redundant channel checking. Enable redundant channel checking. | Table 520. CTRL2 field descriptions(Continued) | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | INPUT | External input signal This read only bit reflects the current state of the signal selected via SECSRC after application of the SIPS bit and filtering. | | VAL | Forced OFLAG Value This bit determines the value of the OFLAG output signal when a software triggered FORCE command occurs. | | FORCE | Force the OFLAG output This write only bit forces the current value of the VAL bit to be written to the OFLAG output. This bit always reads as a zero. The VAL and FORCE bits can be written simultaneously in a single write operation. Write to the FORCE bit only if OUTMODE is 0000 (software controlled). Setting this bit while the OUTMODE is a different value may yield unpredictable results. | | COFRC | Co-channel OFLAG Force This bit enables the compare from another channel within the module to force the state of this counter's OFLAG output signal. O Other channels cannot force the OFLAG of this channel. Other channels may force the OFLAG of this channel. | | COINIT | Co-channel Initialization These bits enable another channel within the module to force the reinitialization of this channel when the other channel has an active compare event. O Other channels cannot force reinitialization of this channel. Other channels may force a reinitialization of this channel's counter using the LOAD reg. Other channels may force a reinitialization of this channel's counter with the CMPLD2 reg when this channel is counting down or the CMPLD1 reg when this channel is counting up. | | SIPS | Secondary Source Input Polarity Select This bit inverts the polarity of the signal selected by the SECSRC bits. 0 True polarity. 1 Inverted polarity. | | PIPS | Primary Source Input Polarity Select This bit inverts the polarity of the signal selected by the PRISRC bits. This only applies if the signal selected by PRISRC is not the prescaled IP Bus clock. O True polarity. 1 Inverted polarity. | | OPS | Output Polarity Select This bit inverts the OFLAG output signal polarity. 0 True polarity. 1 Inverted polarity. | Table 520. CTRL2 field descriptions(Continued) | Field | Description | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MSTR | Master Mode This bit enables the compare function's output to be broadcast to the other channels in the module. The compare signal then can be used to reinitialize the other counters and/or force their OFLAG signal outputs. 0 Disable broadcast of compare events from this channel. 1 Enable broadcast of compare events from this channel. | | OUTMODE | Output Mode These bits determine the mode of operation for the OFLAG output signal. 0000 Software controlled 0001 Clear OFLAG output on successful compare (COMP1 or COMP2) 0010 Set OFLAG output on successful compare (COMP1 or COMP2) 0011 Toggle OFLAG output on successful compare (COMP1 or COMP2) 0100 Toggle OFLAG output using alternating compare registers 0101 Set on compare with COMP1, cleared on secondary source input edge 0110 Set on compare with COMP2, cleared on secondary source input edge 0111 Set on compare, cleared on counter roll-over 1000 Set on successful compare on COMP1, clear on successful compare on COMP2 1001 Asserted while counter is active, cleared when counter is stopped. 1010 Reserved 1100 Reserved 1101 Reserved 1111 Enable gated clock output while counter is active | # 28.6.2.10 Control register 3 (CTRL3) Figure 536. Control register 3 (CTRL3) Table 521. CTRL3 field descriptions | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STPEN | Stop Actions Enable This bit allows the tristating of the timer output during stop mode. 0 Output enable is unaffected by stop mode. 1 Output enable is disabled during stop mode. | | ROC | Reload on Capture These bits enable the capture function to cause the counter to be reloaded from the LOAD register. 00 Do not reload the counter on a capture event. 01 Reload the counter on a capture 1 event. 10 Reload the counter on a capture 2 event. 11 Reload the counter on both a capture 1 event and a capture 2 event. | | C2FCNT | CAPT2 FIFO Word Count This field reflects the number of words in the CAPT2 FIFO. | | C1FCNT | CAPT1 FIFO Word Count This field reflects the number of words in the CAPT1 FIFO. | | DBGEN | Debug Actions Enable These bits allow the counter channel to perform certain actions in response to the device entering debug mode. 00 Continue with normal operation during debug mode. (default) 01 Halt channel counter during debug mode. 10 Force OFLAG to logic 0 (prior to consideration of the OPS bit) during debug mode. 11 Both halt counter and force OFLAG to 0 during debug mode. | # 28.6.2.11 Status register (STS) Figure 537. Status register (STS) Table 522. STS field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WDF | Watchdog Time-out Flag This bit is set when the watchdog times out by counting down to zero. The watchdog must be enabled for time-out to occur and channel 0 must be in quadrature decode count mode (CNTMODE = 100). This bit is cleared by writing a 1 to this bit. This bit is used in channel 0 only. | | RCF | Redundant Channel Flag This bit is set when there is a miscompare between this channel's OFLAG value and the OFLAG value of the corresponding redundant channel. Corresponding channels are grouped together in the following pairs: 0 and 1, 2 and 3, 4 and 5, or 6 and 7. This bit can only be set if the RDNT bit is set. This bit is cleared by writing a 1 to this bit. This bit is used in even channels (0, 2, 4, and 6) only. | | ICF2 | Input Capture 2 Flag This bit is set when an input capture event (as defined by CPT2MODE) occurs and the word count of the CAPT2 FIFO exceeds the value of the CFWM field. This bit is cleared by writing a 1 to this bit if ICF2DE is clear (no DMA) or it is cleared automatically by the DMA access if ICF2DE is set (DMA). | | ICF1 | Input Capture 1 Flag This bit is set when an input capture event (as defined by CPT1MODE) occurs and the word count of the CAPT1 FIFO exceeds the value of the CFWM field. This bit is cleared by writing a 1 to this bit if ICF1DE is clear (no DMA) or it is cleared automatically by the DMA access if ICF1DE is set (DMA). | | IEHF | Input Edge High Flag This bit is set when a positive input transition occurs (on an input selected by SECSRC) while the counter is enabled. This bit is cleared by writing a 1 to this bit. | | IELF | Input Edge Low Flag This bit is set when a negative input transition occurs (on an input selected by SECSRC) while the counter is enabled. This bit is cleared by writing a 1 to this bit. | | TOF | Timer Overflow Flag This bit is set when the counter rolls over its maximum value 0xFFFF or 0x0000 (depending on count direction). This bit is cleared by writing a 1 to this bit. | | TCF2 | Timer Compare 2 Flag This bit is set when a successful compare occurs with COMP2. This bit is cleared by writing a 1 to this bit. | | TCF1 | Timer Compare 1 Flag This bit is set when a successful compare occurs with COMP1. This bit is cleared by writing a 1 to this bit. | | TCF | Timer Compare Flag This bit is set when a successful compare occurs. This bit is cleared by writing a 1 to this bit. | # 28.6.2.12 Interrupt and DMA enable register (INTDMA) Figure 538. Interrupt and DMA enable register (INTDMA) Table 523. INTDMA field descriptions | Field | Description | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ICF2DE | Input Capture 2 Flag DMA Enable Setting this bit enables DMA read requests for CAPT2 when the ICF2 bit is set. Do not set both this bit and the ICF2IE bit. | | ICF1DE | Input Capture 1 Flag DMA Enable Setting this bit enables DMA read requests for CAPT1 when the ICF1 bit is set. Do not set both this bit and the ICF1IE bit. | | CMPLD2DE | Comparator Load Register 2 Flag DMA Enable Setting this bit enables DMA write requests to the CMPLD2 register whenever data is transferred out of the CMPLD2 reg into either the CNTR, COMP1, or COMP2 registers. | | CMPLD1DE | Comparator Load Register 1 Flag DMA Enable Setting this bit enables DMA write requests to the CMPLD1 register whenever data is transferred out of the CMPLD1 reg into either the CNTR, COMP1, or COMP2 registers. | | WDFIE | Watchdog Flag Interrupt Enable Setting this bit enables interrupts when the WDF bit is set. This bit is used in channel 0 only. | | RCFIE | Redundant Channel Flag Interrupt Enable Setting this bit enables interrupts when the RCF bit is set. This bit is used in even channels (0, 2, 4) only. | | ICF2IE | Input Capture 2 Flag Interrupt Enable Setting this bit enables interrupts when the ICF2 bit is set. Do not set both this bit and the ICF2DE bit. | | ICF1IE | Input Capture 1 Flag Interrupt Enable Setting this bit enables interrupts when the ICF1 bit is set. Do not set both this bit and the ICF1DE bit. | | IEHFIE | Input Edge High Flag Interrupt Enable Setting this bit enables interrupts when the IEHF bit is set. | | IELFIE | Input Edge Low Flag Interrupt Enable Setting this bit enables interrupts when the IELF bit is set. | | TOFIE | Timer Overflow Flag Interrupt Enable Setting this bit enables interrupts when the TOF bit is set. | | Field | Description | |--------|-----------------------------------------------------------------------------------------------------| | TCF2IE | Timer Compare 2 Flag Interrupt Enable Setting this bit enables interrupts when the TCF2 bit is set. | | TCF1IE | Timer Compare 1 Flag Interrupt Enable Setting this bit enables interrupts when the TCF1 bit is set. | | TCFIE | Timer Compare Flag Interrupt Enable Setting this bit enables interrupts when the TCF bit is set. | Table 523. INTDMA field descriptions(Continued) ## 28.6.2.13 Comparator Load register 1 (CMPLD1) This read/write register is the preload value for the COMP1 register. This register can also be used to load into the CNTR. This register is not byte accessible. More information on the use of this register can be found in Section 28.7.2.12: Usage of Compare Load registers. Table 524. CMPLD1 field descriptions | Field | Description | |--------------|-----------------------------------------------------| | CMPLD1[15:0] | Specifies the preload value for the COMP1 register. | ## 28.6.2.14 Comparator Load register 2 (CMPLD2) This read/write register is the preload value for the COMP2 register. This register can also be used to load into the CNTR. This register is not byte accessible. More information on the use of this register can be found in Section 28.7.2.12: Usage of Compare Load registers. 577 ### Table 525. CMPLD2 field descriptions | Field | Description | |--------------|-----------------------------------------------------| | CMPLD2[15:0] | Specifies the preload value for the COMP2 register. | # 28.6.2.15 Compare and Capture Control register (CCCTRL) Figure 541. Compare and Capture Control register (CCCTRL) Table 526. CCCTRL field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CLC2 | Compare Load Control 2 These bits control when COMP2 is preloaded. It also controls the loading of CNTR. 000 Never preload. 001 Reserved 010 Load COMP2 with CMPLD1 upon successful compare with the value in COMP1. 011 Load COMP2 with CMPLD1 upon successful compare with the value in COMP2. 100 Load COMP2 with CMPLD2 upon successful compare with the value in COMP1. 101 Load COMP2 with CMPLD2 upon successful compare with the value in COMP1. 102 Load CNTR with CMPLD2 upon successful compare with the value in COMP1. 103 Load CNTR with CMPLD2 upon successful compare with the value in COMP1. 104 Load CNTR with CMPLD2 upon successful compare with the value in COMP1. | | CLC1 | Compare Load Control 1 These bits control when COMP1 is preloaded. It also controls the loading of CNTR. 000 Never preload. 001 Reserved 010 Load COMP1 with CMPLD1 upon successful compare with the value in COMP1. 011 Load COMP1 with CMPLD1 upon successful compare with the value in COMP2. 100 Load COMP1 with CMPLD2 upon successful compare with the value in COMP1. 101 Load COMP1 with CMPLD2 upon successful compare with the value in COMP1. 102 Load CNTR with CMPLD1 upon successful compare with the value in COMP1. 103 Load CNTR with CMPLD1 upon successful compare with the value in COMP1. 104 Load CNTR with CMPLD1 upon successful compare with the value in COMP2. | Table 526. CCCTRL field descriptions(Continued) | Field | Description | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CMPMODE | Compare Mode These bits control when the COMP1 and COMP2 registers are used in regards to the counting direction. 00 COMP1 register is used when the counter is counting up. COMP2 register is used when the counter is counting up. 01 COMP1 register is used when the counter is counting down. COMP2 register is used when the counter is counting up. 10 COMP1 register is used when the counter is counting up. COMP2 register is used when the counter is counting down. 11 COMP1 register is used when the counter is counting down. COMP2 register is used when the counter is counting down. | | CPT2MODE | Capture 2 Mode Control These bits control the operation of the CAPT2 register as well as the operation of the ICF2 flag by defining which input edges cause a capture event. The input source is the secondary count source. 00 Disabled. 01 Capture falling edges. 10 Capture rising edges. 11 Capture any edge. | | CPT1MODE | Capture 1 Mode Control These bits control the operation of the CAPT1 register as well as the operation of the ICF1 flag by defining which input edges cause a capture event. The input source is the secondary count source. 00 Disabled. 01 Capture falling edges. 10 Capture rising edges. 11 Capture any edge. | | CFWM | Capture FIFO Water Mark This field represents the water mark level for the CAPT1 and CAPT2 FIFOs. The capture flags, ICF1 and ICF2, are not set until the word count of the corresponding FIFO is greater than this water mark level. | | ONESHOT | One-Shot Capture Mode This bit selects between free-running and one-shot mode for the input capture circuitry. If both capture circuits are enabled, then capture circuit 1 is armed first after the ARM bit is set. Once a capture occurs, capture circuit 1 is disarmed and capture circuit 2 is armed. After capture circuit 2 performs a capture, it is disarmed and the ARM bit is cleared. No further captures will be performed until the ARM bit is set again. If only one of the capture circuits is enabled, then a single capture will occur on the enabled capture circuit and the ARM bit is then cleared. If both capture circuits are enabled, then capture circuit 1 is armed first after the ARM bit is set. Once a capture occurs, capture circuit 1 is disarmed and capture circuit 2 is armed. After capture circuit 2 performs a capture, it is disarmed and capture circuit 1 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit. O Free-running mode is selected 1 One-shot mode is selected. | | | <u> </u> | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Field | Description | | ARM | Arm Capture Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self cleared when in one-shot mode and the enabled capture circuit(s) has had a capture event(s). O Input capture operation is disabled. Input capture operation as specified by the CPT1MODE and CPT2MODE bits is enabled. | Table 526. CCCTRL field descriptions(Continued) # 28.6.2.16 Input Filter Register (FILT) Figure 542. Input Filter register (FILT) Table 527. FILT field descriptions | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FILT_CNT[2:0] | Input Filter Sample Count These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. A value of 0 represents 3 samples. A value of 7 represents 10 samples. The value of FILT_CNT affects the input latency as described in Section 28.6.2.17: Input filter considerations. | | FILT_PER[7:0] | Input Filter Sample Period These bits represent the sampling period (in IPBus clock cycles) of the eTimer input signal. Each input is sampled multiple times at the rate specified by FILT_PER. If FILT_PER is 0x00 (default), then the input filter is bypassed. The value of FILT_PER affects the input latency as described in Section 28.6.2.17: Input filter considerations. | ### 28.6.2.17 Input filter considerations The FILT\_PER value should be set such that the sampling period is larger the period of the expected noise. This way a noise spike will only corrupt one sample. The FILT\_CNT value should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the FILT\_CNT + 3 power. The values of FILT\_PER and FILT\_CNT must also be traded off against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting FILT\_PER to a non-zero value) introduces a latency of: {[(FILT\_CNT + 3) × FILT\_PER] + 2} IPBus clock periods. # 28.6.3 Watchdog timer registers The base address of the Watchdog Timer registers is equal to the base address of the eTimer plus an offset of 0x100. These registers are implemented only on eTimer\_0. ## 28.6.3.1 Watchdog Time-Out registers (WDTOL and WDTOH) Figure 543. Watchdog Time-out Low Word register (WDTOL) Figure 544. Watchdog Time-Out High Word register (WDTOH) Table 528. WDTOL, WDTOH field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WDTO | Watchdog Time-out These registers are combined to form the 32-bit time-out count for the Timer watchdog function. This time-out count is used to monitor for inactivity on the inputs when channel 0 is in the quadrature decode count mode. The watchdog function is enabled whenever WDTO contains a non-zero value (although actual counting only occurs if channel 0 is in quadrature decode counting mode). The watchdog time-out down counter is loaded whenever WDTOH is written. These registers are not byte accessible. See Section 28.7.3.5: Watchdog timer for more information on the use of the watchdog timer. Note: The Watchdog registers are implemented only on eTimer_0. | # 28.6.4 Configuration registers The base address of the configuration registers is equal to the base address of the eTimer plus an offset of 0x010C. ## 28.6.4.1 Channel Enable register (ENBL) Figure 545. Channel Enable register (ENBL) Table 529. ENBL field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ENBL | Timer Channel Enable These bits enable the prescaler (if it is being used) and counter in each channel. Multiple ENBL bits can be set at the same time to synchronize the start of separate channels. If an ENBL bit is set, then the corresponding channel will start counting as soon as the CNTMODE field has a value other than 000. When an ENBL bit is clear, the corresponding channel maintains its current value. 0 Timer channel is disabled. 1 Timer channel is enabled. (default) | # 28.6.4.2 DMA Request Select registers (DREQ0, DREQ1) Figure 546. DMA Request 0 Select register (DREQ0) Figure 547. DMA Request 1 Select register (DREQ1) Table 530. DREQn field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DREQ <i>n</i> _EN | DMA Request Enable Use these bits to enable each of the four module level DMA request outputs. Program the DREQ fields prior to setting the corresponding enable bit. Clearing this enable bit will remove the request but will not clear the flag that is causing the request. 1 = DMA request enabled. 0 = DMA request disabled. | | DREQn | DMA Request Select Use these fields to select which DMA request source will be muxed onto one of the two module level DMA request outputs. Make sure each of the DREQ registers is programmed with a different value else a single DMA source will cause multiple DMA requests. Enable a DMA request in the channel specific INTDMA register after the DREQ registers are programmed. 00000 Channel 0 CAPT1 DMA read request 00001 Channel 0 CAPT2 DMA read request 00010 Channel 0 CMPLD1 DMA write request 00011 Channel 0 CMPLD1 DMA write request 00110 Channel 1 CAPT1 DMA read request 00110 Channel 1 CAPT2 DMA read request 00110 Channel 1 CMPLD1 DMA write request 00110 Channel 1 CMPLD1 DMA write request 00111 Channel 1 CMPLD2 DMA write request 01000 Channel 2 CAPT1 DMA read request 01001 Channel 2 CAPT2 DMA read request 01010 Channel 2 CMPLD1 DMA write request 01011 Channel 2 CMPLD2 DMA write request 01100 Channel 3 CAPT1 DMA read request 01101 Channel 3 CAPT2 DMA read request 01110 Channel 3 CAPT2 DMA read request 01111 Channel 3 CMPLD1 DMA write request 01111 Channel 3 CMPLD2 DMA write request 10110 Channel 4 CAPT2 DMA read request 10000 Channel 4 CAPT2 DMA read request 10010 Channel 4 CAPT2 DMA read request 10010 Channel 5 CAPT1 DMA read request 10010 Channel 5 CAPT1 DMA read request 10010 Channel 5 CAPT2 DMA read request 10110 write request 10110 Channel 5 CAPT2 DMA write request 10110 Channel 5 CAPT2 DMA read request 10110 Channel 5 CAPT2 DMA read request 10110 Channel 5 CAPT2 DMA write request 10110 Channel 5 CMPLD2 DMA write request 10110 Channel 5 CMPLD2 DMA write request 10110 Ch | # 28.7 Functional description ### 28.7.1 **General** Each channel has two basic modes of operation: it can count internal or external events, or it can count an internal clock source while an external input signal is asserted, thus timing the width of the external input signal. - The counter can count the rising, falling, or both edges of the selected input pin. - The counter can decode and count quadrature encoded input signals. - The counter can count up and down using dual inputs in a "count with direction" format. - The counter's terminal count value (modulo) is programmable. - The value that is loaded into the counter after reaching its terminal count is programmable. - The counter can count repeatedly, or it can stop after completing one count cycle. - The counter can be programmed to count to a programmed value and then immediately reinitialize, or it can count through the compare value until the count "rolls over" to zero. The external inputs to each counter/timer are shareable among each of the channels within the module. The external inputs can be used as: - Count commands - Timer commands - They can trigger the current counter value to be "captured" - They can be used to generate interrupt requests The polarity of the external inputs is selectable. The primary output of each channel is the output signal OFLAG. The OFLAG output signal can be: - Set, cleared, or toggled when the counter reaches the programmed value. - The OFLAG output signal may be output to an external pin instead of having that pin serve as a timer input. - The OFLAG output signal enables each counter to generate square waves, or pulse stream outputs. - The polarity of the OFLAG output signal is programmable. Any channel can be assigned as a Master. A master's compare signal can be broadcast to the other channels within the module. The other channels can be configured to reinitialize their counters and/or force their OFLAG output signals to predetermined values when a Master channel's compare event occurs. # 28.7.2 Counting modes The selected external signals are sampled at the eTimer's base clock rate and then run through a transition detector. The maximum count rate is one-half of the eTimer's base clock rate when using an external signal. Internal clock sources can be used to clock the counters at the eTimer's base clock rate. If a counter is programmed to count to a specific value and then stop, the CNTMODE field in the CTRL1 register is cleared when the count terminates. ### 28.7.2.1 STOP mode When the CNTMODE field is set to 000, the counter is inert. No counting will occur. Stop mode will also disable the interrupts caused by input transitions on a selected input pin. #### 28.7.2.2 COUNT mode When the CNTMODE field is set to 001, the counter will count the rising edges of the selected clock source. This mode is useful for generating periodic interrupts for timing purposes, or counting external events such as "widgets" on a conveyor belt passing a sensor. If the selected input is inverted by setting the PIPS bit, then the negative edge of the selected external input signal is counted. See Section 28.7.2.9: CASCADE-COUNT mode through Section 28.7.2.10: PULSE-OUTPUT mode for additional capabilities of this operating mode. ### 28.7.2.3 EDGE-COUNT mode When the CNTMODE field is set to 010, the counter will count both edges of the selected external clock source. This mode is useful for counting the changes in the external environment such as a simple encoder wheel. ### 28.7.2.4 GATED-COUNT mode When the CNTMODE field is set to 011, the counter will count while the selected secondary input signal is high. This mode is used to time the duration of external events. If the selected input is inverted by setting the PIPS bit, then the counter will count while the selected secondary input is low. ### 28.7.2.5 QUADRATURE-COUNT mode When the CNTMODE field is set to 100, the counter will decode the primary and secondary external inputs as quadrature encoded signals. Quadrature signals are usually generated by rotary or linear sensors used to monitor movement of motor shafts or mechanical equipment. The quadrature signals are square waves that are 90 degrees out of phase. The decoding of quadrature signal provides both count and direction information. *Figure 548* shows a timing diagram illustrating the basic operation of a quadrature incremental position encoder. Figure 548. Quadrature incremental position encoder ### 28.7.2.6 SIGNED-COUNT mode When the CNTMODE field is set to 101, the counter counts the primary clock source while the selected secondary source provides the selected count direction (up/down). #### 28.7.2.7 TRIGGERED-COUNT mode When the CNTMODE field is set to 110, the counter will begin counting the primary clock source after a positive transition (negative if SIPS = 1) of the secondary input occurs. The counting will continue until a compare event occurs or another positive input transition is detected. Subsequent secondary positive input transitions will continue to restart and stop the counting until a compare event occurs. Figure 549. Triggered Count mode (length = 1) ### 28.7.2.8 **ONE-SHOT** mode When the CNTMODE field is set to 110 and the counter is set to reinitialize at a compare event (LENGTH = 1), and the OFLAG OUTMODE is set to 0101 (cleared on init, set on compare), the counter works in ONE-SHOT mode. If an external events causes the counter to count, when terminal count is reached, the output is asserted. This delayed output can be used to provide timing delays. Figure 550. One-Shot mode (length = 1) ### 28.7.2.9 CASCADE-COUNT mode When the CNTMODE field is set to 111, the counter's input is connected to the output of another selected counter. The counter will count up and down as compare events occur in the selected source counter. This cascaded or "daisy-chained" mode enables multiple counters to be cascaded to yield longer counter lengths. When operating in cascade mode, a special high speed signal path is used between modules rather than the OFLAG output signal. If the selected source counter is counting up and it experiences a compare event, the counter will be incremented. If the selected source counter is counting down and it experiences a compare event, the counter will be decremented. Either one or two counters may be cascaded to create a 32-bit wide synchronous counter. Whenever any counter is read within a counter module, all of the counters' values within the module are captured in their respective HOLD registers. This action supports the reading of a cascaded counter chain. First read any counter of a cascaded counter chain, then read the HOLD registers of the other counters in the chain. The cascaded counter mode is synchronous. Note: It is possible to connect counters together by using the other (non-cascade) counter modes and selecting the outputs of other counters as a clock source. In this case, the counters are operating in a "ripple" mode, where higher order counters will transition a clock later than a purely synchronous design. One channel can be cascaded with any other channel, but channels cannot be cascaded more than two deep. Separate cascades of pairs of channels can be created. For example, channels 0 and 1 can be cascaded, and channels and cascaded separately. However, channels 0, 1, and 5 cannot be cascaded. #### 28.7.2.10 PULSE-OUTPUT mode When the counter is set up with CNTMODE = 001, and the OFLAG OUTMODE is set to 1111 (gated clock output), and the ONCE bit is set, then the counter will output a pulse stream of pulses that has the same frequency of the selected clock source, and the number of output pulses is equal to the compare value minus the init value. This mode is useful for driving step motor systems. Note: This does not work if the PRISRC is set to 11000. Figure 551. Pulse Output mode ### 28.7.2.11 Usage of compare registers The dual compare registers (COMP1 and COMP2) provide a bidirectional modulo count capability. The COMP1 register should be set to the desired maximum count value or 0xFFFF to indicate the maximum unsigned value prior to roll-over, and the COMP2 register should be set to the minimum count value or 0x0000 to indicate the minimum unsigned value prior to roll-under. Use caution when changing COMP1 and COMP2 while the counter is active. If the counter has already passed the new value, it will count to 0xFFFF or 0x0000, roll over, then begin counting toward the new value. The check is: CNTR = COMPx, *not* CNTR > COMP1 or CNTR < COMP2. Using the CMPLD1 and CMPLD2 registers to preload compare values helps to minimize this problem. ### 28.7.2.12 Usage of Compare Load registers The CMPLD1, CMPLD2, and CCCTRL registers offer a high degree of flexibility for loading compare registers with user-defined values on different compare events. To ensure correct functionality while using these registers, the following methods are recommended. The purpose of the compare load feature is to allow quicker updating of the compare registers. A compare register can be updated using interrupts. However, because of the latency between an interrupt event occurring and the service of that interrupt, there is the possibility that the counter may have already counted past the new compare value by the time the compare register is updated by the interrupt service routine. The counter would then continue counting until it rolled over and reached the new compare value. To address this, the compare registers are updated in hardware in the same way the counter register is reinitialized to the value stored in the LOAD register. The compare load feature allows the user to calculate new compare values and store them in to the comparator load registers. When a compare event occurs, the new compare values in the comparator load registers are written to the compare registers eliminating the use of software to do this. #### 28.7.2.13 MODULO COUNTING mode To create a modulo counter using COMP1 and COMP2 as the counter boundaries (instead of 0x0000 and 0xFFFF), set the registers in the following manner. Set CNTMODE to either 100 (quadrature count mode) or 101 (count with direction mode). Use count through rollover (LENGTH = 0) and continuous count (ONCE = 0). Set COMP1 and CMPLD1 to the upper boundary value. Set COMP2 and CMPLD2 to the lower boundary value. Set CMPMODE = 10 (COMP1 is used when counting up and COMP2 is used when counting down). Set CLC2 = 110 (load CNTR with value of CMPLD2 on COMP1 compare) and CLC1 = 111 (load CNTR with value of CMPLD1 on COMP2 compare). ### 28.7.3 Other features ### 28.7.3.1 Redundant OFLAG checking This mode allows the user to bundle two timer functions generating any pattern to compare their resulting OFLAG behaviors (output signal). The redundant mode is used to support online checks for functional safety reasons. Whenever a mismatch between the two adjacent channels occurs, it is reported via an interrupt to the core and the two outputs are put into their inactive states. An error is flagged via the RCF flag. This feature can be tested by forcing a transition on one of the OFLAGs using the VAL and FORCE bits of the channel. ### 28.7.3.2 Loopback checking This mode is always available in that one channel can generate an OFLAG while another channel uses the first channels' OFLAG as its input to be measured and verified to be as expected. ### 28.7.3.3 Input capture mode Input capture measures pulse width (by capturing the counter value on two successive input edges) or waveform period (by capturing the counter value on two consecutive rising edges or two consecutive falling edges). The capture registers store a copy of the counter's value when an input edge (positive, negative, or both) is detected. The type of edge to be captured by each circuit is determined by the CPT1MODE and CPT2MODE bits whose functionality is shown in *Figure 541*. The arming logic controls the operation of the capture circuits to allow captures to be performed in a free-running (continuous) or one-shot fashion. In free-running mode, the capture sequences will be performed indefinitely. If both capture circuits are enabled, they will work together in a ping-pong style where a capture event from one circuit leads to the arming of the other and vice versa. In one-shot mode, only one capture sequence will be performed. If both capture circuits are enabled, capture circuit 0 is armed first. When a capture event occurs, capture circuit 1 is armed. Once the second capture occurs, further captures are disabled until another capture sequence is initiated. Both capture circuits are capable of generating an interrupt to the CPU. ### 28.7.3.4 Master/Slave mode Any timer channel can be assigned as a Master (MSTR = 1). A Master's compare signal can be broadcast to the other channels within the module. The other counters can be configured to reinitialize their counters (COINIT = 1) and/or force their OFLAG output signals (COFRC = 1) to predetermined values when a Master counter compare event occurs. ### 28.7.3.5 Watchdog timer The watchdog timer monitors for a stalled count when channel 0 is in quadrature count mode. When the watchdog is enabled, it loads the time-out value into a down counter. The down counter counts as long as channel 0 is in quadrature decode count mode. If this down counter reaches 0, an interrupt is asserted. The down counter is reloaded to the time-out value each time the counter value from channel 0 changes. If the channel 0 count value is toggling between two values (indicating a possibly stalled encoder), then the down counter is not reloaded. ### 28.8 Clocks The eTimer module implements a protocol clock running at a frequency ≥ 120 MHz. # 28.9 Interrupts Each of the channels within the eTimer can generate an interrupt from several sources. The watchdog also generate interrupts. The interrupt service routine (ISR) must check the related interrupt enables and interrupt flags to determine the actual cause of the interrupt. **Table 531. Interrupt summary** | Table 55 f. Interrupt Summary | | | | | |----------------------------------|-------------------|---------------------|--------------------------------------|-------------------------------------------------| | Core<br>Interrupt | Interrupt<br>Flag | Interrupt<br>Enable | Name | Description | | | eTimer_0 | | | | | | TCF | TCFIE | Compare interrupt | Compare of counter and related compare register | | | TCF1 | TCF1IE | Compare 1 interrupt | Compare of the counter and COMP1 register | | | TCF2 | TCF2IE | Compare 2 interrupt | Compare of the counter and COMP2 register | | Channels | TOF | TOFIE | Overflow interrupt | Generated on counter roll-over or roll-under | | 0–5 | IELF | IELFIE | Input Low Edge interrupt | Falling edge of the secondary input signal | | | IEHF | IEHFIE | Input High Edge interrupt | Rising edge of the secondary input signal | | | ICF1 | ICF1IE | Input Capture 1 interrupt | Input capture event for CAPT1 | | | ICF2 | ICF2IE | Input Capture 2 interrupt | Input capture event for CAPT2 | | Watchdog | WDF | WDFIE | Watchdog time-out interrupt | Watchdog has timed out | | Redundant<br>Channel<br>Checking | RCF | RCFIE | Redundant Channel<br>Fault interrupt | Miscompare with redundant channel | | | | | eTimer_1 | | | | TCF | TCFIE | Compare interrupt | Compare of counter and related compare register | | | TCF1 | TCF1IE | Compare 1 interrupt | Compare of the counter and COMP1 register | | | TCF2 | TCF2IE | Compare 2 interrupt | Compare of the counter and COMP2 register | | Channels | TOF | TOFIE | Overflow interrupt | Generated on counter roll-over or roll-under | | 0–5 | IELF | IELFIE | Input Low Edge interrupt | Falling edge of the secondary input signal | | | IEHF | IEHFIE | Input High Edge interrupt | Rising edge of the secondary input signal | | | ICF1 | ICF1IE | Input Capture 1 interrupt | Input capture event for CAPT1 | | | ICF2 | ICF2IE | Input Capture 2 interrupt | Input capture event for CAPT2 | | Redundant<br>Channel<br>Checking | RCF | RCFIE | Redundant Channel<br>Fault interrupt | Miscompare with redundant channel | # 28.10 DMA # Table 532. DMA summary | DMA Request | DMA Enable | Name | Description | |-----------------|------------|----------------------|------------------------| | Channels<br>0–5 | ICF1DE | CAPT1 read request | CAPT1 contains a value | | | ICF2DE | CAPT2 read request | CAPT2 contains a value | | | CMPLD1DE | CMPLD1 write request | CMPLD1 needs an update | | | CMPLD2DE | CMPLD2 write request | CMPLD2 needs an update | # 29 Functional Safety # 29.1 Introduction This chapter describes the following modules that help add reliability to the SPC56xP60x/54x. - Register protection module - Software watchdog timer (SWT) # 29.2 Register protection module ### 29.2.1 Overview The register protection module offers a mechanism to protect defined memory-mapped address locations in a module under protection from being written. The address locations that can be protected are module-specific. The register protection module is located between the module under protection and the PBRIDGE. This is shown in *Figure 552*. Figure 552. Register protection module block diagram ### 29.2.2 Features The register protection module includes these features: - Restrict write accesses for the module under protection to supervisor mode only - Lock registers for first 6 KB of memory-mapped address space - Address mirror automatically sets corresponding lock bit - Once configured lock bits can be protected from changes # 29.2.3 Modes of operation The register protection module is operable when the module under protection is operable. ## 29.2.4 External signal description There are no external signals. # 29.2.5 Memory map and registers description This section provides a detailed description of the memory map of a module using the Register protection. The original 16 KB module memory space is divided into five areas as shown in *Figure 553*. Base + 0x0000 module register space 6 KB Area 1 Base + 0x1800 Area 2 2 KB Reserved Base + 0x2000 mirror module register space with user defined soft locking function Area 3 6 KB Base + 0x3800 1.5 KB Lock Bits Area 4 Base + 0x3E00 512 Bytes Configuration Area 5 Base + 0x3FFF Figure 553. Register protection memory diagram Area 1 is 6 KB and holds the normal functional module registers and is transparent for all read/write operations. Area 2, 2 KB starting at address 0x1800, is reserved. Area 3 is 6 KB, starting at address 0x2000 and is a mirror of area 1. A read/write access to these 0x2000 + X addresses will read/write the register at address X. As a side effect, a write access to address 0x2000 + X will set the optional Soft Lock Bits for this address X in the same cycle as the register at address X is written. Not all registers in area 1 need to have protection defined by associated Soft Lock Bits. For unprotected registers at address Y, accesses to address 0x2000 + Y will be identical to accesses at address Y. Only for registers implemented in area 1 and defined as protectable Soft Lock Bits will be available in area 4. Area 4 is 1.5 KB and holds the Soft Lock Bits, one bit per byte in area 1. The four Soft Lock Bits associated with one module register word are arranged at byte boundaries in the memory map. The Soft Lock Bit registers can be directly written using a bit mask. Area 5 is 512 bytes and holds the configuration bits of the protection mode. There is one configuration hard lock bit per module that prevents all further modifications to the Soft Lock Bits and can only be cleared by a system reset once set. The other bits, if set, will allow user access to the protected module. If any locked byte is accessed with a write transaction, a transfer error will be issued to the system and the write transaction will not be executed. This is true even if not all accessed bytes are locked. Accessing unimplemented 32-bit registers in areas 4 and 5 will result in a transfer error. ## 29.2.5.1 Register protection memory map Table 533 shows the registers in the Safety Port. Offset from **REG PROT BASE** Location Register (0xFFFE\_8000) Module Register 0 (MR0)–Module Register 6143(MR6143) 0x0000-0x17FF on page 923 0x1800-0x1FFF Reserved Module Register 0 (MR0) + Set Soft Lock Bit 0 (LMR0)-0x2000-0x37FF Module Register 6143 (MR6143) + Set Soft Lock Bit 6143 on page 923 (LMR6143) Soft Lock Bit Register 0 (SLBR0): Soft Lock Bits 0:3-0x3800-0x3DFF Soft Lock Bit Register 1535 (SLBR1535): Soft Lock Bits on page 923 6140:6143 0x3E00-0x3FFB Reserved 0x3FFC Global Configuration Register (GCR) on page 924 Table 533. Register protection memory map Note: Reserved registers in area #2 will be handled according to the protected IP (module under protection). ### 29.2.5.2 Registers description This section describes in address order all the register protection registers. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order. ## 29.2.5.2.1 Module registers (MR0-6143) This is the lower 6 KB module memory space that holds all the functional registers of the module that is protected by the register protection module. ### 29.2.5.2.2 Module Register and Set Soft Lock Bit (LMR0-6143) This is memory area #3 that provides mirrored access to the MR0–6143 registers with the side effect of setting Soft Lock Bits in case of a write access to a MR that is defined as protectable by the locking mechanism. Each MR is protectable by one associated bit in a SLBRn[SLBm], according to the mapping described in *Table 534*. ### 29.2.5.2.3 Soft Lock Bit Register (SLBR0-1535) These registers hold the Soft Lock Bits for the protected registers in memory area #1. Figure 554. Soft Lock Bit Register (SLBRn) Table 534. SLBRn field descriptions | Field | Description | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WE0<br>WE1<br>WE2<br>WE3 | Write Enable Bits for Soft Lock Bits (SLB): WE0 enables writing to SLB0. WE1 enables writing to SLB1. WE2 enables writing to SLB2. WE3 enables writing to SLB3. 0 SLB is not modified. 1 Value is written to SLB. | | SLB0<br>SLB1<br>SLB2<br>SLB3 | Soft Lock Bits for one MR $n$ register:<br>SLB0 can block accesses to MR[ $(n \times 4) + 0$ ]<br>SLB1 can block accesses to MR[ $(n \times 4) + 1$ ]<br>SLB2 can block accesses to MR[ $(n \times 4) + 2$ ]<br>SLB3 can block accesses to MR[ $(n \times 4) + 3$ ]<br>0 Associated MR $n$ byte is unprotected and writeable.<br>1 Associated MR $n$ byte is locked against write accesses. | *Table 535* gives some examples how SLBR*n*[SLB] and MR*n* correspond. Table 535. Soft Lock Bits vs. Protected Address | Soft Lock Bit | Protected address | |---------------|-------------------| | SLBR0[SLB0] | MR0 | | SLBR0[SLB1] | MR1 | | SLBR0[SLB2] | MR2 | | Table 535. Soft Lock Bits vs. Protected Address(Continued) | | | |------------------------------------------------------------|-------------------|--| | Soft Lock Bit | Protected address | | | Soft Lock Bit | Protected address | |---------------|-------------------| | SLBR0[SLB3] | MR3 | | SLBR1[SLB0] | MR4 | | SLBR1[SLB1] | MR5 | | SLBR1[SLB2] | MR6 | | SLBR1[SLB3] | MR7 | | SLBR2[SLB0] | MR8 | | | | # 29.2.5.2.4 Global Configuration Register (GCR) The Global Configuration Register (GCR) controls global configurations related to register protection. Figure 555. Global Configuration Register (GCR) Table 536. GCR field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HLB | Hard Lock Bit This register cannot be cleared once it is set by software. It can only be cleared by a system reset. O All SLB bits are accessible and can be modified. 1 All SLB bits are write protected and can not be modified. | | UAA | User Access Allowed 0 The registers in the module under protection can only be written in supervisor mode. All write accesses in non-supervisor mode are not executed and a transfer error is issued. This access restriction is in addition to any access restrictions imposed by the protected IP module. 1 The registers in the module under protection can be accessed in the mode defined for the module registers without any additional restrictions. | Note: The GCR[UAA] bit has no effect on the allowed access modes for the registers in the Register protection module. ## 29.2.6 Functional description ### 29.2.6.1 General This module provides a generic register (address) write-protection mechanism. The protection size can be: - 32-bit (address == multiples of 4) - 16-bit (address == multiples of 2) - 8-bit (address == multiples of 1) - unprotected (address == multiples of 1) For all addresses that are protected there are SLBR*n*[SLB*m*] bits that specify whether the address is locked. When an address is locked it can only be read but not written in any mode (supervisor/normal). If an address is unprotected the corresponding SLBR*n*[SLB*m*] bit is always 0b0 no matter what software is writing to. ### 29.2.6.2 Change lock settings To change the setting whether an address is locked or unlocked, the corresponding SLBRn[SLBm] bit needs to be changed. This can be done using the following methods: - Modify the SLBRn[SLBm] bit directly by writing to area #4 - Set the SLBR*n*[SLB*m*] bit(s) by writing to the mirror module space (area #3) Both methods are explained in the following sections. ## 29.2.6.2.1 Change lock settings directly via area #4 In memory area #4 the lock bits are located. They can be modified by writing to them. Each SLBR*n*[SLB*m*] bit has a corresponding SLBR*n*[WE*m*] mask bit, which protects it from being modified. This masking makes clear-modify-write operations unnecessary. Figure 556 shows two modification examples. In the left example there is a write access to the SLBRn register specifying a mask value that allows modification of all SLBRn[SLBm] bits. The example on the right specifies a mask that only allows modification of the bits SLBRn[SLB[3:1]]. write data write data to SLB0 to SLB1 to SLB2 to SLB3 to SLB0 to SLB1 to SLB2 to SLB3 SLBRn[WE[3:0]] 0 SLBRn[WE[3:0]] 1 1 1 1 1 change allowed change allowed SLB3 | SLBRn[SLB[3:0]] SLB0 SLB1 SLB2 SLB0 SLB1 SLB2 SLB3 SLBRn[SLB[3:0]] Figure 556. Change lock settings directly via area #4 *Figure 556* showed four registers that can be protected 8-bit wise. In *Figure 557* registers with 16-bit protection and in *Figure 558* registers with 32-bit protection are shown. to SLB0 to SLB1 to SLB2 to SLB3 write data to SLB0 to SLB1 to SLB2 to SLB3 write data Χ SLBRn[WE[3:0]] 0 SLBRn[WE[3:0]] Χ 1 Χ 0 update lock bits update lock bits SLB0 SLB1 SLB2 SLB2 SLB3 SLB0 SLB1 SLB3 **SLBR SLBR** Figure 557. Change lock settings for 16-bit protected addresses On the right side of *Figure 557* it is shown that the data written to SLBR*n*[SLB0] is automatically written to SLBR*n*[SLB1] also. This is done as the address reflected by SLBR*n*[SLB0] is protected 16-bit wise. Note that in this case the write enable SLBR*n*[WE0] must be set while SLBR*n*[WE1] does not matter. As the enable bits SLBR*n*[WE[3:2]] are cleared the lock bits SLBR*n*[SLB[3:2]] remain unchanged. In the example on the left side of *Figure 557* the data written to SLBR*n*[SLB0] is mirrored to SLBR*n*[SLB1] and the data written to SLBR*n*[SLB2] is mirrored to SLBR*n*[SLB3] as for both registers the write enables are set. In *Figure 558* a 32-bit wise protected register is shown. When SLBR*n*[WE0] is set the data written to SLBR*n*[SLB0] is automatically written to SLBR*n*[SLB[3:1]] also. Otherwise SLBR*n*[SLB[3:0]] remains unchanged. Figure 558. Change lock settings for 32-bit protected addresses *Figure 559* shows an example that has a mixed protection size configuration. Figure 559. Change lock settings for mixed protection The data written to SLBR*n*[SLB0] is mirrored to SLBR*n*[SLB1] as the corresponding register is 16-bit protected. The data written to SLBR*n*[SLB2] is blocked as the corresponding register is unprotected. The data written to SLBR*n*[SLB3] is written to SLBR*n*[SLB3]. ### 29.2.6.2.2 Enable locking via mirror module space (area #3) It is possible to enable locking for a register after writing to it. To do so the mirrored module address space must be used. *Figure 560* shows one example. Figure 560. Enable locking via mirror module space (area #3) When writing to address 0x0008 the registers MR9 and MR8 in the protected module are updated. The corresponding lock bits remain unchanged (left part of *Figure 557*). When writing to address 0x2008 the registers MR9 and MR8 in the protected module are updated. The corresponding lock bits SLBR2.SLB[1:0] are set while the lock bits SLBR2.SLB[3:2] remain unchanged (right part of *Figure 557*). Figure 561 shows an example where some addresses are protected and some are not. Figure 561. Enable locking for protected and unprotected addresses In the example in *Figure 561*, addresses 0x0C and 0x0D are unprotected. Therefore their corresponding lock bits SLBR3.SLB[1:0] are always 0b0 (shown in bold). When doing a 32-bit write access to address 0x200C only lock bits SLBR3.SLB[3:2] are set while bits SLBR3.SLB[1:0] stay 0b0. Note: Lock bits can only be set via writes to the mirror module space. Reads from the mirror module space will not change the lock bits. ### 29.2.6.2.3 Write protection for locking bits Changing the locking bits through any of the procedures mentioned in Section 29.2.6.2.1: Change lock settings directly via area #4, and Section 29.2.6.2.2: Enable locking via mirror module space (area #3) is only possible as long as the GCR[HLB] bit is cleared. Once this bit is set the locking bits can no longer be modified until there was a system reset. ### 29.2.6.3 Access errors The protection module generates transfer errors under several circumstances. For the area definition refer to *Figure 553*. - 1. If accessing area #1 or area #3, the protection module will pass on any access error from the underlying Module under Protection. - If user mode is not allowed, user writes to all areas will assert a transfer error and the writes will be blocked. - If accessing the reserved area #2, a transfer error will be asserted. - If accessing unimplemented 32-bit registers in area #4 and area #5 a transfer error will be asserted. - If writing to a register in area #1 and area #3 with Soft Lock Bit set for any of the affected bytes a transfer error is asserted and the write will be blocked. Also the complete write operation to non-protected bytes in this word is ignored. - If writing to a Soft Lock Register in area #4 with the Hard Lock Bit being set a transfer error is asserted. - Any write operation in any access mode to area #3 while Hard Lock Bit GCR[HLB] is set ### 29.2.7 Reset The reset state of each individual bit is shown in *Section 29.2.5.2: Registers description*. In summary, after reset, locking for all MR*n* registers is disabled. The registers can be accessed in Supervisor Mode only. # 29.3 Software Watchdog Timer (SWT) #### 29.3.1 Overview The Software Watchdog Timer (SWT) is a peripheral module that can prevent system lockup in situations such as software getting trapped in a loop or if a bus transaction fails to terminate. When enabled, the SWT requires periodic execution of a watchdog servicing sequence. Writing the sequence resets the timer to a specified time-out period. If this servicing action does not occur before the timer expires the SWT generates an interrupt or hardware reset. The SWT can be configured to generate a reset or interrupt on an initial time-out, a reset is always generated on a second consecutive time-out. The SWT provides a window functionality. When this functionality is programmed, the servicing action should take place within the defined window. When occurring outside the defined period, the SWT will generate a reset. ### 29.3.2 Features The SWT has the following features: - 32-bit time-out register to set the time-out period - The unique SWT counter clock is the undivided low power internal oscillator (IRC 16 MHz), no other clock source can be selected - Programmable selection of window mode or regular servicing - Programmable selection of reset or interrupt on an initial time-out - Master access protection - Hard and soft configuration lock bits - The SWT is started on exit of power-on phase (RGM phase 2) to monitor flash boot sequence phase. It is then reset during RGM phase 3 and optionally enabled when platform reset is released depending on value of flash user option bit 31 (WATCHDOG\_EN). ## 29.3.3 Modes of operation The SWT supports three device modes of operation: normal, debug and stop. When the SWT is enabled in normal mode, its counter runs continuously. In debug mode, operation of the counter is controlled by the FRZ bit in the SWT\_CR. If the FRZ bit is set, the counter is stopped in debug mode, otherwise it continues to run. In stop mode, operation of the counter is controlled by the STP bit in the SWT\_CR. If the STP bit is set, the counter is stopped in stop mode, otherwise it continues to run. As soon as out of stop mode, SWT will continue from the state it was before entering this mode. Software watchdog is not available during stand-by. As soon as out of stand-by, the SWT behaves as in a usual "out of reset" situation. ### 29.3.4 External signal description The SWT module does not have any external interface signals. # 29.3.5 SWT memory map and registers description The SWT programming model has six 32-bit registers, listed in *Table 537*. The programming model can only be accessed using 32-bit (word) accesses. References using a different size are invalid. Other types of invalid accesses include: writes to read only registers, incorrect values written to the service register when enabled, accesses to reserved addresses and accesses by masters without permission. If the RIA bit in the SWT\_CR is set, the SWT generates a system reset on an invalid access. Otherwise, a bus error is generated. If either the HLK or SLK bits in the SWT\_CR are set, then the SWT\_CR, SWT\_TO and SWT\_WN registers are read only. Table 537. SWT memory map | Offset from<br>SWT_BASE<br>0xFFF3_8000 (SWT_0)<br>0x8FF3_8000 (SWT_1) | Register | Location | |-----------------------------------------------------------------------|-------------------------------|-------------| | 0x0000 | SWT_CR—SWT Control Register | on page 930 | | 0x0004 | SWT_IR—SWT Interrupt Register | on page 932 | | Offset from<br>SWT_BASE<br>0xFFF3_8000 (SWT_0)<br>0x8FF3_8000 (SWT_1) | Register | Location | |-----------------------------------------------------------------------|------------------------------------|-------------| | 0x0008 | SWT_TO—SWT Time-Out register | on page 932 | | 0x000C | SWT_WN—SWT Window Register | on page 933 | | 0x0010 | SWT_SR—SWT Service Register | on page 933 | | 0x0014 | SWT_CO—SWT Counter Output register | on page 934 | | 0x0018 | SWT_SK—SWT Service Key register | on page 935 | | 0x001C-0x03FF | Reserved | | Table 537. SWT memory map(Continued) ## 29.3.5.1 SWT Control Register (SWT\_CR) The SWT\_CR contains fields for configuring and controlling the SWT. The reset value of this register is device specific. Some devices can be configured to automatically clear the SWT\_CR[WEN] bit during the boot process. This register is read-only if either the SWT\_CR[HLK] or SWT\_CR[SLK] bits are set. Figure 562. SWT Control Register (SWT\_CR) The default reset value for SWT\_0 is 0xFF00\_011B, corresponding to MAP1 = 1 (only data bus access allowed), RIA = 1 (reset on invalid SWT access), SLK = 1 (soft lock), CSL = 1 (IRC clock source for counter), FRZ = 1 (freeze on debug), WEN = 1 (watchdog enable). This last bit is cleared when exiting ME RESET mode in case flash user option bit 31 (WATCHDOG\_EN) is 0. For SWT\_1 the reset value is 0xFF00\_011A and WEN = 0 (watchdog disabled). Table 538. SWT\_CR field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 014 | · | | MAPn | Master Access Protection for Master <i>n</i> The platform bus master assignments are device specific. 0 Access for the master is disabled. 1 Access for the master is enabled. Note: The Master n refers to the Logical Master ID, for details please refer Table 130: Logical master IDs. Master can have Logical Master ID higher than 0x7 and SWT only looks at the 3 LSB of this ID. | | KEY | Keyed Service Mode 0 Fixed Service Sequence, the fixed sequence 0xA602, 0xB480 is used to service the watchdog. 1 Keyed Service Mode, two pseudorandom key values are used to service the watchdog. | | RIA | Reset on Invalid Access 0 Invalid access to the SWT generates a bus error. 1 Invalid access to the SWT causes a system reset if WEN = 1. | | WND | Window Mode O Regular mode, service sequence can be done at any time. Windowed mode, the service sequence is only valid when the down counter is less than the value in the SWT_WN register. | | ITR | Interrupt Then Reset O Generate a reset on a time-out. Generate an interrupt on an initial time-out, reset on a second consecutive time-out. | | HLK | Hard Lock This bit is only cleared at reset. 0 SWT_CR, SWT_TO and SWT_WN are read/write registers if SLK = 0. 1 SWT_CR, SWT_TO and SWT_WN are read only registers. | | SLK | Soft Lock This bit is cleared by writing the unlock sequence to the service register. 0 SWT_CR, SWT_TO and SWT_WN are read/write registers if HLK = 0. 1 SWT_CR, SWT_TO and SWT_WN are read only registers. | | CSL | Clock Selection Selects the internal 16 MHz IRC oscillator clock that drives the internal timer. CSL bit can be written. The status of the bit has no effect on counter clock selection on the device. O System clock. (Not applicable in SPC56xP60x/54x). Oscillator clock. | | STP | Stop Mode Control Allows the watchdog timer to be stopped when the device enters stop mode. 0 SWT counter continues to run in stop mode. 1 SWT counter is stopped in stop mode. | | FRZ | Debug Mode Control Allows the watchdog timer to be stopped when the device enters debug mode. 0 SWT counter continues to run in debug mode. 1 SWT counter is stopped in debug mode. | | WEN | Watchdog Enabled 0 SWT is disabled. 1 SWT is enabled. | ## 29.3.5.2 SWT Interrupt Register (SWT\_IR) The SWT\_IR contains the time-out interrupt flag. Figure 563. SWT Interrupt Register (SWT\_IR) Table 539. SWT\_IR field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIF | Time-out Interrupt Flag The flag and interrupt are cleared by writing a 1 to this bit. Writing a 0 has no effect. O No interrupt request. Interrupt request due to an initial time-out. | # 29.3.5.3 SWT Time-Out register (SWT\_TO) The SWT Time-Out (SWT\_TO) register contains the 32-bit time-out period. The reset value for this register is device specific. This register is read only if either the SWT\_CR[HLK] or SWT\_CR[SLK] bits are set. Figure 564. SWT Time-Out register (SWT\_TO) The default counter value (SWT\_TO\_RST) is 0x0003\_A980, which corresponds to approximately 15 ms with the 16 MHz IRC clock. Table 540. SWT\_TO field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WTO | Watchdog time-out period in clock cycles An internal 32-bit down counter is loaded with this value or 0x0100, whichever is greater when the service sequence is written or when the SWT is enabled. | # 29.3.5.4 SWT Window Register (SWT\_WN) The SWT Window (SWT\_WN) register contains the 32-bit window start value. This register is cleared on reset. This register is read only if either the SWT\_CR[HLK] or SWT\_CR[SLK] bits are set. Figure 565. SWT Window register (SWT\_WN) Table 541. SWT\_WN field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | WST | Window start value When window mode is enabled, the service sequence can only be written when the internal down counter is less than this value. | # 29.3.5.5 SWT Service Register (SWT\_SR) The SWT Time-Out (SWT\_SR) service register is the target for service sequence writes used to reset the watchdog timer. Figure 566. SWT Service Register (SWT\_SR) Table 542. SWT\_SR field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WSC | Watchdog Service Code This field services the watchdog and clears the SWT_CR[SLK] soft lock bit. To service the watchdog, the value 0xA602 followed by 0xB480 is written to the WSC field. To clear the SWT_CR[SLK] soft lock bit, the value 0xC520 followed by 0xD928 is written to the WSC field. | # 29.3.5.6 SWT Counter Output register (SWT\_CO) The SWT Counter Output (SWT\_CO) register is a read only register that shows the value of the internal down counter when the SWT is disabled. Figure 567. SWT Counter Output register (SWT\_CO) Table 543. SWT\_CO field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CNT | Watchdog Count When the watchdog is disabled (SWT_CR[WEN]=0) this field shows the value of the internal down counter. When the watchdog is enabled the value of this field is 0x0000_0000. Values in this field can lag behind the internal counter value for as many as 6 system plus 8 counter clock cycles. Therefore, the value read from this field immediately after disabling the watchdog may be higher than the actual value of the internal counter. | ## 29.3.5.7 SWT Service Key Register (SWT\_SK) The SWT Service Key (SWT\_SK) register holds the previous (or initial) service key value. This register is read only if either the SWT\_CR[HLK] or SWT\_CR[SLK] bits are set. Figure 568. SWT Service Key Register (SWT\_SK) Table 544. SWT\_SK field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Service Key This field is the previous (or initial) service key value used in keyed service mode. If SWT_CR[KEY] is set, the next key value to be written to the SWT_SK is (17*SK+3) mod 2 <sup>16</sup> . | # 29.3.6 Functional description The SWT is a 32-bit timer designed to enable the system to recover in situations such as software getting trapped in a loop or if a bus transaction fails to terminate. It includes a control register (SWT\_CR), an interrupt register (SWT\_IR), a time-out register (SWT\_TO), a window register (SWT\_WN), a service register (SWT\_SR), a counter output register (SWT\_CO) and a service key register (SWT\_SK). The SWT\_CR includes bits to enable the timer, set configuration options and lock configuration of the module. The watchdog is enabled by setting the SWT\_CR[WEN] bit. The reset value of the SWT\_CR[WEN] bit is device specific. If the reset value of this bit is 1, the watchdog starts operation automatically after reset is released. Some devices can be configured to clear this bit automatically during the boot process. The SWT\_TO register holds the watchdog time-out period in clock cycles unless the value is less than 0x100 in which case the time-out period is set to 0x100. This time-out period is loaded into an internal 32-bit down counter when the SWT is enabled and each time a valid service operation is performed. The SWT\_CR[CSL] bit selects which clock (system or oscillator) is used to drive the down counter. The reset value of the SWT\_TO register is device specific. The configuration of the SWT can be locked through use of either a soft lock or a hard lock. In either case, when locked the SWT\_CR, SWT\_TO, SWT\_WN and SWT\_SK registers are read only. The hard lock is enabled by setting the SWT\_CR[HLK] bit which can only be cleared by a reset. The soft lock is enabled by setting the SWT\_CR[SLK] bit and is cleared by writing the unlock sequence to the service register. The unlock sequence is a write of 0xC520 followed by a write of 0xD928 to the SWT\_SR[WSC] field. There is no timing requirement between the two writes. The unlock sequence logic ignores service sequence writes and recognizes the 0xC520, 0xD928 sequence regardless of previous writes. The unlock sequence can be written at any time and does not require the SWT\_CR[WEN] bit to be set. When enabled, the SWT requires periodic execution of a servicing operation which consists of writing two values to the SWT\_SR. Writing the proper sequence of values loads the internal down counter with the time-out period. There is no timing requirement between the two writes and the service sequence logic ignores unlock sequence writes. If the SWT\_CR[KEY] bit is zero, the fixed sequence 0xA602, 0xB480 is written to the SWT\_SR[WSC] field to service the watchdog. If the SWT\_CR[KEY] bit is set, then two pseudorandom keys are written to the SWT\_SR[WSC] field to service the watchdog. The key values are determined by the pseudorandom key generator defined in *Figure 569*. This algorithm will generate a sequence of 2<sup>16</sup> different key values before repeating. The state of the key generator is held in the SWT\_SK register. For example, if SWT\_SK[SK] is 0x0100 then the service sequence keys are 0x1103, 0x2136. In this mode, each time a valid key is written to the SWT\_SR, the SWT\_SK register is updated. So, after servicing the watchdog by writing 0x1103 and then 0x2136 to the SWT\_SR[WSC] field, SWT\_SK[SK] is 0x2136 and the next key sequence is 0x3499, 0x7E2C. ### Figure 569. Pseudorandom Key Generator $$SK_{n+1} = (17*SK_n+3) \mod 2^{16}$$ Accesses to SWT registers occur with no peripheral bus wait states. (The peripheral bus bridge may add one or more system wait states.) However, due to synchronization logic in the SWT design, recognition of the service sequence or configuration changes may require up to three system plus seven counter clock cycles. If window mode is enabled (SWT\_CR[WND] bit is set), the service sequence must be performed in the last part of the time-out period defined by the window register. The window is open when the down counter is less than the value in the SWT\_WN register. Outside of this window, service sequence writes are invalid accesses and generate a bus error or reset depending on the value of the SWT\_CR[RIA] bit. For example, if the SWT\_TO register is set to 5000 and SWT\_WN register is set to 1000 then the service sequence must be performed in the last 20% of the time-out period. There is a short lag in the time it takes for the window to open due to synchronization logic in the watchdog design. This delay could be up to three system plus four counter clock cycles. The interrupt then reset bit (SWT\_CR[ITR]) controls the action taken when a time-out occurs. If the SWT\_CR[ITR] bit is not set, a reset is generated immediately on a time-out. If the SWT\_CR[ITR] bit is set, an initial time-out causes the SWT to generate an interrupt and load the down counter with the time-out period. If the service sequence is not written before the second consecutive time-out, the SWT generates a system reset. The interrupt is indicated by the time-out interrupt flag (SWT\_IR[TIF]). The interrupt request is cleared by writing a one to the SWT\_IR[TIF] bit. The SWT\_CO register shows the value of the down counter when the watchdog is disabled. When the watchdog is enabled this register is cleared. The value shown in this register can lag behind the value in the internal counter for up to six system plus eight counter clock cycles. The SWT\_CO can be used during a software self test of the SWT. For example, the SWT can be enabled and not serviced for a fixed period of time less than the time-out value. Then RM0083 Functional Safety the SWT can be disabled (SWT\_CR[WEN] cleared) and the value of the SWT\_CO read to determine if the internal down counter is working properly. # 30 Fault Collection and Control Unit (FCCU) #### 30.1 Introduction The Fault Collection and Control Unit (FCCU) offers a programmable redundant hardware channel to collect errors and to lead the device in a controlled way to a safe state when a failure is present in the device. No CPU intervention is requested for collection and control operation. The FCCU offers a systematic approach to manage fault detection and control. The main functions supported by the module are: - Configurable and graded fault control via user software control - Internal reactions: - No reset reaction - IRQ - External reaction (failure is reported to the outside world via output pins) - Watchdog timer for the re-configuration phase - Configuration lock - NVM configuration loading - Self checking capabilities: - FCCU internal control logic redundancy - Additional parity check for the associated configuration registers Two classes of faults — critical and non-critical — are identified based on the criticality and the related reactions. Internal (short or long 'functional' reset, interrupt request) and external (FCCU\_F signaling) reactions are statically defined or programmable based on the fault criticality. The default configuration can be modified only in a specific FCCU state for application/test/debugging purposes. ## 30.1.1 Glossary and acronyms Table 545. Acronyms | Term | Description | |------|-----------------------------| | RCC | Redundancy control checkers | | IPS | Internal peripheral system | | NMI | Non-maskable interrupts | | IRQ | Interrupt request | | FSM | Finite state machine | | CF | Critical fault | | NCF | Non-critical fault | | WS | Wait state | | SW | Software | ## Table 545. Acronyms(Continued) | Term | Description | | | | | | | | | |------|-------------------------|--|--|--|--|--|--|--|--| | NVM | Nonvolatile memory | | | | | | | | | | CPU | Central processing unit | | | | | | | | | ## 30.2 Main features - Management of: - 32 critical faults - 32 non-critical faults - Hardware or software fault recovery management - Fault detection collection - Fault injection (fake faults) - External reaction via fault-state dedicated system signals (FCCU\_F pins) - Internal (chip) reactions (alarm state): interrupt request - Internal (chip) reactions (fault state): - Bi-Stable, Dual-Rail and Time Switching output protocols using FCCU\_F pins - Internal (to the FCCU) watchdog timer for the re-configuration phase - Configuration lock - NVM configuration loading - Self-checking capabilities: - FSM redundancy - Parity check for the configuration registers ## 30.3 Block diagram The top-level diagram of the FCCU is shown in Figure 570. Figure 570. FCCU top-level diagram As shown in Figure 570, the FCCU includes the following sub-modules: - REG if: it includes the register file, the register interface, the IRQ interface and the parity block (PB) for the configuration registers. - HNSHK blocks (master and slave blocks): it includes the FSMs to support the handshake between the REG if and the FSM unit due to the usage of 2 asynchronous clocks (system clock and IRCOSC clock). - Finite State Machine (FSM) units implement the main functions of the FCCU. These units also include also the watchdog timer (WDOG), the SAFE mode request timer (SMRT), and the alarm timer (ALRT). - FAULT if: implements the interface for the fault conditioning and management - FCCU Fx units implement the output stage to manage the FCCU F pins. - RCCx units implement the redundancy control checker to monitor the FSM unit state and its configuration. # 30.4 Signal description The FCCU generates two external signals, FCCU\_F[0] and FCCU\_F[1]. These are described in *Section 30.7.8: FCCU\_F interface*. # 30.5 Register interface The register interface is a slave bus used for configuration purposes via the CPU. The following bus operations are supported: - Word (32-bit) data write/read operations to any registers - Low and high half-words (16-bit, data[0:15] or data[16:31]) data write/read operations to any registers - Byte (8 bits, data[0:7] or data[8:15] or data[16:23] or data[24:31]) data write/read operations to any registers Any other operation (free byte enables, misaligned word or half-word access or other operations) are not supported. The FCCU generates a transfer error in the following cases: - Any write/read access executed outside the address space of the peripheral - Any write/read operation different from byte/halfword/word (free byte enables, misaligned access, or other operations) on each register - Any write access to the configuration registers not executed while the FCCU is not in CONFIG state The registers of the FCCU are accessible (read/write) in each access mode: user, supervisor, or test. ## 30.6 Memory map and register description The FCCU registers are listed in *Table 546*. The contents of the configuration registers (labeled as "W in CONFIG state only" in the Access column) can be locked by the OP16 operation as defined in the FCCU\_CTRL register. Table 546. FCCU memory map | Address offset | Register | Access <sup>(1)</sup> | Location | |----------------|---------------------------------------------------|----------------------------------------|-------------| | 0x00 | FCCU Control Register (FCCU_CTRL) | R/W always | on page 943 | | 0x04 | FCCU CTRL Key Register (FCCU_CTRLK) | W always | on page 946 | | 0x08 | FCCU Configuration Register (FCCU_CFG) | R always;<br>W in CONFIG<br>state only | on page 946 | | 0x0C | FCCU CF Configuration Register 0 (FCCU_CF_CFG0) | | | | 0x10 | FCCU CF Configuration Register 1 (FCCU_CF_CFG1) | R always; | on nage 040 | | 0x14 | FCCU CF Configuration Register 2 (FCCU_CF_CFG2) | W in CONFIG<br>state only | on page 949 | | 0x18 | FCCU CF Configuration Register 3 (FCCU_CF_CFG3) | | | | 0x1C | FCCU NCF Configuration Register 0 (FCCU_NCF_CFG0) | | | | 0x20 | FCCU NCF Configuration Register 1 (FCCU_NCF_CFG1) | R always;<br>W in CONFIG | on page 950 | | 0x24 | FCCU NCF Configuration Register 2 (FCCU_NCF_CFG2) | state only | on page 930 | | 0x28 | FCCU NCF Configuration Register 3 (FCCU_NCF_CFG3) | | | Table 546. FCCU memory map(Continued) | Address offset | Register | Access <sup>(1)</sup> | Location | | |----------------|-----------------------------------------------------|------------------------|-------------|--| | 0x2C | FCCU CFS Configuration Register 0 (FCCU_CFS_CFG0) | | | | | 0x30 | FCCU CFS Configuration Register 1 (FCCU_CFS_CFG1) | | | | | 0x34 | FCCU CFS Configuration Register 2 (FCCU_CFS_CFG2) | | | | | 0x38 | FCCU CFS Configuration Register 3 (FCCU_CFS_CFG3) | R always; | on nago 050 | | | 0x3C | FCCU CFS Configuration Register 4 (FCCU_CFS_CFG4) | W in CONFIG state only | on page 950 | | | 0x40 | FCCU CFS Configuration Register 5 (FCCU_CFS_CFG5) | | | | | 0x44 | FCCU CFS Configuration Register 6 (FCCU_CFS_CFG6) | | | | | 0x48 | FCCU CFS Configuration Register 7 (FCCU_CFS_CFG7) | | | | | 0x4C | FCCU NCFS Configuration Register 0 (FCCU_NCFS_CFG0) | | | | | 0x50 | FCCU NCFS Configuration Register 1 (FCCU_NCFS_CFG1) | | | | | 0x54 | FCCU NCFS Configuration Register 2 (FCCU_NCFS_CFG2) | | | | | 0x58 | FCCU NCFS Configuration Register 3 (FCCU_NCFS_CFG3) | R always; | 050 | | | 0x5C | FCCU NCFS Configuration Register 4 (FCCU_NCFS_CFG4) | W in CONFIG state only | on page 952 | | | 0x60 | FCCU NCFS Configuration Register 5 (FCCU_NCFS_CFG5) | | | | | 0x64 | FCCU NCFS Configuration Register 6 (FCCU_NCFS_CFG6) | | | | | 0x68 | FCCU NCFS Configuration Register 7 (FCCU_NCFS_CFG7) | | | | | 0x6C | FCCU CF Status Register 0 (FCCU_CFS0) | | | | | 0x70 | FCCU CF Status Register 1 (FCCU_CFS1) | DAM almana | on none 050 | | | 0x74 | FCCU CF Status Register 2 (FCCU_CFS2) | R/W always | on page 952 | | | 0x78 | FCCU CF Status Register 3 (FCCU_CFS3) | | | | | 0x7C | FCCU CF Key Register (FCCU_CFK) | W always | on page 954 | | | 0x80 | FCCU NCF Status Register 0 (FCCU_NCFS0) | | | | | 0x84 | FCCU NCF Status Register 1 (FCCU_NCFS1) | DAM almana | on none 054 | | | 0x88 | FCCU NCF Status Register 2 (FCCU_NCFS2) | - R/W always | on page 954 | | | 0x8C | FCCU NCF Status Register 3 (FCCU_NCFS3) | 1 | | | | 0x90 | FCCU NCF Key Register (FCCU_NCFK) | W always | on page 956 | | | 0x94 | FCCU NCF Enable Register 0 (FCCU_NCFE0) | | | | | 0x98 | FCCU NCF Enable Register 1 (FCCU_NCFE1) | R always; | on need 057 | | | 0x9C | FCCU NCF Enable Register 2 (FCCU_NCFE2) | W in CONFIG state only | on page 957 | | | 0xA0 | FCCU NCF Enable Register 3 (FCCU_NCFE3) | | | | | Address offset | Register | Access <sup>(1)</sup> | Location | | |----------------|-----------------------------------------------------|----------------------------------------------|-------------|--| | 0xA4 | FCCU NCF Time-out Enable Register 0 (FCCU_NCF_TOE0) | | | | | 0xA8 | FCCU NCF Time-out Enable Register 1 (FCCU_NCF_TOE1) | R always; | on nogo 059 | | | 0xAC | FCCU NCF Time-out Enable Register 2 (FCCU_NCF_TOE2) | W in CONFIG state only | on page 958 | | | 0xB0 | FCCU NCF Time-out Enable Register 3 (FCCU_NCF_TOE3) | | | | | 0xB4 | FCCU NCF Time-out Register (FCCU_NCF_TO) | R always;<br>W in CONFIG<br>state only | on page 958 | | | 0xB8 | FCCU CFG Timeout Register (FCCU_CFG_TO) | R always;<br>W always except<br>CONFIG state | on page 959 | | | 0xC0 | FCCU Status Register (FCCU_STAT) | R always | on page 960 | | | 0xC4 - 0xC7 | Reserved | | | | | 0xD8 | FCCU CF Fake Register (FCCU_CFF) | W always | on page 961 | | | 0xDC | FCCU NCF Fake Register (FCCU_NCFF) | W always | on page 962 | | | 0xE0 | FCCU IRQ Status Register (FCCU_IRQ_STAT) | R/W always | on page 962 | | | 0xE4 | FCCU IRQ Enable Register (FCCU_IRQ_EN) | R/W always | on page 963 | | | 0xE8 | FCCU XTMR Register (FCCU_XTMR) | R always | on page 964 | | | 0xEC | FCCU MCS Register (FCCU_MCS) | R always | on page 965 | | Table 546. FCCU memory map(Continued) ## 30.6.1 FCCU Control Register (FCCU\_CTRL) The FCCU\_CTRL register allows execution of the following operations: - Move the FCCU state from the NORMAL state into the CONFIG state - Move the FCCU state from the CONFIG state into the NORMAL state - Read or clear the CF status register - Read or clear the NCF status register - Read the FCCU FSM status register - Read or clear the FCCU freeze registers - Lock the FCCU configuration registers - Read the ALARM timer - Read the SMRT timer - Read the Watchdog timer - Load the NVM configuration (only for test purposes) Some critical operations (OP1, OP2, OP16, and OP31) require a key as defined in the FCCU\_CTRLK register. <sup>1.</sup> In this column, R/W = read/write, R = read-only, and W = write-only. 1. 1 when NVM interface is used, 0 otherwise. Figure 571. FCCU Control Register (FCCU\_CTRL) Table 547. FCCU\_CTRL field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NVML | NVM configuration loaded 0 No NVM configuration loaded. 1 NVM configuration loaded. At the end of the reset PHASE3, NVML = 1 and OPS = 11 if the NVM interface of the FCCU is correctly driven by the SSCM interface. This bit can be read and cleared (via OP15 operation) by the software. | | OPS | Operation status 00 Idle. 01 In progress. 10 Aborted. 11 Successful. This bit can be read and cleared (via OP15 operation) by the software. | Table 547. FCCU\_CTRL field descriptions(Continued) | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPR | Operation run Operation run Operation run Operation run Operation run Operation run Operation Set the FCCU into the CONFIG state [OP1]. Operation Set the FCCU into the NORMAL state [OP2]. Operation Read the FCCU state (refer to the FCCU_STAT register) [OP3]. Operation Read the FCCU frozen status flags [OP4]. Operation Read the FCCU frozen status flags [OP6]. Operation Read the FCCU frozen status flags [OP6]. Operation Read the FCCU frozen status flags [OP6]. Operation Read the FCCU frozen status flags [OP7]. Operation Read the FCCU frozen status flags [OP8]. CFG status register (refer to the frozen registers) [OP13]. Operation Read the ALARM timer (refer to the FCCU_XTMR) [OP15]. Operation Read the ALARM timer (refer to the FCCU_XTMR) [OP17]. Operation Read the ALARM timer (refer to the FCCU_XTMR) [OP18]. Operation Read the CFG timer (refer to the FCCU_XTMR) [OP18]. Operation Read the CFG timer (refer to the FCCU_XTMR) [OP18]. Operation Read the CFG timer (refer to the FCCU_XTMR) [OP18]. The software must not modify the OPR field until the completion of the operation (any write operation will be ignored until then). After the operation has been completed, the OPS field is set and the OPR field is automatically cleared (OPR = 000). Your software must not program the following opcodes: OP11 and OP12 (these opcodes are automatically selected when the FCCU_CFS | | | only for test/debug purposes. | ## 30.6.2 FCCU CTRL Key Register (FCCU\_CTRLK) The FCCU\_CTRLK register implements the key access for the operations OP1, OP2, OP16, OP31 according to the following sequence: - 1. Write the key into the FCCU\_CTRLK register. - 2. Write the FCCU\_CTRL register (operations OP1, OP2, OP16, or OP31). The FCCU\_CTRLK register is not readable. A read operation always returns 0x0000\_0000. The key must be written by a word (32-bit) data write operation. Figure 572. FCCU CTRL Key Register (FCCU\_CTRLK) Table 548. FCCU\_CTRLK field descriptions ## 30.6.3 FCCU Configuration Register (FCCU\_CFG) The FCCU\_CFG register is accessible in write mode only in the CONFIG state. It defines the global configuration for the FCCU. Figure 573. FCCU Configuration Register (FCCU\_CFG) Table 549. FCCU\_CFG field descriptions | Field | Description | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RCCE1 | RCC1 enable 0 RCC1 disabled. 1 RCC1 enabled. Note: In case a single checker (RCC1 or RCC0 unit) is enabled, both the checkers assert a fault condition (destructive reset). | | RCCE0 | RCC0 enable 0 RCC0 disabled. 1 RCC0 enabled. Note: In case a single checker (RCC1 or RCC0 unit) is enabled, both the checkers assert a fault condition (destructive reset). | | SMRT | SAFE Mode Request Timer 0000 SAFE mode request delay = 1 period (IRCOSC clock). 0001 SAFE mode request delay = 2 periods (IRCOSC clock). 0010 SAFE mode request delay = 4 periods (IRCOSC clock). 1111 SAFE mode request delay = 32768 periods (IRCOSC clock). | | FCCU_CFG.CM | Configuration mode 0 Configuration labelling: a specific FCCU_F configuration is assigned in CONFIG state. 1 Configuration transparency: the FCCU_F protocol is the same in CONFIG and NORMAL states. | | FCCU_CFG.SM | Switching mode 0 FCCU_F protocol (dual-rail, time-switching) slow switching mode. 1 FCCU_F protocol (dual-rail, time-switching) fast switching mode. SM has no effect on the bi-stable protocol. | | FCCU_CFG.PS | Polarity selection 0 FCCU_F[1] active high, FCCU_F[0] active high. 1 FCCU_F[1] active low, FCCU_F[0] active low. | Table 549. FCCU\_CFG field descriptions(Continued) | Field | Description | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FCCU_CFG.FOM | Fault Output Mode selection 000 Dual-Rail (default state; FCCU_F[1:0]= outputs). 001 Time Switching (FCCU_F[1:0]= outputs). 010 Bi-Stable (FCCU_F[1:0]= outputs). 011 Reserved. 100 Reserved. 101 Test0 (FCCU_F[0] = input, FCCU_F[1]= output) 110 Test1 (FCCU_F[0] = output, FCCU_F[1]= output) 111 Test2 (FCCU_F[0] = output, FCCU_F[1]= input) Note: In Testn mode, a simple double-stage resynchronization stage is used to resynchronize the FCCU_F input/outputs on the system/IRCOSC clock. | | FCCU_CFG.FOP | Fault Output Prescaler FOP defines the prescaler setting used to generate the FCCU_F protocol frequency. 00 0000 Input clock frequency (IRCOSC clock) is divided by 2 00 0001 Input clock frequency (IRCOSC clock) is divided by 4 00 0010 Input clock frequency (IRCOSC clock) is divided by 6 00 0011 Input clock frequency (IRCOSC clock) is divided by 8 00 0100 Input clock frequency (IRCOSC clock) is divided by 10 00 0101 Input clock frequency (IRCOSC clock) is divided by 12 00 0110 Input clock frequency (IRCOSC clock) is divided by 14 The following equation gives the FCCU_F frequency: $f_{\text{FCCU\_F}} = f_{\text{IRCOSC}}/(1024 \times (\text{FOP} + 1) \times 2)$ | ## 30.6.4 FCCU CF Configuration Register (FCCU\_CF\_CFG0...3) The FCCU\_CF\_CFGx register is accessible in write mode only in the CONFIG state. It contains the configuration of each critical fault in terms of fault recovery management. The configuration depends on the type of signaling following a fault event. Hardware recoverable faults should be configured only if a previous latching stage captures and hold the physical fault otherwise the fault can be lost. All the other faults should be configured as SW fault. - 1. Writable only in the CONFIG state. - 2. 1 for FCCU\_CF\_CFG0; 0 otherwise. Figure 574. FCCU CF Configuration Register (FCCU\_CF\_CFG0...3) Table 550. FCCU\_CF\_CFG0...3 field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CFCx | Critical fault configuration 0 Hardware recoverable fault. 1 Software recoverable fault. The critical fault configuration defines the fault recovery mode. Hardware-recoverable faults are self recovered (status flag clearing) if the root cause has been removed. SW recoverable faults are recovered (status flag clearing) by software clearing the related status flag. | ## 30.6.5 FCCU NCF Configuration Register (FCCU\_NCF\_CFG0...3) The FCCU\_NCF\_CFGx register is accessible in write mode only in the CONFIG state. It contains the configuration of each non-critical fault in terms of fault recovery management. The configuration depends on the type of signaling of a fault event. HW recoverable faults should be configured only if a previous latching stage captures and hold the physical fault otherwise the fault can be lost. All the other faults should be configured as SW fault. | Offset: 0x01C–0x028 (4 registers) | | | | | | | | | | | Access<br>read/v | | | | | | |-----------------------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | 31 | :30 | :29 | C28 | :27 | :26 | :25 | :24 | :23 | :22 | :21 | :20 | :19 | 118 | :17 | 16 | | W | NCFC | NCFC | NCFC | NCFC | NCFC27 | NCFC26 | NCFC | NCFC | NCFC | NCFC | NCFC21 | NCFC20 | NCFC | NCFC | NCFC | NCFC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 <sup>(2)</sup> | | | | | | '<br>I | | | | '<br>I | | | | | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | :15 | C14 | C13 | C12 | :11 | :10 | 60 | 38 | 27 | 90 | 35 | 34 | 33 | 32 | 21 | 8 | | W | NCFC | NCFC | NCFC | NCFC | NCFC11 | NCFC10 | NCFC | NCFC8 | NCFC7 | NCFC6 | NCFC5 | NCFC4 | NCFC3 | NCFC. | NCFC1 | NCFC0 | | Reset | 0/1 <sup>(2)</sup> - 1. Writable only in the CONFIG state. - 2. 1 for FCCU NCF CFG0; 0 otherwise. Figure 575. FCCU NCF Configuration Register (FCCU\_NCF\_CFG0...3) Field Non-critical fault configuration 0: HW recoverable fault 1: SW recoverable fault The non-critical fault configuration defines the fault recovery mode. HW recoverable faults are self recovered (status flag clearing and related) if the root cause has been removed. SW recoverable faults are recovered (status flag clearing) by SW clearing of the related status flag. This register can be read and written by the software. Table 551. FCCU\_NCF\_CFG0...3 field descriptions ## 30.6.6 FCCU CFS Configuration Register (FCCU\_CFS\_CFG0...7) The FCCU\_CF\_FS\_CFGx register is accessible in write mode only in the CONFIG state. It contains the configuration of each critical fault in terms of fault reaction (short or long 'functional' reset) when it is the root cause for the FAULT state transition. | Offset: ( | 0x02C | ; | | | | | | | | | | | | | Access<br>read/v | : User<br>vrite <sup>(1)</sup> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |-----------|---------|-----|-----|-----|-----|-----|-----|--------|-----|--------|-----|--------|-----|--------|------------------|--------------------------------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|--------|--|------|-----|-----|-----|-----|-----|-----| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>W | CFS | C15 | CFS | C14 | CFS | C13 | CFS | CFSC12 | 6C11 | CFS | C10 | CFS | SC9 | CFS | SC8 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>W | L CFSC7 | | CFS | SC6 | CFS | SC5 | CFS | SC4 | CFS | SC3 | CFS | SC2 | CFS | SC1 | CFS | SC0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1. Writable only in the CONFIG state. Figure 576. FCCU CFS Configuration Register 0 (FCCU\_CFS\_CFG0) 1. Writable only in the CONFIG state. 1. Writable only in the CONFIG state. Figure 577. FCCU CFS Configuration Register 1 (FCCU\_CFS\_CFG1) | Offset: | 0x034 | 0x048 | 8 (6 re | gisters) | ) | | | | | | | | | | Access<br>read/v | : User<br>vrite <sup>(1)</sup> | |---------|-------|-------|---------|----------|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|------------------|--------------------------------| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R<br>W | CFS | SC15 | CFS | C14 | CFS | C13 | CFS | C12 | CFS | SC11 | CFS | C10 | CFS | SC9 | CFS | SC8 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R<br>W | CF | SC7 | CF | SC6 | CFS | SC5 | CFS | 6C4 | CF | SC3 | CFS | SC2 | CFS | SC1 | CFS | SC0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 578. FCCU CFS Configuration Register 2...7 (FCCU\_CFS\_CFG2...7) 577 Table 552. FCCU\_CFS\_CFG0...7 field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CFSCx | Critical fault state configuration 00: No reset reaction 01: Short functional reset (FAULT state reaction) 10: Long functional reset (FAULT state reaction) 11: No reset reaction This register can be read and written by the software. | ## 30.6.7 FCCU NCFS Configuration Register (FCCU\_NCFS\_CFG0...7) The FCCU\_NCF\_FS\_CFGx register is accessible in write mode only in the CONFIG state. It contains the configuration of each non-critical fault in terms of fault reaction (short or long 'functional' reset) when it is the root cause for the FAULT state transition. Figure 579. FCCU NCFS Configuration Register (FCCU\_NCFS\_CFG0...7) Table 553. FCCU\_NCFS\_CFG0...7 field descriptions | Field | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NCFSCx | Non-critical fault state configuration 00: No reset reaction 01: Short 'functional' reset (FAULT state reaction) 10: Long 'functional' reset (FAULT state reaction) 11: No reset reaction This register can be read and written by the software. | ## 30.6.8 FCCU CF Status Register (FCCU\_CFS0...3) The FCCU\_CFSx register contains the latched fault indication collected from the critical fault sources. Faults are latched even if the FCCU is in the CONFIG state and independently from the enabling or reactions programmed for the CF. No reactions are executed until the FCCU moves in the NORMAL state. FCCU reacts and moves from the NORMAL or ALARM state into the FAULT state if a critical fault is triggered. The status bits of the FCCU\_CFSx register, configured as SW recoverable faults, can be cleared by the following locked sequence: - to write the proper key into the FCCU\_CFK register - to clear the status (flag) bit CFSx $\rightarrow$ the opcode OP11 is automatically set into the FCCU\_CTRL.OPR field - to wait for the completion of the operation (FCCU\_CTRL.OPS field) - to read the FCCU\_CFSx register in order to verify the effective deletion and in case of failure to repeat the sequence As result of the above sequence, in addition the FAULT interface provides support to clear the external FAULT root. The FCCU moves from the FAULT state into the NORMAL state if the source fault which caused the transition into the FAULT state has been removed (HW recoverable fault) or cleared via SW (SW recoverable fault). Concurrently the FAULT interface provides support to clear the FAULT root. In case of nested faults that are not all recovered, the FCCU remains into the FAULT state or moves into the ALARM state. The SW application executes the FCCU CFSx read operation by the following sequence: - to set the OP9 operation into the FCCU\_CTRL.OPR field - to wait for the completion of the operation (FCCU\_CTRL.OPS field) - to read the FCCU CFSx register The following errors are ignored: - to write a wrong key into the FCCU CFK register - to attempt to clear a HW recoverable error | Offset: | 0x06C | -0x07 | 8 (4 re | gisters | ) | | | | | | | | Acce | ess: Us | er read | d/write | |---------|-------|-------|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|---------|---------|---------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | R | CFS31 | CFS30 | CFS29 | CFS28 | CFS27 | CFS26 | CFS25 | CFS24 | CFS23 | CFS22 | CFS21 | CFS20 | CFS19 | CFS18 | CFS17 | CFS16 | | W | w1c | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | !<br> | | | | | | | | !<br> | | | | | | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | R | CFS15 | CFS14 | CFS13 | CFS12 | CFS11 | CFS10 | CFS9 | CFS8 | CFS7 | CFS6 | CFS5 | CFS4 | CFS3 | CFS2 | CFS1 | CFS0 | | W | w1c | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 580. FCCU CF Status Register (FCCU\_CFS0...3) Note: Register FCCU CFS0 shows status of CF[0:31]. Register FCCU\_CFS1 shows status of CF[37] (bit26). All other register bits of FCCU\_CFS1 are unused. Register FCCU\_CFS2 and Register FCCU\_CFS3 are implemented but are not used. They do not show any status. | Table 554. FCCU | CFS03 field | descriptions | |-----------------|-------------|--------------| |-----------------|-------------|--------------| | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CFSx | Critical fault status 0: No critical fault latched 1: Critical fault latched The status bits related to the critical fault configured as HW recoverable faults are read-only and the flag is self cleared when the fault source is removed. The status bits related to the critical fault configured as SW recoverable faults are write-clear and the SW application can recover from a faulty condition. | ## 30.6.9 FCCU CF Key Register (FCCU\_CFK) The FCCU\_CFK register implements the key access to clear the status flags of the FCCU\_CFSx register. The status bits of the FCCU\_CFSx register, configured as SW recoverable faults, can be cleared by the following locked sequence: - Write the CFCK key into the FCCU\_CFK register - Clear the status (flag) bit CFSx Note: The key must be written for each FCCU\_CFSx clear operation. The FCCU\_CFK register is not readable, a 0x00000000 value is always returned in case of read operation. Figure 581. FCCU CF Key Register (FCCU\_CFK) Table 555. FCCU\_CFK field descriptions | Field | Description | |-------|---------------------------------| | CFK | Critical fault key = 0x618B7A50 | ## 30.6.10 FCCU NCF Status Register (FCCU\_NCFS0...3) The FCCU\_NCFSx register contains the latched fault indication collected from the non-critical fault sources. Faults are latched also in the CONFIG state and independently from the enabling or reactions programmed for the NCF. No reactions are executed until the FCCU moves in the NORMAL state. FCCU reacts and moves from the NORMAL state into the ALARM state only if the respective enable bit for a fault is set in the FCCU\_NCFEx register and the respective enable bit for the time-out is set in the FCCU\_TOEx register. FCCU reacts and moves from the NORMAL or ALARM state into the FAULT state if the respective enable bit for a fault is set in the FCCU\_NCFEx register and the respective enable bit for the time-out is disabled in the FCCU\_TOEx register. FCCU reacts and moves from the ALARM state into the FAULT state if the time-out (FCCU\_TO register) is elapsed before to recovery the fault. The time-out is stopped only when the FCCU returns in the NORMAL state. The status bits of the FCCU\_NCFSx register, configured as SW recoverable faults, can be cleared by the following locked sequence: - Write the proper key into the FCCU NCFK register - Clear the status (flag) bit NCFSx → the opcode OP12 is automatically set into the FCCU\_CTRL.OPR field - Wait for the completion of the operation (FCCU\_CTRL.OPS field) - Read the FCCU\_NCFSx register in order to verify the effective deletion and in case of failure to repeat the sequence As result of the above sequence, in addition the FAULT interface provides support to clear the external FAULT root. The FCCU moves from the FAULT or ALARM state into the NORMAL state if all the source faults which caused the transition into the FAULT state has been removed (HW recoverable fault) or cleared via SW (SW recoverable fault). In case of nested faults that are not all recovered, the FCCU will remain in the FAULT or ALARM state. The SW application executes the FCCU NCFSx read operation by the following sequence: - to set the OP10 operation into the FCCU CTRL.OPR field - to wait for the completion of the operation (FCCU CTRL.OPS field) - to read the FCCU\_NCFSx register In case of re-configuration of the FCCU (CONFIG state), before to return in NORMAL state the pending status bits into the FCCU\_NCFSx must be cleared in order to avoid a false transition in ALARM/FAULT state. The following errors are ignored: - to write a wrong key into the FCCU\_NCFK register - to attempt to clear a HW recoverable error Figure 582. FCCU NCF Status Register (FCCU\_NCFS0...3) Table 556. FCCU\_NCFS0...3 field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Non-critical fault status 0: No "non-critical" fault latched 1: "non-critical fault" latched | | NCFSx | The status bits related to the non-critical fault configured as HW recoverable faults are read-only and the flag is self cleared when the fault source is removed. | | | The status bits related to the critical fault configured as SW recoverable faults are write-clear and the SW application can recover from a faulty condition. | ## 30.6.11 FCCU NCF Key Register (FCCU\_NCFK) The FCCU\_NCFK register implements the key access to clear the status flags of the FCCU\_NCFSx register. The status bits of the FCCU\_NCFSx register, configured as SW recoverable faults, can be cleared by the following locked sequence: - to write the key into the FCCU NCFK register - to clear the status (flag) bit NCFSx Note: The key must be written for reach FCCU\_NCFSx clear operation. The FCCU\_NCFK register is not readable, a 0x00000000 value is always returned in case of read operation. Figure 583. FCCU NCF Key Register (FCCU\_NCFK) Table 557. FCCU\_NCFK field descriptions | Field | Description | |-------|---------------------------------| | NCFK | Critical fault key = 0xAB3498FE | ## 30.6.12 FCCU NCF Enable Register (FCCU\_NCFE0...3) The FCCU\_NCFEx register enables the critical fault sources to allow a transition from the NORMAL into the FAULT or ALARM state. In case of fault masking, the respective status bit into the FCCU\_NCFSx register is anyway set (for debugging purposes), only the reaction is masked. The FCCU\_NCFEs register is accessible in write mode only in the CONFIG state. - 1. Writable only in the CONFIG state. - 2. 1 for FCCU\_NCFE0; 0 otherwise. Figure 584. FCCU NCF Enable Register (FCCU\_NCFE0...3) Table 558. FCCU NCFE0...3 field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------| | NCFEx | Non-critical fault enable 0: No actions following the respective critical fault assertion 1: FCCU moves to ALARM or FAULT state | ## 30.6.13 FCCU NCF Time-out Enable Register (FCCU\_NCF\_TOE0...3) The FCCU\_NCFTOEx register enables a transition from the NORMAL state into the ALARM state if the respective non-critical fault is enabled (NCFEx and NCFTOEx are set). In case the respective time-out is disabled (NCFTOEx is cleared) and the non-critical fault is enabled (NCFEx is set) the FCCU moves into the FAULT state if the related non-critical fault is asserted. The timer (preset with the time-out value defined by FCCU\_TO register) is started when the FCCU moves into the ALARM state. If the fault is not recovered within the time-out the FCCU moves from the ALARM state to the FAULT state. The FCCU NCFTOEx register is accessible in write mode, only in the CONFIG state. - 1. Writable only in the CONFIG state. - 2. 1 for FCCU\_NCF\_TOE0; 0 otherwise. Figure 585. FCCU NCF Time-out Enable Register (FCCU\_NCF\_TOE0...3) Table 559. FCCU\_NCF\_TOE0...3 field descriptions | Field | Description | | | | | | |---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | NCFTOEx | Non-critical fault time-out enable 0: FCCU moves into the FAULT state if the respective fault is disabled (NCFEx is cleared) 1: FCCU moves into the ALARM state if the respective fault is enabled (NCFEx is set) | | | | | | ## 30.6.14 FCCU NCF Time-out Register (FCCU\_NCF\_TO) The FCCU\_NCF\_TO register defines the preset value of the timer for the recovery of the non-critical faults (enabled). Once FCCU enters in ALARM state, following the assertion of a non-critical fault enabled (NCFEx and NCFTOEx are set), the timer starts the count down. If the fault is not recovered within the time-out the FCCU moves from the ALARM state to the FAULT state. The FCCU\_NCF\_TO register is accessible in write mode, only in the CONFIG state. Figure 586. FCCU NCF Time-out Register (FCCU\_NCF\_TO) Table 560. FCCU\_NCF\_TO field descriptions | Field | Description | |-------|-------------------------------------| | ТО | Non-critical fault timeout | | 10 | $Timeout = (TO) \times t_{RC16MHz}$ | ## 30.6.15 FCCU CFG Timeout Register (FCCU\_CFG\_TO) The FCCU\_CFG\_TO register defines the preset value of the watchdog timer for the recovery from the CONFIG state. Once FCCU enters in CONFIG state, following a SW request (OP1 opcode), the watchdog timer is initialized and starts the countdown if the reset is not asserted. If the configuration is not completed within the time-out, the FCCU moves automatically from the CONFIG state to the NORMAL state and the default values for the configuration register is restored. The watchdog time-out is clocked with the IRCOSC clock (16 MHz). The default time-out value is 4,096 ms. The FCCU\_CFG\_TO register is accessible in write mode, in any state excluded the CONFIG state as follows the execution of the OP1 opcode (NORMAL to CONFIG state) and until the completion of the OP2 opcode (CONFIG to NORMAL state). In case of watchdog time-out the FCCU\_CFG\_TO register is not accessible until the OP14 operation (CONFIG to NORMAL) has been completed. Figure 587. FCCU CFG Timeout Register (FCCU\_CFG\_TO) Table 561. FCCU\_CFG\_TO field descriptions | Field | Description | |-------|--------------------------------------------| | | Configuration time-out | | | $Timeout = T_{RC16MHz} \times 2^{(TO+10)}$ | | ТО | | | | 000: Time-out = 64 μs | | | | | | 111: Time-out = 8,192 ms | ## 30.6.16 FCCU Status Register (FCCU\_STAT) The FCCU\_STAT register includes the FCCU status for debugging/test purposes. The FCCU finite state machine operates by the IRCOSC clock asynchronous with the system clock. The FCCU status read operation requires a safe mechanism operated by a HW/SW synchronization sequence. The SW application executes a FCCU status read operation by the following sequence: - to set the OP3 operation into the FCCU CTRL.OPR field - to wait for the completion of the operation (FCCU\_CTRL.OPS field) - to read the FCCU status (FCCU\_STAT register) Figure 588. FCCU Status Register (FCCU\_STAT) | Table 562. | FCCU_ST | AT field o | descriptions | |------------|---------|------------|--------------| | | | | | | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------| | STATUS | FCCU Status 000: NORMAL state. 001: CONFIG state 010: ALARM state 011: FAULT state Other: UNKNOWN state This bit can be read by the software. | ## 30.6.17 FCCU CF Fake Register (FCCU\_CFF) The FCCU\_CFF register contains a unique code to set a "critical fault" in mutually exclusive mode by the external FAULT interface. It allows the SW emulation of the critical faults, by the injection of the fault directly in the FAULT root, in order to verify the entire path and reaction. The fault injection mechanism is optional. The reaction following a fake critical fault cannot be masked. The FCCU\_CFF is a write-only register with a set of codes corresponding to each critical fault injection. Figure 589. FCCU CF Fake Register (FCCU\_CFF) Table 563. FCCU\_CFF field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FCFC | Fake critical fault code 00h: Fake critical fault injection at critical fault source 0 01h: Fake critical fault injection at critical fault source 1 02h: Fake critical fault injection at critical fault source 2 1Fh: Fake critical fault injection at critical fault source 31 others: No fault injection These bits are always read as '0' by software. | ## 30.6.18 FCCU NCF Fake Register (FCCU\_NCFF) The FCCU\_NCFF register contains a unique code to set a "non-critical fault" in mutually exclusive mode by the external FAULT interface. It allows the SW emulation of the non-critical faults, by the injection of the fault directly in the FAULT root, in order to verify the entire path and reaction. The fault injection mechanism is optional. The reaction following a fake non-critical fault can be masked. The FCCU\_NCFF is a write-only register with a set of codes corresponding to each non-critical fault injection. Figure 590. FCCU NCF Fake Register (FCCU\_NCFF) Table 564. FCCU\_NCFF field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FNCFC | Fake non-critical fault code 00h: Fake non-critical fault injection at non-critical fault source 0 01h: Fake non-critical fault injection at non-critical fault source 1 02h: Fake non-critical fault injection at non-critical fault source 2 1Fh: Fake non-critical fault injection at non-critical fault source 31 others: No fault injection These bits are always read as '0' by software. | #### 30.6.19 FCCU IRQ Status Register (FCCU\_IRQ\_STAT) The FCCU\_IRQ\_STAT register defines the FCCU interrupt status register related to the following events: - Configuration time-out error - Alarm interrupt The external interrupt is asserted if any interrupt status bit of the FCCU\_IRQ\_STAT is set and the respective enable bit of the FCCU\_IRQ\_EN register is also set. The ALARM interrupts is asserted and cleared according to the FCCU state. The status bits of the FCCU IRQ STAT trace the status of the related interrupt lines. Figure 591. FCCU IRQ Status Register (FCCU\_IRQ\_STAT) Table 565. FCCU\_IRQ\_STAT field descriptions | Field | Description | | |-------------|----------------------------------------------------------------------------------------------------------------------|--| | CFG_TO_STAT | Configuration Time-out Status 0: No configuration time-out error 1: Configuration time-out error | | | | This bit can be read and cleared by the software. | | | ALRM_STAT | Alarm Interrupt Status 0: Alarm interrupt is OFF 1: Alarm interrupt is ON This bit can be only read by the software. | | ## 30.6.20 FCCU IRQ Enable Register (FCCU\_IRQ\_EN) The FCCU\_IRQ\_EN register defines the FCCU interrupt enable register related to the following events: • Configuration time-out error The external interrupt is asserted if any interrupt status bit of the FCCU\_IRQ\_STAT is set and the respective enable bit of the FCCU\_IRQ\_EN register is also set. Figure 592. FCCU IRQ Enable Register (FCCU\_IRQ\_EN) Table 566. FCCU\_IRQ\_EN field descriptions | Field | Description | | |------------|----------------------------------------------------------------------------------------------------------------------------------|--| | CFG_TO_IEN | Configuration Time-out Interrupt Enable 0: Configuration time-out interrupt disabled 1: Configuration time-out interrupt enabled | | | | This bit can be read and written by the software. | | ## 30.6.21 FCCU XTMR Register (FCCU\_XTMR) The FCCU\_XTMR contains the read values of the Alarm, Watchdog or Safe Mode Request Timer. These timers are clocked on the IRCOSC clock. The SW application executes the timer read operation by the following sequence: - to set the OP17 or OP18 or OP19 operation into the FCCU CTRL.OPR field - to wait for the completion of the operation (FCCU\_CTRL.OPS field) - to read the FCCU\_XTMR Table 567. Timer state/value | TIMER | CONFIG state | NORMAL state | ALARM state | FAULT state | |-------|--------------|---------------|-------------|----------------------| | ALARM | 00000000h | Initial value | Running | Idle/End of count | | SMRT | 00000001h | Initial value | _ | Running/End of count | | CFG | Running | 0001FFFFh | 0001FFFFh | 0001FFFFh | Figure 593. FCCU XTMR Register (FCCU\_XTMR) Table 568. FCCU\_XTMR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------| | XTMR | Alarm/Watchdog/Safe request timer The current timer value is measured in IRCOSC clock cycles. These bits can be read by the software. | ## 30.6.22 FCCU MCS Register (FCCU\_MCS) The FCCU\_MCS register contains a queue of the last 4 chip modes. MCS0 is the latest one, while MCS3 is the oldest one. In addition a qualifier indicates if the FCCU is in the FAULT state when the chip mode has been captured. The chip mode is synchronous to the system clock and provided by a different module while the FCCU state is synchronous to the IRCOSC clock, therefore some uncertainty must be considered regarding the FAULT state indication. Figure 594. FCCU MCS Register (FCCU\_MCS) | Field | Description | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | VLx | Valid It indicates that the correspondent MCSx and FSx fields are valid. 0: MCSx, FSx fields are not significative 1: MCSx, FSx fields are significative These bits can be read by the software. | | | FSx | Fault status It indicates that the correspondent MCSx field has been captured when the FCCU is in FAULT state. 0: MCSx field captured in any state different from the FAULT state 1: MCSx field captured in FAULT state These bits can be read by the software. | | | MCSx | Chip mode The MCSx is the chip mode. MCS0 = latest state MCS3 = oldest state On any chip mode change the previous chip modes are shifted (MCS3 = MCS2, MCS2= MCS1, MCS1= MCS0) and the latest one is captured in MCS0. | | Table 569, FCCU MCS field descriptions ## 30.7 Functional description These bits can be read by the software. #### 30.7.1 Definitions In general, the following definitions are applicable for the fault management: - HW recoverable fault: the fault indication is a level sensitive signal that is asserted as long as the fault cause has not been removed. Typically the fault signal is latched in a external module at the FCCU. The FCCU state transitions are consequently executed on the state changes of the input fault signal. No SW intervention in the FCCU is required to recover the fault condition. - SW recoverable fault: the fault indication is a signal asserted without a defined time duration. The fault signal is captured in the FCCU. The fault recovery is executed following a SW recovery procedure (status/flag register clearing). The following type of reset are applicable (see *Chapter 8: Reset Generation Module (MC\_RGM)*): 'Destructive' reset: any type of reset related to a power failure condition that implies a complete system reinitialization ## 30.7.2 FSM description The FCCU functionality is depicted by the FSM diagram given in *Figure 595*. Basically four states are identified with the following meaning: CONFIG— the configuration state is used only to modify the default configuration of the FCCU. A sub-set of the FCCU registers, dedicated to define the FCCU configuration (global configuration, reactions to fault, time-out, non-critical fault masking) can be accessed in write mode only in the CONFIG state. The CONFIG state is accessible only from NORMAL state and if the configuration is not locked. The configuration lock can be disabled only by a global reset of the FCCU. The configuration shall always be locked when running a safety critical application. The CONFIG to NORMAL state transition can be executed by SW or automatically following a time-out condition of the watchdog. The incoming faults, occurring during the configuration phase (CONFIG state) are latched in order to process them when the FCCU is moved into the NORMAL state, according to the selected configuration. - NORMAL—the FCCU operating state when no faults are occurring. It is also the default state on the reset exit. The FSM will leave the NORMAL state following one of these events: - Critical faults → the FCCU moves to the FAULT state - Unmasked non-critical faults with the time-out disabled → the FCCU moves to the FAULT state - Unmasked non-critical faults with the time-out enabled → the FCCU moves to the ALARM state - Masked non-critical faults → the FCCU stays in NORMAL state - ALARM— the FCCU moves into the ALARM state when an unmasked non-critical fault occurs and the time-out is enabled. The transition to the ALARM state goes along with an interrupt. By definition, this fault may be recovered within a programmable time-out period, before it generates a transition to the FAULT state. The time-out is reinitialized if the FCCU state moves to the NORMAL state. The time-out is stopped if the FCCU state moves to the FAULT state due to a critical-fault occurring when the FCCU is in ALARM state. The time-out restarts following the recovery from the FAULT state. - FAULT— the FCCU moves into the FAULT state when one of the following condition occurs: - Critical fault - Time-out related to a non-critical fault when the FCCU is in the ALARM state - Unmasked non-critical faults with the time-out disabled - The transition from NORMAL/ALARM state goes along with the generation of: - FCCU F signalling Figure 595. FCCU state diagram ## 30.7.3 Self-checking capabilities The FCCU includes some features to support self-checking capabilities of the main FSM in running mode. The FSM unit is duplicated and its state (internal state and relevant outputs) is checked by two RCCx units (cycle accurate). The following checks (per IRCOSC clock cycle) are provided by the RCCx units: - all the FSM outputs and its internal state for the redundant FSM instances are checked to detect runtime faults on the FSM outputs and its internal state - parity bits (computed at byte level) on the configuration registers are checked to detect run time faults on the configuration inputs of the FSM - parity bits (computed at byte level) on the interface used to clear the FCCU\_CFSx and FCCU\_NCFSx status registers - FCCU\_F protocol state in dual-rail, time-switching and bi-stable mode - common mode signals (handshake interface signals activated only in CONFIG state) congruence with the FSM state In case of failure, each RCCx unit provides an interrupt request. The RCCx state is frozen in a status register. To guarantee the self checking capabilities through the FAULT interface, each critical fault source must be duplicated on a couple of CF inputs. Two separate IRCOSC clock inputs are routed to the redundant sub-modules (FSMx, RCCx, FCCU\_Fx, FAULT-if). An external (to the FCCU) monitor of the IRCOSC clocks and an external reaction ('functional' reset to the MC\_RGM) is required to cover potential fault on the IRCOSC clocks. Self checking capabilities cover the HW reaction of the FCCU due to the assertion of an external fault. The register interface and the handshake modules are not covered by self-checking capabilities. Any operation executed by SW (configuration, fault recovery) must be cross-verified by redundancy checks via SW (registers read following a write/clear operation, internal FCCU state, and so on). A typical sequence with self checking failure and related reaction is given in *Figure 596*. Figure 596. Self-checking reaction #### 30.7.4 Reset interface The FCCU has two input resets and two output resets related to the FAULT state. | Reset source | Support | |---------------------|----------| | External reset | enabled | | POR | enabled | | STCU | enabled | | 'Functional' reset | disabled | | 'Destructive' reset | enabled | Table 570. Reset sources ## 30.7.5 Fault priority scheme and nesting The FAULT state has a higher priority than the ALARM state in case of concurrent fault events (critical and non-critical) that occur in the NORMAL state. In case of concurrent critical faults, the fault reaction corresponds to the worst case (that is, a long 'functional' reset is asserted in case it has been programmed). The ALARM to FAULT state transition occurs if a critical fault or a non-critical fault (unmasked and with time-out disabled) is asserted in the ALARM state. Any critical fault (programmed to react with a hard or soft reaction) that occurs when the FCCU is already in the FAULT state causes an immediate hard or soft reaction (long or short 'functional' reset). The ALARM to NORMAL state transition occurs only if all the non-critical faults (including the faults that have been collected after the entry in the ALARM state) have been cleared (SW or HW recovery) otherwise the FCCU will remain in the ALARM state. The FAULT to NORMAL state transition occurs only if all the critical and non-critical faults (including the faults that have been collected after the entry in the FAULT/ALARM state) have been cleared (SW or HW recovery) otherwise the FCCU will remain in the FAULT state (if any critical fault is still pending) or will return in the ALARM state (if any non-critical fault is still pending and the time-out is not elapsed). In general, no fault nesting is supported except for the non-critical versus critical faults that causes a ALARM to FAULT state transition. In this case the NCT timer is stopped until the FAULT state is recovered. ## 30.7.6 Fault recovery The following timing diagrams describe the main use cases of the FCCU in terms of fault events and related recovery. A typical sequence related to a critical FAULT management, given in *Figure 597* or *Figure 598*, is following described: - Critical fault assertion - FCCU state transition (automatic): NORMAL → FAULT - FAULT recovery (by SW): FCCU state transition FAULT → NORMAL Figure 597. Critical FAULT recovery (a) Figure 598. Critical FAULT recovery (b) A typical sequence related to a non-critical FAULT management (ALARM state), given in *Figure 599* and *Figure 600*, is following described: - Non-critical fault assertion - FCCU state transition (automatic): NORMAL → ALARM - alarm interrupt request - time-out running - Chip mode: RUN - Alarm interrupt management - FAULT recovery (by SW): FCCU state transition ALARM → NORMAL Non-critical fault event Chip mode RUN FCCU state NORMAL Alarm interrupt request NCF timer IDLE TIMER ON IDLE FCCU reset Figure 599. Non-critical FAULT (ALARM state) recovery (a) Figure 600. Non-critical FAULT (ALARM state) recovery (b) A typical sequence related to a non-critical FAULT management (ALARM $\rightarrow$ FAULT state), given in *Figure 601*, is following described: - Non-critical fault assertion - FCCU state transition (automatic): NORMAL → ALARM - Alarm interrupt request - Time-out running - FCCU state transition (following the time-out trigger): ALARM → FAULT Figure 601. Non-critical FAULT (ALARM -> FAULT state) recovery A typical sequence related to a critical FAULT (with nesting) management, given in *Figure 602*, is following described: - Critical fault assertion - FCCU state transition (automatic): NORMAL → FAULT - FAULT recovery (by SW): FCCU state transition FAULT → NORMAL Critical fault event FCCU state NORMAL FAULT NORMAL FCCU\_F IDLE ERROR ON IDLE FCCU reset Figure 602. Critical FAULT (nesting) recovery A typical sequence related to a critical FAULT (with non-critical fault nesting) management (ALARM $\rightarrow$ FAULT $\rightarrow$ ALARM state), given in *Figure 603*, where the faults are recovered sequentially, is following described: - Non-critical fault assertion - FCCU state transition (automatic): NORMAL → ALARM - Alarm interrupt request - Time-out running - Critical fault assertion - FCCU state transition (automatic): ALARM → FAULT - FAULT (CF) recovery (by SW): FCCU state transition FAULT → ALARM, because only the critical fault has been recovered - Time-out is still running - Alarm interrupt management - FAULT (NCF) recovery (by SW): FCCU state transition ALARM → NORMAL Figure 603. Critical FAULT (and non-critical FAULT nesting) recovery #### 30.7.7 **NVM** interface The NVM provides the FCCU with the initial configuration information shown in *Table 571*. Table 571. NVM configuration | Flash memory option bit locations | Description | |-----------------------------------|----------------------------| | BIU4[20] | Initial FCCU_CFG.CM value | | BIU4[21] | Initial FCCU_CFG.SM value | | BIU4[22] | Initial FCCU_CFG.PS value | | BIU4[23:25] | Initial FCCU_CFG.FOM value | | BIU4[26:31] | Initial FCCU_CFG.FOP value | Figure 604 shows the FCCU configuration sequence after a power-on, 'destructive', or external reset. phase1 phase2 phase3 self test phase1 phase2 phase3 run power-on, 'destructive', external, or self-test completed reset asynch FCCU configuration CONFIG RESET from NVM FCCU\_CFG.PS, FCCU\_CFG.FOM, DEFAULT (reset value) DEFAULT/(reset value) **CONFIG** XXX FCCU CFG.FOP NORMAL RESET **NORMAL** RESET NORMAL CONFIG XXX FCCU state FCCU F[1:0] PROT1 PROT2 (from FCCU) High-Z High-Z High-Z (STCU control) (reset) (MC control) FCCU\_F[1:0] PROT2 (top) High-Z Figure 604. NVM interface #### 30.7.8 FCCU\_F interface The FCCU provides two external bidirectional signals (FCCU\_F interface). Different protocols for the FCCU\_F interface are supported, selecting the FCCU\_CFG.FOM register field: - Dual rail protocol - Time switching protocol - Bi-stable protocol - Test mode The signal polarity and the frequency can be programmed, setting the FCCU\_CFG.PS and FCCU CFG.FOP register fields. All the diagrams and tables are related to the default configuration selection (FCCU\_CFG.FOP = 0b), switching mode (FCCU\_CFG.SM = 0b) and config mode (FCCU\_CFG.CM = 0b). In case of inverted polarity (FCCU\_CFG.FOP = 1b) all the values on the FCCU\_F output pins are inverted. Two modes can be programmed to define the FCCU\_F protocol transitions in dual-rail or time-switching mode: - Slow switching mode: no FCCU\_F frequency violation during the FCCU state transition (NORMAL to ERROR or viceversa and CONFIG to NORMAL). The FCCU\_F protocol transition occurs after a max delay equal to the duration of the semi-period of the FCCU\_F frequency. - Fast switching mode: The FCCU\_F protocol transition (NORMAL to ERROR or viceversa and CONFIG to NORMAL) occurs immediately. A pulse with the minimum duration corresponding to 16 MHz / 1024 (IRCOSC clock) period can occurs in fast switching mode. It implies a frequency violation of the FCCU\_F protocol. Two modes, depending on the FCCU\_CFG.CM bit setting, can be programmed to define the FCCU\_F protocol in CONFIG state: - configuration labelling: the CONFIG state is marked by a specific FCCU F setting - configuration transparency: the CONFIG and NORMAL state are equivalent The FCCU\_F frequency is programmable based on the IRCOSC clock frequency divided by a fixed prescaler (1024). The external monitor of the FCCU\_F protocol should oversample the FCCU\_F signals in order to synchronize periodically the external clock (used by the monitor) and the IRCOSC clock detecting the edge transition of the FCCU\_F protocol in dual-rail or time-switching mode. Note: The initial values, after the reset phase, of the FCCU\_CFG.CM, FCCU\_CFG.SM, FCCU\_CFG.PS, FCCU\_CFG.FOP, FCCU\_CFG.FOM registers are set by the NVM interface (see Section 30.7.7: NVM interface). #### 30.7.8.1 Dual-rail protocol Dual-rail encoding is an alternate method for encoding bits. In contrast with classical encoding, where each signal carries a single-bit value, dual-rail encoded circuits use two wires to carry each bit. The encoding scheme is given in *Table 572* and the related timing diagram is given in *Figure 605* and *Figure 606*. Table 572. Dual-rail encoding | Logical state | Dual-rail encoding<br>(output pins FCCU_F[1:0]) | Note | | |---------------|-------------------------------------------------|----------------------|--| | non-faulty | 10 | toggling | | | non-faulty | 01 | toggling | | | faulty | 00 | toggling | | | faulty | 11 | | | | reset | high-Z | no toggling | | | configuration | high-Z | when FCCU_CFG.CM = 0 | | | configuration | = non-faulty | when FCCU_CFG.CM = 1 | | As long as FCCU is in NORMAL or ALARM state, output will show "no-faulty" signal. Output pins FCCU\_F[0] and FCCU\_F[1] will toggle between 01 and 10 with a given frequency. By default the frequency is the IRCOSC clock frequency divided by 18\*1024. During the RESET phase and during self testing the output pins are set as "high impedance". Note: Figure 605 and Figure 606 are formatted to display the behavior in all four phases (reset, normal, error, and config), not to imply transitions between one phase to another. In particular, transition from error phase to config phase is not possible. Figure 605. Dual-rail protocol (slow switching mode) #### 30.7.8.2 Time switching protocol The encoding scheme is given in *Table 573* and the related timing diagram is given in *Figure 607*. 577 | Logical state | Time switching encoding (output pins FCCU_F[1:0]) | Note | | |---------------|---------------------------------------------------|----------------------|--| | non-faulty | 10 | toggling | | | non-faulty | 01 | toggling | | | faulty | 10 | no toggling | | | reset | high-Z | no toggling | | | configuration | 01 | when FCCU_CFG.CM = 0 | | | Comiguration | = non-faulty | when FCCU_CFG.CM = 1 | | Table 573. Time switching encoding As long as FCCU is in NORMAL or ALARM state, outputs will show "non-faulty" signal. Output pins #0, #1 will toggle between "01" and "10" with a given frequency. By default the frequency is the IRCOSC clock frequency divided by 18\*1024. In the FAULT state, the output pin FCCU\_F[0] is set as low. In Time Switching mode the second output (FCCU\_F[1]) is the inverted signal of first output (FCCU\_F[0]). Values 00 on the outputs indicate a fault in the error out protocol itself. This state must be considered as critical fault, because no reliable error out indication is available any more. In the RESET phase the output pins are set as "high impedance". Note: Figure 607 is formatted to display the behavior in all four phases (reset, normal, error, and config), not to imply transitions between one phase to another. In particular, transition from error phase to config phase is not possible. Figure 607. Time-switching protocol #### 30.7.8.3 Bi-stable protocol The encoding scheme is given in *Table 574* and the related timing diagram is given in *Figure 608*. Bi-stable encoding Logical state Note (output pins FCCU\_F[1:0]) 01 non-faulty no toggling 10 faulty no toggling reset high-Z no toggling 10 when FCCU CFG.CM = 0 configuration = non-faulty when FCCU CFG.CM = 1 Table 574. Bi-stable encoding In the FAULT state, the faulty logical state is indicated. In NORMAL or ALARM state, "nofaulty" state is indicated. In Bi-stable mode the second output (FCCU\_F[1]) is the inverted signal of first output (FCCU F[0]). In the RESET phase the output pins are set as "high impedance". Note: Figure 608 is formatted to display the behavior in all four phases (reset, normal, error, and config), not to imply transitions between one phase to another. In particular, transition from error phase to config phase is not possible. Figure 608. Bi-stable protocol #### 30.7.9 **Fault mapping** Table 575 and Table 576 show the source of the fault signals and the type of fault input these signals are connected to at the FCCU. | rance or or a complemed or common range | | | |-----------------------------------------|--------|-----------------------------| | Critical fault | Module | Fault type | | CF[0] | CORE_0 | Core Checkstop mode entered | | CF[1] | CORE_0 | Core reset output | | CF[2] | CORE_1 | Core Checkstop mode entered | | CF[3] | CORE_1 | Core reset output | Table 575. FCCU mapping of critical faults | Critical fault | Module | Fault type | |----------------|--------|-----------------------------| | CF[0] | CORE_0 | Core Checkstop mode entered | | CF[1] | CORE_0 | Core reset output | | CF[2] | CORE_1 | Core Checkstop mode entered | | CF[3] | CORE_1 | Core reset output | DocID018714 Rev 5 978/1102 Table 575. FCCU mapping of critical faults(Continued) | Critical fault | Module | Fault type | |----------------|---------------|-------------------------------| | CF[4] | FLASH | Flash fatal error | | CF[5] | JTAG | JTAG reset (TAP controller) | | CF[6] | Code Flash | ECC Multi bit error | | CF[7] | Data Flash | ECC Multi bit error | | CF[8] | SRAM | ECC Multi bit error | | CF[14] | SWT_0 | Software Watchdog Timer Reset | | CF[15] | SWT_1 | Software Watchdog Timer Reset | | CF[16] | ECSM_0 | ECC not correctable error | | CF[17] | ECSM_1 | ECC not correctable error | | CF[22] | SSCM_XFER_ERR | SSCM transfer error | # Table 576. FCCU mapping of non-critical faults | Non-critical fault | Module | Fault type | |--------------------|---------|-----------------------------------------| | NCF[2] | FMPLL_0 | Loss of lock | | NCF[4] | CMU_0 | Loss of XOSC clock | | NCF[5] | CMU_0 | FMPLL_0_CLK frequency out of range | | NCF[6] | CMU_1 | SYS_CLK frequency out of range | | NCF[8] | ECSM_0 | ECC 1-bit error correction notification | | NCF[9] | ECSM_1 | ECC 1-bit error correction notification | | NCF[10] | CRC_0 | CRC Output Check | | NCF[11] | CRC_1 | CRC Output Check | | NCF[13] | PMU | LVD 1.2 digital Fault | | NCF[15] | PMU | LVD 2.7 VREG Fault | | NCF[16] | PMU | LVD 2.7 FLASH Fault | | NCF[17] | PMU | LVD 2.7 I/O Fault | | NCF[21] | MC_ME | Software device reset | # 31 Wakeup Unit (WKPU) ### 31.1 Overview The Wakeup Unit (WKPU) supports one external source that causes non-maskable interrupt requests. ### 31.2 Features The WKPU provides non-maskable interrupt support with these features: - 1 NMI source - 1 analog glitch filter - Independent interrupt destination: non-maskable interrupt, critical interrupt, or machine check request - Edge detection ## 31.3 External signal description The WKPU has one signal input that can be used as non-maskable interrupt. Note: The user should be aware that the Wake-up pins are enabled in ALL modes, therefore, the Wake-up pins should be correctly terminated to ensure minimal current consumption. Any unused Wake-up signal input should be terminated by using an external pull-up or pull-down, or by internal pull-up enabled at WKUP\_WIPUER. Also care has to be taken on packages where the Wake-up signal inputs are not bonded. For these packages the user must ensure the internal pull-up are enabled for those signals not bonded. # 31.4 Memory map and registers description This section provides a detailed description of all registers accessible in the WKPU module. ### **31.4.1 Memory map** Table 577 lists the WKPU registers. Table 577. WKPU memory map | Offset from<br>WKPU_BASE<br>(0xC3F9_4000) | Register | Location | |-------------------------------------------|--------------------------------|-------------| | 0x0000 | NSR—NMI Status Flag Register | on page 981 | | 0x0004-0x0007 | Reserved | | | 0x0008 | NCR—NMI Configuration Register | on page 981 | | 0x000C-0x3FFF | Reserved | | ### 31.4.2 Registers description This section describes the Wakeup Unit registers. ### 31.4.2.1 NMI Status Flag Register (NSR) This register holds the non-maskable interrupt status flags. Figure 609. NMI Status Flag Register (NSR) Table 578. NSR field descriptions | Field | Description | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>NIF | NMI Status Flag This flag can be cleared only by writing a 1. Writing a 0 has no effect. If enabled (NCR.NREEor NCR.NFEE is set), NIFcauses an interrupt request. 0: No event has occurred on the pad. 1: An event as defined by NRRC.NREE or NCR.NFEE has occurred. | | 1<br>NOVF | NMI Overrun Status Flag This flag can be cleared only by writing a 1. Writing a 0 has no effect. It will be a copy of the current NIF value whenever an NMI event occurs, thereby indicating to the software that an NMI occurred while the last one was not yet serviced. If enabled (NCR.NREEor NCR.NFEE set), NOVF causes an interrupt request. 0: No overrun has occurred on NMI input. 1: An overrun has occurred on NMI input. | ### 31.4.2.2 NMI Configuration Register (NCR) This register holds the configuration bits for the non-maskable interrupt settings. Figure 610. NMI Configuration Register (NCR) Table 579. NCR field descriptions | Field | Description | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>NLOCK | NMI Configuration Lock Register Writing a 1 to this bit locks the configuration for the NMI until it is unlocked by a system reset. Writing a 0 has no effect. | | 1-2<br>NDSS | NMI Destination Source Select 00: Non-maskable interrupt 01: Critical interrupt 10: Machine check request 11: Reserved | | 5<br>NREE | NMI Rising-edge Events Enable 0: Rising-edge event is disabled 1: Rising-edge event is enabled | | 6<br>NFEE | NMI Falling-edge Events Enable 0: Falling-edge event is disabled 1: Falling-edge event is enabled | | 7<br>NFE | NMI Filter Enable Enable analog glitch filter on the NMI pad input. 0: Filter is disabled 1: Filter is enabled | Note: Writing a 0 to both NREE and NFEE disables the NMI functionality completely (that is, no system wakeup or interrupt will be generated on any pad activity)! # 31.5 Functional description ### 31.5.1 General This section provides a complete functional description of the Wakeup Unit. ### 31.5.2 Non-Maskable Interrupts The Wakeup Unit supports one non-maskable interrupt, which is allocated to pin 1. The Wakeup Unit supports the generation of three types of interrupts from the NMI input to the device. The Wakeup Unit supports the capturing of a second event per NMI input before the interrupt is cleared, thus reducing the chance of losing an NMI event. Each NMI passes through a bypassable analog glitch filter. Note: Glitch filter control and pad configuration should be done while the NMI is disabled in order to avoid erroneous triggering by glitches caused by the configuration process itself. Figure 611. NMI pad diagram #### 31.5.2.1 NMI management The NMI can be enabled or disabled using the single NCR laid out to contain all configuration bits for an NMI in a single byte (see *Figure 610*). The pad defined as an NMI can be configured by the user to recognize interrupts with an active rising edge, an active falling edge or both edges being active. A setting of having both edge events disabled results in no interrupt being detected and should not be configured. The active NMI edge is controlled by the user through the configuration of the NREE and NFEE bits. Note: After reset, NREE and NFEE are set to 0, therefore the NMI functionality is disabled after reset and must be enabled explicitly by software. Once the pad's NMI functionality has been enabled, the pad cannot be reconfigured in the IOMUX to override or disable the NMI. The NMI destination interrupt is controlled by the user through the configuration of the NDSS bits. See *Table 579* for details. An NMI supports a status flag and an overrun flag, which are located in the NSR (see *Figure 609*). This register is a clear-by-write-1 register type, preventing inadvertent overwriting of other flags in the same register. The status flag is set whenever an NMI event is detected. The overrun flag is set whenever an NMI event is detected and the status flag is set (that is, has not yet been cleared). Note: The overrun flag is cleared by writing a 1 to the appropriate overrun bit in the NSR. If the status bit is cleared and the overrun bit is still set, the pending interrupt will not be cleared. # 32 Periodic Interrupt Timer (PIT) ### 32.1 Introduction The Periodic Interrupt Timer (PIT) block implements several timers that can be used for DMA triggering, general purpose interrupts and system wakeup. Figure 612 shows the PIT block diagram. Figure 612. PIT block diagram #### 32.1.1 Overview This chapter describes the function of the PIT. The PIT is an array of four timers that can be used to raise interrupts and trigger DMA channels. #### 32.1.2 Features The main features of this block are: - Timers can generate DMA trigger pulses to initiate DMA transfers with other peripherals (ex: initiate a SPI message transfer sequence) - Timers can generate interrupts - All interrupts are maskable - Independent timeout periods for each timer # 32.2 Signal description The PIT module has no external pins. # 32.3 Memory map and registers description This section provides a detailed description of all registers accessible in the PIT module. ## 32.3.1 Memory map Table 580 gives an overview on all PIT registers. Table 580. PIT memory map | Offset from PIT_BASE (0xC3FF_0000) | Register | Location | | |------------------------------------|--------------------------------------|-------------|--| | 0x0000 | PITMCR—PIT Module Control Register | on page 987 | | | 0x0004-0x00FF | Reserved | | | | | Timer Channel 0 | | | | 0x0100 | LDVAL0—Timer 0 Load Value Register | on page 988 | | | 0x0104 | CVAL0—Timer 0 Current Value Register | on page 989 | | | 0x0108 | TCTRL0—Timer 0 Control Register | on page 990 | | | 0x010C | TFLG0—Timer 0 Flag Register | on page 991 | | | | Timer Channel 1 | · | | | 0x0110 | LDVAL1—Timer 1 Load Value Register | on page 988 | | | 0x0114 | CVAL1—Timer 1 Current Value Register | on page 989 | | | 0x0118 | TCTRL1—Timer 1 Control Register | on page 990 | | | 0x011C | TFLG1—Timer 1 Flag Register | on page 991 | | | | Timer Channel 2 | | | | 0x0120 | LDVAL2—Timer 2 Load Value Register | on page 988 | | | 0x0124 | CVAL2—Timer 2 Current Value Register | on page 989 | | | 0x0128 | TCTRL2—Timer 2 Control Register | on page 990 | | | 0x012C | TFLG2—Timer 2 Flag Register | on page 991 | | | | Timer Channel 3 | | | | 0x0130 | LDVAL3—Timer 3 Load Value Register | on page 988 | | | 0x0134 | CVAL3—Timer 3 Current Value Register | on page 989 | | | 0x0138 | TCTRL3—Timer 3 Control Register | on page 990 | | | 0x013C | TFLG3—Timer 3 Flag Register | on page 991 | | | 0x0140-0x3FFF | Reserved | | | Note: Reserved registers read as 0. Writes have no effect. ### 32.3.2 Registers description This section describes in address order all the PIT registers and their individual bits. PIT registers are accessible only when the core is in supervisor mode. #### 32.3.2.1 PIT Module Control Register (PITMCR) This register controls whether the timer clocks are enabled and whether the timers run in debug mode. Figure 613. PIT Module Control Register (PITMCR) Table 581. PITMCR field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MDIS | Module Disable Used to disable the module clock. This bit should be enabled before any other setup is done. 0: Clock for PIT Timers is enabled 1: Clock for PIT Timers is disabled (default) | | FRZ | Freeze Allows the timers to be stopped when the device enters debug mode. 0: Timers continue to run in debug mode. 1: Timers are stopped in debug mode. | ### 32.3.2.2 Timer Load Value Register *n* (LDVAL*n*) These registers select the timeout period for the timer interrupts. Channel Base + 0x0000 LDVAL0 = PIT\_BASE + 0x0100 Address: LDVAL1 = PIT\_BASE + 0x0110 Access: User read/write LDVAL2 = PIT BASE + 0x0120 LDVAL3 = PIT BASE + 0x0130 R TSV TSV TSV TSV TSV **TSV TSV** TSV TSV TSV **TSV** TSV **TSV** TSV TSV **TSV** W Reset TSV TSV TSV TSV TSV **TSV TSV TSV** TSV7 TSV6 TSV5 TSV4 TSV3 TSV2 TSV1 TSV0 W Reset Figure 614. Timer Load Value Register n (LDVALn) Table 582. LDVALn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TSVn | Time Start Value Bits These bits set the timer start value. The timer will count down until it reaches 0, then it will generate an interrupt and load this register value again. Writing a new value to this register will not restart the timer, instead the value will be loaded once the timer expires. To abort the current cycle and start a timer period with the new value, the timer must be disabled and enabled again (see Figure 619). | ### 32.3.2.3 Current Timer Value Register n (CVALn) These registers indicate the current timer position. Channel Base + 0x0004 CVAL0 = PIT\_BASE + 0x0104 Address: CVAL1 = PIT\_BASE + 0x0114 Access: User read-only CVAL2 = PIT BASE + 0x0124 CVAL3 = PIT BASE + 0x0134 TVL3 TVL3 TVL2 TVL2 TVL2 TVL2 TVL2 TVL1 TVL1 TVL2 TVL2 TVL2 TVL2 TVL2 TVL1 TVL1 W Reset TVL1 TVL1 TVL1 TVL1 TVL1 TVL9 TVL8 TVL7 TVL6 TVL5 TVL4 TVL3 TVL2 TVL1 TVL0 R Reset Figure 615. Current Timer Value register n (CVALn) Table 583. CVALn field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TVLn | Current Timer Value These bits represent the current timer value. Note that the timer uses a downcounter. Note: The timer values will be frozen in Debug mode if the FRZ bit is set in the PIT Module Control Register (see Figure 613: PIT Module Control Register (PITMCR)). | Reset ### 32.3.2.4 Timer Control Register *n* (TCTRL*n*) The TCTRL register contains the control bits for each timer. Channel Base + 0x0008 TCTRL0 = PIT\_BASE + 0x0108 Address: TCTRL1 = PIT\_BASE + 0x0118 Access: User read/write TCTRL2 = PIT\_BASE + 0x0128 TCTRL3 = PIT BASE + 0x0138 R W Reset R TIE TEN Figure 616. Timer Control register *n* (TCTRL*n*) Table 584. TCTRLn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIE | Timer Interrupt Enable Bit 0: Interrupt requests from Timer x are disabled 1: Interrupt will be requested whenever TIF is set When an interrupt is pending (TIF set), enabling the interrupt will immediately cause an interrupt event. To avoid this, the associated TIF flag must be cleared first. | | TEN | Timer Enable Bit 0: Timer will be disabled 1: Timer will be active | #### 32.3.2.5 Timer Flag Register *n* (TFLG*n*) These registers contain the PIT interrupt flags. Channel Base + 0x000C TFLG0 = PIT BASE + 0x010C Address: TFLG1 = PIT\_BASE + 0x011C Access: User read/write TFLG2 = PIT BASE + 0x012C TFLG3 = PIT BASE + 0x013C R W Reset TIF R W w1c Reset Figure 617. Timer Flag register n (TFLGn) #### Table 585. TFLGn field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIF | Time Interrupt Flag TIF is set to 1 at the end of the timer period. This flag can be cleared only by writing it with a 1. Writing a 0 has no effect. If enabled (TIE = 1), TIF causes an interrupt request. 0: Time-out has not yet occurred 1: Time-out has occurred | # 32.4 Functional description ### 32.4.1 General This section gives detailed information on the internal operation of the module. Each timer can be used to generate trigger pulses as well as to generate interrupts, each interrupt will be available on a separate interrupt line. #### 32.4.1.1 Timers The timers generate triggers at periodic intervals, when enabled. They load their start values, as specified in their LDVAL registers, then count down until they reach 0. Then they load their respective start value again. Each time a timer reaches 0, it will generate a trigger pulse, and set the interrupt flag. All interrupts can be enabled or masked (by setting the TIE bits in the TCTRL registers). A new interrupt can be generated only after the previous one is cleared. If desired, the current counter value of the timer can be read via the CVAL registers. The counter period can be restarted, by first disabling, then enabling the timer with the TEN bit (see *Figure 618*). The counter period of a running timer can be modified, by first disabling the timer, setting a new load value and then enabling the timer again (see *Figure 619*). It is also possible to change the counter period without restarting the timer by writing the LDVAL register with the new load value. This value will then be loaded after the next trigger event (see *Figure 620*). Figure 618. Stopping and starting a timer Figure 619. Modifying running timer period Figure 620. Dynamically setting a new load value #### 32.4.1.2 Debug mode In Debug mode, the timers are frozen. This is intended to aid software development, allowing the developer to halt the processor, investigate the current state of the system (e.g., timer values) and then continue the operation. ### 32.4.2 Interrupts All of the timers support interrupt generation. Refer to *Chapter 9: Interrupt Controller (INTC)* for related vector addresses and priorities. Timer interrupts can be disabled by setting the TIE bits to zero. The timer interrupt flags (TIF) are set to 1 when a timeout occurs on the associated timer, and are cleared to 0 by writing a 1 to that TIF bit. # 32.5 Initialization and application information ### 32.5.1 Example configuration In the example configuration: - The PIT clock has a frequency of 50 MHz - Timer 1 creates an interrupt every 5.12 ms - Timer 3 creates a trigger event every 30 ms First the PIT module needs to be activated by writing a 0 to the MDIS bit in the PITMCR. The 50 MHz clock frequency equates to a clock period of 20 ns. Timer 1 needs to trigger every 5.12 ms/20 ns = 256000 cycles and timer 3 every 30 ms/20 ns = 1500000 cycles. The value for the LDVAL register trigger would be calculated as (period / clock period) -1. The LDVAL registers must be configured as follows: - LDVAL for Timer 1: 0x0003 E7FF - LDVAL for Timer 3: 0x0016 E35F The interrupt for Timer 1 is enabled by setting TIE in the TCTRL1 register. The timer is started by writing a 1 to bit TEN in the TCTRL1 register. Timer 3 shall be used only for triggering. Therefore Timer 3 is started by writing a 1 to bit TEN in the TCTRL3 register, bit TIE stays at 0. The following example code matches the described setup: ``` // turn on PIT PIT_CTRL = 0x00; // RTI PIT_RTI_LDVAL = 0x004C4B3F; // setup RTI for 5000000 cycles PIT_RTI_TCTRL = PIT_TIE; // let RTI generate interrupts PIT_RTI_TCTRL |= PIT_TEN; // start RTI // Timer 1 PIT_LDVAL1 = 0x0003E7FF; // setup timer 1 for 256000 cycles PIT_TCTRL1 = TIE; // enable Timer 1 interrupts PIT_TCTRL1 |= TEN; // start timer 1 // Timer 3 PIT_LDVAL3 = 0x0016E35F; // setup timer 3for 1500000 cycles PIT_TCTRL3 = TEN; // start timer 3 ``` # 33 System Timer Module (STM) #### 33.1 Overview The System Timer Module (STM) is a 32-bit timer designed to support commonly required system and application software timing functions. The STM includes a 32-bit up counter and four 32-bit compare channels with a separate interrupt source for each channel. The counter is driven by the system clock divided by an 8-bit prescale value (1 to 256). ### 33.2 Features The STM has the following features: - One 32-bit up counter with 8-bit prescaler - Four 32-bit compare channels - Independent interrupt source for each channel - Counter can be stopped in debug mode # 33.3 Modes of operation The STM supports two device modes of operation: normal and debug. When the STM is enabled in normal mode, its counter runs continuously. In debug mode, operation of the counter is controlled by the FRZ bit in the STM\_CR. If the FRZ bit is set, the counter is stopped in debug mode, otherwise it continues to run. # 33.4 External signal description The STM does not have any external interface signals. # 33.5 Memory map and registers description The STM programming model has fourteen 32-bit registers. The STM registers can only be accessed using 32-bit (word) accesses. Attempted references using a different size or to a reserved address generates a bus error termination. STM registers are accessible only when the core is in supervisor mode. ### 33.5.1 Memory map The STM memory map is shown in Table 586. Table 586. STM memory map | Offset from<br>STM_BASE<br>0xFFF3_C000 (STM_0)<br>0x8FF3_C000 (STM_1) | Register | Location | |-----------------------------------------------------------------------|-------------------------------------------|-------------| | 0x0000 | STM_CR—STM Control Register | on page 995 | | 0x0004 | STM_CNT—STM Counter Value | on page 996 | | 0x0008-0x000F | Reserved | | | 0x0010 | STM_CCR0—STM Channel 0 Control Register | on page 997 | | 0x0014 | STM_CIR0—STM Channel 0 Interrupt Register | on page 997 | | 0x0018 | STM_CMP0—STM Channel 0 Compare Register | on page 998 | | 0x001C | Reserved | | | 0x0020 | STM_CCR1—STM Channel 1 Control Register | on page 997 | | 0x0024 | STM_CIR1—STM Channel 1 Interrupt Register | on page 997 | | 0x0028 | STM_CMP1—STM Channel 1 Compare Register | on page 998 | | 0x002C | Reserved | | | 0x0030 | STM_CCR2—STM Channel 2 Control Register | on page 997 | | 0x0034 | STM_CIR2—STM Channel 2 Interrupt Register | on page 997 | | 0x0038 | STM_CMP2—STM Channel 2 Compare Register | on page 998 | | 0x003C | Reserved | | | 0x0040 | STM_CCR3—STM Channel 3 Control Register | on page 997 | | 0x0044 | STM_CIR3—STM Channel 3 Interrupt Register | on page 997 | | 0x0048 | STM_CMP3—STM Channel 3 Compare Register | on page 998 | | 0x004C-0x3FFF | Reserved | | # 33.5.2 Registers description The following sections detail the individual registers within the STM programming model. ### 33.5.2.1 STM Control Register (STM\_CR) The STM Control Register (STM\_CR) includes the prescale value, freeze control and timer enable bits. Figure 621. M Control Register (STM\_CR) Table 587. STM\_CR field descriptions | Field | Description | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPS[7:0] | Counter Prescaler Selects the clock divide value for the prescaler (1 - 256). 0x00 Divide system clock by 1. 0x01 Divide system clock by 2 0xFF Divide system clock by 256. | | FRZ | Freeze Allows the timer counter to be stopped when the device enters debug mode. 0 STM counter continues to run in debug mode. 1 STM counter is stopped in debug mode. | | TEN | Timer Counter Enabled 0 Counter is disabled. 1 Counter is enabled. | ### 33.5.2.2 STM Count Register (STM\_CNT) The STM Count Register (STM\_CNT) holds the timer count value. Figure 622. STM Count Register (STM\_CNT) Table 588. STM\_CNT field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | CNT | Timer count value used as the time base for all channels. When enabled, the counter increments at the rate of the system clock divided by the prescale value. | ### 33.5.2.3 STM Channel Control Register (STM\_CCRn) The STM Channel Control Register (STM\_CCRn) enables and services channel n of the timer. Figure 623. STM Channel Control Register (STM\_CCRn) Table 589. STM\_CCRn field descriptions | Field | Description | |-------|-----------------------------------------------------------------------| | CEN | Channel Enable 0 The channel is disabled. 1 The channel is enabled. | #### 33.5.2.4 STM Channel Interrupt Register (STM\_CIRn) The STM Channel Interrupt Register (STM\_CIRn) enables and services channel n of the timer. Figure 624. STM Channel Interrupt Register (STM\_CIRn) Table 590. STM\_CIRn field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CIF | Channel Interrupt Flag The flag and interrupt are cleared by writing a 1 to this bit. Writing a 0 has no effect. O No interrupt request. Interrupt request due to a match on the channel. | #### 33.5.2.5 STM Channel Compare Register (STM\_CMPn) The STM Channel Compare Register (STM\_CMPn) holds the compare value for channel n. Table 591. STM CMPn field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CMP | Compare value for channel n If the STM_CCRn[CEN] bit is set and the STM_CMPn register matches the STM_CNT register, a channel interrupt request is generated and the STM_CIRn[CIF] bit is set. | ## 33.6 Functional description The System Timer Module (STM) is a 32-bit timer designed to support commonly required system and application software timing functions. The STM includes a 32-bit up counter and four 32-bit compare channels with a separate interrupt source for each channel. The STM has one 32-bit up counter (STM\_CNT) that is used as the time base for all channels. When enabled, the counter increments at the system clock frequency divided by a prescale value. The STM\_CR[CPS] field sets the divider to any value in the range from 1 to 256. The counter is enabled with the STM\_CR[TEN] bit. When enabled in normal mode the counter continuously increments. When enabled in debug mode the counter operation is controlled by the STM\_CR[FRZ] bit. When the STM\_CR[FRZ] bit is set, the counter is stopped in debug mode, otherwise it continues to run in debug mode. The counter rolls over at 0xFFFF\_FFFF to 0x0000\_0000 with no restrictions at this boundary. The STM has four identical compare channels. Each channel includes a channel control register (STM\_CCRn), a channel interrupt register (STM\_CIRn) and a channel compare register (STM\_CMPn). The channel is enabled by setting the STM\_CCRn[CEN] bit. When enabled, the channel will set the STM\_CIR[CIF] bit and generate an interrupt request when the channel compare register matches the timer counter. The interrupt request is cleared by writing a 1 to the STM\_CIRn[CIF] bit. A write of 0 to the STM\_CIRn[CIF] bit has no effect. # 34 Cyclic Redundancy Check (CRC) #### 34.1 Introduction The Cyclic Redundancy Check (CRC) computing unit is dedicated to the computation of CRC, thus off-loading the CPU. The SPC56xP60x/54x CRC supports three contexts. Each context has a separate CRC computation engine in order to allow the concurrent computation of the CRC of multiple data streams. The CRC computation is performed at speed without wait states insertion. Bit-swap and bit-inversion operations can be applied on the final CRC signature. Each context can be configured with one of three hard-wired polynomials, normally used for most of the standard communication protocols. The data stream supports multiple data width (byte/half-word/word) formats. ### 34.1.1 Glossary - CRC: cyclic redundancy check - CPU: central processing unit - DMA: direct memory access - CCITT: ITU-T (for Telecommunication Standardization Sector of the International Telecommunications Union) - SW: softwareWS: wait state - SPI: serial peripheral interface #### 34.2 Main features - 3 contexts for the concurrent CRC computation - Separate CRC engine for each context - Zero-wait states during the CRC computation (pipeline scheme) - 3 hard-wired polynomials (CRC-8 VDA CAN, CRC-16-CCITT and CRC-32 Ethernet) - Support for byte/half-word/word width of the input data stream #### 34.2.1 Standard features - IPS bus interface - CRC-8 VDA CAN - CRC-16-CCITT - CRC-32 Ethernet # 34.3 Block diagram Figure 626 shows the top level diagram of the CRC unit. Config and Data Registers Crc\_compare\_error Config and CRC Engine context 1 context 2 context 3 context 3 Figure 626. CRC top level diagram #### 34.3.1 IPS bus interface The IPS bus interface is a slave bus used for configuration and data streaming (CRC computation) purposes via CPU or DMA. The following bus operations (contiguous byte enables) are supported: - Word (32-bit) data write/read operations to any registers - Low and high half-words (16-bit, data[31:16] or data[15:0]) data write/read operations to any registers - Byte (8-bit, data[31:24] or data[23:16] or data[15:8] or data[7:0]) data write/read operations to any registers - Any other operation (free byte enables or other operations) must be avoided. The CRC generates a transfer error in the following cases: - Any write/read access to the register addresses not mapped on the peripheral but included in the address space of the peripheral. - Any write/read operation different from byte/hword/word (free byte enables or other operations) on each register. The registers of the CRC module are accessible (read/write) in each access mode: user, supervisor, or test. In terms of bus performance of the operations, following the summary: - 0 WS (single bus cycle) for each write/read operations to the CRC\_CFG and CRC\_INP registers - 0 WS (single bus cycle) for each write operation to the CRC CSTAT register - Double WS (3 bus cycles) for each read operation to the CRC\_CSTAT or CRC\_OUTP registers immediately following (next clock cycle) a write operation to the CRC\_CSTAT, CRC\_INP or CRC\_CFG registers belonging to the same context. In all the other cases no WS are inserted. # 34.4 Functional description The CRC module supports the CRC computation for each context. Each context has a own complete set of registers including the CRC engine. The data flow of each context can be interleaved. The data stream can be structured as a sequence of byte, half-words or words. The input data sequence is provided, eventually mixing the data formats (byte, half-word, word), writing to the input data register (CRC\_INP). The data stream is generally executed by N concurrent DMA data transfers (mem2mem) where N is less or equal to the number of contexts. Three standard generator polynomials are given in *Equation 68*, *Equation 69* and *Equation 70* for the CRC computation of each context. #### **Equation 68 CRC-8 VDA CAN)** $$x^8 + x^4 + x^3 + x^2 + 1$$ #### Equation 69 CRC-16-CCITT (x25 protocol) $$x^{16} + x^{12} + x^5 + 1$$ #### **Equation 70 CRC-32 (Ethernet protocol)** $$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$$ Figure 627. CRC-CCITT engine concept scheme The initial seed value of the CRC can be programmed initializing the CRC\_CSTAT register. The concept scheme (serial data loading) of the CRC engine is given in *Figure 627* for the CRC-CCITT. The design implementation executes the CRC computation in a single clock cycle (parallel data loading). A pipeline scheme has been adopted to de-couple the IPS bus interface from the CRC engine in order to allow the computation of the CRC at speed (zero wait states). In case of usage of the CRC signature for encapsulation in the data frame of a communication protocol (e.g., SPI, ..) a bit swap (MSB $\rightarrow$ LSB, LSB $\rightarrow$ MSB) and/or bit inversion of the final CRC signature can be applied (CRC\_OUTP register) before to transmit the CRC. The usage of the CRC is summarized in the flow-chart given in Figure 628. **577** Figure 628. CRC computation flow # 34.5 Memory map and registers description Table 592 shows the CRC memory map. Table 592. CRC memory map | Offset from<br>CRC_BASE<br>0xFFE6_8000<br>(CRC_0)<br>0x9FE7_0000<br>(CRC_1) | Register | Location | |-----------------------------------------------------------------------------|--------------------------------------------------|--------------| | 0x0000 | CRC_CFG—CRC Configuration Register, Context 1 | on page 1004 | | 0x0004 | CRC_INP—CRC Input Register, Context 1 | on page 1005 | | 0x0008 | CRC_CSTAT—CRC Current Status Register, Context 1 | on page 1006 | Table 592. CRC memory map(Continued) | Offset from<br>CRC_BASE<br>0xFFE6_8000<br>(CRC_0)<br>0x9FE7_0000<br>(CRC_1) | Register | Location | |-----------------------------------------------------------------------------|---------------------------------------------------|--------------| | 0x000C | CRC_OUTP—CRC Output Register, Context 1 | on page 1007 | | 0x0010 | CRC_CFG—CRC Configuration Register, Context 2 | on page 1004 | | 0x0014 | CRC_INP—CRC Input Register, Context 2 | on page 1005 | | 0x0018 | CRC_CSTAT—CRC Current Status Register, Context 2 | on page 1006 | | 0x001C | CRC_OUTP—CRC Output Register, Context 2 | on page 1007 | | 0x0020 | CRC_CFG—CRC Configuration Register, Context 3 | on page 1004 | | 0x0024 | CRC_INP—CRC Input Register, Context 3 | on page 1005 | | 0x0028 | CRC_CSTAT—CRC Current Status Register, Context 3 | on page 1006 | | 0x002C | CRC_OUTP—CRC Output Register, Context 3 | on page 1007 | | 0x0030-0x00FF | Reserved | | | 0x0100 | CRC_OUTP_CHK—CRC Output Check Register, Context 1 | on page 1007 | | 0x0110 | CRC_OUTP_CHK—CRC Output Check Register, Context 2 | on page 1007 | | 0x0120 | CRC_OUTP_CHK—CRC Output Check Register, Context 3 | on page 1007 | | 0x0124-0x3FFF | Reserved | | ## 34.5.1 CRC Configuration Register (CRC\_CFG) Figure 629. CRC Configuration Register (CRC\_CFG) <sup>1.</sup> Only for CRC module 2 POLIG is "1", CRC\_CFG - correct reset value is 0x0004. Table 593. CRC\_CFG field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:7 | LEN: Length of data in payload Maximum possible data length is 256 (0-255). | | 8:27 | Reserved These are reserved bits. These bits are always read as 0 and must always be written with 0. | | 28:29 | POLYG: Polynomial selection 00: CRC-CCITT polynomial 01: CRC-32 polynomial 10: CRC-8 polynomial 11: CRC-8 polynomial This bit can be read and written by the software. This bit can be written only during the configuration phase. | | 30 | SWAP: SWAP selection 0: No swap selection applied on the CRC_OUTP content 1: Swap selection (MSB -> LSB, LSB -> MSB) applied on the CRC_OUTP content. In case of CRC-CCITT polynomial the swap operation is applied on the 16 LSB bits. This bit can be read and written by the software. This bit can be written only during the configuration phase. | | 31 | INV: INV selection 0: No inversion selection applied on the CRC_OUTP content 1: Inversion selection (bit x bit) applied on the CRC_OUTP content. In case of CRC-CCITT polynomial the inversion operation is applied on the 16 LSB bits. This bit can be read and written by the software. This bit can be written only during the configuration phase. | # 34.5.2 CRC Input Register (CRC\_INP) Figure 630. CRC Input Register (CRC\_INP) Table 594. CRC\_INP field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:31 | INP: Input data for the CRC computation The INP register can be written at byte, half-word (high and low) or word in any sequence. In case of half-word write operation, the bytes must be contiguous. This register can be read and written by the software. | # 34.5.3 CRC Current Status Register (CRC\_CSTAT) Figure 631. CRC Current Status Register (CRC\_CSTAT) Table 595. CRC\_CSTAT field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:31 | CSTAT: Status of the CRC signature The CSTAT register includes the current status of the CRC signature. No bit swap and inversion are applied to this register. In case of CRC-CCITT polynomial only the16 LSB bits are significant. The 16 MSB bits are tied at 0b during the computation. The CSTAT register can be written at byte, half-word or word. This register can be read and written by the software. This register can be written only during the configuration phase. | ### 34.5.4 CRC Output Register (CRC\_OUTP) Figure 632. CRC Output Register (CRC\_OUTP) Table 596. CRC\_OUTP field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:31 | OUTP: Final CRC signature The OUTP register includes the final signature corresponding to the CRC_CSTAT register value eventually swapped and inverted. In case of CRC-CCITT polynomial only the 16 LSB bits are significant. The 16 MSB bits are tied at 0b during the computation. This register can be read by the software. | # 34.5.5 CRC Output Check Register (CRC\_OUTP\_CHK) Figure 633. CRC Output Check Register (CRC\_OUTP\_CHK) ### 34.6 Use cases and limitations Table 597. CRC\_OUTP\_CHK field descriptions | Field | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0:31 | OUTP_CHK: Output data for the CRC comparison The OUTP_CHK register can be written at byte, half-word (high and low) or word in any sequence. In case of half-word write operation, the bytes must be contiguous. This register can be read and written by the software. | Two main use cases shall be considered: - Calculation of the CRC of the configuration registers during the process safety time - Calculation of the CRC on the incoming/outgoing frames for the communication protocols (not protected with CRC by definition of the protocol itself) used as a safetyrelevant peripheral. The signature of the configuration registers is computed in a correct way only if these registers do not contain any status bit. Assuming that the DMA engine has N channels (greater or equal to the number of contexts) configurable for the following type of data transfer: mem2mem, periph2mem, mem2periph, the following sequence, as given in *Figure 634*, shall be applied to manage the transmission data flow: - DMA/CRC module configuration (context x, channel x) by CPU - Payload transfer from the MEM to the CRC module (CRC\_INP register) to calculate the CRC signature (phase1) by DMA (mem2mem data transfer, channel x) - CRC signature copy from the CRC module (CRC\_OUTP register) to the MEM (phase 2) by CPU - Data block (payload + CRC) transfer from the MEM to the PERIPH module (e.g., SPI Tx FIFO) (phase 3) by DMA (mem2periph data transfer, channel x) Transmission Phase 1 Memory CRC (context x) **DMA** CRC\_INP **Payload** (mem2mem CRC\_OUTP channel x) **Transmission Phase 2** Memory CRC (context x) CRC\_INP Payload CPU CRC\_OUTP **CRC Checksum Transmission Phase 3** Memory SPI DMA Tx FIFO **Payload** (mem2periph channel x) **CRC Checksum** Figure 634. DMA-CRC Transmission Sequence The following sequence, as given in *Figure 635*, shall be applied to manage the reception data flow: - DMA/CRC module configuration (context x, channel x) by CPU - Data block (payload + CRC) transfer from the PERIPH (e.g., SPI Rx FIFO) module to the MEM (phase 1) by DMA (periph2mem data transfer, channel x) - Data block transfer (payload) transfer from the MEM to the CRC module (CRC\_INP register) to calculate the CRC signature (phase 2) by DMA (mem2mem data transfer, channel x) - Data block transfer (CRC) transfer from the MEM to the CRC module (CRC\_OUTP\_CHK register) to compare with the calculated CRC signature (phase 2) by DMA (mem2mem data transfer, channel x) - CRC signature check from the CRC module (CRC\_OUTP register) by CPU (phase 3) Figure 635. DMA-CRC Reception Sequence # 35 Boot Assist Module (BAM) # 35.1 Overview The Boot Assist Module is a block of read-only memory containing VLE code that is executed according to the boot mode of the device. The BAM allows downloading boot code via the FlexCAN or LINFlex interfaces into internal SRAM and then executing it. ## 35.2 Features The BAM provides the following features: - SPC56xP60x/54x in static mode if internal flash is not initialized or invalid - Programmable 64-bit password protection for serial boot mode - Serial boot loads the application boot code from a FlexCAN or LINFlex bus into internal SRAM - Censorship protection for internal flash module # 35.3 Boot modes The SPC56xP60x/54x device supports the following boot modes: - Single Chip (SC) The device boots from the first bootable section of the Flash main array. - Serial Boot (SBL) The device downloads boot code from either LINFlex or FlexCAN interface and then execute it. If booting is not possible with the selected configuration (e.g., if no Boot ID is found in the selected boot location) then the device enters the static mode. # 35.4 Memory map The BAM code resides in a reserved 8 KB ROM mapped from address 0xFFFF\_C000. The address space and memory used by the BAM application is shown in *Table 598*. Table 598. BAM memory organization | Parameter | Address | |------------------------------|-------------| | BAM entry point | 0xFFFF_C000 | | Downloaded code base address | 0x4000_0100 | The RAM location where to download the code can be any 4-byte-aligned location starting from the address 0x4000 0100. # 35.5 Functional description # 35.5.1 Entering boot modes The SPC56xP60x/54x detects the boot mode based on external pins and device status. The following sequence applies (see *Figure 636*): - To boot either from FlexCAN or LINFlex, the device must be forced into an Alternate Boot Loader Mode via the FAB (Force Alternate Boot Mode), which must be asserted before initiating the reset sequence. The type of alternate boot mode is selected according to the ABS (Alternate Boot Selector) pins (see *Table 599*). - If FAB is not asserted, the device boots from the lowest Flash sector that contains a valid boot signature. - If no Flash sector contains a valid boot signature, the device will go into static mode. Figure 636. Boot mode selection Boot configuration pins are: - PAD A[2] ABS[0], - PAD A[3] ABS[1], - PAD A[4] FAB Table 599. Hardware configuration to select boot mode | FAB | ABS[1:0] <sup>(1)</sup> | Standby-RAM<br>Boot Flag | Boot ID | Boot Mode | |-----|-------------------------|--------------------------|---------|--------------------------------------------------------------------| | 1 | 00 | 0 | _ | LINFlex without autobaud | | 1 | 01 | 0 | _ | FlexCAN without autobaud | | 1 | 10 | 0 | _ | Scan of both serial interfaces (FlexCAN and LINFlex) with autobaud | <sup>1.</sup> During reset the boot configuration pins are weak pull down. # 35.5.2 SPC56xP60x/54x boot pins The TX/RX pin (LINFlex\_0 and FlexCAN\_0) used for serial boot and configuration boot pins to select the serial boot mode are described in the *Table 600* for all packages. Table 600. SPC56xP60x/54x boot pins | Dout win | Function | Pin | | | |---------------------|----------|---------|---------|------------------------| | Port pin | | 100-pin | 144-pin | 176-pin <sup>(1)</sup> | | A[2] <sup>(2)</sup> | ABS[0] | 57 | 84 | 102 | | A[3] <sup>(2)</sup> | ABS[1] | 64 | 92 | 116 | | A[4] <sup>(2)</sup> | FAB | 75 | 108 | 132 | | B[0] | CAN_0 TX | 76 | 109 | 133 | | B[1] | CAN_0 RX | 77 | 110 | 134 | | B[2] | LIN_0 TX | 79 | 114 | 138 | | B[3] | LIN_0 RX | 80 | 116 | 140 | <sup>1. 176-</sup>pin LQFP available only as development package. <sup>2.</sup> Weak pull down during reset. # 35.5.3 Reset Configuration Half Word (RCHW) The SPC56xP60x/54x Flash is partitioned into boot sectors as shown in *Table 602*. Each boot sector contains the Reset Configuration Half-Word (RCHW) at offset 0x00. Figure 637. Reset Configuration Half Word (RCHW) Table 601. RCHW field descriptions | Field | Description | | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0-6 | Reserved | | | 7<br>VLE | VLE Indicator This bit configures the MMU for the boot block to execute as either Power Architecture technology code or as VLE code. 0 Boot code executes as Power Architecture technology code 1 Boot code executes as VLE code | | | 8-15<br>BOOT_ID[0:7] | Is valid if its value is 0x5A, then the sector is considered bootable. | | Figure 638. SPC56xP60x/54x Flash partitioning and RCHW search Table 602. Flash boot sector | Block | Address | |-------|-------------| | 0 | 0x0000_0000 | | 1 | 0x0000_4000 | | 2 | 0x0000_8000 | | 3 | 0x0001_0000 | | 4 | 0x0001_8000 | | 5 | 0x0001_C000 | # 35.5.4 Single chip boot mode In single chip boot mode, the hardware searches the flash boot sector for a valid boot ID. As soon the device detects a bootable sector, it jumps within this sector and reads the 32-bit word at offset 0x4. This word is the address where the startup code is located (reset boot vector). Then the device executes this startup code. A user application should have a valid instruction at the reset boot vector address. If a valid RCHW is not found, the BAM code is executed. In this case BAM moves the SPC56xP60x/54x into static mode. #### 35.5.4.1 Boot and alternate boot Some applications require an alternate boot sector in the flash so that the main sector in flash can be erased and reprogrammed in the field. When an alternate boot is needed, the user can create two bootable sectors. The low sector is the main boot sector and the high sector is the alternate boot sector. The alternate boot sector does not need to be consecutive to the main boot sector. This ensures that even if one boot sector is erased still there will always be another active boot sector: - Sector shall be activated (i.e., program a valid BOOT\_ID instead of 0xFF as initially programmed). - Sector shall be deactivated writing to 0 some of the bits BOOT\_ID bit field (bit1 and/or bit3, and/or bit4, and/or bit6). # 35.5.5 Boot through BAM # 35.5.5.1 Executing BAM Single chip boot mode is managed by hardware and BAM does not participate in it. BAM is executed only on these two following cases: - Serial boot mode has been selected by FAB pin - Hardware has not found a valid Boot-ID in any Flash boot locations If one of these conditions is true, the device fetches code at location 0xFFFF\_C000 and BAM application starts. #### 35.5.5.2 BAM software flow Figure 639 illustrates the BAM logic flow. BAM entry 0xFFFF\_C000 Save default configuration The selected boot mode is verified by reading the SSCM\_STATUS register (bits BMODE and ABD) Check boot mode Restore Boot mode default STATIC mode valid? NO configuration YES Download new Restore Execute and save to default new code SRAM configuration Figure 639. BAM logic flow The first action is to save the initial device configuration. In this way is possible to restore the initial configuration after downloading the new code but before executing it. This allows the new code being executed as the device was just coming out of reset. The BMODE and ABD fields of SSCM\_STATUS register (see Section 10.2.2.1: System Status register (STATUS)) indicate which boot has to be executed (see Table 603). If the BMODE field shows either a single chip value (011) or a reserved value, the boot mode is not considered valid and the BAM pushes the device into static mode. In all other cases the code of the relative boot is called. Data is downloaded and saved into proper SRAM location. Table 603. Fields of SSCM STATUS register used by BAM | Field | Description | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BMODE<br>[2:0] | Device Boot Mode 000 Test Flash/autobaud_scan 001 CAN Serial Boot Loader 010 SCI Serial Boot Loader 011 Single Chip 100–111 Reserved This field is updated only during reset. | Then, the initial device configuration is restored and the code jumps to the address of downloaded code. At this point BAM has just finished its task. If an error occurs, (e.g., communication error, wrong boot selected, etc.), the BAM restores the default configuration and puts the device into static mode. Static mode means the device enters the low power mode SAFE and the processor executes a wait instruction. This is needed if the device cannot boot in the selected mode. During BAM execution and after, the mode reported by the field S\_CURRENT\_MODE of the register ME\_GS in the module ME Module is "DRUN". #### 35.5.5.3 BAM resources BAM uses/initializes the following MCU resources: - ME and CGM modules to initialize mode and clock sources - CAN 0, LINFlex 0, and their pads when performing serial boot mode - SSCM to check the boot mode and during password check (see Table 603 and Figure 640) - External oscillator The following hardware resources are used only when autobaud feature is selected: - STM to measure the baud rate - CMU to measure the external clock frequency related to the internal RC clock source - FMPLL to work with system clock near the maximum allowed frequency (this to have higher resolution during baud rate measurement). As already mentioned, the initial configuration is restored before executing the downloaded code When the autobaud feature is disabled, the system clock is selected directly from the external oscillator. Thus the oscillator frequency defines baud rates for serial interfaces used to download the user application (see *Table 604*). Table 604. Serial boot mode without autobaud—baud rates | Crystal frequency<br>(MHz) | LINFlex baud rate<br>(baud) | FlexCAN bit rate<br>(bit/s) | |----------------------------|-----------------------------|-----------------------------| | f <sub>extal</sub> | f <sub>extal</sub> / 833 | f <sub>extal</sub> / 40 | | 8 | 9600 | 200 K | | 12 | 14400 | 300 K | | Crystal frequency<br>(MHz) | LINFlex baud rate<br>(baud) | FlexCAN bit rate (bit/s) | |----------------------------|-----------------------------|--------------------------| | 16 | 19200 | 400 K | | 20 | 24000 | 500 K | | 40 | 48000 | 1 M | Table 604. Serial boot mode without autobaud—baud rates(Continued) #### 35.5.5.4 Download and execute the new code From a high level perspective, the download protocol follows these steps: - Send message and receive acknowledge message for autobaud or autobit rate selection. (optional step). - 2. Send 64-bit password. - 3. Send start address, size of downloaded code in bytes, and VLE bit<sup>(n)</sup>. - Download data. 1020/1102 Execute code from start address. Each step must be complete before the next step starts. The step from 2 to 5 are correct if autobaud is disabled. Otherwise, to measure the baud rate, some data is sent from the host to the MCU before step 2 (see Section 35.6.1: Autobaud feature). The communication is done in half duplex manner. Any transmission from the host is followed by the MCU transmission: - Host sends data to MCU and start waiting. - 2. MCU echoes to host the data received. - 3. MCU verifies if echo is correct. - If data is correct, the host can continue to send data. - If data is not correct, the host stops transmitting and the MCU needs to be reset. All multi-byte data structures are sent MSB first. A more detailed description of these steps follows. ## 35.5.5.5 Download 64-bit password and password check The first 64 received bits represent the password. This password is sent to the Password Check procedure for verification. Password check data flow is shown in Figure 640 where: - SSCM STATUS[SEC] = 1 means flash secured - SSCM\_STATUS[PUB] = 1 means flash with public access. In case of flash with public access, the received password is compared with the public password 0xFEED\_FACE\_CAFE\_BEEF. Since the device supports only VLE code and does not support Book E code, this flag is used only for backward compatibility. If public access is not allowed but the flash is not secured, the received password is compared with the value saved on NVPWD0 and NVPWD1 registers. In uncensored devices, it is possible to download code via LINFlex or FlexCAN (serial boot mode) into internal SRAM with any 64-bit private password stored in the flash and provided during the boot sequence. In the previous cases, comparison is done by the BAM application. If it goes wrong, BAM pushes the device into static mode. In case of public access not allowed and flash secured, the password is written into SSCM[PWCMPH/L] registers. In case of flash secured with public access not allowed (user password configured in the NVPWD0 and NVPWD1 registers), the user must set the swapped password: NVPWD1 and NVPWD0 to access the device (refer to following examples). #### Example 16 In devices with flash secured, registers are programmed: NVPWD0 = 0x87654321 NVPWD1 = 0x12345678 NVSCI0 = 0x55AA1111 NVSCI1 = 0x55AA1111 To download the code via SLB, the provided password is 0x1234\_5678\_8765\_4321 (swapped WITH respect to NVPWD0/NVPWD1 —> NVPWD1/NVPWD0). #### Example 17 In devices with flash NOT secured, registers are programmed: NVPWD0 = 0x87654321 NVPWD1 = 0x12345678 NVSCI0 = 0x55AA55AA NVSCI1 = 0x55AA55AA To download the code via SLB the provided password is 0x8765\_4321\_1234\_5678 (as expected from NVPWD0/NVPWD1). After a fixed time waiting, comparison is done by hardware. Then BAM again verifies the SEC flag in SSCM\_STATUS: - SEC = 0, flash is now unsecured and BAM continues its task - SEC = 1, flash is still secured because password was wrong; BAM puts the device into static mode. This fixed time depends on external crystal oscillator frequency (XOSC). With XOSC of 12 MHz, fixed time is 350 ms. Figure 640. Password check flow # 35.5.5.6 Download start address, VLE bit and code size The next 8 bytes received by the MCU contain a 32-bit Start Address, the VLE mode bit and a 31-bit code Length as shown in *Figure 641*. The VLE bit (Variable Length Instruction) indicates which instruction set for which the code has been compiled. This device family supports only VLE = 1. The bit is used for backward compatibility. The Start Address defines where the received data will be stored and where the MCU will branch after the download is finished. The two LSB bits of the Start Address are ignored by the BAM program, such that the loaded code should be 32-bit word aligned. The Length defines how many data bytes have to be loaded. | | START_ADDRESS[31:16] | | |-----|----------------------|--| | | | | | | START_ADDRESS[15:0] | | | | | | | VLE | CODE_LENGTH[30:16] | | | | | | | | CODE_LENGTH[15:0] | | Figure 641. Start address, VLE bit and download size in bytes #### 35.5.5.7 Download data Each byte of data received is stored into device's SRAM, starting from the address specified in the previous protocol step. The address increments until the number of bytes of data received matches the number of bytes specified in the previous protocol step. Since the SRAM is protected by 32-bit wide Error Correction Code (ECC), BAM always writes bytes into SRAM grouped into 32-bit words. If the last byte received does not fall onto a 32-bit boundary, BAM fills it with 0 bytes. Then a "dummy" word (0x0000 0000) is written to avoid ECC error during core prefetch. ### **35.5.5.8** Execute code The BAM program waits for the last echo message transmission being completed. Then it restores the initial MCU configuration and jumps to the loaded code at Start Address that was received in step 3 of the protocol. At this point BAM has finished its tasks and MCU is controlled by new code executing from SRAM. ### 35.5.6 Boot from UART—autobaud disabled ### 35.5.6.1 Configuration Boot from UART protocol is implemented by LINFlex\_0 module. Pins used are: - LINFlex\_TX corresponds to pin B[2] - LINFlex\_RX corresponds to pin B[3] When autobaud feature is disabled, the system clock is driven by external oscillator. LINFlex controller is configured to operate at a baud rate = system clock frequency/833 (see *Table 604* for baud rate example), using 8-bit data frame without parity bit and 1 stop bit. ### Figure 642. LINFlex bit timing in UART mode ### 35.5.6.2 UART boot mode download protocol Table 605 summarizes the download protocol and BAM action during the UART boot mode. Table 605. UART boot mode download protocol (autobaud disabled) | Protocol step | Host sent<br>message | BAM response<br>message | Action | |---------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | 1 | 64-bit password (MSB first) | 64-bit password | Password checked for validity and compared against stored password. | | 2 | 32-bit store address | 32-bit store address | Load address is stored for future use. | | 3 | VLE bit +<br>31-bit number of bytes<br>(MSB first) | VLE bit +<br>31-bit number of<br>bytes (MSB first) | Size of download is stored for future use. Verify if VLE bit is set to 1. | | 4 | 8 bits of raw binary<br>data | 8 bits of raw binary data 8-bit data are packed into 32-bit word. This word saved into SRAM starting from the "Load address" increments until the number of conceived and stored matches the size as specification previous step. | | | 5 | none | none | Branch to downloaded code. | # 35.5.7 Bootstrap with FlexCAN—autobaud disabled ## 35.5.7.1 Configuration Boot from FlexCAN protocol is implemented by the FlexCAN\_0 module. Pins used are: - CAN\_TX corresponds to pin B[0] - CAN\_RX corresponds to pin B[1]. Boot from FlexCAN with autobaud disabled uses system clock driven by the external oscillator. The FlexCAN controller is configured to operate at a baud rate equal to the system clock frequency/40 (see *Table 604* for examples of baud rate). It uses the standard 11-bit identifier format detailed in the FlexCAN 2.0A specification. FlexCAN controller bit timing is programmed with 10 time quanta, and the sample point is 2 time quanta before the end, as shown in *Figure 643*. Figure 643. FlexCAN bit timing # 35.6 FlexCAN boot mode download protocol *Table 606* summarizes the download protocol and BAM action during the FlexCAN boot mode. All data are transmitted bytewise. | 1 ' | | | · · · · · · · · · · · · · · · · · · · | |---------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Protocol step | Host sent<br>message | BAM response<br>message | Action | | 1 | FlexCAN ID 0x011 + 64-bit password | FlexCAN ID 0x001 + 64-bit password | Password checked for validity and compared against stored password. | | 2 | FlexCAN ID 0x012 +<br>32-bit store address +<br>VLE bit+ 31-bit<br>number of bytes | FlexCAN ID 0x002 +<br>32-bit store address +<br>VLE bit + 31-bit<br>number of bytes | Load address is stored for future use. Size of download is stored for future use. Verify if VLE bit is set to 1. | | 3 | FlexCAN ID 0x013 +<br>8 to 64 bits of raw<br>binary data | FlexCAN ID 0x003 + 8 to 64 bits of raw binary data | 8-bit data are packed into 32-bit words. These words are saved into SRAM starting from the "Load address". "Load address" increments until the number of data received and stored matches the size as specified in the previous step. | | 4 | none | none | Branch to downloaded code. | Table 606. FlexCAN boot mode download protocol (autobaud disabled) # 35.6.1 Autobaud feature The autobaud feature allows boot operation with a wide range of baud rates independent of the external oscillator frequency. ### 35.6.1.1 Configuration SPC56xP60x/54x devices implement the autobaud feature via FlexCAN or LINFlex selecting the active serial communication peripheral by means of an autoscan routine. When autobaud configuration is selected by ABS and FAB pins, the autoscan routine starts and listens to the active bus protocol. Initially the LinFlex\_0 RX pin and FlexCAN\_0 RX pin are configured as GPIO inputs: for 176-pin, 144-pin, and 100-pin LQFP packages internal weak pull-up enabled for both RX pins The autoscan routine waits in polling for the first LOW level to select which routine will be executed: - FlexCAN Autobaud routine - LinFlex Autobaud routine Then the measurement baud rate is computed to configure the serial communication at the right rate. In the end of baud rate measurement, LinFlex\_0 RX pin and FlexCAN\_0 RX pin switches to work as dedicated pin. Baud rate measurement is using the System Timer Module (STM) which is driven by the system clock. Measurement itself is performed by software polling the related inputs as general purpose IO's, resulting in a detection granularity that is directly related to the execution speed of the software. One main difference of the autobaud feature is that the system clock is not driven directly by the external oscillator, but it is driven by the FMPLL output. The reason is that to have an optimum resolution for baud rate measurement, the system clock needs to be nearer to the maximum allowed device's frequency. This is achieved with the following two steps: - 1. Using the Clock Monitor Unit (CMU) and the internal RC oscillator (IRC), the external frequency is measured using the IRC as reference to determine this frequency. - Based on the result of this measurement, the FMPLL is programmed to generate a system clock that is configured to be near, but lower, to the maximum allowed frequency. The relation between system clock frequency and external clock frequency with FMPLL configuration value is shown in *Table 607*. | f <sub>osc</sub> [MHz] | f <sub>rc</sub> /f <sub>osc</sub> <sup>(1)</sup> | f <sub>sys</sub> [MHz] | |------------------------|--------------------------------------------------|------------------------| | 4–8 | 4–2 | 16–32 | | 8–12 | 2–4/3 | 32–48 | | 12–16 | 4/3–1 | 36–48 | | 16–24 | 1–2/3 | 32–48 | | > 24 | < 2/3 | > 24 | Table 607. System clock frequency related to external clock frequency These values and consequently the f<sub>sys</sub> suffer from the precision of RC internal oscillator used to measure f<sub>osc</sub> through CMU module. After setting up the system clock, the BAM autoscan code configures the FlexCAN RX pin (B[1] on all packages) and LINFlex RX pin (B[3] on LQFP100 or B[7] on LQFP64) as GPIO inputs and searches for FlexCAN RX pin level to verify if CAN is connected or not. Then continuously waits in polling on change of RX pins level. The FlexCAN RX pin level takes precedence. First signal found at low level selects the serial boot routine that will be executed. In case a low level is detected on any input, the corresponding autobaud measurement functionality is started: - when FlexCAN RX (corresponds to pin B[1]) level is low, the CAN autobaud measurement starts and then sets up the FlexCAN baud rate accordingly; - when UART RX (corresponds to pin B[3] on LQFP100 or B[7] on LQFP64) level is low, the UART autobaud measurement starts and then sets up the LINFlex baud rate accordingly. After performing the autobaud measurement and setting up the baud rate, the corresponding RX input is reconfigured and the related standard download process is started; in case of a detected CAN transmission a download using the CAN protocol as described in Section 35.5.7: Bootstrap with FlexCAN—autobaud disabled, and in case of a detected UART transmission a download using the UART protocol as described in Section 35.5.6: Boot from UART—autobaud disabled. The following *Figure 644* identifies the corresponding flow and steps. Note: When autobaud scan is selected, initially both LINFlex\_0 RX pin and FlexCAN\_0 RX pin should be at high level. No external circuity should pull-down them to allow right autoscan. Figure 644. BAM Autoscan code flow ### 35.6.1.2 Boot from UART with autobaud enabled The only difference between booting from UART with autobaud enabled and booting from UART with autobaud disabled is that a further byte is sent from the host to the MCU when autobaud is enabled. The value of that byte is 0x00. This first byte measures the time from falling edge and rising edge. The baud rate can be calculated from this time. Start bit 0x0 Figure 645. Baud measurement on UART boot Initially the UART RX pin is configured as GPIO input and it waits in polling for the first falling edge, then STM starts. UART RX pin waits again for the first rising. Then STM stops and from its measurement baud rate is computed. The LINFlex module is configured to work in UART mode with the calculated baud rate. Then an acknowledge byte (0x59, ASCII char "Y") is sent. From this point, the BAM follows the normal UART mode boot protocol (see Figure 646). Figure 646. BAM rate measurement flow during UART boot ## 35.6.1.2.1 Choosing the host baud rate The calculation of the UART baud rate from the length of the first 0 byte that is received, allows the operation of the boot loader with a wide range of baud rates. However, to ensure proper data transfer, the upper and lower limits have to be kept. SCI autobaud rate feature operates by polling the LINFlex\_RX pin for a low signal. The length of time until the next low to high transition is measured using the System Timer Module (STM) time base. This high-low-high transition is expected to be a zero byte: a start bit (low) followed by eight data bits (low) followed by a stop bit (high). Upon reception of a zero byte and configuration of the baud rate, an acknowledge byte is returned to the host using the selected baud rate. Time base is enabled at reception of first low bit, disabled and read at reception of next high bit. Error introduced due to polling will be small (typically < 6 cycles). The following equation gives the relation between baud rate and LINFlex register configuration: ### **Equation 71** $$LDIV = \frac{f_{cpu}}{16 \cdot baudrate}$$ LDIV is an unsigned fixed point number and its mantissa is coded into 13 bits of the LINFlex's register LINIBRR. From this equation and considering that a single UART transmission contains 9 bits, it is possible to obtain the connection between time base measured by STM and LINIBB register: #### **Equation 72** $$LINIBRR = \frac{timebase}{144}$$ To minimize errors in baud rate, a large external oscillator frequency value and low baud rate signal are preferred. Example 18 Baud rate calculation for 24 kBaud signal Considering a 24 kbaud signal and the device operating with 20 MHz external frequency. Over 9 bits the STM will measure: (9 × 20 MHz)/24 kbaud = 7497 cycles. Error expected to be approximately ± 6 cycles due to polling. Thus, LINIBB will be set to 52 (rounding required). This results in a baud rate of 24.038 kbaud. Error of < 0.2%. To maintain the maximum deviation between host and calculated baud rate, recommendations for the user are listed *Table 608*. Table 608. Maximum and minimum recommended baud rates | f <sub>sys</sub> = f <sub>xtal</sub> (MHz) | Max baud rate for guaranteed < 2.5% deviation | Min baud rate for guaranteed < 2.5% deviation | |--------------------------------------------|-----------------------------------------------|-----------------------------------------------| | 4 | 13.4 Kbit/s<br>(SBR = 19) | 30 bit/s<br>(SBR = 8192) | | 8 | 26.9 Kbit/s 60 bit/s (SBR = 19) (SBR = 8192) | | | 12 | 38.4 Kbit/s<br>(SBR = 20) | 90 bit/s<br>(SBR = 8192) | | f <sub>sys</sub> = f <sub>xtal</sub> (MHz) | Max baud rate for guaranteed < 2.5% deviation | Min baud rate for guaranteed < 2.5% deviation | |--------------------------------------------|-----------------------------------------------|-----------------------------------------------| | 16 | 51.2 Kbit/s<br>(SBR = 20) | 120 bit/s<br>(SBR = 8192) | | 20 | 64.0 Kbit/s<br>(SBR = 20) | 150 bit/s<br>(SBR = 8192) | Table 608. Maximum and minimum recommended baud rates(Continued) Higher baud rates high may be used, but the user will be required to ensure they fall within an acceptable error range. This is illustrated in *Figure 647*, which shows the effect of quantization error on the baud rate selection. Figure 647. Baud rate deviation between host and SPC56xP60x/54x Example 19 Baud rate calculation for 250 kBaud signal Considering reception of a 250kBaud signal from the host and SPC56xP60x/54x operating with a 4 MHz oscillator. Over 9 bits the time base will measure: $(9 \times 4e6)/250e3 = 144$ cycles. Thus, LINIBB is set to 144/144 = 1. This results in a baud rate of exactly 250 kBd. However, a slower 225 kBd signal operating with 4 MHz XTAL would again result in LINIBB = 1, but this time with an 11.1% deviation. ### 35.6.1.3 Boot from FlexCAN with autobaud enabled The only difference between booting from FlexCAN with autobaud enabled and booting from FlexCAN with autobaud disabled is that the following initialization FlexCAN frame is sent for baud measurement purposes from the host to the MCU when autobaud is enabled: - Standard identifier = 0x0, - Data Length Code (DLC) = 0x0. As all the bits to be transmitted are dominant bits, there is a succession of 5 dominant bits and 1 stuff bit on the FlexCAN network (see *Figure 648*). From the duration of this frame, the MCU calculates the corresponding baud rate factor with respect to the current CPU clock and initializes the FlexCAN interface accordingly. Figure 648. Bit time measure In FlexCAN boot mode, the FlexCAN RX pin is first configured to work as a GPIO input. In the end of baud rate measurement, it switches to work with the FlexCAN module. The baud rate measurement flow is detailed in *Figure 649*. Figure 649. BAM rate measurement flow during FlexCAN boot # 35.6.1.3.1 Choosing the host baud rate The calculation of the FlexCAN baud rate allows the operation of the boot loader with a wide range of baud rates. However, to ensure proper data transfer, the upper and lower limits have to be kept. Pins are measured until reception of the 5th recessive bit. Thus a total of 29 bit-times are measured (see *Figure 648*). When calculating bit times and prescalers, to minimize any errors, ideally operate with the minimum system clock prescaler divider (CAN\_CR[PRESDIV]) and maximum number of time quanta possible. After measuring the 29 bit times, the results stored in the STM time base are used to select PRESDIV. The number of time quanta in a FlexCAN bit time is given by: Bit time = SYNCSEG + TSEG1 + TESG2 SYNCSEG = Exactly one time quantum. TSEG1 = PROGPSEG + PSEG1 + 2 TSEG2 = PSEG2 + 1 Time base result = 29 × (Presdiv+1) × (SYNCSEG + TSEG1 + TSEG2) FlexCAN protocol specifies that the FlexCAN bit timing should comprise a minimum of 8 time quanta and a maximum of 25 time quanta. Therefore, the available range is: For 29 bit times, the possible range in which the result in the time base may lie, accounting for PRESDIV, is: $(232 \times (1 + PRESDIV)) \le time base \le (725 \times (1 + PRESDIV))$ Therefore, the available values of the time base can be divided into windows of 725 counts. PRESDIV Time base Minimum Time base Maximum 0 232 725 1 726 1450 2 1451 2175 3 2176 2900 Table 609. Prescaler/divider and time base values In the BAM, the time base is divided by 726, the remainder is discarded. The result provides the CAN\_CR[PRESDIV] to be selected. To help compensate for any error in the calculated baud rate, the resynchronization jump width will be increased from its default value of 1 to a fixed value of 2 time quanta. This is the maximum value allowed that can accommodate all permissible can baud rates. See *Table 610*. Table 610. FlexCAN standard compliant bit timing segment settings | Time Segment 1 | Time Segment 2 | RJW | |----------------|----------------|-----| | 510 | 2 | 12 | | 411 | 3 | 13 | | 512 | 4 | 14 | | 613 | 5 | 14 | | 714 | 6 | 14 | | 815 | 7 | 14 | | 916 | 8 | 14 | Timing segment 2 is kept as large as possible to keep sample time within bit time. Table 611. Lookup table for FlexCAN bit timings | Desired number of | Time Segment 2 | Time segment 1 | | | |------------------------|----------------|----------------|-----------|--| | Time quanta (DTq) | PSEG2+1 | PSEG1+1 | PROPSEG+1 | | | 8 to 13 <sup>(1)</sup> | 2 | 2 | DTq-5 | | | 8 to 13 <sup>(2)</sup> | 3 | 2 | DTq-6 | | | 14 to 15 | 3 | 3 | DTq-6 | | | 16 to 17 | 4 | 4 | DTq-7 | | | 18 to 19 | 5 | 5 | DTq-8 | | | 20 to 21 | 6 | 6 | DTq-9 | | | 22 to 23 | 7 | 7 | DTq-10 | | | 24 to 25 | 8 | 8 | DTq-11 | | <sup>1.</sup> PRESDIV+1 > 1. Table 612. PRESDIV + 1 = 1 | Desired number of time quanta | Register contents for CANA_CR | |-------------------------------|-------------------------------| | 8 | 0x004A_2001 | | 9 | 0x004A_2002 | | 10 | 0x004A_2003 | | 11 | 0x004A_2004 | | 12 | 0x004A_2005 | | 13 | 0x004A_2006 | <sup>2.</sup> PRESDIV+1 = 1 (to accommodate information processing time IPT of 3 tq) Note: All TSEG1 and TSEG2 times have been chosen to preserve a sample time between 70% and 85% of the bit time. Desired number of time quanta Register contents for CANA\_CR 8 0xYY49\_2002 9 0xYY49 2003 10 0xYY49\_2004 11 0xYY49 2005 12 0xYY49\_2006 0xYY49\_2007 13 14 0xYY52 2007 15 0xYY52\_2008 0xYY5B\_2008 16 17 0xYY5B 2009 18 0xYY64\_2009 19 0xYY64\_200A 20 0xYY6D 200A 0xYY6D\_200B 21 22 0xYY76\_200B 23 0xYY76 200C 24 0xYY7F\_200C 25 0xYY7F\_200D Table 613. PRESDIV + 1 > 1 (YY = PRESDIV) Worked examples showing FlexCAN Autobaud rate: # Example 20 8 MHz crystal Consider case where using an 8 MHz crystal, user attempts to send 1 MB (max permissible baud rate) FlexCAN message. - Time base, clocking at crystal frequency, would measure: - 1MB = 8 clocks/bit => 29 \* 8 = 232 clocks - To calculate PRESDIV = 232/725 =>PRESDIV = 0 - To calculate time quanta requirement: - Time base result = 29 \*(Presdiv+1) \* (SYNCSEG + TSEG1 + TSEG2) - 232 = 29 \* 1 \* (1 + TSEG1 + TSEG2) - 1 + TSEG1 + TSEG2 = 8. - From the lookup table, CANA\_CR = 0x004A\_2001. - This give a baud rate of X. This give 0% error. #### Example 21 20 MHz crystal Consider case where using a 20 MHz crystal, user attempts to send 62.5 Kb/s FlexCAN message. - Time base, clocking at crystal frequency, would measure: - 62.5 Kb/s = 320 clocks/bit => 29 \* 320 = 9280 clocks - To calculate PRESDIV = 9280/725 = 12r580 => PRESDIV = 12 - To calculate time quanta requirement: - Time base result = 29 x (Presdiv+1) x (SYNCSEG + TSEG1 + TSEG2) - 9280 = 29 x 13 x (1 + TSEG1 + TSEG2) - 1 + TSEG1 + TSEG2 = 24.6~ 25 (need to round up S/W must track remainder) - From the lookup table, CANA CR = 0x0C7F 200D. - This give a baud rate of 61.538k Baud - This equates to an error of: ~1.6% This excludes cycle count error introduced due to software polling likely to be ~6 system clocks. # 35.6.2 Interrupt No interrupts are generated by or are enabled by the BAM. # 35.7 Censorship Censorship can be enabled to protect the contents of the flash memory from being read or modified. In order to achieve this, the censorship mechanism controls access to the: - JTAG / Nexus debug interface - Serial boot mode (which could otherwise be used to download and execute code to query or modify the flash memory) To re-gain access to the flash memory via JTAG or serial boot, a 64-bit password must be correctly entered. #### Caution: When censorship has been enabled, the only way to regain access is with the password. If this is forgotten or not correctly configured, then there is no way back into the device. There are two 64-bit values stored in the shadow flash which control the censorship (see *Table 173* for a full description): - Nonvolatile Private Censorship Password registers, NVPWD0 and NVPWD1 - Nonvolatile System Censorship Control registers, NVSCI0 and NVSCI1 ### 35.7.0.1 Censorship password registers (NVPWD0 and NVPWD1) The two private password registers combine to form a 64-bit password that should be programmed to a value known only by you. After factory test these registers are programmed as shown below: - NVPWD0 = 0xFEED\_FACE - NVPWD1 = 0xCAFE BEEF This means that even if censorship was inadvertently enabled by writing to the censorship control registers, there is an opportunity to get back into the microcontroller using the default private password of 0xFEED\_FACE\_CAFE\_BEEF. When configuring the private password, each half word (16-bit) must contain at least one "1" and one "0". Some examples of legal and illegal passwords are shown in *Table 614*: Table 614. Examples of legal and illegal passwords | Legal (valid) passwords | Illegal (invalid) passwords | |-------------------------|-----------------------------| | 0x0001_0001_0001 | 0x0000_XXXX_XXXX | | 0xfffe_fffe_fffe | 0xffff_XXXX_XXXX_XXXX | | 0x1XXX_X2XX_XX4X_XXX8 | | In uncensored devices it is possible to download code via LINFlex or FlexCAN (Serial Boot Mode) into internal SRAM even if the 64-bit private password stored in the flash and provided during the boot sequence is a password that does not conform to the password rules. # 35.7.0.2 Nonvolatile System Censorship Control registers (NVSCI0 and NVSCI1) These registers are used together to define the censorship configuration. After factory test these registers are programmed as shown below which disables censorship: - NVSCI0 = 0x55AA 55AA - NVSCI1 = 0x55AA 55AA Each 32-bit register is split into an upper and lower 16-bit field. The upper 16 bits (the SC field) are used to control serial boot mode censorship. The lower 16 bits (the CW field) are used to control flash memory boot censorship. #### Caution: If the contents of the shadow flash memory are erased and the NVSCI0,1 registers are not re-programmed to a valid value, the microcontroller will be permanently censored with no way for you to regain access. A microcontroller in this state cannot be debugged or re-flashed. ## 35.7.0.3 Censorship configuration The steps to configuring censorship are: - 1. Define a valid 64-bit password that conforms to the password rules. - 2. Using the table and flow charts below, decide what level of censorship you require and configure the NVSCI0,1 values. - 3. Re-program the shadow flash memory and NVPWD0,1 and NVSCI0,1 registers with your new values. A POR is required before these will take effect. ### Caution: lf (NVSCI0 and NVSCI1 do not match) or (Either NVSCI0 or NVSCI1 is not set to 0x55AA) then the microcontroller will be permanently censored with no way to get back in. *Table 615* shows all the possible modes of censorship. The red shaded areas are to be avoided as these show the configuration for a device that is permanently locked out. If you wish to enable censorship with a private password there is only one valid configuration — to modify the CW field in both NVSCI0,1 registers so they match but do not equal 0x55AA. This will allow you to enter the private password in both serial and flash boot modes. | Table 615. Censorship | configuration | and truth table | |-----------------------|---------------|-----------------| |-----------------------|---------------|-----------------| | Boot configuration | | Serial Censorship | | Internal | | | | |------------------------------|----------------------------------------------------|--------------------------------------------|------------------------------------|--------------------------|-----------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------| | FAB<br>pin<br>state | Control options | censorship<br>control word<br>(NVSCIn[SC]) | control word<br>(NVSCIn[CW]) | flash<br>memory<br>state | Nexus<br>state | Serial<br>password | JTAG<br>password | | | Uncensored | 0xXXXX AND<br>NVSCI0 ==<br>NVSCI1 | 0x55AA AND<br>NVSCI0 ==<br>NVSCI1 | Enabled | Enabled | | N/A | | 0 (flash<br>memor<br>y boot) | Private flash<br>memory password<br>and censored | 0x55AA AND<br>NVSCI0 ==<br>NVSCI1 | !0x55AA AND<br>NVSCI0 ==<br>NVSCI1 | Enabled | Enabled<br>with<br>password | | NVPWD <b>1,0</b><br>(SSCM<br>reads flash<br>memory <sup>(1)</sup> ) | | | Censored with no password access (lockout) | _ | !0X55AA<br>PR<br>= NVSCI1 | Enabled | Disabled | | N/A | | | Private flash<br>memory password<br>and uncensored | 0x55AA AND<br>NVSCI0 == NVSCI1 | | Enabled | Enabled | NVPWD <b>0,1</b><br>(BAM reads<br>flash<br>memory <sup>(1)</sup> ) | | | 1<br>(serial | Private flash<br>memory password<br>and censored | 0x55AA AND<br>NVSCI0 ==<br>NVSCI1 | !0x55AA AND<br>NVSCI0 ==<br>NVSCI1 | Enabled | Disabled | NVPWD <b>1,0</b><br>(SSCM<br>reads flash<br>memory <sup>(1)</sup> ) | | | boot) | Public password and uncensored | !0x55AA AND<br>NVSCI0 !=<br>NVSCI1 | 0X55AA AND<br>NVSCI0 !=<br>NVSCI1 | Enabled | Enabled | Public<br>(0xFEED_F<br>ACE_CAFE<br>_BEEF) | | | | Public password<br>and censored<br>(lockout) | | 55AA<br>) != NVSCI1 | Disabled | Disabled | Public<br>(0xFEED_F<br>ACE_CAFE<br>_BEEF) | | <sup>=</sup> Microcontroller permanently locked out = Not applicable The flow charts in *Figure 650* and *Figure 651* provide a way to quickly check what will happen with different configurations of the NVSCI0,1 registers as well as detailing the correct way to enter the serial password. In the password examples, assume the 64-bit password has been programmed into the shadow flash memory in the order {NVPWD0, NWPWD1} and has a value of 0x01234567\_89ABCDEF. When the SSCM reads the passwords from flash memory, the NVPWD0 and NVPWD1 password order is swapped, so you have to submit the 64-bit password as {NVPWD1, NVPWD0}. Figure 650. Censorship control in flash memory boot mode Figure 651. Censorship control in serial boot mode # 36 Voltage Regulators and Power Supplies # 36.1 Voltage regulator The power blocks are used for providing 1.2 V digital supply to the internal logic of the device. The main/input supply is 3.3 V to 5.0 V $\pm 10\%$ and the digital/regulated output supply has a trim target voltage of 1.28 V. The voltage regulator used in SPC56xP60x/54x is the high power or main regulator (HPREG). The internal voltage regulator requires an external ballast transistor and (external) capacitance (CREG) to be connected to the device in order to provide a stable low voltage digital supply to the device. Capacitances should be placed on the board as near as possible from the associated pins. The regulator has a digital domain called the High Power domain that has a low voltage detector for the 1.2 V output voltage. Additionally, there are two low voltage detectors for the main/input supply with different threshold, one at 3.3 V level and the other one at 5 V level. # 36.1.1 High Power or Main Regulator (HPREG) The HPREG converts the 3.3 V–5 V input supply to a 1.2 V digital supply. The nominal target output is 1.28 V. Due to all variations, the actual output will be in range of 1.08 V to 1.32 V in the full current load range (0–250 mA) after trimming. The stabilization for HPREG is achieved using an external capacitance. The minimum recommended value is $3 \times 10 \, \mu F$ with low ESR (refer to datasheet for details). Note: In general an offset voltage must be avoided to pre-charge $V_{DD\_HV\_REG}$ through parasitic paths to allow a correct power up sequence. The MCU supply must power on from GND to power supply with a monotonic ramp, minimum and maximum values as described in the data sheet $(TV_{DD})$ . # 36.1.2 Low Voltage Detectors (LVD) and Power On Reset (POR) Five types of low voltage detectors are provided on the device: - V<sub>REGLVDMOK</sub> L monitors the 3.3 V regulator supply - V<sub>FLLVDMOK</sub> L monitors the 3.3 V flash supply - V<sub>IOLVDMOK</sub> L monitors the 3.3 V I/O supply - V<sub>IOLVDM5OK</sub> L monitors the 5 V I/O supply - V<sub>MLVDDOK L</sub> monitors the 1.2 V digital logic supply LVD\_MAIN is the main voltage LVD with a threshold set around 2.7 V. LVD\_MAIN5 is the main voltage LVD with a threshold set around 4 V. The LVD\_MAIN and LVD\_MAIN5 sense the 3.3 V–5 V power supply for CORE, shared with IO ring supply and indicate when the 3.3 V–5 V supply is stabilized. The threshold levels of LVD\_MAIN5 are trimmable with the help of LVDM5[0:3] trim bits. The LVD\_MAIN and LVD\_MAIN5 detectors sense the $V_{DDIO}$ supply and provide $V_{IOLVDMOK\_H}/V_{IOLVDM5OK\_H}$ and $V_{IOLVDMOK\_L}/V_{IOLVDM5OK\_L}$ as active high signals at 3.3 V and 1.2 V supply levels, respectively. Two more LVD\_MAIN detectors are also used for sensing VDDREG and VDDFLASH. An LVD\_DIG in the regulator senses the HPREG output. It provides $V_{MLVDDOK\_H}$ and $V_{MLVDOK\_L}$ as active high signals. The reference voltage used for all LVDs is trimmed for LVD\_DIG using the bits LP[4:7]. Therefore, during the pre-trimming period, LVD\_DIG exhibits higher thresholds, whereas post trimming, the thresholds come in the desired range. The trimming bits are provided by SSCM device option bits, which are updated during the reset phase (RGM reset phase 2) only. Power-down pins are provided for LVDs. When LVDs are powered down, their outputs are pulled high. LVDs are not controllable by the user. The only option is the possibility to mask LVD\_MAIN5 using the mask bit (5V\_LVD\_MASK) in the VREG\_CTL register. POR is required to initialize the device during supply rise. POR works only on the rising edge of main supply. To ensure its functioning during the following rising edge of the supply, it is reset by the output of the LVD\_MAIN block when main supply reaches below the lower voltage threshold of the LVD\_MAIN. POR is asserted on power-up when $V_{DD}$ supply is above $V_{PORUP}$ minimum (refer to datasheet for details). It is released only after $V_{DD}$ supply is above $V_{PORH}$ (refer to datasheet for details). $V_{DD}$ above $V_{PORH}$ ensures power management module including internal LVDs modules are fully functional. # 36.1.3 VREG digital interface The voltage regulator digital interface provides the temporization delay at initial power-up and at exit from low-power modes. A signal, indicating that Low Power domain is powered, is used at power-up to release reset to temporization counter. On completion of the delay counter, a end-of-count signal is released, it is gated with an other signal indicating main domain voltage fine in order to release the VREGOK signal. This is used by RGM to release the reset to the device. The VREG digital interface also holds control register to mask 5 V LVD status coming from the voltage regulator at the power-up. # 36.1.4 Registers Description # 36.1.4.1 Voltage Regulator Control Register (VREG\_CTL) Figure 652. Voltage Regulator Control register (VREG\_CTL) Table 616. VREG\_CTL field descriptions | Field | Description | | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 5V_LVD_MASK | Mask bit for 5 V LVD from regulator This is a read/write bit and must be unmasked by writing a 1 by software to generate LVD functional reset request to RGM for 5 V trip. 0 5 V LVD not masked 1 5 V LVD masked | | Reset #### Address: 0xC3FE 8084 Access: User read-only R W Reset 5V\_LVD\_STATUS R W # 36.1.4.2 Voltage Regulator Status register (VREG\_STATUS) Figure 653. Voltage Regulator Status register (VREG\_STATUS) Table 617. VREG\_STATUS field descriptions | Field | Description | |---------------|---------------------------------------------------------------------| | 5V_LVD_STATUS | Status bit for 5 V LVD from regulator 0 5 V LVD not OK 1 5 V LVD OK | # 36.2 Power supply strategy The SPC56xP60x/54x provides three dedicated supply domains at the package level: - HV—High voltage external power supply for I/Os, voltage regulator module, and most analog modules - This must be provided externally through $V_{DD\_HV}/V_{SS\_HV}$ power pins. Voltage values should be aligned with $V_{DD}/V_{SS}$ . Refer to the device datasheet for details. - ADC—High voltage external power supply for ADC module This must be provided externally through V<sub>DD\_HV\_ADx</sub>/V<sub>SS\_HV\_ADx</sub> power pins. Voltage values should be aligned with V<sub>DD\_HV\_ADx</sub>/V<sub>SS\_HV\_ADx</sub>. Refer to the device datasheet for details. - LV—Low voltage internal power supply for core, PLL, and flash digital logic This is provided to the core, PLL and flash. Four V<sub>DD\_LV</sub>/V<sub>SS\_LV</sub> pins pairs are provided to connect the low voltage power supply. Refer to the device datasheet for details. The three dedicated supply domains are further divided within the package in order to reduce EMI and noise as much as possible: - HV\_REG—High voltage regulator supply - HV IOn—High voltage PAD supply - HV\_FL—High voltage flash supply - HV\_OSC<sup>(0)</sup>—High voltage external oscillator and regulator supply - HV\_AD—High voltage supply and reference for ADC module. Supplies are further star routed to reduce impact of ADC resistive reference on ADC capacitive reference accuracy. - LV\_COR*n*—Low voltage supply for the core. It is also used to provide supply for PLL and Flash memory through double bonding. o.Regulator ground is separated from oscillator ground and shorted to the LV ground through star routing. # 37 IEEE 1149.1 Test Access Port Controller (JTAGC) # 37.1 Introduction The JTAG port of the device consists of three inputs and one output. These pins include test data input (TDI), test mode select (TMS), test clock input (TCK) and test data output (TDO). TDI, TMS, TCK and TDO are compliant with the IEEE 1149.1-2001 standard and are shared with the NDI through the test access port (TAP) interface. # 37.2 Block diagram Figure 654 is a block diagram of the JTAG Controller (JTAGC). Figure 654. JTAG controller block diagram # 37.3 Overview The JTAGC provides the means to test device functionality and connectivity while remaining transparent to system logic when not in test mode. Testing is performed via a boundary scan technique, as defined in the IEEE 1149.1-2001 standard. In addition, instructions can be executed that allow the Test Access Port (TAP) to be shared with other modules on the MCU. All data input to and output from the JTAGC is communicated in serial format. # 37.4 Features The JTAGC is compliant with the IEEE 1149.1-2001 standard, and supports the following features: - IEEE 1149.1-2001 Test Access Port (TAP) interface - Four pins (TDI, TMS, TCK, and TDO)—see Section 37.6: External signal description. - A 5-bit instruction register that supports several IEEE 1149.1-2001 defined instructions, as well as several public and private MCU specific instructions. - Test data registers: a bypass register, a boundary scan register, and a device identification register. - A TAP controller state machine that controls the operation of the data registers, instruction register, and associated circuitry. # 37.5 Modes of operation The JTAGC uses a power-on reset indication as its primary reset signals. Several IEEE 1149.1-2001 defined test modes are supported, as well as a bypass mode. ### 37.5.1 Reset The JTAGC is placed in reset when the TAP controller state machine is in the TEST-LOGIC-RESET state. The TEST-LOGIC-RESET state is entered upon the assertion of the power-on reset signal, or through TAP controller state machine transitions controlled by TMS. Asserting power-on reset results in asynchronous entry into the reset state. While in reset, the following actions occur: - The TAP controller is forced into the test-logic-reset state, thereby disabling the test logic and allowing normal operation of the on-chip system logic to continue unhindered. - The instruction register is loaded with the IDCODE instruction. In addition, execution of certain instructions can result in assertion of the internal system reset. These instructions include EXTEST, CLAMP, and HIGHZ. # 37.5.2 IEEE 1149.1-2001 defined test modes The JTAGC supports several IEEE 1149.1-2001 defined test modes. The test mode is selected by loading the appropriate instruction into the instruction register while the JTAGC is enabled. Supported test instructions include EXTEST, HIGHZ, CLAMP, SAMPLE and SAMPLE/PRELOAD. Each instruction defines the set of data registers that can operate and interact with the on-chip system logic while the instruction is current. Only one test data register path is enabled to shift data between TDI and TDO for each instruction. The boundary scan register is enabled for serial access between TDI and TDO when the EXTEST, SAMPLE or SAMPLE/PRELOAD instructions are active. The single-bit bypass register shift stage is enabled for serial access between TDI and TDO when the HIGHZ, CLAMP or reserved instructions are active. The functionality of each test mode is explained in more detail in *Section 37.8.4: JTAGC instructions*. # 37.5.2.1 Bypass mode When no test operation is required, the BYPASS instruction can be loaded to place the JTAGC into bypass mode. While in bypass mode, the single-bit bypass shift register provides a minimum-length serial path to shift data between TDI and TDO. ## 37.5.2.2 TAP sharing mode There are four selectable auxiliary TAP controllers that share the TAP with the JTAGC. Selectable TAP controllers include the Nexus port controller (NPC), e200 OnCE, and eDMA Nexus. The instructions required to grant ownership of the TAP to the auxiliary TAP controllers are ACCESS\_AUX\_TAP\_CORE0, ACCESS\_AUX\_TAP\_CORE1, ACCESS\_AUX\_TAP\_NASPS\_0, and ACCESS\_AUX\_TAP\_NASPS\_1 and ACCESS\_AUX\_TAP\_NPC. Instruction opcodes for each instruction are shown in *Table 620*. When the access instruction for an auxiliary TAP is loaded, control of the JTAG pins is transferred to the selected TAP controller. Any data input via TDI and TMS is passed to the selected TAP controller, and any TDO output from the selected TAP controller is sent back to the JTAGC to be output on the pins. The JTAGC regains control of the JTAG port during the UPDATE-DR state if the PAUSE-DR state was entered. Auxiliary TAP controllers are held in RUN-TEST/IDLE while they are inactive. For more information on the TAP controllers refer to *Chapter 38: Nexus Port Controller (NPC)*. # 37.6 External signal description The JTAGC consists of four signals that connect to off-chip development tools and allow access to test support functions. The JTAGC signals are outlined in *Table 618*. | Name | I/O | Function | Reset state | Pull <sup>(2)</sup> | |------|-----|------------------|-----------------------|---------------------| | TCK | I | Test clock | _ | Down | | TDI | I | Test data in | _ | Up | | TDO | 0 | Test data out | High Z <sup>(3)</sup> | Down <sup>(3)</sup> | | TMS | I | Test mode select | _ | Up | Table 618. JTAG signal properties<sup>(1)</sup> - 1. Test clock frequency must always be less than one fourth of system clock frequency. - 2. The pull is not implemented in this module. Pullup/down devices are implemented in the pads. - TDO output buffer enable is negated when JTAGC is not in the Shift-IR or Shift-DR states. A weak pulldown can be implemented on TDO. # 37.7 Memory map and registers description This section provides a detailed description of the JTAGC registers accessible through the TAP interface, including data registers and the instruction register. Individual bit-level descriptions and reset states of each register are included. These registers are not memory-mapped and can only be accessed through the TAP. # 37.7.1 Instruction register The JTAGC uses a 5-bit instruction register as shown in *Figure 655*. The instruction register allows instructions to be loaded into the module to select the test to be performed or the test data register to be accessed or both. Instructions are shifted in through TDI while the TAP controller is in the Shift-IR state, and latched on the falling edge of TCK in the Update-IR state. The latched instruction value can only be changed in the update-IR and test-logic-reset TAP controller states. Synchronous entry into the test-logic-reset state results in the IDCODE instruction being loaded on the falling edge of TCK. Asynchronous entry into the test-logic-reset state results in asynchronous loading of the IDCODE instruction. During the capture-IR TAP controller state, the instruction shift register is loaded with the value 0b10101, making this value the register's read value when the TAP controller is sequenced into the Shift-IR state. Figure 655. 5-bit Instruction register # 37.7.2 Bypass register The bypass register is a single-bit shift register path selected for serial data transfer between TDI and TDO when the BYPASS, CLAMP, HIGHZ or reserve instructions are active. After entry into the capture-DR state, the single-bit shift register is set to a logic 0. Therefore, the first bit shifted out after selecting the bypass register is always a logic 0. # 37.7.3 Device identification register The device identification register, shown in *Figure 656*, allows the part revision number, design center, part identification number, and manufacturer identity code to be determined through the TAP. The device identification register is selected for serial data transfer between TDI and TDO when the IDCODE instruction is active. Entry into the capture-DR state while the device identification register is selected loads the IDCODE into the shift register to be shifted out on TDO in the Shift-DR state. No action occurs in the update-DR state. Figure 656. Device identification register | Field | Description | |--------------|-------------------------------------------------------------------------------------------------------------------------------------| | 0–3<br>PRN | Part revision number. Contains the revision number of the device. This field changes with each revision of the device or module. | | 4–9<br>DC | Design center. For the SPC56xP60x/54x this value is 0x2B. | | 10–19<br>PIN | Part identification number. Contains the part number of the device. For the SPC56xP60x/54x, this value is 0x224. | | 20–30<br>MIC | Manufacturer identity code. Contains the reduced Joint Electron Device Engineering Council (JEDEC) ID for STMicroelectronics, 0x20. | | 31<br>ID | IDCODE register ID. Identifies this register as the device identification register and not the bypass register. Always set to 1. | Table 619. Device identification register field descriptions # 37.7.4 Boundary scan register The boundary scan register is connected between TDI and TDO when the EXTEST, SAMPLE or SAMPLE/PRELOAD instructions are active. It captures input pin data, forces fixed values on output pins, and selects a logic value and direction for bidirectional pins. Each bit of the boundary scan register represents a separate boundary scan register cell, as described in the IEEE 1149.1-2001 standard and discussed in *Section 37.8.5: Boundary scan*. The size of the boundary scan register and bit ordering is device-dependent and can be found in the device BSDL file. # 37.8 Functional description # 37.8.1 JTAGC reset configuration While in reset, the TAP controller is forced into the test-logic-reset state, thus disabling the test logic and allowing normal operation of the on-chip system logic. In addition, the instruction register is loaded with the IDCODE instruction. # 37.8.2 IEEE 1149.1-2001 (JTAG) Test Access Port (TAP) The JTAGC uses the IEEE 1149.1-2001 Test Access Port (TAP) for accessing registers. This port can be shared with other TAP controllers on the MCU. For more detail on TAP sharing via JTAGC instructions refer to Section 37.8.4.2: ACCESS\_AUX\_TAP\_x instructions. Data is shifted between TDI and TDO though the selected register starting with the least significant bit, as illustrated in *Figure 657*. This applies for the instruction register, test data registers, and the bypass register. Figure 657. Shifting data through a register # 37.8.3 TAP controller state machine The TAP controller is a synchronous state machine that interprets the sequence of logical values on the TMS pin. *Figure 658* shows the machine's states. The value shown next to each state is the value of the TMS signal sampled on the rising edge of the TCK signal. As *Figure 658* shows, holding TMS at logic 1 while clocking TCK through a sufficient number of rising edges also causes the state machine to enter the test-logic-reset state. Figure 658. IEEE 1149.1-2001 TAP controller finite state machine 4 # 37.8.3.1 Selecting an IEEE 1149.1-2001 register Access to the JTAGC data registers is done by loading the instruction register with any of the JTAGC instructions while the JTAGC is enabled. Instructions are shifted in via the select-IR-scan path and loaded in the update-IR state. At this point, all data register access is performed via the select-DR-scan path. The select-DR-scan path reads or writes the register data by shifting in the data (LSB first) during the shift-DR state. When reading a register, the register value is loaded into the IEEE 1149.1-2001 shifter during the capture-DR state. When writing a register, the value is loaded from the IEEE 1149.1-2001 shifter to the register during the update-DR state. When reading a register, there is no requirement to shift out the entire register contents. Shifting can be terminated after fetching the required number of bits. ## 37.8.4 JTAGC instructions This section gives an overview of each instruction. Refer to the IEEE 1149.1-2001 standard for more details. The JTAGC implements the IEEE 1149.1-2001 defined instructions listed in *Table 620*. Instruction Code[4:0] Instruction summary **IDCODE** 00001 Selects device identification register for shift Selects boundary scan register for shifting, sampling, and 00010 SAMPLE/PRELOAD preloading without disturbing functional operation Selects boundary scan register for shifting and sampling without **SAMPLE** 00011 disturbing functional operation Selects boundary scan register while applying preloaded values to 00100 **EXTEST** output pins and asserting functional reset Selects bypass register while tristating all output pins and 01001 HIGHZ asserting functional reset Selects bypass register while applying preloaded values to output CI AMP 01100 pins and asserting functional reset ACCESS\_AUX\_TAP\_NPC 10000 Grants the Nexus port controller (NPC) ownership of the TAP 10001 Enables access to Core\_0 TAP controller ACCESS\_AUX\_TAP\_CORE0 11001 Enables access to Core 1 TAP controller ACCESS AUX TAP CORE1 Selects the ACCESS\_AUX\_NASPS\_0 configuration that connects 10111 the auxiliary TAP interface to the Nexus SRAM Port sniffer ACCESS\_AUX\_TAP\_NASPS\_0 connected between the XBAR\_0 and the SRAMC\_0 Selects the ACCESS\_AUX\_NASPS\_1 configuration that connects 11000 the auxiliary TAP interface to the Nexus SRAM Port sniffer ACCESS\_AUX\_TAP\_NASPS\_1 connected between the XBAR\_0 and the SRAMC\_1 **BYPASS** 11111 Selects bypass register for data operations Table 620. JTAG instructions | Instruction | Code[4:0] | Instruction summary | |---------------------------------------|-------------------------|-----------------------------------| | Factory Debug Reserved <sup>(1)</sup> | 00101<br>00110<br>01010 | Intended for factory debug only | | Reserved | All Other<br>Codes | Decoded to select bypass register | Table 620. JTAG instructions(Continued) ### 37.8.4.1 BYPASS instruction BYPASS selects the bypass register, creating a single-bit shift register path between TDI and TDO. BYPASS enhances test efficiency by reducing the overall shift path when no test operation of the MCU is required. This allows more rapid movement of test data to and from other components on a board that are required to perform test functions. While the BYPASS instruction is active the system logic operates normally. ## 37.8.4.2 ACCESS\_AUX\_TAP\_x instructions The ACCESS\_AUX\_TAP\_x instructions allow the Nexus modules on the MCU to take control of the TAP. When this instruction is loaded, control of the TAP pins is transferred to the selected auxiliary TAP controller. Any data input via TDI and TMS is passed to the selected TAP controller, and any TDO output from the selected TAP controller is sent back to the JTAGC to be output on the pins. The JTAGC regains control of the JTAG port during the UPDATE-DR state if the PAUSE-DR state was entered. Auxiliary TAP controllers are held in RUN-TEST/IDLE while they are inactive. ### 37.8.4.3 CLAMP instruction CLAMP allows the state of signals driven from MCU pins to be determined from the boundary scan register while the bypass register is selected as the serial path between TDI and TDO. CLAMP enhances test efficiency by reducing the overall shift path to a single bit (the bypass register) while conducting an EXTEST type of instruction through the boundary scan register. CLAMP also asserts the internal system reset for the MCU to force a predictable internal state. # 37.8.4.4 EXTEST — external test instruction EXTEST selects the boundary scan register as the shift path between TDI and TDO. It allows testing of off-chip circuitry and board-level interconnections by driving preloaded data contained in the boundary scan register onto the system output pins. Typically, the preloaded data is loaded into the boundary scan register using the SAMPLE/PRELOAD instruction before the selection of EXTEST. EXTEST asserts the internal system reset for the MCU to force a predictable internal state while performing external boundary scan operations. ### 37.8.4.5 HIGHZ instruction HIGHZ selects the bypass register as the shift path between TDI and TDO. While HIGHZ is active, all output drivers are placed in an inactive drive state (for example, high impedance). HIGHZ also asserts the internal system reset for the MCU to force a predictable internal state. <sup>1.</sup> Intended for factory debug, and not customer use. #### 37.8.4.6 IDCODE instruction IDCODE selects the 32-bit device identification register as the shift path between TDI and TDO. This instruction allows interrogation of the MCU to determine its version number and other part identification data. IDCODE is the instruction placed into the instruction register when the JTAGC is reset. ### 37.8.4.7 SAMPLE instruction The SAMPLE instruction obtains a sample of the system data and control signals present at the MCU input pins and just before the boundary scan register cells at the output pins. This sampling occurs on the rising edge of TCK in the capture-DR state when the SAMPLE instruction is active. The sampled data is viewed by shifting it through the boundary scan register to the TDO output during the Shift-DR state. There is no defined action in the update-DR state. Both the data capture and the shift operation are transparent to system operation. #### 37.8.4.8 SAMPLE/PRELOAD instruction The SAMPLE/PRELOAD instruction has two functions: - The SAMPLE part of the instruction samples the system data and control signals on the MCU input pins and just before the boundary scan register cells at the output pins. This sampling occurs on the rising-edge of TCK in the capture-DR state when the SAMPLE/PRELOAD instruction is active. The sampled data is viewed by shifting it through the boundary scan register to the TDO output during the shift-DR state. Both the data capture and the shift operation are transparent to system operation. - The PRELOAD part of the instruction initializes the boundary scan register cells before selecting the EXTEST or CLAMP instructions to perform boundary scan tests. This is achieved by shifting in initialization data to the boundary scan register during the shift-DR state. The initialization data is transferred to the parallel outputs of the boundary scan register cells on the falling edge of TCK in the update-DR state. The data is applied to the external output pins by the EXTEST or CLAMP instruction. System operation is not affected. # 37.8.5 Boundary scan The boundary scan technique allows signals at component boundaries to be controlled and observed through the shift-register stage associated with each pad. Each stage is part of a larger boundary scan register cell, and cells for each pad are interconnected serially to form a shift-register chain around the border of the design. The boundary scan register consists of this shift-register chain, and is connected between TDI and TDO when the EXTEST, SAMPLE, or SAMPLE/PRELOAD instructions are loaded. The shift-register chain contains a serial input and serial output, as well as clock and control signals. # 37.9 e200z0 OnCE controller The e200z0 core OnCE controller supports a complete set of Nexus 1 debug features, as well as providing access to the Nexus 2+ configuration registers. A complete discussion of the e200z0 OnCE debug features is available in the core reference manual. # 37.9.1 e200z0 OnCE controller block diagram Figure 659 is a block diagram of the e200z0 OnCE block. e200z0 TRST Test Access Port (TAP) From **JTAGC** Controller e200z0 TMS TCK -**TDO Mux** Control TAP Instruction Register (OnCE OCMD) **Bypass Register** e200z0 TDO (to JTAGC) TDI External Data Register OnCE Mapped Debug Registers Auxiliary Data Register Figure 659. e200z0 OnCE block diagram # 37.9.2 e200z0 OnCE controller functional description The functional description for the e200z0 OnCE controller is the same as for the JTAGC, with the differences described as follows. ### 37.9.2.1 Enabling the TAP controller To access the e200z0 OnCE controller, the proper JTAGC instruction needs to be loaded in the JTAGC instruction register, as discussed in *Section 37.5.2.2: TAP sharing mode*. The e200z0 OnCE TAP controller may either be accessed independently or chained with the e200z1 OnCE TAP controller, such that the TDO output of the e200z1 TAP controller is fed into the TDI input of the e200z0 TAP controller. The chained configuration allows commands to be loaded into both core's OnCE registers in one shift operation, so that both cores can be sent a GO command at the same time for example. # 37.9.3 e200z0 OnCE controller registers description Most e200z0 OnCE debug registers are fully documented in the core reference manual. # 37.9.3.1 OnCE Command register (OCMD) The OnCE command register (OCMD) is a 10-bit shift register that receives its serial data from the TDI pin and serves as the instruction register (IR). It holds the 10-bit commands to be used as input for the e200z0 OnCE Decoder. The OCMD is shown in *Figure 660*. The OCMD is updated when the TAP controller enters the update-IR state. It contains fields for controlling access to a resource, as well as controlling single-step operation and exit from OnCE mode. Although the OCMD is updated during the update-IR TAP controller state, the corresponding resource is accessed in the DR scan sequence of the TAP controller, and as such, the update-DR state must be transitioned through in order for an access to occur. In addition, the update-DR state must also be transitioned through in order for the single-step and/or exit functionality to be performed, even though the command appears to have no data resource requirement associated with it. Figure 660. OnCE Command register (OCMD) Table 621. e200z0 OnCE register addressing | RS[0:6] | Register selected | |---------------------|--------------------------------------| | 000 0000 000 0001 | Reserved | | 000 0010 | JTAG ID (read-only) | | 000 0011 – 000 1111 | Reserved | | 001 0000 | CPU Scan Register (CPUSCR) | | 001 0001 | No Register Selected (Bypass) | | 001 0010 | OnCE Control Register (OCR) | | 001 0011 – 001 1111 | Reserved | | 010 0000 | Instruction Address Compare 1 (IAC1) | | 010 0001 | Instruction Address Compare 2 (IAC2) | | 010 0010 | Instruction Address Compare 3 (IAC3) | | 010 0011 | Instruction Address Compare 4 (IAC4) | | 010 0100 | Data Address Compare 1 (DAC1) | | 010 0101 | Data Address Compare 2 (DAC2) | | 010 0110 | Data Value Compare 1 (DVC1) | | 010 0111 | Data Value Compare 2 (DVC2) | | 010 1000 – 010 1111 | Reserved | | 011 0000 | Debug Status Register (DBSR) | | 011 0001 | Debug Control Register 0 (DBCR0) | | 011 0010 | Debug Control Register 1 (DBCR1) | | RS[0:6] | Register selected | |---------------------|-------------------------------------------------------------------------| | 011 0011 | Debug Control Register 2 (DBCR2) | | 011 0100 – 101 1111 | Reserved (do not access) | | 110 1111 | Shared Nexus Control Register (SNC) (only available on the e200z0 core) | | 111 0000 – 111 1001 | General Purpose Register Selects [0:9] | | 111 1010 – 111 1011 | Reserved | | 111 1100 | Nexus 2+ Access | | 111 1101 | LSRL Select<br>(factory test use only) | | 111 1110 | Enable_OnCE | | 111 1111 | Bypass | Table 621. e200z0 OnCE register addressing(Continued) # 37.10 Initialization/Application Information The test logic is a static logic design, and TCK can be stopped in either a high or low state without loss of data. However, the system clock is not synchronized to TCK internally. Any mixed operation using both the test logic and the system functional logic requires external synchronization. To initialize the JTAGC module and enable access to registers, the following sequence is required: - Place the JTAGC in reset through TAP controller state machine transitions controlled by TMS - Load the appropriate instruction for the test or action to be performed. # 38 Nexus Port Controller (NPC) # 38.1 Information specific to this device This section presents device-specific parameterization, customization, and feature availability information not specifically referenced in the remainder of this chapter. ### 38.1.1 Parameter values The parameter values for this device are shown in *Table 622*. Table 622. Device parameter values | Parameter | Value | |---------------------------------------------------|-------| | Number of MDO pins available in reduced-port mode | 4 | | Number of MDO pins available in full-port mode | 12 | | Number of blocks that input an EVTO | 1 | | Part identification number | 0x2A2 | | Manufacturer identity code (MIC) | 0x020 | | Design center code (DC) | 0x2B | # 38.1.2 Unavailable features This device does not support an MCKO division factor of 3. Therefore, the setting PCR[MCKO\_DIV] = 2 (see *Table 627*) is not available on this device. Nexus DDR mode works only for MCKO division factors of 2, 4, and 8. Therefore, the setting PCR[MCKO\_DIV] = 0 (see *Table 627*) will not support Nexus DDR mode on this device. # 38.2 Introduction Figure 661 is a block diagram of the Nexus Port Controller (NPC) block. Figure 661. Nexus Port Controller Block Diagram ### 38.2.1 Overview On a system-on-a-chip device, there are often multiple blocks that require development support. Each of these blocks implements a development interface based on the IEEE-ISTO 5001-2001 standard. The blocks share input and output ports that interface with the development tool. The NPC controls the usage of the input and output port in a manner that allows all the individual development interface blocks to share the port, and appear to the development tool to be a single block. # 38.2.2 Features The NPC block performs the following functions: - Controls arbitration for ownership of the Nexus Auxiliary Output Port - Nexus Device Identification Register and Messaging - Generates MCKO enable and frequency division control signals - Controls sharing of EVTO - Generates an MCKO clock gating control signal to enable gating of MCKO when the auxiliary output port is idle - Control of the device-wide debug mode - Generates censorship status, and power-on reset status - System clock locked status indication via MDO[0] following power-on reset - Provides Nexus support for censorship mode - RDY pin support to increase the transfer rate of the IEEE 1149.1 port for large data read requests # 38.2.3 Modes of operation The NPC block uses the JCOMP input, the censorship status, and an internal power-on reset indication as its primary reset signals. Upon exit of reset, the mode of operation is determined by the Port Configuration Register (PCR) settings. #### 38.2.3.1 Reset The NPC block is asynchronously placed in reset when either power-on reset is asserted, JCOMP is not set for Nexus access, the device enters censored mode, or the TAP controller state machine is in the Test-Logic-Reset state. Holding TMS high for 5 consecutive rising edges of TCK guarantees entry into the Test-Logic-Reset state regardless of the current TAP controller state. Following negation of power-on reset, the NPC remains in reset until the system clock achieves lock. The NPC is unaffected by other sources of reset. While in reset, the following actions occur: - The TAP controller is forced into the Test-Logic-Reset state - The auxiliary output port pins are negated - The TDI, TMS, and TCK TAP inputs are ignored (when in power-on reset, censored mode or JCOMP not set for NPC operation only) - Registers default back to their reset values ### 38.2.3.2 Disabled-Port Mode In disabled-port mode, auxiliary output pin port enable signals are negated, thereby disabling message transmission. Any debug feature that generates messages can not be used. The primary features available are class 1 features and read/write access to the registers. Class 1 features include the ability to trigger a breakpoint event indication through EVTO. ### 38.2.3.3 Full-Port Mode Full-port mode (FPM) is entered by asserting the MCKO\_EN and FPM bits in the PCR. All trace features are enabled or can be enabled by writing the configuration registers via the TAP. The number of MDO pins available is device-specific. #### 38.2.3.4 Reduced-Port Mode Reduced-port mode (RPM) is entered by asserting the MCKO\_EN bit and deasserting the FPM bit in the PCR. All trace features are enabled or can be enabled by writing the configuration registers via the TAP. The number of MDO pins available is device-specific. ### 38.2.3.5 Censored Mode When the device is in censored mode, reading the contents of internal flash externally is not allowed. To prevent Nexus modules from violating censorship, the NPC is held in reset when in censored mode, asynchronously holding all other Nexus modules in reset as well. This prevents Nexus read/write to memory mapped resources and the transmission of Nexus trace messages. #### 38.2.3.6 Nexus Double Data Rate Mode Nexus double data rate (DDR) mode is enabled by asserting the DDR\_EN bit in the PCR. In double data rate mode, message data is updated between the edges (both rising and falling, for cut2) of MCKO, effectively doubling message throughput. # 38.3 External signal description ### 38.3.1 Overview The NPC pin interface provides for the transmission of messages from Nexus blocks to the external development tools and for access to Nexus client registers. The NPC pin definition is outlined in *Table 623*. | Table 023. Nr O digital i Toperties | | | | | |-------------------------------------|-----------|-----------------------------------------|-----------------------|---------------------| | Name | Port | Function | Reset State | Pull <sup>(1)</sup> | | EVTO | Auxiliary | Event Out pin | 0b1 | _ | | JCOMP | JTAG | JTAG Compliancy and TAP Sharing Control | _ | Down | | MDO | Auxiliary | Message Data Out pins | 0 <sup>(2)</sup> | _ | | MSEO | Auxiliary | Message Start/End Out pins | 0b11 | _ | | TCK | JTAG | Test Clock Input | _ | Down | | TDI | JTAG | Test Data Input | _ | Up | | TDO | JTAG | Test Data Output | High Z <sup>(3)</sup> | | | TMS | JTAG | Test Mode Select Input | _ | Up | | RDY | JTAG | Data ready for transfer to/from NRRs | _ | _ | **Table 623. NPC Signal Properties** # 38.3.2 Detailed signal descriptions This section describes each of the signals listed in *Table 623* in more detail. The JTAG test clock (TCK) input from the pin is not a direct input to the NPC. The NPC requires two separate input clocks for TCK clocked logic, one for posedge (rising edge TCK) logic and one for negedge (falling edge TCK) logic. Both clocks are derived from the pin TCK, and generated external to the NPC. # 38.3.2.1 **EVTO** - Event Out Event Out (EVTO) is an output pin that is asserted upon breakpoint occurrence to provide breakpoint status indication. The EVTO output of the NPC is generated based on the values of the individual EVTO signals from all Nexus blocks that implement the signal. <sup>1.</sup> The pull is not implemented in this block. Pullup/pulldown devices are implemented in the pads. <sup>2.</sup> Following a power-on reset, MDO[0] remains asserted until power-on reset is exited and the system clock achieves lock. TDO output buffer enable is negated when the NPC is not in the Shift-IR or Shift-DR states. A weak pull may be implemented on TDO at the SoC level. # 38.3.2.2 JCOMP - JTAG Compliancy The JCOMP signal provides the ability to share the TAP. The NPC TAP controller is enabled when JCOMP is set to the NPC enable encoding, otherwise the NPC TAP controller remains in reset. # 38.3.2.3 MDO - Message Data Out Message Data Out (MDO) are output pins used for uploading OTM, BTM, DTM, and other messages to the development tool. The development tool should sample MDO on the rising edge of MCKO. The width of the MDO bus used is determined by reset configuration. # 38.3.2.4 MSEO\_B - Message Start/End Out Message Start/End Out ( $\overline{\text{MSEO}}$ ) are two output pins that indicates when a message on the MDO pins has started, when a variable length packet has ended, or when the message has ended. The development tool should sample MSEO on the rising edge of MCKO. ## 38.3.2.5 TCK - Test Clock Input Test Clock Input (TCK) pin is used to synchronize the test logic and control register access through the JTAG port. ## 38.3.2.6 TDI - Test Data Input Test Data Input (TDI) pin receives serial test instruction and data. TDI is sampled on the rising edge of TCK. ## 38.3.2.7 TDO - Nexus Test Data Output Test Data Output (TDO) pin transmits serial output for instructions and data. TDO is three-stateable and is actively driven in the SHIFT-IR and SHIFT-DR controller states. TDO is updated on the falling edge of TCK and sampled by the development tool on the rising edge of TCK. #### 38.3.2.8 TMS - Test Mode Select Test Mode Select Input (TMS) pin is used to sequence the IEEE 1149.1-2001 TAP controller state machine. TMS is sampled on the rising edge of TCK. # 38.3.2.9 RDY — Data ready for transfer The RDY pin, supported on cut2 only, exists to increase the transfer rate of the IEEE 1149.1 port. It is used to signal when data are ready to be transferred to and from NRRs. This may eliminate the need to poll NRRs for status information for synchronization purposes. This capability becomes especially important when performing read/write access transfers to different speed target memories. The RDY pin asserts (asynchronously) a logic low whenever the read/write access transfer has completed without error and then deasserts when the IEEE 1149.1 state machine has reached the CAPTURE\_DR state. # 38.4 Register definition This section provides a detailed description of the NPC registers accessible to the end user. Individual bit-level descriptions and reset states of the registers are included. Table 624 shows the NPC registers by index values. The registers are not memory-mapped and can only be accessed via the TAP. The NPC block does not implement the client select control register because the value does not matter when accessing the registers. Note that the bypass and instruction registers have no index values. These registers are not accessed in the same manner as Nexus client registers. Refer to the individual register descriptions for more detail. Table 624. NPC Registers | Index | Register | |-------|-----------------------------------| | 0 | Device ID Register (DID) | | 127 | Port Configuration Register (PCR) | # 38.4.1 Register descriptions This section consists of NPC register descriptions. ## 38.4.1.1 Bypass Register The bypass register is a single-bit shift register path selected for serial data transfer between TDI and TDO when the BYPASS instruction or any unimplemented instructions are active. After entry into the Capture-DR state, the single-bit shift register is set to a logic 0. Therefore, the first bit shifted out after selecting the bypass register is always a logic 0. # 38.4.1.2 Instruction Register The NPC block uses a 4-bit instruction register as shown in *Table 662*. The instruction register is accessed via the SELECT\_IR\_SCAN path of the tap controller state machine, and allows instructions to be loaded into the block to enable the NPC for register access (NEXUS\_ENABLE) or select the bypass register as the shift path from TDI to TDO (BYPASS or unimplemented instructions). Instructions are shifted in through TDI while the TAP controller is in the Shift-IR state, and latched on the falling edge of TCK in the Update-IR state. The latched instruction value can only be changed in the Update-IR and Test-Logic-Reset TAP controller states. Synchronous entry into the Test-Logic-Reset state results in synchronous loading of the BYPASS instruction. Asynchronous entry into the Test-Logic-Reset state results in asynchronous loading of the BYPASS instruction. During the Capture-IR TAP controller state, the instruction register is loaded with the value of the previously executed instruction, making this value the register's read value when the TAP controller is sequenced into the Shift-IR state. Figure 662. 4-Bit Instruction Register | | 3 | 2 | 1 | 0 | |--------|--------|------------|-----------|----------| | R | Previ | ous Instr | uction Op | code | | W | | nstructio | n Opcode | 9 | | Reset: | BYPASS | 3 Instruct | ion Opco | de (0xF) | # 38.4.1.3 Nexus Device ID Register (DID) The device identification register, shown in *Figure 663*, allows the part revision number, design center, part identification number, and manufacturer identity code of the part to be determined through the auxiliary output port. Figure 663. Nexus Device ID Register **Table 625. DID Field Descriptions** | Bit | Name | Description | |-------|---------|-----------------------------------------------------------------------------------------------------------------------| | 31:28 | PRN | Part Revision Number These bits contain the revision number of the part | | 27:22 | DC | Design Center These bits indicate the device design center | | 21:12 | PIN | Part Identification Number These bits contain the part number of the device | | 11:1 | MIC | Manufacturer Identity Code These bits contain the reduced Joint Electron Device Engineering Council (JEDEC) ID | | 0 | Bit [0] | IDCODE Register ID Bit [0] identifies this register as the device identification register and not the bypass register | # 38.4.1.4 Port Configuration Register (PCR) Figure 664. Port Configuration Register (PCR) The PCR, shown in *Figure 664*, is used to select the NPC mode of operation, enable MCKO and select the MCKO frequency, and enable or disable MCKO gating. This register should be configured as soon as the NPC is enabled. The PCR may be rewritten by the debug tool subsequent to the enabling of the NPC for low power debug support. In this case, the debug tool may set and clear the LP\_DBG and LPn SYN bits, but must preserve the original state of the remaining bits in the register. Note: The mode or clock division must not be modified after MCKO has been enabled. Changing the mode or clock division while MCKO is enabled can produce unpredictable results. Table 626. PCR field descriptions | Name | Description | |---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FPM | Full Port Mode The value of the FPM bit determines if the auxiliary output port uses the full MDO port or a reduced MDO port to transmit messages. | | | 1 = All MDO pins are used to transmit messages<br>0 = A subset of MDO pins are used to transmit messages | | MCKO_GT | MCKO Clock Gating Control This bit is used to enable or disable MCKO clock gating. If clock gating is enabled, the MCKO clock is gated when the NPC is in enabled mode but not actively transmitting messages on the auxiliary output port. When clock gating is disabled, MCKO is allowed to run even if no auxiliary output port messages are being transmitted. | | | 1 = MCKO gating is enabled<br>0 = MCKO gating is disabled | Table 626. PCR field descriptions(Continued) | Name | Description | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MCKO_EN | MCKO Enable This bit enables the MCKO clock to run. When enabled, the frequency of MCKO is determined by the MCKO_DIV field. 1 = MCKO clock is enabled | | | 0 = MCKO clock is driven to zero | | MCKO_DIV | MCKO Division Factor The value of this signal determines the frequency of MCKO relative to the system clock frequency when MCKO_EN is asserted. <i>Table 627</i> shows the meaning of MCKO_DIV Values. In this table, SYS_CLK represents the system clock frequency. | | | EVTO/EVTI Enable | | EVT_EN | This bit enables the EVTO/EVTI port functions. | | _ | 1 = EVTO/EVTI port enabled<br>0 = EVTO/EVTI port disabled | | DDR_EN | Double Data Rate Mode Enable This bit enables Nexus double data rate (DDR) mode. In DDR mode, message data is updated on both rising and falling edges of MCKO, effectively doubling message throughput. | | | 1 = DDR mode enabled<br>0 = DDR mode disabled | | NEXCFG | Nexus Configuration Select Generic Nexus control bit. Function is SoC specific. | | NEXO O | 1 = NEXCFG set<br>0 = NEXCFG cleared | | LP DBG EN | Low Power Debug Enable This bit enables debug functionality on exit from low power modes on supported devices. | | (1) | 1 = Low power debug enabled<br>0 = Low power debug disabled | | LPn_SYN <sup>(1)</sup> | Low Power Mode n Synchronization These bits are used to synchronize the entry into low power modes between the device and debug tool. Supported devices set these bits before a pending entry into low power mode. After reading the bit as set, the debug tool then clears the bit to acknowledge to the device that it may enter the low power mode. | | | 1 = Low power mode entry pending<br>0 = Low power mode entry acknowledged | | PSTAT_EN | Processor Status Mode Enable <sup>(2)</sup> This bit enables processor status (PSTAT) mode. In PSTAT mode, all auxiliary output port MDO pins are used to transmit processor status information, and Nexus messaging is unavailable. | | | 1 = PSTAT mode enabled<br>0 = PSTAT mode disabled | <sup>1.</sup> This feature is not implemented in SPC56xP60x/54x. <sup>2.</sup> PSTAT Mode is intended for factory processor debug only. The PSTAT\_EN bit should be written to disable PSTAT mode if Nexus messaging is desired. No Nexus messages are transmitted under any circumstances when PSTAT mode is enabled. | MCKO_DIV[2:0] | MCKO Frequency | |---------------|------------------------| | 0 | SYS_CLK <sup>(1)</sup> | | 1 | SYS_CLK/2 | | 2 | SYS_CLK/3 | | 3 | SYS_CLK/4 | | 4 | Reserved | | 5 | Reserved | | 6 | Reserved | | 7 | SYS_CLK/8 | Table 627. MCKO\_DIV Values # 38.5 Functional description # 38.5.1 NPC reset configuration The NPC is placed in disabled mode upon exit of reset. If message transmission via the auxiliary port is desired, a write to the PCR is then required to enable the NPC and select the mode of operation. Asserting MCKO\_EN places the NPC in enabled mode and enables MCKO. The frequency of MCKO is selected by writing the MCKO\_DIV field. Asserting or negating the FPM bit selects full-port or reduced-port mode, respectively. Table 628 describes the NPC reset configuration options. **JCOMP** Equal to MCKO\_EN bit of the Port **FPM** bit of the Port Configuration **Configuration Register** npc\_jcomp\_plug? **Configuration Register** Χ Χ Reset no 0 Χ Disabled yes 1 1 Full-Port Mode yes 1 0 Reduced-Port Mode yes **Table 628. NPC Reset Configuration Options** # 38.5.2 Auxiliary Output Port The auxiliary output port is shared by each of the Nexus modules on the device. The NPC communicates with each of the Nexus modules and arbitrates for access to the port. ### 38.5.2.1 Output Message Protocol The protocol for transmitting messages via the auxiliary port is accomplished with the MSEO functions. The MSEO pins are used to signal the end of variable-length packets and the end of messages. They are not required to indicate the end of fixed-length packets. MDO and MSEO are sampled on the rising edge of MCKO. The SYS\_CLK setting for MCKO frequency should only be used if this setting does not violate the maximum operating frequency of the auxiliary port pins. *Figure 665* illustrates the state diagram for MSEO transfers. All transitions not included in the figure are reserved, and must not be used. Figure 665. MSEO Transfers (for 2-bit MSEO) # 38.5.2.2 Output Messages In addition to sending out messages generated in other Nexus blocks, the NPC can also output the device ID message contained in the device ID register and the port replacement output message on the MDO pins. The device ID message can also be sent out serially through TDO. *Table 629* describes the device ID and port replacement output messages that the NPC can transmit on the auxiliary port. The TCODE is the first packet transmitted. ### Table 629. NPC Output Messages | Message Name | Min.<br>Packet<br>Size<br>(bits) | Max<br>Packet<br>Size<br>(bits) | Packet<br>Type | Packet<br>Name | Packet Description | |-------------------|----------------------------------|---------------------------------|----------------|----------------|-----------------------| | Device ID Message | 6 | 6 | fixed | TCODE | Value = 1 | | Device ID Message | 32 | 32 | fixed | ID | DID register contents | Figure 666 shows the various message formats that the pin interface formatter has to encounter. Note that for variable-length fields, the transmitted size of the field is determined from the range of the least significant bit to the most significant non-zero-valued bit (i.e. most significant zero-valued bits are not transmitted). ### Figure 666. Message Field Sizes | Message | TCODE | Field #1 | Field #2 | Field #3 | Field #4 | Field #5 | Min.<br>Size <sup>1</sup><br>(bits) | Max<br>Size <sup>2</sup><br>(bits) | |-------------------|-------|------------|----------|----------|----------|----------|-------------------------------------|------------------------------------| | Device ID Message | 1 | Fixed = 32 | NA | NA | NA | NA | 38 | 38 | #### NOTES: - 1. Minimum information size. The actual number of bits transmitted depends on the number of MDO pins - 2. Maximum information size. The actual number of bits transmitted depends on the number of MDO pins The double edges in *Figure 666* indicate the starts and ends of messages. Fields without shaded areas between them are grouped into super-fields and can be transmitted together without end-of-packet indications between them. # 38.5.2.3 Rules of Message - A variable-sized field within a message must end on a port boundary. (Port boundaries depend on the number of MDO pins active with the current reset configuration.) - A variable-sized field may start within a port boundary only when following a fixedlength field. - Super-fields must end on a port boundary. - When a variable-length field is sized such that it does not end on a port boundary, it is necessary to extend and zero fill the remaining bits after the highest order bit so that it can end on a port boundary. - Multiple fixed-length packets may start and/or end on a single clock. - When any packet follows a variable-length packet, it must start on a port boundary. - The field containing the TCODE number is always transferred out first, followed by subsequent fields of information. - Within a field, the lowest significant bits are shifted out first. Figure 667 shows the transmission sequence of a message that is made up of a TCODE followed by two fields. 3 FIELD #2 FIELD #1 TCODE (6 bits) msb Isb msb Isb msb Isb Figure 667. Transmission Sequence of Messages #### 38.5.3 IEEE 1149.1-2001 (JTAG) TAP The NPC block uses the IEEE 1149.1-2001 TAP for accessing registers. Each of the individual Nexus blocks on the device implements a TAP controller for accessing its registers as well. TAP signals include TCK, TDI, TMS, and TDO. There may also be other blocks on the MCU that use the TAP and implement a TAP controller. The value of the JCOMP input controls ownership of the port between Nexus and non-Nexus blocks sharing the TAP. Refer to the IEEE 1149.1-2001 specification for further detail on electrical and pin protocol compliance requirements. The NPC implements a Nexus controller state machine that transitions based on the state of the IEEE 1149.1-2001 state machine shown in Figure 669. The Nexus controller state machine is defined by the IEEE-ISTO 5001-2001 standard. It is shown in Figure 670. The instructions implemented by the NPC TAP controller are listed in *Table 630*. The value of the NEXUS-ENABLE instruction is 0b0000. Each unimplemented instruction acts like the BYPASS instruction. The size of the NPC instruction register is 4-bits. | Instruction Name Private/<br>Public | | Opcode | Description | |-------------------------------------|---------|---------------|-----------------------------------------------------------------------------------| | NEXUS-ENABLE | public | 0x0 | Activate Nexus controller state machine to read and write NPC registers. | | BYPASS | private | () <b>x</b> ⊢ | NPC BYPASS instruction. Also the value loaded into the NPC IR upon exit of reset. | Table 630. Implemented Instructions Data is shifted between TDI and TDO starting with the least significant bit as illustrated in Figure 668. This applies for the instruction register and all Nexus tool-mapped registers. **MSB** LSB TDI Selected Register ▶ TDO Figure 668. Shifting Data Into Register #### **Enabling the NPC TAP controller** 38.5.3.1 Assertion of the power-on reset signal, entry into censored mode, or setting JCOMP to a value other than the NPC enable encoding resets the NPC TAP controller. When not in DocID018714 Rev 5 1072/1102 power-on reset or censored mode, the NPC TAP controller is enabled by driving JCOMP with the NPC enable value and exiting the Test-Logic-Reset state. Loading the NEXUS-ENABLE instruction then grants access to Nexus debug. **TEST LOGIC** RESET 0 1 RUN-TEST/IDLE SELECT-DR-SCAN SELECT-IR-SCAN 0 0 0 CAPTURE-DR CAPTURE-IR 0 0 SHIFT-IR SHIFT-DR 0 1 1 1 1 EXIT1-DR EXIT1-IR 0 0 PAUSE-DR PAUSE-IR 0 0 1 0 0 EXIT2-IR EXIT2-DR 1 1 **UPDATE-DR UPDATE-IR** 0 0 NOTE: The value shown adjacent to each state transition in this figure represents the value of TMS at the time of a rising edge of TCK. Figure 669. IEEE 1149.1-2001 TAP Controller State Machine 57 #### 38.5.3.2 Retrieving device IDCODE The Nexus TAP controller does not implement the IDCODE instruction. However, the device identification message can be output by the NPC through the auxiliary output port or shifted out serially by accessing the Nexus Device ID register through the TAP. Transmission of the device identification message on the auxiliary output port MDO pins occurs immediately after a write to the PCR, if the NPC is enabled. Transmission of the device identification message serially via TDO is achieved by performing a read of the register contents as described in Section 38.5.3.4: Selecting a Nexus Client Register. #### 38.5.3.3 Loading NEXUS-ENABLE Instruction Access to the NPC registers is enabled when the TAP controller instruction register is loaded with the NEXUS-ENABLE instruction. This instruction is shifted in via the SELECT-IR-SCAN path and loaded in the UPDATE-IR state. At this point, the Nexus controller state machine, shown in Figure 670, transitions to the REG SELECT state. The Nexus controller has three states: idle, register select, and data access. Table 631 illustrates the IEEE 1149.1 sequence to load the NEXUS-ENABLE instruction. Figure 670. NEXUS Controller State Machine Table 631. Loading NEXUS-ENABLE instruction | Clock | TMS | IEEE 1149.1 State | Nexus State | Description | | | | | |--------|-----|-------------------|-------------|----------------------------------------------------------------------------------|--|--|--|--| | 0 | 0 | RUN-TEST/IDLE | IDLE | IEEE 1149.1-2001 TAP controller in idle state | | | | | | 1 | 1 | SELECT-DR-SCAN | IDLE | Transitional state | | | | | | 2 | 1 | SELECT-IR-SCAN | IDLE | Transitional state | | | | | | 3 | 0 | CAPTURE-IR | IDLE | Internal shifter loaded with current instruction | | | | | | 4 | 0 | SHIFT-IR | IDLE | TDO becomes active, and the IEEE 1149.1-2001 | | | | | | 3 TCKS | | | | shifter is ready. Shift in all but the last bit of the NEXUS_ENABLE instruction. | | | | | | 12 | 1 | EXIT1-IR | IDLE | Last bit of instruction shifted in | | | | | | 13 | 1 | UPDATE-IR | IDLE | NEXUS-ENABLE loaded into instruction register | | | | | | 14 | 0 | RUN-TEST/IDLE | REG_SELECT | Ready to be read/write Nexus registers | | | | | # 38.5.3.4 Selecting a Nexus Client Register When the NEXUS-ENABLE instruction is decoded by the TAP controller, the input port allows development tool access to all Nexus registers. Each register has a 7-bit address index. All register access is performed via the SELECT-DR-SCAN path. The Nexus Controller defaults to the REG\_SELECT state when enabled. Accessing a register requires two passes through the SELECT-DR-SCAN path: one pass to select the register and the second pass to read/write the register. The first pass through the SELECT-DR-SCAN path is used to enter an 8-bit Nexus command consisting of a read/write control bit in the LSB followed by a 7-bit register address index, as illustrated in *Figure 671*. The read/write control bit is set to 1 for writes and 0 for reads. Figure 671. IEEE 1149.1 Controller Command Input MSB LSB 7-bit register index R/W The second pass through the SELECT-DR-SCAN path is used to read or write the register data by shifting in the data (LSB first) during the SHIFT-DR state. When reading a register, the register value is loaded into the IEEE 1149.1-2001 shifter during the CAPTURE-DR state. When writing a register, the value is loaded from the IEEE 1149.1-2001 shifter to the register during the UPDATE-DR state. When reading a register, there is no requirement to shift out the entire register contents. Shifting may be terminated once the required number of bits have been acquired. Table 632 illustrates a sequence which writes a 32-bit value to a register Clock **TMS IEEE 1149.1 State Nexus State** Description 0 **RUN-TEST/IDLE REG SELECT** IEEE 1149.1-2001 TAP controller in idle state 1 1 SELECT-DR-SCAN **REG SELECT** First pass through SELECT-DR-SCAN path Internal shifter loaded with current value of 2 0 CAPTURE-DR REG\_SELECT controller command input. 3 0 SHIFT-DR **REG SELECT** TDO becomes active, and write bit and 6 bits of register index shifted in. 7 TCKs 12 1 EXIT1-DR **REG\_SELECT** Last bit of register index shifted into TDI 13 1 **UPDATE-DR REG SELECT** Controller decodes and selects register 14 1 SELECT-DR-SCAN DATA\_ACCESS Second pass through SELECT-DR-SCAN path 0 **CAPTURE-DR** DATA\_ACCESS 15 Internal shifter loaded with current value of register 16 0 SHIFT-DR DATA ACCESS TDO becomes active, and outputs current value of register while new value is shifted in through TDI 31 TCKs Last bit of current value shifted out TDO. Last bit of 48 EXIT1-DR DATA\_ACCESS 1 new value shifted in TDL Table 632. Write to a 32-Bit Nexus Client Register | | | | | <u> </u> | |-------|-----|-------------------|-------------|------------------------------------------------------------------------------------------------------| | Clock | TMS | IEEE 1149.1 State | Nexus State | Description | | 49 | 1 | UPDATE-DR | DATA_ACCESS | Value written to register | | 50 | 0 | RUN-TEST/IDLE | REG_SELECT | Controller returned to idle state. It could also return to SELECT-DR-SCAN to write another register. | Table 632. Write to a 32-Bit Nexus Client Register(Continued) # 38.5.4 Nexus JTAG Port Sharing Each of the individual Nexus blocks on the device implements a TAP controller for accessing its registers. When Nexus has ownership of the TAP, only the block whose NEXUS-ENABLE instruction is loaded has control of the TAP. This allows the interface to all of these individual TAP controllers to appear to be a single port from outside the device. If no register is selected as the shift path for a Nexus block, that block acts like a single-bit shift register, or bypass register. # 38.5.5 MCKO and ipg\_sync\_mcko MCKO is an output clock to the development tools used for the timing of MSEO and MDO pin functions. MCKO is derived from the system clock and its frequency is determined by the value of the MCKO\_DIV field in the PCR. Possible operating frequencies include system clock, one-half system clock, one-quarter system clock, and one-eighth system clock speed. The NPC also generates an MCKO clock gating control output signal. This output can be used by the MCKO generation logic to gate the transmission of MCKO when the auxiliary port is enabled but not transmitting messages. The setting of the MCKO\_GT bit inside the PCR determines whether or not MCKO gating control is active. The MCKO\_GT bit resets to a logic 0. In this state gating of MCKO is disabled. To enable gating of MCKO, the MCKO\_GT bit in the PCR is written to a logic 1. # 38.5.6 EVTO Sharing The NPC block controls sharing of the EVTO output between all Nexus clients that produce an EVTO signal. The NPC assumes incoming EVTO signals will be asserted for one system clock period. After receiving a single clock period of asserted EVTO from any Nexus client, the NPC latches the result, and drives EVTO for one MCKO period on the following clock. When there is no active MCKO, such as in disabled mode, the NPC drives EVTO for two system clock periods. EVTO sharing is active as long as the NPC is not in reset. # 38.5.7 Nexus Reset Control The JCOMP input that is used as the primary reset signal for the NPC is also used by the NPC to generate a single-bit reset signal for other Nexus blocks. If JCOMP is negated, an internal reset is asserted, indicating that all Nexus modules should be held in reset. Internal Nexus reset is also asserted when the device is in censored mode. # 38.5.8 System Clock Locked Indication Following a power-on reset, MDO[0] can be monitored to provide the lock status of the system clock. MDO[0] is driven to a logic 1 until the system clock achieves lock after exiting power-on reset. Once the system clock is locked, MDO[0] is negated and tools may begin Nexus configuration. Loss of lock conditions that occur subsequent to the exit of power-on reset and the initial lock of the system clock do not cause a Nexus reset, and therefore do not result in MDO[0] driven high. # 38.6 Initialization/Application Information # 38.6.1 Accessing NPC tool-mapped registers To initialize the TAP for Nexus register accesses, the following sequence is required: - 1. Enable the Nexus TAP controller - 2. Load the TAP controller with the NEXUS-ENABLE instruction To write control data to NPC tool-mapped registers, the following sequence is required: - 1. Write the 7-bit register index and set the write bit to select the register with a pass through the SELECT-DR-SCAN path in the TAP controller state machine. - 2. Write the register value with a second pass through the SELECT-DR-SCAN path. Note that the prior value of this register is shifted out during the write. To read status and control data from NPC tool-mapped registers, the following sequence is required: - 1. Write the 7-bit register index and clear the write bit to select register with a pass through SELECT-DR-SCAN path in the TAP controller state machine. - 2. Read the register value with a second pass through the SELECT-DR-SCAN path. Data shifted in is ignored. See the IEEE-ISTO 5001-2001 standard for more detail. # Appendix A Registers Under Protection For SPC56xP60x/54x, the Register Protection module is operable on the registers listed in *Table 633*. Table 633. Registers under protection | Module | Register | Register size (bits) | Register offset | Protected bitfields | | | | | |------------|----------------------------------------------------------------|----------------------|-----------------|---------------------|--|--|--|--| | | Code Flash—Base address: 0xC3F8_8000 4 registers to protect | | | | | | | | | Code Flash | MCR | 32 | 0x0000 | bits[0:31] | | | | | | Code Flash | PFCR0 | 32 | 0x001C | bits[0:31] | | | | | | Code Flash | PFCR1 | 32 | 0x0020 | bits[0:31] | | | | | | Code Flash | PFAPR | 32 | 0x0024 | bits[0:31] | | | | | | | Data Flash—Base address: 0xC3F8_C000<br>1 register to protect | | | | | | | | | Data Flash | MCR | 32 | 0x0000 | bits[0:31] | | | | | | | SIU lite—Base address: 0xC3F9_0000<br>154 registers to protect | | | | | | | | | SIUL | IRER | 32 | 0x0018 | bits[0:31] | | | | | | SIUL | IREER | 32 | 0x0028 | bits[0:31] | | | | | | SIUL | IFEER | 32 | 0x002C | bits[0:31] | | | | | | SIUL | IFER | 32 | 0x0030 | bits[0:31] | | | | | | SIUL | PCR0 | 16 | 0x0040 | bits[0:15] | | | | | | SIUL | PCR1 | 16 | 0x0042 | bits[0:15] | | | | | | SIUL | PCR2 | 16 | 0x0044 | bits[0:15] | | | | | | SIUL | PCR3 | 16 | 0x0046 | bits[0:15] | | | | | | SIUL | PCR4 | 16 | 0x0048 | bits[0:15] | | | | | | SIUL | PCR5 | 16 | 0x004A | bits[0:15] | | | | | | SIUL | PCR6 | 16 | 0x004C | bits[0:15] | | | | | | SIUL | PCR7 | 16 | 0x004E | bits[0:15] | | | | | | SIUL | PCR8 | 16 | 0x0050 | bits[0:15] | | | | | | SIUL | PCR9 | 16 | 0x0052 | bits[0:15] | | | | | | SIUL | PCR10 | 16 | 0x0054 | bits[0:15] | | | | | | SIUL | PCR11 | 16 | 0x0056 | bits[0:15] | | | | | | SIUL | PCR12 | 16 | 0x0058 | bits[0:15] | | | | | | SIUL | PCR13 | 16 | 0x005A | bits[0:15] | | | | | | SIUL | PCR14 | 16 | 0x005C | bits[0:15] | | | | | | SIUL | PCR15 | 16 | 0x005E | bits[0:15] | | | | | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |--------|----------|----------------------|-----------------|---------------------| | SIUL | PCR16 | 16 | 0x0060 | bits[0:15] | | SIUL | PCR17 | 16 | 0x0062 | bits[0:15] | | SIUL | PCR18 | 16 | 0x0064 | bits[0:15] | | SIUL | PCR19 | 16 | 0x0066 | bits[0:15] | | SIUL | PCR20 | 16 | 0x0068 | bits[0:15] | | SIUL | PCR21 | 16 | 0x006A | bits[0:15] | | SIUL | PCR22 | 16 | 0x006C | bits[0:15] | | SIUL | PCR23 | 16 | 0x006E | bits[0:15] | | SIUL | PCR24 | 16 | 0x0070 | bits[0:15] | | SIUL | PCR25 | 16 | 0x0072 | bits[0:15] | | SIUL | PCR26 | 16 | 0x0074 | bits[0:15] | | SIUL | PCR27 | 16 | 0x0076 | bits[0:15] | | SIUL | PCR28 | 16 | 0x0078 | bits[0:15] | | SIUL | PCR29 | 16 | 0x007A | bits[0:15] | | SIUL | PCR30 | 16 | 0x007C | bits[0:15] | | SIUL | PCR31 | 16 | 0x007E | bits[0:15] | | SIUL | PCR32 | 16 | 0x0080 | bits[0:15] | | SIUL | PCR33 | 16 | 0x0082 | bits[0:15] | | SIUL | PCR48 | 16 | 0x00A0 | bits[0:15] | | SIUL | PCR49 | 16 | 0x00A2 | bits[0:15] | | SIUL | PCR50 | 16 | 0x00A4 | bits[0:15] | | SIUL | PCR51 | 16 | 0x00A6 | bits[0:15] | | SIUL | PCR52 | 16 | 0x00A8 | bits[0:15] | | SIUL | PCR53 | 16 | 0x00AA | bits[0:15] | | SIUL | PCR54 | 16 | 0x00AC | bits[0:15] | | SIUL | PCR55 | 16 | 0x00AE | bits[0:15] | | SIUL | PCR56 | 16 | 0x00B0 | bits[0:15] | | SIUL | PCR57 | 16 | 0x00B2 | bits[0:15] | | SIUL | PCR58 | 16 | 0x00B4 | bits[0:15] | | SIUL | PCR59 | 16 | 0x00B6 | bits[0:15] | | SIUL | PCR60 | 16 | 0x00B8 | bits[0:15] | | SIUL | PCR61 | 16 | 0x00BA | bits[0:15] | | SIUL | PCR62 | 16 | 0x00BC | bits[0:15] | | SIUL | PCR63 | 16 | 0x00BE | bits[0:15] | | SIUL | PCR64 | 16 | 0x00C0 | bits[0:15] | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |--------|----------|----------------------|-----------------|---------------------| | SIUL | PCR65 | 16 | 0x00C2 | bits[0:15] | | SIUL | PCR66 | 16 | 0x00C4 | bits[0:15] | | SIUL | PCR67 | 16 | 0x00C6 | bits[0:15] | | SIUL | PCR68 | 16 | 0x00C8 | bits[0:15] | | SIUL | PCR69 | 16 | 0x00CA | bits[0:15] | | SIUL | PCR70 | 16 | 0x00CC | bits[0:15] | | SIUL | PCR71 | 16 | 0x00CE | bits[0:15] | | SIUL | PCR72 | 16 | 0x00D0 | bits[0:15] | | SIUL | PCR73 | 16 | 0x00D2 | bits[0:15] | | SIUL | PCR74 | 16 | 0x00D4 | bits[0:15] | | SIUL | PCR75 | 16 | 0x00D6 | bits[0:15] | | SIUL | PCR76 | 16 | 0x00D8 | bits[0:15] | | SIUL | PCR77 | 16 | 0x00DA | bits[0:15] | | SIUL | PCR78 | 16 | 0x00DC | bits[0:15] | | SIUL | PCR79 | 16 | 0x00DE | bits[0:15] | | SIUL | PCR80 | 16 | 0x00E0 | bits[0:15] | | SIUL | PCR81 | 16 | 0x00E2 | bits[0:15] | | SIUL | PCR82 | 16 | 0x00E4 | bits[0:15] | | SIUL | PCR83 | 16 | 0x00E6 | bits[0:15] | | SIUL | PCR84 | 16 | 0x00E8 | bits[0:15] | | SIUL | PCR85 | 16 | 0x00EA | bits[0:15] | | SIUL | PCR86 | 16 | 0x00EC | bits[0:15] | | SIUL | PCR87 | 16 | 0x00EE | bits[0:15] | | SIUL | PCR88 | 16 | 0x00F0 | bits[0:15] | | SIUL | PCR89 | 16 | 0x00F2 | bits[0:15] | | SIUL | PCR90 | 16 | 0x00F4 | bits[0:15] | | SIUL | PCR91 | 16 | 0x00F6 | bits[0:15] | | SIUL | PCR92 | 16 | 0x00F8 | bits[0:15] | | SIUL | PCR93 | 16 | 0x00FA | bits[0:15] | | SIUL | PCR94 | 16 | 0x00FC | bits[0:15] | | SIUL | PCR95 | 16 | 0x00FE | bits[0:15] | | SIUL | PCR96 | 16 | 0x0100 | bits[0:15] | | SIUL | PCR97 | 16 | 0x0102 | bits[0:15] | | SIUL | PCR98 | 16 | 0x0104 | bits[0:15] | | SIUL | PCR99 | 16 | 0x0106 | bits[0:15] | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | | |--------|------------------|----------------------|-----------------|---------------------|--| | SIUL | PCR100 | 16 | 0x0108 | bits[0:15] | | | SIUL | PCR101 | 16 | 0x010A | bits[0:15] | | | SIUL | PCR102 | 16 | 0x010C | bits[0:15] | | | SIUL | PCR103 | 16 | 0x010E | bits[0:15] | | | SIUL | PCR104 | 16 | 0x0110 | bits[0:15] | | | SIUL | PCR105 | 16 | 0x0112 | bits[0:15] | | | SIUL | PCR106 | 16 | 0x0114 | bits[0:15] | | | SIUL | PCR107 | 16 | 0x0116 | bits[0:15] | | | SIUL | PSMI0_3 | 32 | 0x0500 | bits[0:31] | | | SIUL | PSMI4_7 | 32 | 0x0504 | bits[0:31] | | | SIUL | PSMI8_11 | 32 | 0x0508 | bits[0:31] | | | SIUL | PSMI12_15 | 32 | 0x050C | bits[0:31] | | | SIUL | PSMI28_31 | 32 | 0x051C | bits[0:31] | | | SIUL | PSMI32_35 | 32 | 0x0520 | bits[0:31] | | | SIUL | PSMI36_39 | 32 | 0x0524 | bits[0:31] | | | SIUL | IFMC0 | 32 | 0x1000 | bits[0:31] | | | SIUL | IFMC1 | 32 | 0x01004 | bits[0:31] | | | SIUL | IFMC2 | 32 | 0x1008 | bits[0:31] | | | SIUL | IFMC3 | 32 | 0x100C | bits[0:31] | | | SIUL | IFMC4 | 32 | 0x1010 | bits[0:31] | | | SIUL | IFMC5 | 32 | 0x1014 | bits[0:31] | | | SIUL | IFMC6 | 32 | 0x1018 | bits[0:31] | | | SIUL | IFMC7 | 32 | 0x101C | bits[0:31] | | | SIUL | IFMC8 | 32 | 0x1020 | bits[0:31] | | | SIUL | IFMC9 | 32 | 0x1024 | bits[0:31] | | | SIUL | IFMC10 | 32 | 0x1028 | bits[0:31] | | | SIUL | IFMC11 | 32 | 0x102C | bits[0:31] | | | SIUL | IFMC12 | 32 | 0x1030 | bits[0:31] | | | SIUL | IFMC13 | 32 | 0x1034 | bits[0:31] | | | SIUL | IFMC14 | 32 | 0x1038 | bits[0:31] | | | SIUL | IFMC15 32 0x103C | | 0x103C | bits[0:31] | | | SIUL | IFMC16 32 0x1040 | | bits[0:31] | | | | SIUL | IFMC17 32 0x1044 | | bits[0:31] | | | | SIUL | IFMC18 | 32 | 0x1048 | bits[0:31] | | | SIUL | IFMC19 | 32 | 0x104C | bits[0:31] | | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |--------|----------------|--------------------------------------------------|-----------------|---------------------| | SIUL | IFMC20 | 32 | 0x1050 | bits[0:31] | | SIUL | IFMC21 | IFMC21 32 | | bits[0:31] | | SIUL | IFMC22 | 32 | 0x1058 | bits[0:31] | | SIUL | IFMC23 | 32 | 0x105C | bits[0:31] | | SIUL | IFMC24 | 32 | 0x1060 | bits[0:31] | | SIUL | IFMC25 | 32 | 0x1064 | bits[0:31] | | SIUL | IFMC26 | 32 | 0x1068 | bits[0:31] | | SIUL | IFMC27 | 32 | 0x106C | bits[0:31] | | SIUL | IFMC28 | 32 | 0x1070 | bits[0:31] | | SIUL | IFMC29 | 32 | 0x1074 | bits[0:31] | | SIUL | IFMC30 | 32 | 0x1078 | bits[0:31] | | SIUL | IFMC31 | 32 | 0x107C | bits[0:31] | | SIUL | IFCP | 32 | 0x1080 | bits[0:31] | | | Power Manag | ement Unit—Base addre<br>1 register to protect | | | | PMU | VREG_CTL | 32 | 0x0000 | bits[0:31] | | | MC Mode | Entry—Base address: 0<br>36 registers to protect | | | | MC ME | ME_ME | 32 | 0x0008 | bits[0:31] | | MC ME | ME_IM | 32 | 0x0010 | bits[0:31] | | MC ME | ME_TEST_MC | 32 | 0x0024 | bits[0:31] | | MC ME | ME_SAFE_MC | 32 | 0x0028 | bits[0:31] | | MC ME | ME_DRUN_MC | 32 | 0x002C | bits[0:31] | | MC ME | ME_RUN0_MC | 32 | 0x0030 | bits[0:31] | | MC ME | ME_RUN1_MC | 32 | 0x0034 | bits[0:31] | | MC ME | ME_RUN2_MC | 32 | 0x0038 | bits[0:31] | | MC ME | ME_RUN3_MC | 32 | 0x003C | bits[0:31] | | MC ME | ME_HALT0_MC | 32 | 0x0040 | bits[0:31] | | MC ME | ME_STOP0_MC 32 | | 0x0048 | bits[0:31] | | MC ME | ME_RUN_PC0 | 32 | 0x0080 | bits[0:31] | | MC ME | ME_RUN_PC1 | 32 | 0x0084 | bits[0:31] | | MC ME | ME_RUN_PC2 | 32 | 0x0088 | bits[0:31] | | MC ME | ME_RUN_PC3 | 32 | 0x008C | bits[0:31] | | MC ME | ME_RUN_PC4 | 32 | 0x0090 | bits[0:31] | | MC ME | ME_RUN_PC5 | 32 | 0x0094 | bits[0:31] | Table 633. Registers under protection(Continued) | Module | Register | Registers under protec | Register offset | Protected bitfields | |---------|----------------------|--------------------------------------------------|-----------------|---------------------| | MC ME | ME RUN PC6 | 32 | 0x0098 | bits[0:31] | | MC ME | ME_RUN_PC7 32 0x009C | | bits[0:31] | | | MC ME | ME_LP_PC0 | 32 | 0x00A0 | bits[0:31] | | MC ME | ME_LP_PC1 | 32 | 0x00A4 | bits[0:31] | | MC ME | ME_LP_PC2 | 32 | 0x00A8 | bits[0:31] | | MC ME | ME_LP_PC3 | 32 | 0x00AC | bits[0:31] | | MC ME | ME_LP_PC4 | 32 | 0x00B0 | bits[0:31] | | MC ME | ME_LP_PC5 | 32 | 0x00B4 | bits[0:31] | | MC ME | ME_LP_PC6 | 32 | 0x00B8 | bits[0:31] | | MC ME | ME_LP_PC7 | 32 | 0x00BC | bits[0:31] | | MC ME | ME_PCTL[47] | 32 | 0x00C4 | bits[0:31] | | MC ME | ME_PCTL[1619] | 32 | 0x00D0 | bits[0:31] | | MC ME | ME_PCTL[2427] | 32 | 0x00D8 | bits[0:31] | | MC ME | ME_PCTL[3235] | 32 | 0x00E0 | bits[0:31] | | MC ME | ME_PCTL[3639] | 32 | 0x00E4 | bits[0:31] | | MC ME | ME_PCTL[4043] | 32 | 0x00E8 | bits[0:31] | | MC ME | ME_PCTL[4851] | 32 | 0x00F0 | bits[0:31] | | MC ME | ME_PCTL[8487] | 32 | 0x0114 | bits[0:31] | | MC ME | ME_PCTL[9295] | 32 | 0x011C | bits[0:31] | | | MC Clock Gene | ration Module—Base add<br>8 registers to protect | <del>-</del> | | | MC CGM | CGM_OC_EN | 8 | 0x0370 | bits[0:7] | | MC CGM | CGM_OCDS_SC | 8 | 0x0374 | bits[0:7] | | MC CGM | CGM_AC0_SC | 8 | 0x0380 | bits[0:31] | | MC CGM | CGM_AC0_DC[03] | 8 | 0x0384 | bits[0:31] | | MC CGM | CGM_AC1_SC | 8 | 0x0388 | bits[0:31] | | MC CGM | CGM_AC1_DC[03] | 8 | 0x038C | bits[0:31] | | MC CGM | CGM_AC2_SC | 8 | 0x0390 | bits[0:31] | | MC CGM | CGM_AC2_DC[03] | 8 | 0x0394 | bits[0:31] | | | XOS | 6C—Base address: 0xC3<br>1 register to protect | | | | XOSC | OSC_CTL | 32 | 0x0000 | bits[0:31] | | | IRC_C | DSC—Base address: 0xC<br>1 register to protect | 3FE_0060 | | | IRC_OSC | RC_CTL | 32 | 0x0000 | bits[0:31] | | - | | | | | Table 633. Registers under protection(Continued) | Table 633. Registers under protection(Continued) | | | | | | |--------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------|-----------------|---------------------|--| | Module | Register | Register size (bits) | Register offset | Protected bitfields | | | | FM PLL 0—Base address: 0xC3FE_00A0 2 registers to protect | | | | | | FMPLL 0 | CR | 32 | 0x0000 | bits[0:31] | | | FMPLL 0 | MR | 32 | 0x0004 | bits[0:31] | | | | CMU 0—Base address: 0xC3FE_0100<br>1 register to protect | | | | | | CMU 0 | CMU_CSR | 32 | 0x0000 | bits[0:31] | | | | CMU | 1 1—Base address: 0xC3<br>1 register to protect | <del>_</del> | | | | CMU 1 | CMU_CSR | 32 | 0x0000 | bits[0:31] | | | | MC Reset Gene | ration Module—Base add<br>6 registers to protect | _ | | | | MC RGM | RGM_FERD | 16 | 0x0004 | bits[0:15] | | | MC RGM | RGM_DERD | 16 | 0x0006 | bits[0:15] | | | MC RGM | RGM_FEAR | 16 | 0x0010 | bits[0:15] | | | MC RGM | RGM_DEAR | 16 | 0x0012 | bits[0:15] | | | MC RGM | RGM_FESS | 16 | 0x0018 | bits[0:15] | | | MC RGM | RGM_FBRE | 16 | 0x001C | bits[0:15] | | | | PIT_I | RTI—Base address: 0xC3<br>9 registers to protect | | | | | PIT_RTI | PIT_RTI_PITMCR | 32 | 0x0000 | 32-bit | | | PIT_RTI | PIT_RTI_LDVAL0 | 32 | 0x0100 | 32-bit | | | PIT_RTI | PIT_RTI_TCTRL0 | 32 | 0x0108 | 32-bit | | | PIT_RTI | PIT_RTI_LDVAL1 | 32 | 0x0110 | 32-bit | | | PIT_RTI | PIT_RTI_TCTRL1 | 32 | 0x0118 | 32-bit | | | PIT_RTI | PIT_RTI_LDVAL2 | 32 | 0x0120 | 32-bit | | | PIT_RTI | PIT_RTI_TCTRL2 | 32 | 0x0128 | 32-bit | | | PIT_RTI | PIT_RTI_LDVAL3 | 32 | 0x0130 | 32-bit | | | PIT_RTI | PIT_RTI_TCTRL3 | 32 | 0x0138 | 32-bit | | | | ADC 0—Base address: 0xFFE0_0000 10 registers to protect | | | | | | ADC 0 | CLR0 | 32 | 0x0000 | 32-bit | | | ADC 0 | CLR1 | 32 | 0x0004 | 32-bit | | | ADC 0 | CLR2 | 32 | 0x0008 | 32-bit | | | ADC 0 | CLR3 | 0x000C | 32-bit | | | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |----------|---------------------------|---------------------------------------------------|-----------------|---------------------| | ADC 0 | CLR4 | 32 | 0x0010 | 32-bit | | ADC 0 | TRC0 | TRC0 32 0x0034 | | 32-bit | | ADC 0 | TRC1 | 32 | 0x0038 | 32-bit | | ADC 0 | TRC2 | 32 | 0x003C | 32-bit | | ADC 0 | TRC3 | 32 | 0x0040 | 32-bit | | ADC 0 | PREREG | 32 | 0x00A8 | 32-bit | | | eTimo | er 0—Base address: 0xF<br>24 registers to protec | | | | eTimer 0 | CH0_CTRL | 16 | 0x000E | 16-bit | | eTimer 0 | CH0_CTRL2 | 16 | 0x0010 | 16-bit | | eTimer 0 | CH0_CTRL3 | 16 | 0x0012 | 16-bit | | eTimer 0 | CH0_CCCTRL | 16 | 0x001C | 16-bit | | eTimer 0 | CH1_CTRL | 16 | 0x002E | 16-bit | | eTimer 0 | CH1_CTRL2 | 16 | 0x0030 | 16-bit | | eTimer 0 | CH1_CTRL3 | 16 | 0x0032 | 16-bit | | eTimer 0 | CH1_CCCTRL | 16 | 0x003C | 16-bit | | eTimer 0 | CH2_CTRL | 16 | 0x004E | 16-bit | | eTimer 0 | CH2_CTRL2 | 16 | 0x0050 | 16-bit | | eTimer 0 | CH2_CTRL3 16 0x0052 | | 0x0052 | 16-bit | | eTimer 0 | er 0 CH2_CCCTRL 16 0x005C | | 0x005C | 16-bit | | eTimer 0 | CH3_CTRL | 16 | 0x006E | 16-bit | | eTimer 0 | CH3_CTRL2 | 16 | 0x0070 | 16-bit | | eTimer 0 | CH3_CTRL3 | 16 | 0x0072 | 16-bit | | eTimer 0 | CH3_CCCTRL | 16 | 0x007C | 16-bit | | eTimer 0 | CH4_CTRL | 16 | 0x008E | 16-bit | | eTimer 0 | CH4_CTRL2 | 16 | 0x0090 | 16-bit | | eTimer 0 | CH4_CTRL3 | 16 | 0x0092 | 16-bit | | eTimer 0 | CH4_CCCTRL | 16 | 0x009C | 16-bit | | eTimer 0 | CH5_CTRL | 16 | 0x00AE | 16-bit | | eTimer 0 | CH5_CTRL2 | 16 | 0x00B0 | 16-bit | | eTimer 0 | CH5_CTRL3 16 0x00B2 | | 16-bit | | | eTimer 0 | CH5_CCCTRL | 16 | 0x00BC | 16-bit | | | eTime | er 1—Base address: 0xFl<br>24 registers to protec | _ | | | eTimer 1 | CH0_CTRL | 16 | 0x000E | 16-bit | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |----------|------------|--------------------------------------------------|-----------------|---------------------| | eTimer 1 | CH0_CTRL2 | 16 | 0x0010 | 16-bit | | eTimer 1 | CH0_CTRL3 | 16 | 0x0012 | 16-bit | | eTimer 1 | CH0_CCCTRL | 16 | 0x001C | 16-bit | | eTimer 1 | CH1_CTRL | 16 | 0x002E | 16-bit | | eTimer 1 | CH1_CTRL2 | 16 | 0x0030 | 16-bit | | eTimer 1 | CH1_CTRL3 | 16 | 0x0032 | 16-bit | | eTimer 1 | CH1_CCCTRL | 16 | 0x003C | 16-bit | | eTimer 1 | CH2_CTRL | 16 | 0x004E | 16-bit | | eTimer 1 | CH2_CTRL2 | 16 | 0x0050 | 16-bit | | eTimer 1 | CH2_CTRL3 | 16 | 0x0052 | 16-bit | | eTimer 1 | CH2_CCCTRL | 16 | 0x005C | 16-bit | | eTimer 1 | CH3_CTRL | 16 | 0x00x006E | 16-bit | | eTimer 1 | CH3_CTRL2 | 16 | 0x0070 | 16-bit | | eTimer 1 | CH3_CTRL3 | 16 | 0x0072 | 16-bit | | eTimer 1 | CH3_CCCTRL | 16 | 0x007C | 16-bit | | eTimer 1 | CH4_CTRL | 16 | 0x008E | 16-bit | | eTimer 1 | CH4_CTRL2 | 16 | 0x0090 | 16-bit | | eTimer 1 | CH4_CTRL3 | 16 | 0x0092 | 16-bit | | eTimer 1 | CH4_CCCTRL | 16 | 0x009C | 16-bit | | eTimer 1 | CH5_CTRL | 16 | 0x00AE | 16-bit | | eTimer 1 | CH5_CTRL2 | 16 | 0x00B0 | 16-bit | | eTimer 1 | CH5_CTRL3 | 16 | 0x00B2 | 16-bit | | eTimer 1 | CH5_CCCTRL | 16 | 0x00BC | 16-bit | | | CRC | _0—Base address: 0xFF<br>3 registers to protec | | | | CRC_0 | CRC0_CFG0 | 32 | 0x0000 | 16-bit | | CRC_0 | CRC0_CFG1 | 32 | 0x0010 | 16-bit | | CRC_0 | CRC0_CFG2 | 32 | 0x0020 | 16-bit | | | CRO | 2_1—Base address: 0x9F<br>3 registers to protec | | | | CRC_1 | CRC1_CFG0 | 32 | 0x0000 | 16-bit | | CRC_1 | CRC1_CFG1 | 32 | 0x0010 | 16-bit | | CRC_1 | CRC1_CFG2 | 32 | 0x0020 | 16-bit | | | DSP | I 0—Base address: 0xFF<br>11 registers to protec | _ | | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |--------|------------|--------------------------------------------------|-----------------|---------------------| | DSPI 0 | DSPI_MCR | 32 | 0x0000 | 32-bit | | DSPI 0 | DSPI_TCR | 32 | 0x0008 | 32-bit | | DSPI 0 | DSPI_CTAR0 | 32 | 0x000C | 32-bit | | DSPI 0 | DSPI_CTAR1 | 32 | 0x0010 | 32-bit | | DSPI 0 | DSPI_CTAR2 | 32 | 0x0014 | 32-bit | | DSPI 0 | DSPI_CTAR3 | 32 | 0x0018 | 32-bit | | DSPI 0 | DSPI_CTAR4 | 32 | 0x001C | 32-bit | | DSPI 0 | DSPI_CTAR5 | 32 | 0x0020 | 32-bit | | DSPI 0 | DSPI_CTAR6 | 32 | 0x0024 | 32-bit | | DSPI 0 | DSPI_CTAR7 | 32 | 0x0028 | 32-bit | | DSPI 0 | DSPI_RSER | 32 | 0x0030 | 32-bit | | | DSP | I 1—Base address: 0xFF<br>11 registers to protec | | | | DSPI 1 | DSPI_MCR | 32 | 0x0000 | 32-bit | | DSPI 1 | DSPI_TCR | 32 | 0x0008 | 32-bit | | DSPI 1 | DSPI_CTAR0 | 32 | 0x000C | 32-bit | | DSPI 1 | DSPI_CTAR1 | 32 | 0x0010 | 32-bit | | DSPI 1 | DSPI_CTAR2 | 32 | 0x0014 | 32-bit | | DSPI 1 | DSPI_CTAR3 | 32 | 0x0018 | 32-bit | | DSPI 1 | DSPI_CTAR4 | 32 | 0x001C | 32-bit | | DSPI 1 | DSPI_CTAR5 | 32 | 0x0020 | 32-bit | | DSPI 1 | DSPI_CTAR6 | 32 | 0x0024 | 32-bit | | DSPI 1 | DSPI_CTAR7 | 32 | 0x0028 | 32-bit | | DSPI 1 | DSPI_RSER | 32 | 0x0030 | 32-bit | | | DSP | I 2—Base address: 0xFF<br>11 registers to protec | | | | DSPI 2 | DSPI_MCR | 32 | 0x0000 | 32-bit | | DSPI 2 | DSPI_TCR | 32 | 0x0008 | 32-bit | | DSPI 2 | DSPI_CTAR0 | 32 | 0x000C | 32-bit | | DSPI 2 | DSPI_CTAR1 | 32 | 0x0010 | 32-bit | | DSPI 2 | DSPI_CTAR2 | 32 | 0x0014 | 32-bit | | DSPI 2 | DSPI_CTAR3 | 32 | 0x0018 | 32-bit | | DSPI 2 | DSPI_CTAR4 | 32 | 0x001C | 32-bit | | DSPI 2 | DSPI_CTAR5 | 32 | 0x0020 | 32-bit | | DSPI 2 | DSPI_CTAR6 | 32 | 0x0024 | 32-bit | Table 633. Registers under protection(Continued) | Module | Register | Registers under protection Register size (bits) | Register offset | Protected bitfields | |-----------|---------------|--------------------------------------------------|-----------------|---------------------| | DSPI 2 | DSPI_CTAR7 | 32 | 0x0028 | 32-bit | | DSPI 2 | DSPI RSER | 32 | 0x0030 | 32-bit | | | DSP | I 3—Base address: 0xFF<br>11 registers to protec | _ | | | DSPI 3 | DSPI_MCR | 32 | 0x0000 | 32-bit | | DSPI 3 | DSPI_TCR | 32 | 0x0008 | 32-bit | | DSPI 3 | DSPI_CTAR0 | 32 | 0x000C | 32-bit | | DSPI 3 | DSPI_CTAR1 | 32 | 0x0010 | 32-bit | | DSPI 3 | DSPI_CTAR2 | 32 | 0x0014 | 32-bit | | DSPI 3 | DSPI_CTAR3 | 32 | 0x0018 | 32-bit | | DSPI 3 | DSPI_CTAR4 | 32 | 0x001C | 32-bit | | DSPI 3 | DSPI_CTAR5 | 32 | 0x0020 | 32-bit | | DSPI 3 | DSPI_CTAR6 | 32 | 0x0024 | 32-bit | | DSPI 3 | DSPI_CTAR7 | 32 | 0x0028 | 32-bit | | DSPI 3 | DSPI_RSER | 32 | 0x0030 | 32-bit | | | DSP | I 4—Base address: 0x8F<br>11 registers to protec | | | | DSPI 4 | DSPI_MCR | 32 | 0x0000 | 32-bit | | DSPI 4 | DSPI_TCR | 32 | 0x0008 | 32-bit | | DSPI 4 | DSPI_CTAR0 | 32 | 0x000C | 32-bit | | DSPI 4 | DSPI_CTAR1 | 32 | 0x0010 | 32-bit | | DSPI 4 | DSPI_CTAR2 | 32 | 0x0014 | 32-bit | | DSPI 4 | DSPI_CTAR3 | 32 | 0x0018 | 32-bit | | DSPI 4 | DSPI_CTAR4 | 32 | 0x001C | 32-bit | | DSPI 4 | DSPI_CTAR5 | 32 | 0x0020 | 32-bit | | DSPI 4 | DSPI_CTAR6 | 32 | 0x0024 | 32-bit | | DSPI 4 | DSPI_CTAR7 | 32 | 0x0028 | 32-bit | | DSPI 4 | DSPI_RSER | 32 | 0x0030 | 32-bit | | | FlexCA | AN_0—Base address: 0x<br>7 registers to protec | | | | FlexCAN_0 | CANx_MCR | 32 | 0x0000 | 32-bit | | FlexCAN_0 | CANx_CTRL | 32 | 0x0004 | 32-bit | | FlexCAN_0 | CANx_RXGMASK | 32 | 0x0010 | 32-bit | | FlexCAN_0 | CANx_RX14MASK | 32 | 0x0014 | 32-bit | | FlexCAN_0 | CANx_RX15MASK | 32 | 0x0018 | 32-bit | | | | | | | Table 633. Registers under protection(Continued) | Module | Register | Register size (bits) | Register offset | Protected bitfields | |-------------|------------------|--------------------------------------------------|-----------------|---------------------| | FlexCAN_0 | CANx_IMASK2 | 32 | 0x0024 | 32-bit | | FlexCAN_0 | CANx_IMASK | 32 | 0x0028 | 32-bit | | | FlexCA | AN_1—Base address: 0xi<br>7 registers to protect | _ | | | FlexCAN_1 | CANx_MCR | 32 | 0x0000 | 32-bit | | FlexCAN_1 | CANx_CTRL | 32 | 0x0004 | 32-bit | | FlexCAN_1 | CANx_RXGMASK | 32 | 0x0010 | 32-bit | | FlexCAN_1 | CANx_RX14MASK | 32 | 0x0014 | 32-bit | | FlexCAN_1 | CANx_RX15MASK | 32 | 0x0018 | 32-bit | | FlexCAN_1 | CANx_IMASK2 | 32 | 0x0024 | 32-bit | | FlexCAN_1 | CANx_IMASK | 32 | 0x0028 | 32-bit | | | Flexi | Ray—Base address: 0xFF<br>1 register to protect | _ | | | FlexRay | MCR | 16 | 0x0002 | 16-bit | | | Safety | Port—Base address: 0xl<br>7 registers to protect | | | | Safety port | CANx_MCR | 32 | 0x0000 | 32-bit | | Safety port | CANx_CTRL | 32 | 0x0004 | 32-bit | | Safety port | CANx_RXGMASK | 32 | 0x0010 | 32-bit | | Safety port | CANx_RX14MASK 32 | | 0x0014 | 32-bit | | Safety port | CANx_RX15MASK | 32 | 0x0018 | 32-bit | | Safety port | CANx_IMASK2 | 32 | 0x0024 | 32-bit | | Safety port | CANx_IMASK | 32 | 0x0028 | 32-bit | Table 634. Document revision history | Date | Revision | Changes | |-------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 08-Apr-2011 | 1 | Initial release | | | | | | | | <ul> <li>Added "Core_1 switching off" section.</li> <li>In the "Clock Generation Module (MC_CGM)" chapter: — In the "MC_CGM Memory Map" table: added CMU1 register added CLK_DIV256 register</li> <li>In the Interrupt Controller (INTC)" chapter: — Removed Platform Flash Bank (2,3) abort and Platform Flash Bank (2,3) stall from Interrupt vector table. — Replaced "INTC block diagram" figure. — Replaced "Interrupt Vector" table.</li> <li>In the "System Status and Configuration Module (SSCM)" chapter: — Removed DMA status from feature list. — Added DPMBOOT, DPMKEY, UOPS, and PSA registers. — In the STATUS register, added CER, NXEN1, and VLE field descriptions.</li> </ul> | Table 634. Document revision history | Date | Revision | Changes | |-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | In the "System Integration Unit Lite (SIUL)" chapter: | | | | - Replaced PSMI[0_3:32_35] with PSMI[0_3:36_39] through the chapter. | | | | <ul> <li>Updated "Pad selection" table.</li> </ul> | | | | - In the "System Integration Unit Lite block diagram" figure, replaced 106 wth 108. | | | | In the "e200z0 and e200z0h Core" chapter: | | | | Added "e200z0h Supervisor mode programmer's model" figure. | | | | Replaced "Peripheral Bridge (PBRIDGE)" chapter. | | | | Replaced "Crossbar Switch (XBAR)" chapter. | | | | In the "Error Correction Status Module (ECSM)" chapter: | | | | <ul> <li>In the "Introduction" section, removed "It also provides with register access<br/>protection for the following slave modules: INTC, ECSM, STM, and SWT"<br/>sentence.</li> </ul> | | | | <ul> <li>In the "Features" section, removed "Capability to restrict register access to<br/>supervisor mode to selected on-platform slave devices: INTC, ECSM, STM, and<br/>SWT" bullet.</li> </ul> | | | | Updated MUDCR register, Removed MUDCR[31] and added MUDCR[30] | | | | <ul> <li>Updated contents of "RAM syndrome mapping for single-bit correctable errors"<br/>table.</li> </ul> | | | | - Removed "ECSM_reg_protection" section. | | 29-Jun-2011 | 2<br>(cont.) | In the "Flash Memory" chapter: | | | | <ul> <li>Updated "SPC56xP60x/54x Flash memory architecture" figure.</li> </ul> | | | | - In the "Code Flash module structure" figure, added "Filter Cap" block. | | | | In the "LIN Controller (LINFlex)" chapter: | | | | <ul> <li>In the "Introduction" and "Main features" sections, removed LIN protocol versions</li> <li>2.1 and J2602 because not supported.</li> </ul> | | | | In the "FlexCAN" chapter: | | | | - In the "FlexCAN block diagram" figure: | | | | replaced "64/128/256-byte RAM" with "128-byte RAM" replaced "288/544/1056-byte RAM" with "544-byte RAM" | | | | - In the "FlexCAN memory mapping" section, removed reference to 16 MB | | | | configuration. - In the "FlexCAN module memory map" table, "0x8FFC_0000 (CAN_1)" with | | | | "0x8FFC_4000 (CAN_1)". — In the "Module Configuration Register (MCR)" section: | | | | Removed WAK_MSW field. | | | | <ul> <li>In the SOTF_RST field description, replaced RXIMR0–RXIMR63 with RXIMR0–<br/>RXIMR32.</li> </ul> | | | | - In the "Error and Status Register (ESR)" register, removed WAK_INT bit field. | | | | - In the "Interrupts" section, add a footnote about wakeup interrupt. | | | | <ul> <li>In the "FlexCAN initialization sequence" section, removed paragraphs concerning<br/>SOFT_RST.</li> </ul> | Table 634. Document revision history | Date | Revision | Changes | |-------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 29-Jun-2011 | 2 (cont.) | In the "Analog-to-Digital Converter (ADC)" chapter: - Update the chapter in order to have 27 internal precision channels. In the "Cross Triggering Unit (CTU)" chapter: - In the "Introduction" section, removed the first paragraph. - Replaced "ADC commands translation" table. - In the "ADC results" section, for FIFO1 and FIFO2 there are only 4 entries instead of 16. In the "Semaphore Unit (SEMA4)": - in the "introduction" section, removed the paragraph regarding dual processor mode and Lock Step mode because SPC56xP60/54 operates in Decoupled Parallel Mode (DPM) only. Replaced "Fault Collection and Control Unit (FCCU)" chapter. In the "Cyclic Redundancy Check (CRC)": - In the "CRC top level pinout" table, added "crc_compare_error" row. - Added CRC_OUTP_CHK register. - In the CRC_CFG register: added LEN bit fiked made POLYG bit fiked 2 bits long - In the "DMA-CRC Transmission Sequence" figure, replaced CPU with DMA in the phase 3 scheme. - Updated "DMA-CRC Reception Sequence" figure. In the "Voltage Regulators and Power Supplies" chapter: - Replaced "Five VDD_LV/VSS_LV pins pairs" with "Four VDD_LV/VSS_LV pins pairs". In the "IEEE 1149.1 Test Access Port Controller (JTAGC)" chapter: - In the "JTAG instruction" table, added: ACCESS_AUX_TAP_CORE0, ACCESS_AUX_TAP_CORE1, ACCESS_AUX_TAP_NASPS_0, and ACCESS_AUX_TAP_NASPS_1 rows. In the "TAP sharing mode" section replaced ACCESS_AUX_TAP_ONCE with "ACCESS_AUX_TAP_CORE0, ACCESS_AUX_TAP_NASPS_1". | Table 634. Document revision history | Date | Revision | Changes | |------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Date 06-Jun-2012 | Revision | Chapter 1: Introduction Section 1.7.5: On-chip SRAM with ECC: replaced two occurrences of "3 wait states" to "2 wait states" replaced 60 MHz to 64 MHz Chapter 2: Memory Map Table 4: Memory map: changed the "End address" and the "Size" values of SRAM added footnote about "On-chip Peripherals" changed the start address from "0x8FF7_4000" to "0x9FE7_4000" Chapter 4: Clock Description Added registers for CMU_1 Replaced all occurrences of "FMPLL_1" with "SYS_CLK" Figure 7: SPC56xP60x/54x system clock generation, changed FMPLL_1D1_CLK to FMPLL_0_D1_CLK and added "FMPLL_0_D1_CLK—80 MHz, 50%" Updated Section 4.10.3.2: PLL clock monitor Updated Section 4.10.3.3: System clock monitor Table 13: OSC_CTL memory map,removed access and reset columns per new agreement Table 15: FMPLL memory map,removed access and reset columns per new agreement Table 20: CMU memory map,removed access and reset columns per new agreement Figure 9: SPC56xP60x/54x system clock distribution Part B, replaced "Magic Carpet" with proper content Figure 18: SPC56xP60x/54x with two CMUs, replaced "Magic Carpet" with proper content. Section 4.10.4.3: High Frequency Reference Register FMPLL_0 (CMU_0_HFREFR_0), replaced CMU_0_HFREFR_A with CMU_0_HFREFR_0 Section 4.10.4.4: Low Frequency Reference Register FMPLL_0 (CMU_0_HFREFR_0), replaced CMU_0_HFREFR_A with CMU_0_HFREFR_0. Chapter 6: Mode Entry Module (MC_ME) Table 63: Debug Mode Transition Status Register (ME_DMTS) Field Descriptions, added description of SCSRC_SC bit field Chapter 8: Reset Generation Module (MC_RGM) Replaced all occurrences of RESET_B to RESET_Table 66: MC_RGM Memory Map, removed D_COMP entry. Chapter 7: Power Control Unit (MC_PCU) | | | | Chapter 7: Power Control Unit (MC_PCU) Added PCU_PCONF0, VREG_VCTL and VREG_STATUS Chapter 9: Interrupt Controller (INTC) Through whole chapter, renamed "INTC_PSR260" (was NTC_PSR258_260) Chapter 10: System Status and Configuration Module (SSCM) Table 99: DPMKEY Field Descriptions, added a footnote about reset value of VLE bit field. | Table 634. Document revision history | Date | Revision | , | |-------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24.0 | 1101101011 | · · · · · · · · · · · · · · · · · · · | | Date 06-Jun-2012 | Revision 3 (cont.) | Changes Chapter 11: System Integration Unit Lite (SIUL) Table 104: MIDR1 field descriptions, in the PARTNUM description: replaced "0101_0110_0000_0100: 512 KB" with "0101_0110_0000_0101: 768 KB" added single/dual core details Added Table 113: PCR bit implementation by pad type Figure 120: Parallel GPIO Pad Data Out register 0-3(PGPDO[0:3]), changed offset of PGPDO2 to 0x0C08 Table 104: MIDR1 field descriptions, in the PARTNUM description, added single/dual core details Chapter 13: Peripheral Bridge (PBRIDGE) Table 123: PBRIDGE registers, removed access and reset columns per new agreement Table 124: PBRIDGE memory map, added reserved area from 0x0030 to 0x003F Chapter 14: Crossbar Switch (XBAR) Table 133: XBAR register configuration summary, changed column description (was "XBAR base offset", is "Offset from XBAR_BASE (0xFFF0_4000)") Chapter 16: Internal Static RAM (SRAM) Table 162: SRAM memory map, added a column Chapter 17: Flash Memory Figure 170: Data Flash module structure, changed "Test Sector" size from 16K to 8K Table 164: Flash-related regions in the system memory map, changed "Data Flash Array 0 Test Sector" size from 16K to 8K Table 171: TestFlash structure, changed reserved area for "Code TestFlash" Table 174: Flash registers, added note for UT2, UMISR2, UMISR3 and UMISR4 registers Table 176: Flash 64 KB bank1 register map, replaced UT2, UMISR2, UMISR3 and UMISR4 registers with reserved space Section 17.3.2: Main features, removed "One Time Programmable (OTP) area in TestFlash block" Figure 182: Platform Flash Configuration Register 0 (PFCR0) updated reset value Table 186: PFCR0 field descriptions: updated bit filed name of bit 15, 16, and 24, respectively BK0_RWWC2, BK0_RWWC1, and BK0_RWWC0 added B0_P1_BCFG, B0_P1_DPFE, B0_P1_PFE, B0_P1_PFLM, and | | | | Section 17.3.2: Main features, removed "One Time Programmable (OTP) area in TestFlash block" Figure 182: Platform Flash Configuration Register 0 (PFCR0) updated reset value Table 186: PFCR0 field descriptions: updated bit filed name of bit 15, 16, and 24, respectively BK0_RWWC2, | | | | | | | | updated bit filed name of bit 15, 16, and 24, respectively BK1_RWWC2, BK1_RWWC1, and BK1_RWWC0 updated reset value | | | | Table 202: NVUSRO field descriptions: in the WATCHDOG_EN description, added a note "The WATCHDOG_EN bit is available only for SWT_0" removed OSCILLATOR_MARGIN field and updated UOx bit fields | | | | Figure 198: Non-Volatile User Options register (NVUSRO): removed OSCILLATOR_MARGIN bit | Table 634. Document revision history | Date | Revision | Changes | |-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 06-Jun-2012 | 3<br>(cont.) | Added note in Section 17.3.7.14: User Test 2 register (UT2), Section 17.3.7.17: User Multiple Input Signature Register 3 (UMISR3) and Section 17.3.7.19: User Multiple Input Signature Register 4 (UMISR4) Renamed Section 17.3.8: Code Flash programming considerations (was "Programming considerations") Section 17.2.4: Memory map and registers description, added a note Chapter 19: Enhanced Direct Memory Access (eDMA) Through whole chapter, replaced all occurrences of "EDMA_CERR" with "EDMA_CER" Renamed Figure 213: eDMA Enable Request Register (EDMA_ERQRL) (was "eDMA Enable Request Low Register (EDMA_ERQRL)") Renamed Figure 214: eDMA Enable Error Interrupt Register (EDMA_EEIRL) (was "eDMA Enable Error Interrupt Low Register (EDMA_EEIRL)") Chapter 23: LIN Controller (LINFlex) Figure 419: LIN status register (LINSR), changed LINS access from read/write to write only Figure 424: LIN output compare register (LINOCR), changed note from LINTCSR[LTOM] = 1 to LINTCSR[LTOM] = 0 Added Section 23.8.2.3.2: Dentifier filter mode configuration, changed sentence "the filter must first be deactivated by programming IFER[FACT] = 0" with "the filter must first be activated by programming IFER[FACT] = 1" Section 23.8.2.3: Lidentifier filter mode configuration method now is a section 23.8.2.3: Line timeout mode, changed sentence "ergogramming LINTCSR[LTOM] = 1 enables the output compare mode" Section 23.8.2.3: Line timeout mode, changed sentence "Programming LINTCSR[LTOM] = 0 enables the output compare mode" Section 23.8.3: Line timeout mode, changed sentence "Programming LINTCSR[LTOM] = 0 enables the output compare mode" Section 23.8.3: Line timeout mode, changed sentence "Programming LINTCSR[LTOM] = 0 enables the output compare mode" Section 23.7.1.7: Identifier filter enable register (IFER): Figure 433: Identifier filter enable register (IFER): Figure 433: Identifier filter enable register (IFER): Figure 435: Identifier filter control register (IFER): Figure 437: Identifier filter control register (IFER): Figure 437: Identifier fi | **Table 634. Document revision history** | Date | Revision | Changes | |-------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Date 06-Jun-2012 | Revision 3 (cont.) | Chapter 25: Analog-to-Digital Converter (ADC) Renamed Section 25.3.6.2: Analog watchdog functionality (was "Analog watchdog pulse width modulation bus") and reworded the section Table 472: CDR field descriptions, removed improper cross-references to conditional content for CDATA field Section 25.3.9: Power-down mode, replaced sentence: "If the CTU is enabled and the CSR[CTUSTART] bit is '1', then the MCR[PWDN] bit cannot be set." with "If the CTU is enabled and the MSR[CTUSTART] bit is '1', then the MCR[PWDN] bit cannot be set. Chapter 26: Cross Triggering Unit (CTU) Section 26.4.3: ADC results, replaced "FIFO1 and FIFO2—4 entries" with "FIFO1 and FIFO2—16 entries" Section 26.8.21: Cross triggering unit control register (CTUCR), changed CRU_ADC_R to CTU_ADC_R Table 501: CTUCR field descriptions, added notes for DFE, CGRE, GRE, and TGSISR_RE bit fields. Chapter 28: eTimer Figure 546: DMA Request 0 Select register (DREQ0), changed bit 0 to DREW0_EN Figure 547: DMA Request 1 Select register (DREQ1), changed bit 0 to DREW1_EN Table 530: DREQn field descriptions, added DREW1_EN description Section 28.6.2.13: Comparator Load register 1 (CMPLD1), modified the description of CMPLD field to read, "Specifies the preload value for the COMP1 register" instead of "Specifies the preload value for the COMP1 register" instead of "Specifies the preload value for the COMP2 register" Chapter 29: Functional Safety Section 29.3.5.1: SWT Control Register (SWT_CR), specified reset value for SWT_1. | | | | Table 546: FCCU memory map, in the access description of FCCU_CFG_TO register, changed "R always; W in CONFIG state only" to "R always; W always except CONFIG state" Chapter 33: System Timer Module (STM) Table 586: STM memory map, updated offset values of STM_CCR1, STM_CIR1 and STM_CMP1 Chapter 35: Boot Assist Module (BAM) Table 599: Hardware configuration to select boot mode: rewrote the column title from "ABS[2,0]" to ABS[1:0] removed footnote stating ABS[1] is "don't care" added footnote, "During reset the boot configuration pins are weak pull down. Table 600: SPC56xP60x/54x boot pins, changed the function of A[3], from ABS[2] to ABS[1]. Section 35.5.1: Entering boot modes: Added PAD A[2] note Added the Boot Configuration Pins Added Section 35.5.2: SPC56xP60x/54x boot pins Updated Section 35.5.6.1: Configuration with new Figure 644: BAM Autoscan code flow Section 35.6.1.3: Boot from FlexCAN with autobaud enabled, updated "UART boot mode" with "FlexCAN boot mode". Added Section 35.7: Censorship | Table 634. Document revision history | Table 634. Document revision history | | | | |--------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Date | Revision | Changes | | | 06-Jun-2012 | 3<br>(cont.) | Chapter 36: Voltage Regulators and Power Supplies Updated Section 36.1.1: High Power or Main Regulator (HPREG) Figure 652: Voltage Regulator Control register (VREG_CTL), changed address value to 0xC3FE_8080 Figure 653: Voltage Regulator Status register (VREG_STATUS), changed address value to 0xC3FE_8084 Chapter 37: IEEE 1149.1 Test Access Port Controller (JTAGC) Section 37.7.4: Boundary scan register, replaced the sentence "The size of the boundary scan register is 464 bits." with "The size of the boundary scan register and bit ordering is device-dependent and can be found in the device BSDL file." | | | 18-Sep-2013 | 4 | Updated Disclaimer. | | | 07-Jul-2016 | 5 | Chapter 1: Introduction Table 1: SPC56xP60x/54x device comparison added footnote "LinFlex_1 is Master Only" related to LINFlex modules In Section 1.7.27: Nexus development interface (NDI) added note "At least one TCK clock is necessary for the EVTI signal to be recognized by the MCU." for EVTI pin. Chapter 3: Signal Description: Figure 3: LQFP176 pinout (top view): Changed PB[4] to TDO Changed pins 87,88 to NC Table 7: Pin muxing: In "Functions" column related to A[2] port pin, changed CS3 to CS3_4 In "Functions" column related to A[13] port pin, setted "O" direction for DSPI_1 peripheral In "Functions" column related to D[12] port pin, changed DS7_1 to CS7_1 Chapter 6: Mode Entry Module (MC_ME) In Figure 50: Mode Enable Register (ME_ME) setted to "1" the reset value for "RESET_FUNC" Chapter 9: Interrupt Controller (INTC) removed Figure "INTC Interrupt Acknowledge Register 1 (INTC_IACKR1)" removed Figure "INTC End-of-Interrupt Register 1 (INTC_EOIR1)" In Table 84: Interrupt vector table: setted the 67, 87 and 210 "IRQ #" as reserved renamed "FIFO1_IFIFO4_I" with "FIFO0_IFIFO3_I" Chapter 13: Peripheral Bridge (PBR/IDGE) In Table 130: Logical master IDs, removed the note "The MPU cannot differentiate between core and Nexus accesses to slave ports" for eDMA In Figure 135: Master Priority Register n, Figure 136: Slave General Purpose Control Register n, Figure 135: Master Priority Register n removed "TYPE" row. | | Table 634. Document revision history | Date | Revision | Changes | |-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | Chapter 15: Error Correction Status Module (ECSM) renamed Figure "Platform RAM ECC Data register (PREDR)" name with "RAM ECC Data Register (REDR)" Chapter 16: Internal Static RAM (SRAM) | | | | Updated Table 162: SRAM memory map Chapter 17: Flash Memory In Section 17.3.4.2: Flash module sectorization changed "The Flash Multi-module is | | | | composed of three modules (0, 1 and 2): Read-While-Write is not supported. The code Flash Bank 0 is divided in 18 sectors" with "The Flash Multi-module is composed of three modules (0 and 1): Read-While-Write is not supported. The code Flash Bank 0 is divided in 16 sectors" | | | | Table 169: Code Flash memory storage address map: | | | | Renamed "Block" column with "Sector" | | | | Changed note "Boot can be performed" with "The boot can be performed from any of the six locations B0F0 to BF0F5 in lower address space." | | | | Added Section 17.3.4.2.1.1: Unique Serial Number<br>In Table 174: Flash registers | | | | setted as reserved 0x0028 offset | | | | In Table 175: Flash 1056 KB multi-module register map and Table 170: 64 KB data | | | | Flash module sectorization added SBCE as bit 1 of UT0 register | | | | In Table 177: MCR field descriptions | | | | Add the text below from Flash BG: "The function of this bit is SoC dependent and it can be configured to be disabled (through UT0.SBCE)." for "EDC" field. | | 07-Jul-2016 | 5<br>(cont.) | In Figure 174: Non-Volatile Low/Mid Address Space Block Locking register (NVLML) setted LLK[15:8] as only-read locked to "0" | | | | In Table 179: LML and NVLML field descriptions changed text "MLK[1:0] are related to sectors B0F[7:6]" with "MLK[1:0] are related to sectors B0F[9:8]" and "For code Flash, LLK[5:0] are related to sectors B0F[5:0]" | | | | with "For code Flash, LLK[5:0] are related to sectors B0F[7:0]" In Figure 179: Low/Mid Address Space Block Select register (LMS), setted LLK[15:8] as read only locked to "0" | | | | In <i>Table 180: HBL and NVHBL field descriptions</i> added the sentence "HLK[3:0] are | | | | related to sectors B0F[D:A], respectively. See Table 169 for more information." In <i>Table 184: ADR field descriptions</i> removed "ADR also provides the first address at which a ECC single error correction occurs (MCR[EDC] set)." | | | | Removed Section "Bus Interface Unit 3 register (BIU3)" and "Non-Volatile Bus Interface Unit 3 register (NVBIU3)" | | | | In Table 186: PFCR0 field descriptions, updated the field-bit description BK0_RWSC In Table 187: PFCR1 field descriptions, updated the field-bit description BK1_RWSC In Figure 186: User Test 0 register (UT0) and Table 190: UT0 field descriptions added SBCE as bit 1 of UT0 register | | | | Chapter 18: Memory Protection Unit (MPU) In Section 18.3: Features: | | | | <ul> <li>changed the bullet "4 masters that support the traditional" with "2 bus masters<br/>(processor cores) support the traditional"</li> </ul> | | | | - removed sentence "On this device, the two instantiations of the MPU are referred to<br>as MPU_0 (attached to the slave side of XBAR_0) and MPU_1 (attached to the<br>slave side of XBAR_1). Both instantiations are identical and do not differ in LS<br>Mode or DP Mode." | Table 634. Document revision history | Date | Revision | Changes | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Chapter 19: Enhanced Direct Memory Access (eDMA) Removed "GPE" field from Figure 212: eDMA Error Status Register (EDMA_ESR) and Table 220: EDMA_ESR field descriptions Replaced "DMAHRSL" occurrences with "eDMA_HRSL" | | | | Chapter 20: DMA Channel Mux (DMA_MUX) In Table 243: DMA_MUX memory map, removed channel[16:30] In Table 246: DMA channel mapping, renamed "CTU FIFO [1:4]" with "CTU FIFO [0:3]" | | | | Chapter 21: FlexRay Communication Controller (FlexRay) In Table 324: Channel assignment description, changed the "dynamic segment" column from "transmit on channel A only" to "Reserved (function not available)" | | | | Chapter 23: LIN Controller (LINFlex) In Section 23.7.1.3: LIN status register (LINSR), changed RPS access from read/write "w1c" to only read | | 07-Jul-2016 | 5<br>(cont.) | Chapter 24: FlexCAN In Section 24.1.2: FlexCAN module features changed "Low power modes, with programmable wake up" with "Low power modes" | | | LQFP; 16 channels on 100-pin LQFP" added the followin "There are two types of channels: as many as 15 precision channels (CH0 to CH14) as many as 11 standard channels (CH16 to CH26)" Chapter 26: Cross Triggering Unit (CTU) In Table 474: CTU interrupts, in "Category" column renamed FIFO0_IFIFO3_I Chapter 29: Functional Safety Renamed Figure "SWT Service Register (SWT_SR)" with "S (SWT_SK)" | In Section 25.1.1: Device-specific features, below the bullet "26 channels on 144-pin LQFP; 16 channels on 100-pin LQFP" added the following sentence: "There are two types of channels: as many as 15 precision channels (CH0 to CH14) | | | | Chapter 26: Cross Triggering Unit (CTU) In Table 474: CTU interrupts, in "Category" column renamed FIFO1_I FIFO4_I with | | | | Renamed Figure "SWT Service Register (SWT_SR)" with "SWT Service Key Register (SWT_SK)" In Table 538: SWT_CR field descriptions added note to the description of the | | | | | Table 634. Document revision history | Date | Revision | Changes | |-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07-Jul-2016 | 5<br>(cont.) | Chapter 30: Fault Collection and Control Unit (FCCU) In Figure 573: FCCU Configuration Register (FCCU_CFG), changed reset value as 0x0000_0FFF In Figure 574: FCCU CF Configuration Register (FCCU_CF_CFG03), Figure 575: FCCU NCF Configuration Register (FCCU_NCF_CFG03), Figure 576: FCCU CFS Configuration Register 0 (FCCU_CFS_CFG0), Figure 577: FCCU CFS Configuration Register 1 (FCCU_CFS_CFG1), Figure 579: FCCU NCFS Configuration Register (FCCU_NCFS_CFG07), Figure 582: FCCU NCF Status Register (FCCU_NCFS03), and Figure 585: FCCU NCF Time-out Enable Register (FCCU_NCF_TOE03) updated reset value In Table 576: FCCU mapping of non-critical faults, removed NCF[14] row. Chapter 34: Cyclic Redundancy Check (CRC) In Table 593: CRC_CFG field descriptions, updated reset value from "0x0000_0000" to "0x0000_0004" and added note "Only for CRC module 2 POLIG is "1", CRC_CFG - correct reset value is 0x0004." for "POLYG" field. Chapter 38: Nexus Port Controller (NPC) In Table 626: PCR field descriptions, added the footnote "this feature is not implemented in SPC56xP54/60." for "LP_DBG_EN" and "LPn_SYN" fields. | ## **IMPORTANT NOTICE - PLEASE READ CAREFULLY** STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2016 STMicroelectronics - All rights reserved