# 56F8023 # **Data Sheet** Preliminary Technical Data **56F8000 16-bit Digital Signal Controllers** MC56F8023 Rev. 3 01/2007 # **Document Revision History** | Version History | Description of Change | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------| | Rev. 0 | Initial public release. | | Rev. 1 | In Table 10-4, added an entry for flash data retention with less than 100 program/erase cycles (minimum 20 years). | | | In Table 10-6, changed the device clock speed in STOP mode from 8MHz to 4MHz. | | | <ul> <li>In Table 10-12, changed the typical relaxation oscillator output frequency in Standby<br/>mode from 400kHz to 200kHz.</li> </ul> | | | Changed input propagation delay values in Table 10-20 as follows: | | | Old values: 1 μs typical, 2 μs maximum<br>New values: 35 ns typical, 45 ns maximum | | Rev. 2 | In Table 10-19, changed the maximum ADC internal clock frequency from 8 MHz to 5.33 MHz. | | Rev. 3 | Added the following note to the description of the TMS signal in Table 2-3: | | | <b>Note:</b> Always tie the TMS pin to V <sub>DD</sub> through a 2.2K resistor. | | | Corrected pin number labels in Figure 11-1 as follows: | | | Old labels: Pin 1, Pin 12, Pin 23, Pin 34<br>New labels: Pin 1, Pin 9, Pin 17, Pin 25 | Please see http://www.freescale.com for the most current data sheet revision. # 56F8023 General Description - Up to 32 MIPS at 32MHz core frequency - DSP and MCU functionality in a unified, C-efficient architecture - 32KB (16K x 16) Program Flash - 4KB (2K x 16) Unified Data/Program RAM - One 6-channel PWM module - Two 3-channel 12-bit Analog-to-Digital Converters (ADCs) - Two Internal 12-bit Digital-to-Analog Converters (DACs) - Two Analog Comparators - One Programmable Interval Timer (PIT) - One Queued Serial Communication Interface (QSCI) with LIN slave functionality - One Queued Serial Peripheral Interfaces (QSPI) - · One 16-bit Quad Timer - One Inter-Integrated Circuit (I<sup>2</sup>C) port - Computer Operating Properly (COP)/Watchdog - On-Chip Relaxation Oscillator - Integrated Power-On Reset (POR) and Low-Voltage Interrupt (LVI) Module - JTAG/Enhanced On-Chip Emulation (OnCE™) for unobtrusive, real-time debugging - Up to 26 GPIO lines - 32-pin LQFP Package 56F8023 Block Diagram 56F8023 Data Sheet, Rev. 3 # **56F8023 Data Sheet Table of Contents** | Part 1: Overview5 | Part 8: General-Purpose Input/Output | |----------------------------------------------|------------------------------------------------------| | 1.1. 56F8023 Features 5 | (GPIO) | | 1.2. 56F8023 Description | 8.1. Introduction | | 1.3. Award-Winning Development Environment 8 | 8.2. Configuration | | 1.4. Architecture Block Diagram 8 | 8.3. Reset Values | | 1.5. Product Documentation | 0.0. 100001 Validoo | | 1.6. Data Sheet Conventions | Part 9: Joint Test Action Group (JTAG)113 | | | 9.1. 56F8023 Information | | Part 2: Signal/Connection Descriptions 17 | 9.1. 30F6023 IIII0IIIIali0II | | 2.1. Introduction | Part 10: Specifications | | 2.2. 56F8023 Signal Pins | 10.1. General Characteristics | | 2.2. 301 0020 digital 1 113 | 10.2. DC Electrical Characteristics | | Part 3: OCCS | | | 3.1. Overview | 10.3. AC Electrical Characteristics | | 3.2. Features | 10.4. Flash Memory Characteristics | | 3.3. Operating Modes | 10.5. External Clock Operation Timing 121 | | 3.4. Internal Clock Source | 10.6. Phase Locked Loop Timing | | 3.5. Crystal Oscillator | 10.7. Relaxation Oscillator Timing 122 | | 3.6. Ceramic Resonator | 10.8. Reset, Stop, Wait, Mode Select, | | | and Interrupt Timing 124 | | 3.7. External Clock Input - Crystal | 10.9. Serial Peripheral Interface (SPI) Timing . 125 | | Oscillator Option | 10.10. Quad Timer Timing | | 3.8. Alternate External Clock Input | 10.11. Serial Communication Interface | | Part 4: Mamany Mana 22 | (SCI) Timing | | Part 4: Memory Maps33 | 10.12. Inter-Integrated Circuit Interface | | 4.1. Introduction | (I2C) Timing | | 4.2. Interrupt Vector Table | 10.13. JTAG Timing | | 4.3. Program Map | 10.14. Analog-to-Digital Converter | | 4.4. Data Map | (ADC) Parameters | | 4.5. EOnCE Memory Map | 10.15. Equivalent Circuit for ADC Inputs 134 | | 4.6. Peripheral Memory-Mapped Registers 38 | 10.16. Comparator (CMP) Parameters 134 | | D ( | 10.17. Digital-to-Analog Converter | | Part 5: Interrupt Controller (ITCN) 51 | (DAC) Parameters | | 5.1. Introduction | 10.18. Power Consumption | | 5.2. Features 51 | | | 5.3. Functional Description 52 | Part 11: Packaging | | 5.4. Block Diagram | 11.1. 56F8023 Package and | | 5.5. Operating Modes 54 | Pin-Out Information | | 5.6. Register Descriptions | | | 5.7. Resets | Part 12: Design Considerations | | | 12.1. Thermal Design Considerations 141 | | Part 6: System Integration Module (SIM) 74 | 12.2. Electrical Design Considerations 142 | | 6.1. Introduction | | | 6.2. Features | Part 13: Ordering Information 143 | | 6.3. Register Descriptions | | | 6.4. Clock Generation Overview 99 | Part 14: Appendix | | 6.5. Power-Saving Modes | • • | | 6.6. Resets | | | 6.7. Clocks | | | 6.8. Interrupts | | | | | | Part 7: Security Features 104 | | | 7.1. Operation with Security Enabled104 | | | 7.2. Flash Access Lock and | | | Unlock Mechanisms105 | | | | | ### Part 1 Overview ### 1.1 56F8023 Features ### 1.1.1 Digital Signal Controller Core - Efficient 16-bit 56800E family Digital Signal Controller (DSC) engine with dual Harvard architecture - As many as 32 Million Instructions Per Second (MIPS) at 32MHz core frequency - Single-cycle 16 × 16-bit parallel Multiplier-Accumulator (MAC) - Four 36-bit accumulators, including extension bits - 32-bit arithmetic and logic multi-bit shifter - Parallel instruction set with unique DSP addressing modes - Hardware DO and REP loops - Three internal address buses - Four internal data buses - Instruction set supports both DSP and controller functions - Controller-style addressing modes and instructions for compact code - Efficient C compiler and local variable support - Software subroutine and interrupt stack with depth limited only by memory - JTAG/Enhanced On-Chip Emulation (OnCE) for unobtrusive, processor speed-independent, real-time debugging ### **1.1.2 Memory** - Dual Harvard architecture permits as many as three simultaneous accesses to program and data memory - Flash security and protection that prevent unauthorized users from gaining access to the internal Flash - · On-chip memory - 32KB of Program Flash - 4KB of Unified Data/Program RAM - EEPROM emulation capability using Flash ### 1.1.3 Peripheral Circuits for 56F8023 - One multi-function six-output Pulse Width Modulator (PWM) module - Up to 96MHz PWM operating clock - 15 bits of resolution - Center-aligned and edge-aligned PWM signal mode - Four programmable fault inputs with programmable digital filter - Double-buffered PWM registers - Each complementary PWM signal pair allows selection of a PWM supply source from: - PWM generator - External GPIO - Internal timers - Analog comparator outputs - ADC conversion result which compares with values of ADC high- and low-limit registers to set PWM output - Two independent 12-bit Analog-to-Digital Converters (ADCs) - 2 x 3 channel inputs - Supports both simultaneous and sequential conversions - ADC conversions can be synchronized by both PWM and timer modules - Sampling rate up to 2.67MSPS - 16-word result buffer registers - Two internal 12-bit Digital-to-Analog Converters (DACs) - 2 μs settling time when output swing from rail to rail - Automatic waveform generation generates square, triangle and sawtooth waveforms with programmable period, update rate, and range - One 16-bit multi-purpose Quad Timer module (TMR) - Up to 96MHz operating clock - Eight independent 16-bit counter/timers with cascading capability - Each timer has capture and compare capability - Up to 12 operating modes - One Queued Serial Communication Interface (QSCI) with LIN Slave functionality - Full-duplex or single-wire operation - Two receiver wake-up methods: - Idle line - Address mark - Four-bytes-deep FIFOs are available on both transmitter and receiver - One Queued Serial Peripheral Interfaces (QSPI) - Full-duplex operation - Master and slave modes - Four-words-deep FIFOs available on both transmitter and receiver - Programmable Length Transactions (2 to 16 bits) - One Inter-Integrated Circuit (I<sup>2</sup>C) port - Operates up to 400kbps - Supports both master and slave operation - Supports both 10-bit address mode and broadcasting mode - One 16-bit Programmable Interval Timer (PIT) - Two analog Comparators (CMPs) - Selectable input source includes external pins, DACs - Programmable output polarity - Output can drive Timer input, PWM fault input, PWM source, external pin output and trigger ADCs - Output falling and rising edge detection able to generate interrupts - Computer Operating Properly (COP)/Watchdog timer capable of selecting different clock sources - Up to 26 General-Purpose I/O (GPIO) pins with 5V tolerance - Integrated Power-On Reset and Low-Voltage Interrupt Module - Phase Lock Loop (PLL) provides a high-speed clock to the core and peripherals - Clock sources: - On-chip relaxation oscillator - External clock: Crystal oscillator, ceramic resonator, and external clock source - JTAG/EOnCE debug programming interface for real-time debugging ### 1.1.4 Energy Information - Fabricated in high-density CMOS with 5V tolerance - On-chip regulators for digital and analog circuitry to lower cost and reduce noise - Wait and Stop modes available - ADC smart power management - Each peripheral can be individually disabled to save power # 1.2 56F8023 Description The 56F8023 is a member of the 56800E core-based family of Digital Signal Controllers (DSCs). It combines, on a single chip, the processing power of a DSP and the functionality of a microcontroller with a flexible set of peripherals to create an extremely cost-effective solution. Because of its low cost, configuration flexibility, and compact program code, the 56F8023 is well-suited for many applications. The 56F8023 includes many peripherals that are especially useful for industrial control, motion control, home appliances, general-purpose inverters, smart sensors, fire and security systems, switched-mode power supply, power management, and medical monitoring applications. The 56800E core is based on a dual Harvard-style architecture consisting of three execution units operating in parallel, allowing as many as six operations per instruction cycle. The MCU-style programming model and optimized instruction set allow straightforward generation of efficient, compact DSP and control code. The instruction set is also highly efficient for C compilers to enable rapid development of optimized control applications. The 56F8023 supports program execution from internal memories. Two data operands can be accessed from the on-chip data RAM per instruction cycle. The 56F8023 also offers up to 26 General-Purpose Input/Output (GPIO) lines, depending on peripheral configuration. The 56F8023 Digital Signal Controller includes 32KB of Program Flash and 4KB of Unified Data/Program RAM. Program Flash memory can be independently bulk erased or erased in pages. Program Flash page erase size is 512 Bytes (256 Words). # 1.3 Award-Winning Development Environment Processor Expert<sup>TM</sup> (PE) provides a Rapid Application Design (RAD) tool that combines easy-to-use component-based software application creation with an expert knowledge system. The CodeWarrior Integrated Development Environment is a sophisticated tool for code navigation, compiling, and debugging. A complete set of evaluation modules (EVMs), demonstration board kit and development system cards will support concurrent engineering. Together, PE, CodeWarrior and EVMs create a complete, scalable tools solution for easy, fast, and efficient development. A full set of programmable peripherals — PWM, ADCs, QSCI, QSPI, I2C, PIT, Quad Timers, DACs, and analog comparators — supports various applications. Each peripheral can be independently shut down to save power. Any pin in these peripherals can also be used as General Purpose Input/Outputs (GPIOs). # 1.4 Architecture Block Diagram The 56F8023's architecture is shown in **Figures 1-1**, **1-2**, **1-3**, **1-4**, **1-5**, **1-6**, and **1-7**. **Figure 1-1** illustrates how the 56800E system buses communicate with internal memories and the IPBus Bridge and the internal connections between each unit of the 56800E core. **Figure 1-2** shows the peripherals and control blocks connected to the IPBus Bridge. **Figures 1-3**, **1-4**, **1-5**, **1-6**, and **1-7** detail how the device's I/O pins are muxed. The figures do not show the on-board regulator and power and ground signals. Please see **Part 2**, **Signal/Connection Descriptions**, for information about which signals are multiplexed with those of other peripherals. # 1.4.1 PWM, TMR and ADC Connections Figure 1-3 shows the over- and under-voltage connections from the ADC to the PWM and the connections to the PWM from the TMR and GPIO. These signals can control the PWM outputs in a similar manner to the over- and under-voltage control signals. See the 56F802X and 56F803X Peripheral Reference Manual for additional information. The PWM\_reload\_sync output can be connected to the Timer's Channel 3 input and the Timer's Channels 2 and 3 outputs are connected to the ADC sync inputs. Timer Channel 3 output is connected to SYNC0 and Timer Channel 2 is connected to SYNC1. These are controlled by bits in the SIM Control Register; see Section 6.3.1. Figure 1-1 56800E Core Block Diagram ### **To/From IPBus Bridge** occs Interrupt (ROSC / PLL / Controller OSC) Low-Voltage Interrupt GPIO A POR & LVI **GPIO B** ↓ System POR GPIO C RESET SIM (Muxed with GPIOA7) GPIO D **COP** Reset COP **IPBus** (Continues on Figure 1-3) Figure 1-2 Peripheral Subsystem Figure 1-3 56F8023 I/O Pin-Out Muxing (Part 1/5) Figure 1-4 56F8023 I/O Pin-Out Muxing (Part 2/5) Figure 1-5 56F8023 I/O Pin-Out Muxing (Part 3/5) Figure 1-6 56F8023 I/O Pin-Out Muxing (Part 4/5) Figure 1-7 56F8023 I/O Pin-Out Muxing (Part 5/5) ### 1.5 Product Documentation The documents listed in **Table 1-1** are required for a complete description and proper design with the 56F8023. Documentation is available from local Freescale distributors, Freescale Semiconductor sales offices, Freescale Literature Distribution Centers, or online at: http://www.freescale.com Table 1-1 56F8023 Chip Documentation | Topic | Description | Order Number | |--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------| | DSP56800E<br>Reference Manual | Detailed description of the 56800E family architecture, 16-bit Digital Signal Controller core processor, and the instruction set | DSP56800ERM | | 56F802X and 56F803X<br>Peripheral Reference<br>Manual | Detailed description of peripherals of the 56F802x and 56F803x family of devices | MC56F80xxRM | | 56F802x and 56F803x<br>Serial Bootloader User<br>Guide | Detailed description of the Serial Bootloader in the 56F802x and 56F803x family of devices | 56F80xxBLUG | | 56F8023<br>Technical Data Sheet | Electrical and timing specifications, pin descriptions, and package descriptions (this document) | MC56F8023 | | 56F8023<br>Errata | Details any chip issues that might be present | MC56F8023E | ### 1.6 Data Sheet Conventions This data sheet uses the following conventions: | OVERBAR | This is used to indicate a signal that is active when pulled low. For example, the RESET pin is | |---------|-------------------------------------------------------------------------------------------------| | | and the continue force | active when low. "asserted" A high true (active high) signal is high or a low true (active low) signal is low. "deasserted" A high true (active high) signal is low or a low true (active low) signal is high. | Examples: | Signal/Symbol | Logic State | Signal State | Voltage <sup>1</sup> | |-----------|---------------|-------------|--------------|----------------------| | | PIN | True | Asserted | $V_{IL}/V_{OL}$ | | | PIN | False | Deasserted | $V_{IH}/V_{OH}$ | | | PIN | True | Asserted | $V_{IH}/V_{OH}$ | | | PIN | False | Deasserted | $V_{IL}/V_{OL}$ | <sup>1.</sup> Values for $V_{IL}$ , $V_{OL}$ , $V_{IH}$ , and $V_{OH}$ are defined by individual product specifications. # Part 2 Signal/Connection Descriptions ### 2.1 Introduction The input and output signals of the 56F8023 are organized into functional groups, as detailed in **Table 2-1**. **Table 2-2** summarizes all device pins. In **Table 2-2**, each table row describes the signal or signals present on a pin, sorted by pin number. **Table 2-1 Functional Group Pin Allocations** | Functional Group | Number of Pins | |--------------------------------------------------------------------------|----------------| | Power Inputs (V <sub>DD</sub> , V <sub>DDA</sub> ) | 2 | | Ground (V <sub>SS</sub> , V <sub>SSA</sub> ) | 3 | | Supply Capacitors | 1 | | Reset <sup>1</sup> | 1 | | Pulse Width Modulator (PWM) Ports <sup>1</sup> | 11 | | Serial Peripheral Interface (SPI) Ports <sup>1</sup> | 4 | | Timer Module A (TMRA) Ports <sup>1</sup> | 4 | | Analog-to-Digital Converter (ADC) Ports <sup>1</sup> | 6 | | Serial Communications Interface 0 (SCI0) Ports <sup>1</sup> | 2 | | Inter-Integrated Circuit Interface (I <sup>2</sup> C) Ports <sup>1</sup> | 2 | | JTAG/Enhanced On-Chip Emulation (EOnCE <sup>1</sup> ) | 4 | <sup>1.</sup> Pins may be shared with other peripherals. See Table 2-2. In Table 2-2, peripheral pins in bold identify reset state. Table 2-2 56F8023 Pins | | | | Periph | erals: | | | | | | | | | | |----------|----------|-------------------------------------|--------|--------|------|-------|----------------------------|----------------|---------------|--------|-------------------|------|-------| | Pin<br># | Pin Name | Signal Name | GPIO | I2C | QSCI | QSPI | ADC | PWM | Quad<br>Timer | Comp | Power &<br>Ground | JTAG | Misc. | | 1 | GPIOB6 | GPIOB6, RXD0, SDA,<br>CLKIN | В6 | SDA | RXD0 | | | | | | | | CLKIN | | 2 | GPIOB1 | GPIOB1, SSO, SDA | B1 | SDA | | SS0 | | | | | | | | | 3 | GPIOB7 | GPIOB7, TXD0, SCL | В7 | SCL | TXD0 | | | | | | | | | | 4 | GPIOB5 | GPIOB5, TA1,<br>FAULT3, CLKIN | B5 | | | | | FAULT3 | TA1 | | | | CLKIN | | 5 | GPIOC4 | GPIOC4, ANB0 & CMPBI3 | C4 | | | | ANB0 | | | CMPBI3 | | | | | 6 | GPIOC5 | GPIOC5, ANB1 | C5 | | | | ANB1 | | | | | | | | 7 | GPIOC6 | GPIOC6, ANB2,<br>V <sub>REFHB</sub> | C6 | | | | ANB2<br>V <sub>REFHB</sub> | | | | | | | | 8 | VDDA | V <sub>DDA</sub> | | | | | | | | | $V_{DDA}$ | | | | 9 | VSSA | V <sub>SSA</sub> | | | | | | | | | $V_{SSA}$ | | | | 10 | GPIOC2 | GPIOC2, ANA2,<br>V <sub>REFHA</sub> | C2 | | | | ANA2<br>V <sub>REFHA</sub> | | | | | | | | 11 | GPIOC1 | GPIOC1, ANA1 | C1 | | | | ANA1 | | | | | | | | 12 | GPIOC0 | GPIOC0, ANA0 &<br>CMPAI3 | C0 | | | | ANA0 | | | CMPAI3 | | | | | 13 | vss | V <sub>SS</sub> | | | | | | | | | $V_{SS}$ | | | | 14 | тск | TCK, GPIOD2 | D2 | | | | | | | | | тск | | | 15 | RESET | RESET, GPIOA7 | A7 | | | | | | | | | | RESET | | 16 | GPIOB3 | GPIOB3, MOSI0, TA3,<br>PSRC1 | В3 | | | MOSI0 | | PSRC1 | TA3 | | | | | | 17 | GPIOB2 | GPIOB2, MISO0, TA2,<br>PSRC0 | B2 | | | MISO0 | | PSRC0 | TA2 | | | | | | 18 | GPIOA6 | GPIOA6, FAULT0,<br>TA0 | A6 | | | | | FAULT0 | TA0 | | | | | | 19 | GPIOB4 | GPIOB4, TA0, CLKO,<br>PSRC2 | B4 | | | | | PSRC2 | TA0 | | | | CLKO | | 20 | GPIOA5 | GPIOA5, PWM5, TA3,<br>FAULT2 | A5 | | | | | PWM5<br>FAULT2 | TA3 | | | | | | 21 | GPIOB0 | GPIOB0, SCLK0, SCL | В0 | SCL | | SCLK0 | | | | | | | | | 22 | GPIOA4 | GPIOA4, PWM4, TA2,<br>FAULT1 | A4 | | | | | PWM4<br>FAULT1 | TA2 | | | | | | 23 | GPIOA2 | GPIOA2, PWM2 | A2 | | | | | PWM2 | | | | | | | 24 | GPIOA3 | GPIOA3, PWM3 | А3 | | | | | PWM3 | | | | | | | 25 | VCAP | V <sub>CAP</sub> | | | | | | | | | V <sub>CAP</sub> | | | | 26 | VDD | $V_{DD}$ | | | | | | | | | $V_{DD}$ | | | | 27 | vss | V <sub>SS</sub> | | | | | | | | · | V <sub>SS</sub> | | | | 28 | GPIOA1 | GPIOA1, PWM1 | A1 | | | | | PWM1 | | | | | | # Table 2-2 56F8023 Pins (Continued) | | | | | Peripherals: | | | | | | | | | | |----------|----------|--------------|------|--------------|------|------|-----|------|---------------|------|-------------------|------|-------| | Pin<br># | Pin Name | Signal Name | GPIO | I2C | QSCI | QSPI | ADC | PWM | Quad<br>Timer | Comp | Power &<br>Ground | JTAG | Misc. | | 29 | GPIOA0 | GPIOA0, PWM0 | Α0 | | | | | PWM0 | | | | | | | 30 | TDI | TDI, GPIOD0 | D0 | | | | | | | | | TD1 | | | 31 | TMS | TMS, GPIOD3 | D3 | | | | | | | | | TMS | | | 32 | TDO | TDO, GPIOD1 | D1 | | | | | | | | | TDO | | Figure 2-1 56F8023 Signals Identified by Functional Group # 2.2 **56F8023 Signal Pins** After reset, each pin is configured for its primary function (listed first). Any alternate functionality must be programmed. Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |------------------|-----------------|-------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>DD</sub> | 26 | Supply | Supply | I/O Power — This pin supplies 3.3V power to the chip I/O interface. | | V <sub>SS</sub> | 13 | Supply | Supply | V <sub>SS</sub> — These pins provide ground for chip logic and I/O drivers. | | V <sub>SS</sub> | 27 | | | | | V <sub>DDA</sub> | 8 | Supply | Supply | <b>ADC Power</b> — This pin supplies 3.3V power to the ADC modules. It must be connected to a clean analog power supply. | | V <sub>SSA</sub> | 9 | Supply | Supply | ADC Analog Ground — This pin supplies an analog ground to the ADC modules. | | V <sub>CAP</sub> | 25 | Supply | Supply | $V_{CAP}$ — Connect this pin to a 4.7 $\mu$ F or greater bypass capacitor in order to bypass the core voltage regulator, required for proper chip operation. See <b>Section 10.2.1</b> . | | RESET | 15 | Input | Input,<br>internal<br>pull-up<br>enabled | Reset — This input is a direct hardware reset on the processor. When RESET is asserted low, the chip is initialized and placed in the reset state. A Schmitt trigger input is used for noise immunity. The internal reset signal will be deasserted synchronous with the internal clocks after a fixed number of internal clocks. | | (GPIOA7) | | Input/Open<br>Drain<br>Output | | Port A GPIO — This GPIO pin can be individually programmed as an input or open drain output pin. Note that RESET functionality is disabled in this mode and the chip can only be reset via POR, COP reset, or software reset. After reset, the default state is RESET. | | GPIOA0 | 29 | Input/<br>Output | Input,<br>internal<br>pull-up | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM0) | | Output | enabled | PWM0 — This is one of the six PWM output pins. After reset, the default state is GPIOA0. | Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |------------------------|-----------------|------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------| | GPIOA1 | 28 | Input/<br>Output | Input,<br>internal<br>pull-up | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM1) | | Output | enabled | PWM1 — This is one of the six PWM output pins. | | | | | | After reset, the default state is GPIOA1. | | GPIOA2 | 23 | Input/<br>Output | Input,<br>internal<br>pull-up | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM2) | | Output | enabled | PWM2 — This is one of the six PWM output pins. | | | | | | After reset, the default state is GPIOA2. | | GPIOA3 | 24 | Input/<br>Output | Input,<br>internal<br>pull-up | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM3) | | Output | enabled | PWM3 — This is one of the six PWM output pins. | | | | | | After reset, the default state is GPIOA3. | | GPIOA4 | 22 | Input/<br>Output | Input,<br>internal<br>pull-up | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM4) | | Output | enabled | PWM4 — This is one of the six PWM output pins. | | (TA2 <sup>1</sup> ) | | Input/<br>Output | | TA2 — Timer A, Channel 2 | | (FAULT1 <sup>2</sup> ) | | Input | | Fault1 — This fault input pin is used for disabling selected PWM outputs in cases where fault conditions originate off-chip. | | | | | | After reset, the default state is GPIOA4. The peripheral functionality is controlled via the SIM. See Section 6.3.16. | <sup>&</sup>lt;sup>1</sup>The TA2 signal is also brought out on the GPIOB2-3 pin. <sup>&</sup>lt;sup>2</sup>The Fault1 signal is also brought out on the GPIOB4 pin. Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |------------------------|-----------------|------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | GPIOA5 | 20 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (PWM5) | | Output | | PWM5 — This is one of the six PWM output pins. | | (TA3 <sup>3</sup> ) | | Input/<br>Output | | TA3 — Timer A, Channel 3 | | (FAULT2 <sup>4</sup> ) | | Input | | Fault2 — This fault input pin is used for disabling selected PWM outputs in cases where fault conditions originate off-chip. | | | | | | After reset, the default state is GPIOA5. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | <sup>&</sup>lt;sup>3</sup>The TA3 signal is also brought out on the GPIOB2-3 pin. <sup>&</sup>lt;sup>4</sup>The Fault2 signal is also brought out on the GPIOB4 pin. | GPIOA6 | 18 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port A GPIO — This GPIO pin can be individually programmed as an input or output pin. | |---------------------|----|------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | (FAULT0) | | Input | | <b>Fault0</b> — This fault input pin is used for disabling selected PWM outputs in cases where fault conditions originate off-chip. | | (TA0 <sup>5</sup> ) | | | | TA0 — Timer A, Channel 0. | | | | | | After reset, the default state is GPIOA6. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | <sup>&</sup>lt;sup>5</sup>The TA0 signal is also brought out on the GPIOB4 pin. Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |---------------------------|-----------------|------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GPIOB0 | 21 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (SCLK0) | | Input/<br>Output | Chabled | QSPI0 Serial Clock — In the master mode, this pin serves as an output, clocking slaved listeners. In slave mode, this pin serves as the data clock input. A Schmitt trigger input is used for noise immunity. | | (SCL <sup>6</sup> ) | | Input/<br>Output | | Serial Clock — This pin serves as the I <sup>2</sup> C serial clock. | | | | | | After reset, the default state is GPIOB0. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | | <sup>6</sup> The SCL sign | al is also b | rought out on t | he GPIOB7 pin. | | | GPIOB1 | 2 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | ( <del>SS0</del> ) | | Input/ | Chablea | QSPI0 Slave Select — SS is used in slave mode to indicate to the | | (555) | | Output | | QSPI0 module that the current transfer is to be received. | | (SDA <sup>7</sup> ) | | Output<br>Input | | Serial Data — This pin serves as the I <sup>2</sup> C serial data line. | <sup>&</sup>lt;sup>7</sup>The SDA signal is also brought out on the GPIOB6 pin. Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |----------------------------|-----------------|------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GPIOB2 | 17 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (MISOO) | | Input/<br>Output | citables | QSPI0 Master In/Slave Out — This serial data pin is an input to a master device and an output from a slave device. The MISO line of a slave device is placed in the high-impedance state if the slave device is not selected. The slave device places data on the MISO line a half-cycle before the clock edge the master device uses to latch the data. | | (TA2 <sup>8</sup> ) | | Input/<br>Output | | TA2 — Timer A, Channel 2 | | (PSRC0) | | Input | | PSRC0 — External PWM signal source input for the complementary PWM4/PWM5 pair. | | | | | | After reset, the default state is GPIOB2. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | | <sup>8</sup> The TA2 signa | al is also bi | rought out on th | ne GPIOA4 pin. | | | GPIOB3 | 16 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (MOSI0) | | Input/<br>Output | enabled | <b>QSPI0 Master Out/Slave In</b> — This serial data pin is an output from a master device and an input to a slave device. The master device places data on the MOSI line a half-cycle before the clock edge the slave device uses to latch the data. | | (TA3 <sup>9</sup> ) | | Input/<br>Output | | TA3 — Timer A, Channel 3 | | (PSRC1) | | Input | | PSRC1 — External PWM signal source input for the complementary PWM2/PWM3 pair. | | | | | | After reset, the default state is GPIOB3. The peripheral functionality | <sup>9</sup>The TA3 signal is also brought out on the GPIOA5 pin. Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |----------------------------|-----------------|------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GPIOB4 | 19 | Input/<br>Output | Input,<br>internal<br>pull-up | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (TA0 <sup>10</sup> ) | | Input/<br>Output | enabled | TA0 — Timer A, Channel 0 | | (PSRC2) | | Input<br>Output | | PSRC2 — External PWM signal source input for the complementary PWM0/PWM1 pair. | | (CLKO) | | Output | | Clock Output — This is a buffered clock output; the clock source is selected by Clockout Select (CLKOSEL) bits in the Clock Output Select Register (CLKOUT). See Section 6.3.7. | | | | | | After reset, the default state is GPIOB4. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | | <sup>10</sup> The TA0 sigr | nal is also t | orought out on t | the GPIOB4 and | GPIOA6 pins. | | GPIOB5 | 4 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (TA1) | | Input/<br>Output | enabled | TA1 — Timer A, Channel 1 | | (FAULT3) | | Input | | <b>FAULT3</b> — This fault input pin is used for disabling selected PWM outputs in cases where fault conditions originate off-chip. | | (CLKIN) | | Input | | External Clock Input— This pin serves as an external clock input. | | | | | | After reset, the default state is GPIOB5. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | | | |----------------------------|---------------------------------------------------------------------|------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | GPIOB6 | 1 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | | | (RXD0) | | Input | chabica | Receive Data 0 — QSCI0 receive data input. | | | | (SDA <sup>11</sup> ) | | Input/<br>Output | | Serial Data — This pin serves as the I <sup>2</sup> C serial data line. | | | | (CLKIN) | | Input | | External Clock Input — This pin serves as an external clock input. | | | | | | | | After reset, the default state is GPIOB6. The peripheral functionality is controlled via the SIM (See Section 6.3.16) and the CLKMODE bit of the OCCS Oscillator Control Register. | | | | <sup>11</sup> The SDA sig | <sup>11</sup> The SDA signal is also brought out on the GPIOB1 pin. | | | | | | | GPIOB7 | 3 | Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Port B GPIO — This GPIO pin can be individually programmed as an input or output pin. | | | | (TXD0) | | Input/<br>Output | Chabled | <b>Transmit Data 0</b> — QSCI0 transmit data output or transmit/receive in single wire operation. | | | | (SCL <sup>12</sup> ) | | Input/<br>Output | | Serial Clock — This pin serves as the I <sup>2</sup> C serial clock. | | | | | | Gaipat | | After reset, the default state is GPIOB7. The peripheral functionality is controlled via the SIM. See <b>Section 6.3.16</b> . | | | | <sup>12</sup> The SCL sign | nal is also | brought out on | the GPIOB0 pin. | | | | | GPIOC0 | 12 | Input/<br>Output | Input | Port C GPIO — This GPIO pin can be individually programmed as an input or output pin. | | | | (ANA0 & | | Analog | | ANA0 — Analog input to ADC A, Channel 0. | | | | CMPAI3) | | input | | Comparator A, Input 3 — This is an analog input to Comparator A. | | | | | | | | When used as an analog input, the signal goes to both the ANA0 and CMPAI3. | | | | | | | | After reset, the default state is GPIOC0. | | | Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |-----------------------|-----------------|------------------|-----------------------|----------------------------------------------------------------------------------------------| | GPIOC1 | 11 | Input/<br>Output | Input | Port C GPIO — This GPIO pin can be individually programmed as an input or output pin. | | (ANA1) | | Analog<br>Input | | ANA1 — Analog input to ADC A, Channel 1. | | | | input | | After reset, the default state is GPIOC1. | | GPIOC2 | 10 | Input/<br>Output | Input | <b>Port C GPIO</b> — This GPIO pin can be individually programmed as an input or output pin. | | (ANA2) | | Analog<br>Input | | ANA2 — Analog input to ADC A, Channel 2. | | (V <sub>REFHA</sub> ) | | Analog<br>Input | | V <sub>REFHA</sub> — Analog reference voltage high (ADC A). | | | | mpat | | After reset, the default state is GPIOC2. | | GPIOC4 | 5 | Input/<br>Output | Input | <b>Port C GPIO</b> — This GPIO pin can be individually programmed as an input or output pin. | | (ANB0 & CMPBI3) | | Analog<br>Input | | ANB0 — Analog input to ADC B, Channel 0. | | CIVIPBIS) | | input | | Comparator B, Input 3 — This is an analog input to Comparator B. | | | | | | When used as an analog input, the signal goes to both the ANB0 and CMPBI3. | | | | | | After reset, the default state is GPIOC4. | | GPIOC5 | 6 | Input/<br>Output | Input | <b>Port C GPIO</b> — This GPIO pin can be individually programmed as an input or output pin. | | (ANB1) | | Analog<br>Input | | ANB1 — Analog input to ADC B, Channel 1. | | | | put | | After reset, the default state is GPIOC5. | | GPIOC6 | 7 | Input/<br>Output | Input | <b>Port C GPIO</b> — This GPIO pin can be individually programmed as an input or output pin. | | (ANB2) | | Analog<br>Input | | ANB2 — Analog input to ADC B, Channel 2. | | (V <sub>REFHB</sub> ) | | Input | | V <sub>REFHB</sub> — Analog reference voltage high (ADC B). | | | | | | After reset, the default state is GPIOC6. | Table 2-3 56F8023 Signal and Package Information for the 32-Pin LQFP (Continued) | Signal<br>Name | LQFP<br>Pin No. | Туре | State During<br>Reset | Signal Description | |----------------|-----------------|----------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TDI (GPIOD0) | 30 | Input/<br>Input/<br>Output | Input,<br>internal<br>pull-up<br>enabled | Test Data Input — This input pin provides a serial input data stream to the JTAG/EOnCE port. It is sampled on the rising edge of TCK and has an on-chip pull-up resistor. Port D GPIO — This GPIO pin can be individually programmed as an input or output pin. After reset, the default state is TDI. | | TDO (GPIOD1) | 32 | Output Input/ Output | Output,<br>tri-stated,<br>internal<br>pull-up<br>enabled | Test Data Output — This tri-stateable output pin provides a serial output data stream from the JTAG/EOnCE port. It is driven in the shift-IR and shift-DR controller states, and changes on the falling edge of TCK. Port D GPIO — This GPIO pin can be individually programmed as an input or output pin. | | | | | | After reset, the default state is TDO. | | тск | 14 | Input | Input,<br>internal<br>pull-up<br>enabled | <b>Test Clock Input</b> — This input pin provides a gated clock to synchronize the test logic and shift serial data to the JTAG/EOnCE port. The pin is connected internally to a pull-up resistor. A Schmitt trigger input is used for noise immunity. | | (GPIOD2) | | Input/<br>Output | | Port D GPIO — This GPIO pin can be individually programmed as an input or output pin. After reset, the default state is TCK. | | TMS (GPIOD3) | 31 | Input | Input,<br>internal<br>pull-up<br>enabled | Test Mode Select Input — This input pin is used to sequence the JTAG TAP controller's state machine. It is sampled on the rising edge of TCK and has an on-chip pull-up resistor. Port D GPIO — This GPIO pin can be individually programmed as | | | | Output | | an input or output pin.<br>After reset, the default state is TMS.<br>Note: Always tie the TMS pin to $V_{DD}$ through a 2.2K resistor. | ### Part 3 OCCS ### 3.1 Overview The On-Chip Clock Synthesis (OCCS) module allows designers using an internal relaxation oscillator, an external crystal, or an external clock to run 56F8000 family devices at user-selectable frequencies up to 32MHz. For details, see the OCCS chapter in the **56F802X and 56F803X Peripheral Reference Manual**. ### 3.2 Features The OCCS module interfaces to the oscillator and PLL and offers these features: - Internal relaxation oscillator - Ability to power down the internal relaxation oscillator or crystal oscillator - Ability to put the internal relaxation oscillator into Standby mode - 3-bit postscaler provides control for the PLL output - Ability to power down the PLL - Provides a 2X system clock which operates at twice the system clock to the System Integration Module (SIM) - Provides a 3X system clock which operates at three times the system clock to PWM and Timer modules - Safety shutdown feature is available if the PLL reference clock is lost - Can be driven from an external clock source The clock generation module provides the programming interface for the PLL, internal relaxation oscillator, and crystal oscillator. # 3.3 Operating Modes In 56F8000 family devices, an internal oscillator, an external crystal, or an external clock source can be used to provide a reference clock to the SIM. The 2X system clock source output from the OCCS can be described by one of the following equations: ``` 2X system frequency = oscillator frequency ``` 2X system frequency = (oscillator frequency x 8) / (postscaler) where: postscaler = $$1, 2, 4, 8, 16, \text{ or } 32$$ The SIM is responsible for further dividing these frequencies by two, which will insure a 50% duty cycle in the system clock output. The 56F8000 family devices' on-chip clock synthesis module has the following registers: - Control Register (OCCS CTRL) - Divide-by Register (OCCS DIVBY) - Status Register (OCCS STAT) - Shutdown Register (OCCS SHUTDN) - Oscillator Control Register (OCCS OCTRL) For more information on these registers, please refer to the 56F802X and 56F803X Peripheral Reference Manual. ### 3.4 Internal Clock Source An internal relaxation oscillator can supply the reference frequency when an external frequency source or crystal is not used. It is optimized for accuracy and programmability while providing several power-saving configurations which accommodate different operating conditions. The internal relaxation oscillator has very little temperature and voltage variability. To optimize power, the architecture supports a standby state and a power-down state. During a boot or reset sequence, the relaxation oscillator is enabled by default (the PRECS bit in the PLLCR word is set to 0). Application code can then also switch to the external clock source and power down the internal oscillator, if desired. If a changeover between internal and external clock sources is required at power-on, the user must ensure that the clock source is not switched until the desired external clock source is enabled and stable. To compensate for variances in the device manufacturing process, the accuracy of the relaxation oscillator can be incrementally adjusted to within $\pm$ 0.078% of 8MHz by trimming an internal capacitor. Bits 0-9 of the OSCTL (oscillator control) register allow the user to set in an additional offset (trim) to this preset value to increase or decrease capacitance. Each unit added or subtracted changes the output frequency by about 0.078% of 8MHz, allowing incremental adjustment until the desired frequency accuracy is achieved. The center frequency of the internal oscillator is calibrated at the factory to 8MHz and the TRIM value is stored in the Flash information block and loaded to the FMOPT1 register at reset. When using the relaxation oscillator, the boot code should read the FMOPT1 register and set this value as OSCTL TRIM. For further information, see the **56F802X and 56F803X Peripheral Reference Manual**. # 3.5 Crystal Oscillator The internal crystal oscillator circuit is designed to interface with a parallel-resonant crystal resonator in a frequency range of 4-8MHz, specified for the external crystal. **Figure 3-1** shows a typical crystal oscillator circuit. Follow the crystal supplier's recommendations when selecting a crystal, since crystal parameters determine the component values required to provide maximum stability and reliable start-up. The load capacitance values used in the oscillator circuit design should include all stray layout capacitances. The crystal and associated components should be mounted as near as possible to the EXTAL and XTAL pins to minimize output distortion and start-up stabilization time. ### Crystal Frequency = 4 - 8MHz (optimized for 8MHz) Figure 3-1 External Crystal Oscillator Circuit ### 3.6 Ceramic Resonator The internal crystal oscillator circuit is also designed to interface with a ceramic resonator in the frequency range of 4-8MHz. **Figure 3-2** shows the typical 2- and 3-terminal ceramic resonators and their circuits. Follow the resonator supplier's recommendations when selecting a resonator, since their parameters determine the component values required to provide maximum stability and reliable start up. The load capacitance values used in the resonator circuit design should include all stray layout capacitances. The resonator and associated components should be mounted as near as possible to the EXTAL and XTAL pins to minimize output distortion and start-up stabilization time. Resonator Frequency = 4 - 8MHz (optimized for 8MHz) # 2 Terminal 3 Terminal EXTAL XTAL Sample External Ceramic Resonator Parameters: $R_z = 750 \text{ K}\Omega$ Figure 3-2 External Ceramic Resonator Circuit # 3.7 External Clock Input - Crystal Oscillator Option The recommended method of connecting an external clock is illustrated in **Figure 3-3.** The external clock source is connected to XTAL and the EXTAL pin is grounded. The external clock input must be generated using a relatively low impedance driver. Figure 3-3 Connecting an External Clock Signal using XTAL # 3.8 Alternate External Clock Input The recommended method of connecting an external clock is illustrated in **Figure 3-3.** The external clock source is connected to GPIO6/RXD (primary) or GPIOB5/TA1/FAULT3/XTAL/EXTAL (secondary). The user has the option of using GPIO6/RXD/CLKIN or GPIOB5/TA1/FAULT3/CLKIN as external clock input. Figure 3-4 Connecting an External Clock Signal using GPIO # **Part 4 Memory Maps** ### 4.1 Introduction The 56F8023 device is a 16-bit motor-control chip based on the 56800E core. It uses a Harvard-style architecture with two independent memory spaces for Data and Program. On-chip RAM is shared by both spaces and Flash memory is used only in Program space. This section provides memory maps for: - Program Address Space, including the Interrupt Vector Table - Data Address Space, including the EOnCE Memory and Peripheral Memory Maps On-chip memory sizes for the device are summarized in **Table 4-1**. Flash memories' restrictions are identified in the "Use Restrictions" column of **Table 4-1**. | On-Chip Memory | 56F8023 | Use Restrictions | |---------------------------|------------------------|------------------------------------------------------------------| | Program Flash<br>(PFLASH) | 16k x 16<br>or<br>32KB | Erase / Program via Flash interface unit and word writes to CDBW | **Table 4-1 Chip Memory Configurations** Table 4-1 Chip Memory Configurations | On-Chip Memory | 56F8023 | Use Restrictions | |-------------------|----------------------|---------------------------------------------------| | Unified RAM (RAM) | 2k x 16<br>or<br>4KB | Usable by both the Program and Data memory spaces | # 4.2 Interrupt Vector Table **Table 4-2** provides the 56F8023's reset and interrupt priority structure, including on-chip peripherals. The table is organized with higher-priority vectors at the top and lower-priority interrupts lower in the table. As indicated, the priority of an interrupt can be assigned to different levels, allowing some control over interrupt priorities. All level 3 interrupts will be serviced before level 2, and so on. For a selected priority level, the lowest vector number has the highest priority. The location of the vector table is determined by the Vector Base Address (VBA). Please see Section 5.6.8 for the reset value of the VBA. By default, VBA = 0, and the reset address and COP reset address will correspond to vector 0 and 1 of the interrupt vector table. In these instances, the first two locations in the vector table must contain branch or JMP instructions. All other entries must contain JSR instructions. Table 4-2 Interrupt Vector Table Contents<sup>1</sup> | Peripheral | Vector<br>Number | Priority<br>Level | Vector Base<br>Address + | Interrupt Function | |------------|------------------|-------------------|--------------------------|-----------------------------------------| | core | | | P:\$00 | Reserved for Reset Overlay <sup>2</sup> | | core | | | P:\$02 | Reserved for COP Reset Overlay | | core | 2 | 3 | P:\$04 | Illegal Instruction | | core | 3 | 3 | P:\$06 | SW Interrupt 3 | | core | 4 | 3 | P:\$08 | HW Stack Overflow | | core | 5 | 3 | P:\$0A | Misaligned Long Word Access | | core | 6 | 1-3 | P:\$0C | EOnCE Step Counter | | core | 7 | 1-3 | P:\$0E | EOnCE Breakpoint Unit | | core | 8 | 1-3 | P:\$10 | EOnCE Trace Buffer | | core | 9 | 1-3 | P:\$12 | EOnCE Transmit Register Empty | | core | 10 | 1-3 | P:\$14 | EOnCE Receive Register Full | | core | 11 | 2 | P:\$16 | SW Interrupt 2 | | core | 12 | 1 | P:\$18 | SW Interrupt 1 | | core | 13 | 0 | P:\$1A | SW Interrupt 0 | | | 14 | | | Reserved | | LVI | 15 | 1-3 | P:\$1E | Low-Voltage Detector (Power Sense) | | PLL | 16 | 1-3 | P:\$20 | Phase-Locked Loop | | FM | 17 | 0-2 | P:\$22 | FM Access Error Interrupt | # **Table 4-2 Interrupt Vector Table Contents**<sup>1</sup> (Continued) | Peripheral | Vector<br>Number | Priority<br>Level | Vector Base<br>Address + | Interrupt Function | |------------|------------------|-------------------|--------------------------|---------------------------------------------| | FM | 18 | 0-2 | P:\$24 | FM Command Complete | | FM | 19 | 0-2 | P:\$26 | FM Command, Data, and Address Buffers Empty | | | 20 - 23 | | | Reserved | | GPIOD | 24 | 0-2 | P:\$30 | GPIOD | | GPIOC | 25 | 0-2 | P:\$32 | GPIOC | | GPIOB | 26 | 0-2 | P:\$34 | GPIOB | | GPIOA | 27 | 0-2 | P:\$36 | GPIOA | | QSPI0 | 28 | 0-2 | P:\$38 | QSPI0 Receiver Full | | QSPI0 | 29 | 0-2 | P:\$3A | QSPI0 Transmitter Empty | | | 30 - 31 | | | Reserved | | QSCI0 | 32 | 0-2 | P:\$40 | QSCI0 Transmitter Empty | | QSCI0 | 33 | 0-2 | P:\$42 | QSCI0 Transmitter Idle | | QSCI0 | 34 | 0-2 | P:\$44 | QSCI0 Receiver Error | | QSCI0 | 35 | 0-2 | P:\$46 | QSCI0 Receiver Full | | | 36 - 39 | | | Reserved | | I2C | 40 | 0-2 | P:\$50 | I <sup>2</sup> C Error | | I2C | 41 | 0-2 | P:\$52 | I <sup>2</sup> C General | | I2C | 42 | 0-2 | P:\$54 | I <sup>2</sup> C Receive | | I2C | 43 | 0-2 | P:\$56 | I <sup>2</sup> C Transmit | | I2C | 44 | 0-2 | P:\$58 | I <sup>2</sup> C Status | | TMRA | 45 | 0-2 | P:\$5A | Timer A, Channel 0 | | TMRA | 46 | 0-2 | P:\$5C | Timer A, Channel 1 | | TMRA | 47 | 0-2 | P:\$5E | Timer A, Channel 2 | | TMRA | 48 | 0-2 | P:\$60 | Timer A, Channel 3 | | | 49 - 52 | | | Reserved | | CMPA | 53 | 0-2 | P:\$6A | Comparator A | | СМРВ | 54 | 0-2 | P:\$6C | Comparator B | | PIT0 | 55 | 0-2 | P:\$6E | Interval Timer 0 | | | 56 - 57 | | | Reserved | | ADC | 58 | 0-2 | P:\$74 | ADC A Conversion Complete | | ADC | 59 | 0-2 | P:\$76 | ADC B Conversion Complete | | ADC | 60 | 0-2 | P:\$78 | ADC Zero Crossing or Limit Error | | PWM | 61 | 0-2 | P:\$7A | Reload PWM | | PWM | 62 | 0-2 | P:\$7C | PWM Fault | | SWILP | 63 | -1 | P:\$7E | SW Interrupt Low Priority | <sup>1.</sup> Two words are allocated for each entry in the vector table. This does not allow the full address range to be referenced from the vector table, providing only 19 bits of address. <sup>2.</sup> If the VBA is set to \$0000, the first two locations of the vector table will overlay the chip reset addresses since the reset address would match the base of this vector table. # 4.3 Program Map The Program Memory map is shown in **Table 4-3**. Table 4-3 Program Memory Map<sup>1</sup> at Reset | Begin/End Address | Memory Allocation | |------------------------------|-------------------------------------------------------------------------------------| | P: \$1F FFFF<br>P: \$00 8800 | RESERVED | | P: \$00 87FF<br>P: \$00 8000 | On-Chip RAM <sup>2</sup><br>4KB | | P: \$00 7FFF<br>P: \$00 4000 | Internal Program Flash 32KB Cop Reset Address = \$00 4002 Boot Location = \$00 4000 | | P: \$00 3FFF<br>P: \$00 0000 | RESERVED | <sup>1.</sup> All addresses are 16-bit Word addresses. # 4.4 Data Map Table 4-4 Data Memory Map<sup>1</sup> | Begin/End Address | Memory Allocation | |----------------------------|-------------------------------------------------| | X:\$FF FFFF<br>X:\$FF FF00 | EOnCE<br>256 locations allocated | | X:\$FF FEFF<br>X:\$01 0000 | RESERVED | | X:\$00 FFFF<br>X:\$00 F000 | On-Chip Peripherals<br>4096 locations allocated | | X:\$00 EFFF<br>X:\$00 8800 | RESERVED | | X:\$00 87FF<br>X:\$00 8000 | RESERVED | | X:\$00 7FFF<br>X:\$00 0800 | RESERVED | | X:\$00 07FF<br>X:\$00 0000 | On-Chip Data RAM<br>4KB <sup>2</sup> | <sup>1.</sup> All addresses are 16-bit Word addresses. <sup>2.</sup> This RAM is shared with Data space starting at address X: \$00 0000; see Figure 4-1. <sup>2.</sup> This RAM is shared with Program space starting at P: \$00 8000; see Figure 4-1. Figure 4-1 Dual Port RAM # 4.5 EOnCE Memory Map Figure 4-5 lists all EOnCE registers necessary to access or control the EOnCE. | , | | | |---------------------------|--------------------------|-------------------------------------------------------------| | Address | Register Acronym | Register Name | | X:\$FF FFFF | OTX1 / ORX1 | Transmit Register Upper Word<br>Receive Register Upper Word | | X:\$FF FFFE | OTX / ORX (32 bits) | Transmit Register Receive Register | | X:\$FF FFFD | OTXRXSR | Transmit and Receive Status and Control Register | | X:\$FF FFFC | OCLSR | Core Lock / Unlock Status Register | | X:\$FF FFFB - X:\$FF FFA1 | | Reserved | | X:\$FF FFA0 | OCR | Control Register | | X:\$FF FF9F | | Instruction Step Counter | | X:\$FF FF9E | OSCNTR (24 bits) | Instruction Step Counter | | X:\$FF FF9D | OSR | Status Register | | X:\$FF FF9C | OBASE | Peripheral Base Address Register | | X:\$FF FF9B | OTBCR | Trace Buffer Control Register | | X:\$FF FF9A | OTBPR | Trace Buffer Pointer Register | | X:\$FF FF99 | | Trace Buffer Register Stages | | X:\$FF FF98 | OTB (21 - 24 bits/stage) | Trace Buffer Register Stages | | X:\$FF FF97 | | Breakpoint Unit Control Register | | X:\$FF FF96 | OBCR (24 bits) | Breakpoint Unit Control Register | | X:\$FF FF95 | | Breakpoint Unit Address Register 1 | | X:\$FF FF94 | OBAR1 (24 bits) | Breakpoint Unit Address Register 1 | **Table 4-5 EOnCE Memory Map** **Table 4-5 EOnCE Memory Map (Continued)** | Address | Register Acronym | Register Name | |---------------------------|------------------|------------------------------------| | X:\$FF FF93 | | Breakpoint Unit Address Register 2 | | X:\$FF FF92 | OBAR2 (32 bits) | Breakpoint Unit Address Register 2 | | X:\$FF FF91 | | Breakpoint Unit Mask Register 2 | | X:\$FF FF90 | OBMSK (32 bits) | Breakpoint Unit Mask Register 2 | | X:\$FF FF8F | | Reserved | | X:\$FF FF8E | OBCNTR | EOnCE Breakpoint Unit Counter | | X:\$FF FF8D | | Reserved | | X:\$FF FF8C | | Reserved | | X:\$FF FF8B | | Reserved | | X:\$FF FF8A | OESCR | External Signal Control Register | | X:\$FF FF89 - X:\$FF FF00 | | Reserved | # 4.6 Peripheral Memory-Mapped Registers On-chip peripheral registers are part of the data memory map on the 56800E series. These locations may be accessed with the same addressing modes used for ordinary Data memory, except all peripheral registers should be read or written using word accesses only. **Table 4-6** summarizes base addresses for the set of peripherals on the 56F8023 device. Peripherals are listed in order of the base address. The following tables list all of the peripheral registers required to control or access the peripherals. **Table 4-6 Data Memory Peripheral Base Address Map Summary** | Peripheral | Prefix | Base Address | Table Number | |------------------|--------|--------------|--------------| | Timer A | TMRA | X:\$00 F000 | 4-7 | | ADC | ADC | X:\$00 F080 | 4-8 | | PWM | PWM | X:\$00 F0C0 | 4-9 | | ITCN | ITCN | X:\$00 F0E0 | 4-10 | | SIM | SIM | X:\$00 F100 | 4-11 | | COP | COP | X:\$00 F120 | 4-12 | | CLK, PLL, OSC | occs | X:\$00 F130 | 4-13 | | Power Supervisor | PS | X:\$00 F140 | 4-14 | | GPIO Port A | GPIOA | X:\$00 F150 | 4-15 | | GPIO Port B | GPIOB | X:\$00 F160 | 4-16 | | GPIO Port C | GPIOC | X:\$00 F170 | 4-17 | | GPIO Port D | GPIOD | X:\$00 F180 | 4-18 | | PIT 0 | PIT0 | X:\$00 F190 | 4-19 | Table 4-6 Data Memory Peripheral Base Address Map Summary (Continued) | Peripheral | Prefix | Base Address | Table Number | |------------------|--------|--------------|--------------| | DAC 0 | DAC0 | X:\$00 F1C0 | 4-20 | | DAC 1 | DAC1 | X:\$00 F1D0 | 4-21 | | Comparator A | CMPA | X:\$00 F1E0 | 4-22 | | Comparator B | СМРВ | X:\$00 F1F0 | 4-23 | | QSCI 0 | SCI0 | X:\$00 F200 | 4-24 | | QSPI 0 | SPI0 | X:\$00 F220 | 4-25 | | I <sup>2</sup> C | I2C | X:\$00 F280 | 4-26 | | FM | FM | X:\$00 F400 | 4-27 | Table 4-7 Quad Timer A Registers Address Map (TMRA\_BASE = \$00 F000) | Register Acronym | Address Offset | Register Description | |--------------------------------------------------------------------------------------------|------------------------------|--------------------------------------------------------------------------------| | TMRA0_COMP1 | \$0 | Compare Register 1 | | TMRA0_COMP2 | \$1 | Compare Register 2 | | TMRA0_CAPT | \$2 | Capture Register | | TMRA0_LOAD | \$3 | Load Register | | TMRA0_HOLD | \$4 | Hold Register | | TMRA0_CNTR | \$5 | Counter Register | | TMRA0_CTRL | \$6 | Control Register | | TMRA0_SCTRL | \$7 | Status and Control Register | | TMRA0_CMPLD1 | \$8 | Comparator Load Register 1 | | TMRA0_CMPLD2 | \$9 | Comparator Load Register 2 | | TMRA0_CSCTRL | \$A | Comparator Status and Control Register | | TMRA0_FILT | \$B | Input Filter Register | | | | Reserved | | TMRA0_ENBL | \$F | Timer Channel Enable Register | | TMRA1_COMP1 | \$10 | Compare Register 1 | | TMRA1_COMP2 | \$11 | Compare Register 2 | | TMRA1_CAPT | \$12 | Capture Register | | TMRA1 LOAD | 040 | | | - · · · · · · <del>_</del> <del>_</del> <del>_</del> <del>-</del> · · · · · <del>_</del> _ | \$13 | Load Register | | TMRA1_HOLD | \$13<br>\$14 | Load Register Hold Register | | | · | <u> </u> | | TMRA1_HOLD | \$14 | Hold Register | | TMRA1_HOLD TMRA1_CNTR | \$14<br>\$15 | Hold Register Counter Register | | TMRA1_HOLD TMRA1_CNTR TMRA1_CTRL | \$14<br>\$15<br>\$16 | Hold Register Counter Register Control Register | | TMRA1_HOLD TMRA1_CNTR TMRA1_CTRL TMRA1_SCTRL | \$14<br>\$15<br>\$16<br>\$17 | Hold Register Counter Register Control Register Status and Control Register | Table 4-7 Quad Timer A Registers Address Map (Continued) (TMRA\_BASE = \$00 F000) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------------------------| | TMRA1_FILT | \$1B | Input Filter Register | | | | Reserved | | TMRA2_COMP1 | \$20 | Compare Register 1 | | TMRA2_COMP2 | \$21 | Compare Register 2 | | TMRA2_CAPT | \$22 | Capture Register | | TMRA2_LOAD | \$23 | Load Register | | TMRA2_HOLD | \$24 | Hold Register | | TMRA2_CNTR | \$25 | Counter Register | | TMRA2_CTRL | \$26 | Control Register | | TMRA2_SCTRL | \$27 | Status and Control Register | | TMRA2_CMPLD1 | \$28 | Comparator Load Register 1 | | TMRA2_CMPLD2 | \$29 | Comparator Load Register 2 | | TMRA2_CSCTRL | \$2A | Comparator Status and Control Register | | TMRA2_FILT | \$2B | Input Filter Register | | | | Reserved | | TMRA3_COMP1 | \$30 | Compare Register 1 | | TMRA3_COMP2 | \$31 | Compare Register 2 | | TMRA3_CAPT | \$32 | Capture Register | | TMRA3_LOAD | \$33 | Load Register | | TMRA3_HOLD | \$34 | Hold Register | | TMRA3_CNTR | \$35 | Counter Register | | TMRA3_CTRL | \$36 | Control Register | | TMRA3_SCTRL | \$37 | Status and Control Register | | TMRA3_CMPLD1 | \$38 | Comparator Load Register 1 | | TMRA3_CMPLD2 | \$39 | Comparator Load Register 2 | | TMRA3_CSCTRL | \$3A | Comparator Status and Control Register | | TMRA3_FILT | \$3B | Input Filter Register | | | | Reserved | Table 4-8 Analog-to-Digital Converter Registers Address Map (ADC\_BASE = \$00 F080) | | | - | |------------------|----------------|--------------------------------| | Register Acronym | Address Offset | Register Description | | ADC_CTRL1 | \$0 | Control Register 1 | | ADC_CTRL2 | \$1 | Control Register 2 | | ADC_ZXCTRL | \$2 | Zero Crossing Control Register | | ADC_CLIST 1 | \$3 | Channel List Register 1 | Table 4-8 Analog-to-Digital Converter Registers Address Map (Continued) (ADC\_BASE = \$00 F080) | Register Acronym | Address Offset | Register Description | |------------------|----------------|-------------------------------| | ADC_CLIST 2 | \$4 | Channel List Register 2 | | ADC_CLIST 3 | \$5 | Channel List Register 3 | | ADC_CLIST 4 | \$6 | Channel List Register 4 | | ADC_SDIS | \$7 | Sample Disable Register | | ADC_STAT | \$8 | Status Register | | ADC_RDY | \$9 | Conversion Ready Register | | ADC_LIMSTAT | \$A | Limit Status Register | | ADC_ZXSTAT | \$B | Zero Crossing Status Register | | ADC_RSLT0 | \$C | Result Register 0 | | ADC_RSLT1 | \$D | Result Register 1 | | ADC_RSLT2 | \$E | Result Register 2 | | ADC_RSLT3 | \$F | Result Register 3 | | ADC_RSLT4 | \$10 | Result Register 4 | | ADC_RSLT5 | \$11 | Result Register 5 | | ADC_RSLT6 | \$12 | Result Register 6 | | ADC_RSLT7 | \$13 | Result Register 7 | | ADC_RSLT8 | \$14 | Result Register 8 | | ADC_RSLT9 | \$15 | Result Register 9 | | ADC_RSLT10 | \$16 | Result Register 10 | | ADC_RSLT11 | \$17 | Result Register 11 | | ADC_RSLT12 | \$18 | Result Register 12 | | ADC_RSLT13 | \$19 | Result Register 13 | | ADC_RSLT14 | \$1A | Result Register 14 | | ADC_RSLT15 | \$1B | Result Register 15 | | ADC_LOLIM0 | \$1C | Low Limit Register 0 | | ADC_LOLIM1 | \$1D | Low Limit Register 1 | | ADC_LOLIM2 | \$1E | Low Limit Register 2 | | ADC_LOLIM3 | \$1F | Low Limit Register 3 | | ADC_LOLIM4 | \$20 | Low Limit Register 4 | | ADC_LOLIM5 | \$21 | Low Limit Register 5 | | ADC_LOLIM6 | \$22 | Low Limit Register 6 | | ADC_LOLIM7 | \$23 | Low Limit Register 7 | | ADC_HILIM0 | \$24 | High Limit Register 0 | | ADC_HILIM1 | \$25 | High Limit Register 1 | | ADC_HILIM2 | \$26 | High Limit Register 2 | | ADC_HILIM3 | \$27 | High Limit Register 3 | Table 4-8 Analog-to-Digital Converter Registers Address Map (Continued) (ADC\_BASE = \$00 F080) | Register Acronym | Address Offset | Register Description | |------------------|----------------|------------------------| | ADC_HILIM4 | \$28 | High Limit Register 4 | | ADC_HILIM5 | \$29 | High Limit Register 5 | | ADC_HILIM6 | \$2A | High Limit Register 6 | | ADC_HILIM7 | \$2B | High Limit Register 7 | | ADC_OFFST0 | \$2C | Offset Register 0 | | ADC_OFFST1 | \$2D | Offset Register 1 | | ADC_OFFST2 | \$2E | Offset Register 2 | | ADC_OFFST3 | \$2F | Offset Register 3 | | ADC_OFFST4 | \$30 | Offset Register 4 | | ADC_OFFST5 | \$31 | Offset Register 5 | | ADC_OFFST6 | \$32 | Offset Register 6 | | ADC_OFFST7 | \$33 | Offset Register 7 | | ADC_PWR | \$34 | Power Control Register | | ADC_CAL | \$35 | Calibration Register | | | | Reserved | Table 4-9 Pulse Width Modulator Registers Address Map (PWM\_BASE = \$00 F0C0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|-----------------------------------| | PWM_CTRL | \$0 | Control Register | | PWM_FCTRL | \$1 | Fault Control Register | | PWM_FLTACK | \$2 | Fault Status Acknowledge Register | | PWM_OUT | \$3 | Output Control Register | | PWM_CNTR | \$4 | Counter Register | | PWM_CMOD | \$5 | Counter Modulo Register | | PWM_VAL0 | \$6 | Value Register 0 | | PWM_VAL1 | \$7 | Value Register 1 | | PWM_VAL2 | \$8 | Value Register 2 | | PWM_VAL3 | \$9 | Value Register 3 | | PWM_VAL4 | \$A | Value Register 4 | | PWM_VAL5 | \$B | Value Register 5 | | PWM_DTIM0 | \$C | Dead Time Register 0 | | PWM_DTIM1 | \$D | Dead Time Register 1 | | PWM_DMAP1 | \$E | Disable Mapping Register 1 | | PWM_DMAP2 | \$F | Disable Mapping Register 2 | | PWM_CNFG | \$10 | Configure Register | Table 4-9 Pulse Width Modulator Registers Address Map (Continued) (PWM\_BASE = \$00 F0C0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|--------------------------------------| | PWM_CCTRL | \$11 | Channel Control Register | | PWM_PORT | \$12 | Port Register | | PWM_ICCTRL | \$13 | Internal Correction Control Register | | PWM_SCTRL | \$14 | Source Control Register | | PWM_SYNC | \$15 | Synchronization Window Register | | PWM_FFILT0 | \$16 | Fault0 Filter Register | | PWM_FFILT1 | \$17 | Fault1 Filter Register | | PWM_FFILT2 | \$18 | Fault2 Filter Register | | PWM_FFILT3 | \$19 | Fault3 Filter Register | Table 4-10 Interrupt Control Registers Address Map (ITCN\_BASE = \$00 F0E0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|-----------------------------------------------| | ITCN_IPR0 | \$0 | Interrupt Priority Register 0 | | ITCN_IPR1 | \$1 | Interrupt Priority Register 1 | | ITCN_IPR2 | \$2 | Interrupt Priority Register 2 | | ITCN_IPR3 | \$3 | Interrupt Priority Register 3 | | ITCN_IPR4 | \$4 | Interrupt Priority Register 4 | | ITCN_IPR5 | \$5 | Interrupt Priority Register 5 | | ITCN_IPR6 | \$6 | Interrupt Priority Register 6 | | ITCN_VBA | \$7 | Vector Base Address Register | | ITCN_FIM0 | \$8 | Fast Interrupt Match 0 Register | | ITCN_FIVAL0 | \$9 | Fast Interrupt Vector Address Low 0 Register | | ITCN_FIVAH0 | \$A | Fast Interrupt Vector Address High 0 Register | | ITCN_FIM1 | \$B | Fast Interrupt Match 1 Register | | ITCN_FIVAL1 | \$C | Fast Interrupt Vector Address Low 1 Register | | ITCN_FIVAH1 | \$D | Fast Interrupt Vector Address High 1 Register | | ITCN_IRQP0 | \$E | IRQ Pending Register 0 | | ITCN_IRQP1 | \$F | IRQ Pending Register 1 | | ITCN_IRQP2 | \$10 | IRQ Pending Register 2 | | ITCN_IRQP3 | \$11 | IRQ Pending Register 3 | | | | Reserved | | ITCN_ICTRL | \$16 | Interrupt Control Register | | | | Reserved | # Table 4-11 SIM Registers Address Map (SIM\_BASE = \$00 F100) | Register Acronym | Address Offset | Register Description | |------------------|----------------|---------------------------------------------| | SIM_CTRL | \$0 | Control Register | | SIM_RSTAT | \$1 | Reset Status Register | | SIM_SWC0 | \$2 | Software Control Register 0 | | SIM_SWC1 | \$3 | Software Control Register 1 | | SIM_SWC2 | \$4 | Software Control Register 2 | | SIM_SWC3 | \$5 | Software Control Register 3 | | SIM_MSHID | \$6 | Most Significant Half JTAG ID | | SIM_LSHID | \$7 | Least Significant Half JTAG ID | | SIM_PWR | \$8 | Power Control Register | | | | Reserved | | SIM_CLKOUT | \$A | Clock Out Select Register | | SIM_PCR | \$B | Peripheral Clock Rate Register | | SIM_PCE0 | \$C | Peripheral Clock Enable Register 0 | | SIM_PCE1 | \$D | Peripheral Clock Enable Register 1 | | SIM_SD0 | \$E | Peripheral STOP Disable Register 0 | | SIM_SD1 | \$F | Peripheral STOP Disable Register 1 | | SIM_IOSAHI | \$10 | I/O Short Address Location High Register | | SIM_IOSALO | \$11 | I/O Short Address Location Low Register | | SIM_PROT | \$12 | Protection Register | | SIM_GPSA0 | \$13 | GPIO Peripheral Select Register 0 for GPIOA | | | | Reserved | | SIM_GPSB0 | \$15 | GPIO Peripheral Select Register 0 for GPIOB | | SIM_GPSB1 | \$16 | GPIO Peripheral Select Register 1 for GPIOB | | | | Reserved | | SIM_ISS0 | \$18 | Internal Source Select Register 0 for PWM | | SIM_ISS1 | \$19 | Internal Source Select Register 1 for DACs | | SIM_ISS2 | \$1A | Internal Source Select Register 2 for TMRA | | | | Reserved | Table 4-12 Computer Operating Properly Registers Address Map (COP\_BASE = \$00 F120) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | COP_CTRL | \$0 | Control Register | | COP_TOUT | \$1 | Time-Out Register | # Table 4-12 Computer Operating Properly Registers Address Map (COP BASE = \$00 F120) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | COP_CNTR | \$2 | Counter Register | # Table 4-13 Clock Generation Module Registers Address Map (OCCS\_BASE = \$00 F130) | Register Acronym | Address Offset | Register Description | |------------------|----------------|-----------------------------| | OCCS_CTRL | \$0 | Control Register | | OCCS_DIVBY | \$1 | Divide-By Register | | OCCS_STAT | \$2 | Status Register | | | | Reserved | | OCCS_OCTRL | \$5 | Oscillator Control Register | | OCCS_CLKCHK | \$6 | Clock Check Register | | OCCS_PROT | \$7 | Protection Register | #### Table 4-14 Power Supervisor Registers Address Map (PS BASE = \$00 F140) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | PS_CTRL | \$0 | Control Register | | PS_STAT | \$1 | Status Register | | | | Reserved | #### Table 4-15 GPIOA Registers Address Map (GPIOA\_BASE = \$00 F150) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------------------------| | GPIOA_PUPEN | \$0 | Pull-up Enable Register | | GPIOA_DATA | \$1 | Data Register | | GPIOA_DDIR | \$2 | Data Direction Register | | GPIOA_PEREN | \$3 | Peripheral Enable Register | | GPIOA_IASSRT | \$4 | Interrupt Assert Register | | GPIOA_IEN | \$5 | Interrupt Enable Register | | GPIOA_IEPOL | \$6 | Interrupt Edge Polarity Register | | GPIOA_IPEND | \$7 | Interrupt Pending Register | | GPIOA_IEDGE | \$8 | Interrupt Edge-Sensitive Register | | GPIOA_PPOUTM | \$9 | Push-Pull Output Mode Control Register | | GPIOA_RDATA | \$A | Raw Data Input Register | | GPIOA_DRIVE | \$B | Output Drive Strength Control Register | # Table 4-16 GPIOB Registers Address Map (GPIOB\_BASE = \$00 F160) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------------------------| | GPIOB_PUPEN | \$0 | Pull-up Enable Register | | GPIOB_DATA | \$1 | Data Register | | GPIOB_DDIR | \$2 | Data Direction Register | | GPIOB_PEREN | \$3 | Peripheral Enable Register | | GPIOB_IASSRT | \$4 | Interrupt Assert Register | | GPIOB_IEN | \$5 | Interrupt Enable Register | | GPIOB_IEPOL | \$6 | Interrupt Edge Polarity Register | | GPIOB_IPEND | \$7 | Interrupt Pending Register | | GPIOB_IEDGE | \$8 | Interrupt Edge-Sensitive Register | | GPIOB_PPOUTM | \$9 | Push-Pull Output Mode Control Register | | GPIOB_RDATA | \$A | Raw Data Input Register | | GPIOB_DRIVE | \$B | Output Drive Strength Control Register | # Table 4-17 GPIOC Registers Address Map (GPIOC\_BASE = \$00 F170) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------------------------| | GPIOC_PUPEN | \$0 | Pull-up Enable Register | | GPIOC_DATA | \$1 | Data Register | | GPIOC_DDIR | \$2 | Data Direction Register | | GPIOC_PEREN | \$3 | Peripheral Enable Register | | GPIOC_IASSRT | \$4 | Interrupt Assert Register | | GPIOC_IEN | \$5 | Interrupt Enable Register | | GPIOC_IEPOL | \$6 | Interrupt Edge Polarity Register | | GPIOC_IPEND | \$7 | Interrupt Pending Register | | GPIOC_IEDGE | \$8 | Interrupt Edge-Sensitive Register | | GPIOC_PPOUTM | \$9 | Push-Pull Output Mode Control Register | | GPIOC_RDATA | \$A | Raw Data Input Register | | GPIOC_DRIVE | \$B | Output Drive Strength Control Register | #### Table 4-18 GPIOD Registers Address Map (GPIOD\_BASE = \$00 F180) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------------------------| | GPIOD_PUPEN | \$0 | Pull-up Enable Register | | GPIOD_DATA | \$1 | Data Register | | GPIOD_DDIR | \$2 | Data Direction Register | | GPIOD_PEREN | \$3 | Peripheral Enable Register | | GPIOD_IASSRT | \$4 | Interrupt Assert Register | | GPIOD_IEN | \$5 | Interrupt Enable Register | | GPIOD_IEPOL | \$6 | Interrupt Edge Polarity Register | | GPIOD_IPEND | \$7 | Interrupt Pending Register | | GPIOD_IEDGE | \$8 | Interrupt Edge-Sensitive Register | | GPIOD_PPOUTM | \$9 | Push-Pull Output Mode Control Register | | GPIOD_RDATA | \$A | Raw Data Input Register | | GPIOD_DRIVE | \$B | Output Drive Strength Control Register | Table 4-19 Programmable Interval Timer 0 Registers Address Map (PIT0\_BASE = \$00 F190) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | PIT0_CTRL | \$0 | Control Register | | PIT0_MOD | \$1 | Modulo Register | | PIT0_CNTR | \$2 | Counter Register | Table 4-20 Digital-to-Analog Converter 0 Registers Address Map (DAC0\_BASE = \$00 F1C0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|------------------------| | DAC0_CTRL | \$0 | Control Register | | DAC0_DATA | \$1 | Data Register | | DAC0_STEP | \$2 | Step Register | | DAC0_MINVAL | \$3 | Minimum Value Register | | DAC0_MAXVAL | \$4 | Maximum Value Register | Table 4-21 Digital-to-Analog Converter 0 Registers Address Map (DAC0\_BASE = \$00 F1C0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|------------------------| | DAC0_CTRL | \$0 | Control Register | | DAC0_DATA | \$1 | Data Register | | DAC0_STEP | \$2 | Step Register | | DAC0_MINVAL | \$3 | Minimum Value Register | | DAC0_MAXVAL | \$4 | Maximum Value Register | Table 4-22 Comparator A Registers Address Map (CMPA\_BASE = \$00 F1E0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | CMPA_CTRL | \$0 | Control Register | | CMPA_STAT | \$1 | Status Register | | CMPA_FILT | \$2 | Filter Register | #### Table 4-23 Comparator B Registers Address Map (CMPB\_BASE = \$00 F1F0) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | CMPB_CTRL | \$0 | Control Register | | CMPB_STAT | \$1 | Status Register | | CMPB_FILT | \$2 | Filter Register | Table 4-24 Queued Serial Communication Interface 0 Registers Address Map (QSCI0\_BASE = \$00 F200) | Register Acronym | Address Offset | Register Description | |------------------|----------------|----------------------| | QSCI0_RATE | \$0 | Baud Rate Register | | QSCI0_CTRL1 | \$1 | Control Register 1 | | QSCI0_CTRL2 | \$2 | Control Register 2 | | QSCI0_STAT | \$3 | Status Register | | QSCI0_DATA | \$4 | Data Register | Table 4-25 Queued Serial Peripheral Interface 0 Registers Address Map (QSPI0\_BASE = \$00 F220) | Register Acronym | Address Offset | Register Description | |------------------|----------------|--------------------------------| | QSPI0_SCTRL | \$0 | Status and Control Register | | QSPI0_DSCTRL | \$1 | Data Size and Control Register | | QSPI0_DRCV | \$2 | Data Receive Register | | QSPI0_DXMIT | \$3 | Data Transmit Register | | QSPI0_FIFO | \$4 | FIFO Control Register | | QSPI0_DELAY | \$5 | Delay Register | # Table 4-26 I<sup>2</sup>C Registers Address Map (I2C\_BASE = \$00 F280) | Register Acronym | Address Offset | Register Description | |------------------|----------------|---------------------------------------------------| | I2C_CTRL | \$0 | Control Register | | I2C_TAR | \$2 | Target Address Register | | I2C_SAR | \$4 | Slave Address Register | | I2C_DATA | \$8 | RX/TX Data Buffer and Command Register | | I2C_SSHCNT | \$A | Standard Speed Clock SCL High Count Register | | I2C_SSLCNT | \$C | Standard Speed Clock SCL Low Count Register | | I2C_FSHCNT | \$E | Fast Speed Clock SCL High Count Register | | I2C_FSLCNT | \$10 | Fast Speed Clock SCL Low Count Register | | I2C_ISTAT | \$16 | Interrupt Status Register | | I2C_IMASK | \$18 | Interrupt Mask Register | | I2C_RISTAT | \$1A | Raw Interrupt Status Register | | I2C_RXFT | \$1C | Receive FIFO Threshold Register | | I2C_TXFT | \$1E | Transmit FIFO Threshold Register | | I2C_CLRINT | \$20 | Clear Combined and Individual Interrupts Register | | I2C_CLRRXUND | \$22 | Clear RX_UNDER Interrupt Register | | I2C_CLRRXOVR | \$24 | Clear RX_OVER Interrupt Register | | I2C_CLRTXOVR | \$26 | Clear TX_OVER Interrupt Register | | I2C_CLRRDREQ | \$28 | Clear RD_REQ Interrupt Register | | I2C_CLRTXABRT | \$2A | Clear TX_ABRT Interrupt Register | | I2C_CLRRXDONE | \$2C | Clear RX_DONE Interrupt Register | | I2C_CLRACT | \$2E | Clear Activity Interrupt Register | | I2C_CLRSTPDET | \$30 | Clear STOP_DET Interrupt Register | | I2C_CLRSTDET | \$32 | Clear START_DET Interrupt Register | | I2C_CLRGC | \$34 | Clear GEN_CALL Interrupt Register | # Table 4-26 I<sup>2</sup>C Registers Address Map (Continued) (I2C\_BASE = \$00 F280) | Register Acronym | Address Offset | Register Description | |------------------|----------------|--------------------------------| | I2C_ENBL | \$36 | Enable Register | | I2C_STAT | \$38 | Status Register | | I2C_TXFLR | \$3A | Transmit FIFO Level Register | | I2C_RXFLR | \$3C | Receive FIFO Level Register | | I2C_TXABRTSRC | \$40 | Transmit Abort Status Register | Table 4-27 Flash Module Registers Address Map (FM\_BASE = \$00 F400) | Register Acronym | Address Offset | Register Description | |------------------|----------------|-------------------------------| | FM_CLKDIV | \$0 | Clock Divider Register | | FM_CNFG | \$1 | Configuration Register | | | \$2 | Reserved | | FM_SECHI | \$3 | Security High Half Register | | FM_SECLO | \$4 | Security Low Half Register | | | \$5 - \$9 | Reserved | | FM_PROT | \$10 | Protection Register | | | \$11 - \$12 | Reserved | | FM_USTAT | \$13 | User Status Register | | FM_CMD | \$14 | Command Register | | | \$15 - \$17 | Reserved | | FM_DATA | \$18 | Data Buffer Register | | | \$19 - \$A | Reserved | | FM_IFROPT_1 | \$1B | Information Option Register 1 | | | \$1C | Reserved | | FM_TSTSIG | \$1D | Test Array Signature Register | # Part 5 Interrupt Controller (ITCN) # 5.1 Introduction The Interrupt Controller (ITCN) module arbitrates between various interrupt requests (IRQs), signals to the 56800E core when an interrupt of sufficient priority exists, and to what address to jump in order to service this interrupt. # 5.2 Features The ITCN module design includes these distinctive features: - Programmable priority levels for each IRQ - Two programmable Fast Interrupts - Notification to SIM module to restart clocks out of Wait and Stop modes - Ability to drive initial address on the address bus after reset For further information, see **Table 4-2**, Interrupt Vector Table Contents. # 5.3 Functional Description The Interrupt Controller is a slave on the IPBus. It contains registers that allow each of the 64 interrupt sources to be set to one of four priority levels (excluding certain interrupts that are of fixed priority). Next, all of the interrupt requests of a given level are priority encoded to determine the lowest numerical value of the active interrupt requests for that level. Within a given priority level, number 0 is the highest priority and number 63 is the lowest. # 5.3.1 Normal Interrupt Handling Once the INTC has determined that an interrupt is to be serviced and which interrupt has the highest priority, an interrupt vector address is generated. Normal interrupt handling concatenates the Vector Base Address (VBA) and the vector number to determine the vector address, generating an offset into the vector table for each interrupt. ## 5.3.2 Interrupt Nesting Interrupt exceptions may be nested to allow an IRQ of higher priority than the current exception to be serviced. The 56800E core controls the masking of interrupt priority levels it will accept by setting the I0 and I1 bits in its status register. SR[9] (I1) **Exceptions Masked** SR[8] (10) **Exceptions Permitted** 0 0 Priorities 0, 1, 2, 3 None 0 1 Priorities 1, 2, 3 Priority 0 1 0 Priorities 2, 3 Priorities 0, 1 1 1 Priority 3 Priorities 0, 1, 2 **Table 5-1 Interrupt Mask Bit Definition** The IPIC bits of the ICTRL register reflect the state of the priority level being presented to the 56800E core. **Table 5-2 Interrupt Priority Encoding** | IPIC_VALUE[1:0] | Current Interrupt<br>Priority Level | Required Nested<br>Exception Priority | |-----------------|-------------------------------------|---------------------------------------| | 00 | No interrupt or SWILP | Priorities 0, 1, 2, 3 | | 01 | Priority 0 | Priorities 1, 2, 3 | | 10 | Priority 1 | Priorities 2, 3 | | 11 | Priority 2 or 3 | Priority 3 | ## 5.3.3 Fast Interrupt Handling Fast interrupts are described in the **DSP56800E Reference Manual**. The interrupt controller recognizes Fast Interrupts before the core does. A Fast Interrupt is defined (to the ITCN) by: - 1. Setting the priority of the interrupt as level 2, with the appropriate field in the IPR registers - 2. Setting the FIM*n* register to the appropriate vector number - 3. Setting the FIVALn and FIVAHn registers with the address of the code for the Fast Interrupt When an interrupt occurs, its vector number is compared with the FIM0 and FIM1 register values. If a match occurs, and it is a level 2 interrupt, the ITCN handles it as a Fast Interrupt. The ITCN takes the vector address from the appropriate FIVAL*n* and FIVAH*n* registers, instead of generating an address that is an offset from the VBA. The core then fetches the instruction from the indicated vector address and if it is not a JSR, the core starts its Fast Interrupt handling. # 5.4 Block Diagram Figure 5-1 Interrupt Controller Block Diagram # 5.5 Operating Modes The ITCN module design contains two major modes of operation: - Functional Mode - The ITCN is in this mode by default. - Wait and Stop Modes During Wait and Stop modes, the system clocks and the 56800E core are turned off. The ITCN will signal a pending IRQ to the System Integration Module (SIM) to restart the clocks and service the IRQ. An IRQ can only wake up the core if the IRQ is enabled prior to entering the Wait or Stop mode. # 5.6 Register Descriptions A register address is the sum of a base address and an address offset. The base address is defined at the system level and the address offset is defined at the module level. # Table 5-3 ITCN Register Summary (ITCN\_BASE = \$00 F060) | Register<br>Acronym | Base Address + | Register Name | Section Location | |---------------------|----------------|-------------------------------------------------|------------------| | IPR0 | \$0 | Interrupt Priority Register 0 | 5.6.1 | | IPR1 | \$1 | Interrupt Priority Register 1 | 5.6.2 | | IPR2 | \$2 | Interrupt Priority Register 2 | 5.6.3 | | IPR3 | \$3 | Interrupt Priority Register 3 | 5.6.4 | | IPR4 | \$4 | Interrupt Priority Register 4 | 5.6.5 | | IPR5 | \$5 | Interrupt Priority Register 5 | 5.6.6 | | IPR6 | \$6 | Interrupt Priority Register 6 | 5.6.7 | | VBA | \$7 | Vector Base Address Register | 5.6.8 | | FIM0 | \$8 | Fast Interrupt Match 0 Register | 5.6.9 | | FIVAL0 | \$9 | Fast Interrupt 0 Vector Address Low Register | 5.6.10 | | FIVAH0 | \$A | Fast Interrupt 0 Vector Address High 0 Register | 5.6.11 | | FIM1 | \$B | Fast Interrupt Match 1 Register | 5.6.12 | | FIVAL1 | \$C | Fast Interrupt 1 Vector Address Low Register | 5.6.13 | | FIVAH1 | \$D | Fast Interrupt 1 Vector Address High Register | 5.6.14 | | IRQP0 | \$E | IRQ Pending Register 0 | 5.6.15 | | IRQP1 | \$F | IRQ Pending Register 1 | 5.6.16 | | IRQP2 | \$10 | IRQ Pending Register 2 | 5.6.17 | | IRQP3 | \$11 | IRQ Pending Register 3 | 5.6.18 | | | | Reserved | | | ICTRL | \$16 | Interrupt Control Register | 5.6.19 | | | | Reserved | | | Add.<br>Offset | Register<br>Name | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |----------------|------------------|--------|-------------|-------------------------------------|------|--------|------------------|---------|-------------------|----------|------------------|------------|-------------|------------------|----------------|-----------------|-------------------|--------|--|--|--| | \$0 | IPR0 | R<br>W | PLL | . IPL | LVI | IPL | 0 | 0 | RX_RI | EG IPL | TX_R | EG IPL | TRBL | JF IPL | BKPT_ | _U IPL | STPC | NT IPL | | | | | \$1 | IPR1 | R<br>W | GPIO | D IPL | 0 | 0 | 0 0 0 0 | | 0 | 0 | 0 | FM_C | BE IPL | FM_CC IPL | | FM_ERR IPL | | | | | | | \$2 | IPR2 | R<br>W | | _XMIT<br>PL | 0 | 0 | 0 | 0 | QSPI0_XMIT<br>IPL | | QSPI0_RCV<br>IPL | | GPIC | A IPL | GPIOB IPL | | GPIOC IPL | | | | | | \$3 | IPR3 | R<br>W | I2C_ERR IPL | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | )_RCV<br>PL | QSCI0_<br>IF | _RERR<br>PL | QSCI0_TIDL<br>IPL | | | | | | \$4 | IPR4 | R<br>W | TMRA_3 IPL | | TMRA | _2 IPL | TMRA | _1 IPL | TMRA | _0 IPL | I2C_S | STAT<br>PL | 12C_1 | X IPL | I2C_F | X IPL | I2C_G | EN IPL | | | | | \$5 | IPR5 | R<br>W | 0 | 0 | PITO | ) IPL | COMF | PB IPL | COMF | PA IPL | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | \$6 | IPR6 | | 0 | 0 | 0 | 0 | PWM <sub>.</sub> | _F IPL | PWM_ | RL IPL | ADC_2 | ZC IPL | | B_CC<br>PL | ADC/ | A_CC<br>PL | 0 | 0 | | | | | \$7 | VBA | R<br>W | 0 | 0 VECTOR_BASE_ADDRESS | | | | | | | | | | | | | | | | | | | \$8 | FIM0 | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | FAST INTERRUPT 0 | | | | | | | | | \$9 | FIVAL0 | R<br>W | | FAST INTERRUPT 0 VECTOR ADDRESS LOW | | | | | | | | | | | | | | | | | | | \$A | FIVAH0 | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FA | ST INTE<br>ADD | RRUPT<br>RESS H | | OR | | | | | \$B | FIM1 | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | F.A | AST INT | ERRUP | Г1 | | | | | | \$C | FIVAL1 | R<br>W | | | | | | FAST II | NTERRU | IPT 1 VE | ECTOR A | ADDRES | SS LOW | 1 | | | | | | | | | \$D | FIVAH1 | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FA | ST INTE<br>ADD | RRUPT<br>RESS H | | OR | | | | | \$E | IRQP0 | R<br>W | | | | | | | PEI | NDING[1 | 6:2] | | | | | | | 1 | | | | | \$F | IRQP1 | R<br>W | | | | | | | | PENDIN | G[32:17 | ] | | | | | | | | | | | \$10 | IRQP2 | R<br>W | | | | | | | | PENDIN | G[48:33 | ] | | | | | | | | | | | \$11 | IRQP3 | R<br>W | | | | | | | | PENDIN | G[63:49 | ] | | | | | | | | | | | | Reserved | | | | | | | | | | | | | | | | | | | | | | \$16 | ICTRL | R<br>W | INT | IP | IC | | | | VAB | | | | INT_<br>DIS | 1 | 1 | 1 | 0 | 0 | | | | | | Reserved | VV | | | | | | | | | | | 0 | | | | | | | | | **Figure 5-2 ITCN Register Map Summary** = Reserved ## 5.6.1 Interrupt Priority Register 0 (IPR0) | Base + \$0 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----|-----|-----|-----|----|----|---------|------------|--------------|----------------|--------------|--------|------------|---|------------|---| | Read | PLL | IPI | LVI | IPL | 0 | 0 | RX RE | RX REG IPL | | SIPL TX REGIPL | | IF IPL | BKPT_U IPL | | STPCNT IPL | | | Write | , | | LVI | | | | 10/_1/1 | -0 11 L | TX_INLO II L | | I INDOI II E | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-3 Interrupt Priority Register 0 (IPR0) # 5.6.1.1 PLL Loss of Reference or Change in Lock Status Interrupt Priority Level (PLL IPL)—Bits 15–14 This field is used to set the interrupt priority levels for the PLL Loss of Reference or Change in Lock Status IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 #### 5.6.1.2 Low Voltage Detector Interrupt Priority Level (LVI IPL)—Bits 13–12 This field is used to set the interrupt priority levels for the Low Voltage Detector IRQ. This IRQ is limited to priorities 1 through 3 and is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 #### 5.6.1.3 Reserved—Bits 11–10 This bit field is reserved. Each bit must be set to 0. # 5.6.1.4 EOnCE Receive Register Full Interrupt Priority Level (RX REG IPL)— Bits 9–8 This field is used to set the interrupt priority level for the EOnCE Receive Register Full IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 # 5.6.1.5 EOnCE Transmit Register Empty Interrupt Priority Level (TX\_REG IPL)— Bits 7–6 This field is used to set the interrupt priority level for the EOnCE Transmit Register Empty IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 # 5.6.1.6 EOnCE Trace Buffer Interrupt Priority Level (TRBUF IPL)— Bits 5–4 This field is used to set the interrupt priority level for the EOnCE Trace Buffer IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 # 5.6.1.7 EOnCE Breakpoint Unit Interrupt Priority Level (BKPT U IPL)— Bits 3–2 This field is used to set the interrupt priority level for the EOnCE Breakpoint Unit IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 # 5.6.1.8 EOnCE Step Counter Interrupt Priority Level (STPCNT IPL)— Bits 1–0 This field is used to set the interrupt priority level for the EOnCE Step Counter IRQ. This IRQ is limited to priorities 1 through 3. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 1 - 10 = IRQ is priority level 2 - 11 = IRQ is priority level 3 ## 5.6.2 Interrupt Priority Register 1 (IPR1) | Base + \$1 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------|-------|----|----|----|----|---|---|---|---|------------|---------|---------------------|---|----------------|---| | Read | GPIO | ח ופו | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FM CBE IPL | | FM CC IPL FM ERR IP | | OD IDI | | | Write | 01 10 | DIIL | | | | | | | | | I W_O | JL 11 L | T W_CC IFE | | I W_LIXIX IF L | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-4 Interrupt Priority Register 1 (IPR1) #### 5.6.2.1 GPIOD Interrupt Priority Level (GPIOD IPL)—Bits 15–14 This field is used to set the interrupt priority level for the GPIOD IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 #### 5.6.2.2 Reserved—Bits 13–6 This bit field is reserved. Each bit must be set to 0. # 5.6.2.3 FM Command, Data, Address Buffers Empty Interrupt Priority Level (FM\_CBE IPL)—Bits 5–4 This field is used to set the interrupt priority level for the FM Command, Data Address Buffers Empty IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.2.4 FM Command Complete Interrupt Priority Level (FM\_CC IPL)—Bits 3–2 This field is used to set the interrupt priority level for the FM Command Complete IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.2.5 FM Error Interrupt Priority Level (FM\_ERR IPL)—Bits 1–0 This field is used to set the interrupt priority level for the FM Error IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.3 Interrupt Priority Register 2 (IPR2) | Base + \$2 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------|------|----|----|----|----|-------|----|----|------|-------|---------|-------|--------|-------|--------| | Read | QSCI0 | | 0 | 0 | 0 | 0 | QSPI0 | | | _RCV | GPIO | Δ ΙΡΙ | GPIO | R IPI | GPIO | C IPI | | Write | IF | PL . | | | | | IF | PL | IF | PL | 01 10 | /\ II L | 01 10 | D 11 L | 01 10 | 0 11 L | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-5 Interrupt Priority Register 2 (IPR2) ## 5.6.3.1 QSCI 0 Transmitter Empty Interrupt Priority Level (QSCI0\_XMIT IPL)— Bits 15–14 This field is used to set the interrupt priority level for the QSCI0 Transmitter Empty IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 #### 5.6.3.2 Reserved—Bits 13-10 This bit field is reserved. Each bit must be set to 0. ## 5.6.3.3 QSPI 0 Transmitter Empty Interrupt Priority Level (QSPI0\_XMIT IPL)— Bits 9–8 This field is used to set the interrupt priority level for the QSPI0 Transmitter Empty IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.3.4 QSPI 0 Receiver Full Interrupt Priority Level (QSPI0\_RCV IPL)—Bits 7–6 This field is used to set the interrupt priority level for the QSPI0 Receiver Full IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.3.5 GPIOA Interrupt Priority Level (GPIOA IPL)—Bits 5-4 This field is used to set the interrupt priority level for the GPIOA IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.3.6 GPIOB Interrupt Priority Level (GPIOB IPL)—Bits 3-2 This field is used to set the interrupt priority level for the GPIOB IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.3.7 GPIOC Interrupt Priority Level (GPIOC IPL)—Bits 1-0 This field is used to set the interrupt priority level for the GPIOC IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.4 Interrupt Priority Register 3 (IPR3) | Base + \$3 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|--------|--------|----|----|----|----|---|---|---|---|-------|------|-------|----|-------|----| | Read | I2C EI | RR IPI | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | QSCIO | _ | QSCIO | | QSCIO | | | Write | 120_2. | | | | | | | | | | IF | PL . | RI | PL | IF | PL | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-6 Interrupt Priority Register 3 (IPR3) # 5.6.4.1 I<sup>2</sup>C Error Interrupt Priority Level (I2C\_ERR IPL)—Bits 15–14 This field is used to set the interrupt priority level for the I<sup>2</sup>C Error IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 #### 5.6.4.2 Reserved—Bits 13–6 This bit field is reserved. Each bit must be set to 0. ### 5.6.4.3 QSCI 0 Receiver Full Interrupt Priority Level (QSCI0\_RCV IPL)—Bits 5–4 This field is used to set the interrupt priority level for the QSCI0 Receiver Full IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.4.4 QSCI 0 Receiver Error Interrupt Priority Level (QSCI0\_RERR IPL)— Bits 3–2 This field is used to set the interrupt priority level for the QSCI0 Receiver Error IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.4.5 QSCI 0 Transmitter Idle Interrupt Priority Level (QSCI0\_TIDL IPL)— Bits 1–0 This field is used to set the interrupt priority level for the QSCI0 Transmitter Idle IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ## 5.6.5 Interrupt Priority Register 4 (IPR4) | Base + \$4 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----------|-------|--------|------------|------|----------|--------|---------|--------|----------|-------|--------|-------|-------|-------|--------| | Read | TMRA | 3 IPL | TMRA | 2 IPI | TMRA | 1 IPL | TMRA | 0 IPL | 12C ST | AT IPL | I2C T | X IDI | I2C R | Y IPI | I2C G | EN IPI | | Write | T T WIT O | _0 | TIVITO | TMRA_2 IPL | | _' ''' _ | TIVITO | _0 11 L | 120_01 | /\! II L | 120_1 | X 11 L | 120_1 | L | 120_0 | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-7 Interrupt Priority Register 4 (IPR4) #### 5.6.5.1 Timer A, Channel 3 Interrupt Priority Level (TMRA\_3 IPL)— Bits 15–14 This field is used to set the interrupt priority level for the Timer A, Channel 3 IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.5.2 Timer A, Channel 2 Interrupt Priority Level (TMRA\_2 IPL)— Bits 13–12 This field is used to set the interrupt priority level for the Timer A, Channel 2 IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.5.3 Timer A, Channel 1 Interrupt Priority Level (TMRA\_1 IPL)— Bits 11–10 This field is used to set the interrupt priority level for the Timer A, Channel 1 IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.5.4 Timer A, Channel 0 Interrupt Priority Level (TMRA\_0 IPL)— Bits 9–8 This field is used to set the interrupt priority level for the Timer A, Channel 0 IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.5.5 I<sup>2</sup>C Status Interrupt Priority Level (I2C\_STAT IPL)—Bits 7-6 This field is used to set the interrupt priority level for the I<sup>2</sup>C Status IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.5.6 I<sup>2</sup>C Transmit Interrupt Priority Level (I2C\_TX IPL)—Bits 5-4 This field is used to set the interrupt priority level for the I<sup>2</sup>C Transmit IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.5.7 I<sup>2</sup>C Receive Interrupt Priority Level (I2C\_RX IPL)— Bits 3-2 This field is used to set the interrupt priority level for the I<sup>2</sup>C Receiver IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.5.8 I<sup>2</sup>C General Call Interrupt Priority Level (I2C\_GEN IPL)—Bits 1–0 This field is used to set the interrupt priority level for the I<sup>2</sup>C General Call IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ## 5.6.6 Interrupt Priority Register 5 (IPR5) | Base + \$5 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|------|-----|-------|--------|------|---------|---|---|---|---|---|---|---|---| | Read | 0 | 0 | PITO | IPI | COMF | PR IPI | COMF | Δ ΙΡΙ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | | | 1110 | | OOWII | D 11 L | OOM | /\ II L | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-8 Interrupt Priority Register 5 (IPR6) #### 5.6.6.1 Reserved—Bits 15–14 This bit field is reserved. Each bit must be set to 0. # 5.6.6.2 Programmable Interval Timer 0 Interrupt Priority Level (PIT0 IPL)—Bits 13–12 This field is used to set the interrupt priority level for the Programmable Interval Timer 0 IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.6.3 Comparator B Interrupt Priority Level (COMPB IPL)— Bits 11–10 This field is used to set the interrupt priority level for the Comparator B IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ## 5.6.6.4 Comparator A Interrupt Priority Level (COMPA IPL)— Bits 9–8 This field is used to set the interrupt priority level for the Comparator IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 #### 5.6.6.5 Reserved—Bits 7–0 This bit field is reserved. Each bit must be set to 0. # 5.6.7 Interrupt Priority Register 6 (IPR6) | Base + \$6 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----------|-------|----------|--------|--------|---------|----|------|------|----|---|---| | Read | 0 | 0 | 0 | 0 | PWM | F IPI | PWM | RI IPI | ADC 2 | 7C IPI | | 3_CC | ADCA | | 0 | 0 | | Write | | | | | . ****** | | . *****_ | | /\DO_2 | LO 11 L | IF | PL | IF | 'L | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-9 Interrupt Priority Register 6 (IPR6) #### 5.6.7.1 Reserved—Bits 15–12 This bit field is reserved. Each bit must be set to 0. ### 5.6.7.2 PWM Fault Interrupt Priority Level (PWM\_F IPL)—Bits 11–10 This field is used to set the interrupt priority level for the PWM Fault Interrupt IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 ### 5.6.7.3 Reload PWM Interrupt Priority Level (PWM\_RL IPL)—Bits 9–8 This field is used to set the interrupt priority level for the Reload PWM Interrupt IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.7.4 ADC Zero Crossing Interrupt Priority Level (ADC\_ZC IPL)—Bits 7–6 This field is used to set the interrupt priority level for the ADC Zero Crossing IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.7.5 ADC B Conversion Complete Interrupt Priority Level (ADCB\_CC IPL)—Bits 5–4 This field is used to set the interrupt priority level for the ADC B Conversion Complete IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 # 5.6.7.6 ADC A Conversion Complete Interrupt Priority Level (ADCA\_CC IPL)—Bits 3–2 This field is used to set the interrupt priority level for the ADC A Conversion Complete IRQ. This IRQ is limited to priorities 0 through 2. It is disabled by default. - 00 = IRQ disabled (default) - 01 = IRQ is priority level 0 - 10 = IRQ is priority level 1 - 11 = IRQ is priority level 2 #### 5.6.7.7 Reserved—Bits 1–0 This bit field is reserved. Each bit must be set to 0. # 5.6.8 Vector Base Address Register (VBA) | Base + \$7 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|---------------------|----|----|----|---|-------|--------|--------|------|----------------|---|---|---|---| | Read | 0 | 0 | | | | | | VECTO | OR BAS | E ADDI | RESS | | | | | | | Write | | | VECTOR_BASE_ADDRESS | | | | | | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 <sup>1</sup> | 0 | 0 | 0 | 0 | <sup>1.</sup> The 56F8023 resets to a value of 0 x 0000. This corresponds to reset addresses of 0 x 000000. Figure 5-10 Vector Base Address Register (VBA) #### 5.6.8.1 Reserved—Bits 15-14 This bit field is reserved. Each bit must be set to 0. ## 5.6.8.2 Vector Address Bus (VAB) Bits 13-0 The value in this register is used as the upper 14 bits of the interrupt vector VAB[20:0]. The lower 7 bits are determined based on the highest priority interrupt and are then appended onto VBA before presenting the full VAB to the Core. ## 5.6.9 Fast Interrupt Match 0 Register (FIM0) | Base + \$8 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------------|----|----|----|----|----|----|---|---|---|---|------------------|---|---|---|---|---|--| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FAST INTERRUPT 0 | | | | | | | | Write | | | | | | | | | | | FAST INTERRUPT 0 | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 5-11 Fast Interrupt Match 0 Register (FIM0) #### 5.6.9.1 Reserved—Bits 15–6 This bit field is reserved. Each bit must be set to 0. ### 5.6.9.2 Fast Interrupt 0 Vector Number (FAST INTERRUPT 0)—Bits 5-0 These values determine which IRQ will be Fast Interrupt 0. Fast Interrupts vector directly to a service routine based on values in the Fast Interrupt Vector Address registers without having to go to a jump table first. IRQs used as Fast Interrupts *must* be set to priority level 2. Unexpected results will occur if a Fast Interrupt vector is set to any other priority. A Fast Interrupt automatically becomes the highest-priority level 2 interrupt regardless of its location in the interrupt table prior to being declared as Fast Interrupt. Fast Interrupt 0 has priority over Fast Interrupt 1. To determine the vector number of each IRQ, refer to the vector table. ## 5.6.10 Fast Interrupt 0 Vector Address Low Register (FIVAL0) | Base + \$9 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----------|-----------|-----------|---------|--------|--------|---|---|---|---|---| | Read | | | | | | FAST IN | ITEDDI | IDT 0 VE | CTOR A | \nnbe | SLOW | | | | | | | Write | | | | | | 1 701 11 | VI LIXIXC | /1 1 O VL | .010107 | TODICE | JO LOW | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-12 Fast Interrupt 0 Vector Address Low Register (FIVAL0) # 5.6.10.1 Fast Interrupt 0 Vector Address Low (FIVAL0)—Bits 15–0 The lower 16 bits of the vector address used for Fast Interrupt 0. This register is combined with FIVAH0 to form the 21-bit vector address for Fast Interrupt 0 defined in the FIM0 register. # 5.6.11 Fast Interrupt 0 Vector Address High Register (FIVAH0) Figure 5-13 Fast Interrupt 0 Vector Address High Register (FIVAH0) #### 5.6.11.1 Reserved—Bits 15–5 This bit field is reserved. Each bit must be set to 0. #### 5.6.11.2 Fast Interrupt 0 Vector Address High (FIVAH0)—Bits 4–0 The upper five bits of the vector address used for Fast Interrupt 0. This register is combined with FIVAL0 to form the 21-bit vector address for Fast Interrupt 0 defined in the FIM0 register. # 5.6.12 Fast Interrupt 1 Match Register (FIM1) | Base + \$B | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------------|----|----|----|----|----|----|---|---|---|---|------------------|---|---|---|---|---|--| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FAST INTERRUPT 1 | | | | | | | | Write | | | | | | | | | | | FAST INTERRUPT 1 | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 5-14 Fast Interrupt 1 Match Register (FIM1) #### 5.6.12.1 Reserved—Bits 15-6 This bit field is reserved Each bit must be set to 0 ### 5.6.12.2 Fast Interrupt 1 Vector Number (FAST INTERRUPT 1)—Bits 5–0 These values determine which IRQ will be Fast Interrupt 1. Fast Interrupts vector directly to a service routine based on values in the Fast Interrupt Vector Address registers without having to go to a jump table first. IRQs used as Fast Interrupts *must* be set to priority level 2. Unexpected results will occur if a Fast Interrupt vector is set to any other priority. A Fast Interrupt automatically becomes the highest priority level 2 interrupt, regardless of its location in the interrupt table prior to being declared as Fast Interrupt. Fast Interrupt 0 has priority over Fast Interrupt 1. To determine the vector number of each IRQ, refer to the vector table. # 5.6.13 Fast Interrupt 1 Vector Address Low Register (FIVAL1) Figure 5-15 Fast Interrupt 1 Vector Address Low Register (FIVAL1) # 5.6.13.1 Fast Interrupt 1 Vector Address Low (FIVAL1)—Bits 15–0 The lower 16 bits of the vector address used for Fast Interrupt 1. This register is combined with FIVAH1 to form the 21-bit vector address for Fast Interrupt 1 defined in the FIM1 register. ## 5.6.14 Fast Interrupt 1 Vector Address High (FIVAH1) | Base + \$D | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|---|---|-------------------------|---|---|---|---| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FAST INTERRUPT 1 VECTOR | | | | | | Write | | | | | | | | | | | | ADDRESS HIGH | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 5-16 Fast Interrupt 1 Vector Address High Register (FIVAH1) #### 5.6.14.1 Reserved—Bits 15-5 This bit field is reserved. Each bit must be set to 0. ### 5.6.14.2 Fast Interrupt 1 Vector Address High (FIVAH1)—Bits 4-0 The upper five bits of the vector address used for Fast Interrupt 1. This register is combined with FIVAL1 to form the 21-bit vector address for Fast Interrupt 1 defined in the FIM1 register. ## 5.6.15 IRQ Pending Register 0 (IRQP0) Figure 5-17 IRQ Pending Register 0 (IRQP0) ### 5.6.15.1 IRQ Pending (PENDING)—Bits 16–2 These register bit values represent the pending IRQs for interrupt vector numbers 2 through 16. Ascending IRQ numbers correspond to ascending bit locations. - 0 = IRQ pending for this vector number - 1 = No IRQ pending for this vector number #### 5.6.15.2 Reserved—Bit 0 This bit field is reserved. It must be set to 1. # 5.6.16 IRQ Pending Register 1 (IRQP1) Figure 5-18 IRQ Pending Register 1 (IRQP1) ### 5.6.16.1 IRQ Pending (PENDING)—Bits 32–17 These register bit values represent the pending IRQs for interrupt vector numbers 17 through 32. Ascending IRQ numbers correspond to ascending bit locations. - 0 = IRQ pending for this vector number - 1 = No IRQ pending for this vector number ## 5.6.17 IRQ Pending Register 2 (IRQP2) Figure 5-19 IRQ Pending Register 2 (IRQP2) ### 5.6.17.1 IRQ Pending (PENDING)—Bits 48–33 This register bit values represent the pending IRQs for interrupt vector numbers 33 through 48. Ascending IRQ numbers correspond to ascending bit locations. - 0 = IRQ pending for this vector number - 1 = No IRQ pending for this vector number ## 5.6.18 IRQ Pending Register 3 (IRQP3) Figure 5-20 IRQ Pending Register 3 (IRQP3) # 5.6.18.1 IRQ Pending (PENDING)—Bits 63-49 These register bit values represent the pending IRQs for interrupt vector numbers 49 through 63. Ascending IRQ numbers correspond to ascending bit locations. - 0 = IRQ pending for this vector number - 1 = No IRQ pending for this vector number # 5.6.19 Interrupt Control Register (ICTRL) Figure 5-21 Interrupt Control Register (ICTRL) #### 5.6.19.1 Interrupt (INT)—Bit 15 This *read-only* bit reflects the state of the interrupt to the 56800E core. - 0 = No interrupt is being sent to the 56800E core - 1 = An interrupt is being sent to the 56800E core #### 5.6.19.2 Interrupt Priority Level (IPIC)—Bits 14–13 These *read-only* bits reflect the state of the new interrupt priority level bits being presented to the 56800E core. These bits indicate the priority level needed for a new IRQ to interrupt the current interrupt being sent to the 56800E core. This field is only updated when the 56800E core jumps to a new interrupt service routine. **Note:** Nested interrupts may cause this field to be updated before the original interrupt service routine can read it. - 00 = Required nested exception priority levels are 0, 1, 2, or 3 - 01 = Required nested exception priority levels are 1, 2, or 3 - 10 = Required nested exception priority levels are 2 or 3 11 • 11 = Required nested exception priority level is 3 IPIC\_VALUE[1:0] Current Interrupt Priority Level Required Nested Exception Priority 00 No interrupt or SWILP Priorities 0, 1, 2, 3 01 Priority 0 Priorities 1, 2, 3 10 Priority 1 Priorities 2, 3 Priority 3 Priority 2 or 3 **Table 5-4 Interrupt Priority Encoding** # 5.6.19.3 Vector Number - Vector Address Bus (VAB)—Bits 12-6 This *read-only* field shows bits [7:1] of the Vector Address Bus used at the time the last IRQ was taken. In the case of a Fast Interrupt, it shows the lower address bits of the jump address. This field is only updated when the 56800E core jumps to a new interrupt service routine. **Note:** Nested interrupts may cause this field to be updated before the original interrupt service routine can read it. # 5.6.19.4 Interrupt Disable (INT\_DIS)—Bit 5 This bit allows all interrupts to be disabled. - 0 = Normal operation (default) - 1 = All interrupts disabled #### 5.6.19.5 Reserved—Bits 4-2 This bit field is reserved. Each bit must be set to 1. #### 5.6.19.6 Reserved—Bits 1-0 This bit field is reserved. Each bit must be set to 0. ## 5.7 Resets #### 5.7.1 General Table 5-5 Reset Summary | Reset | Priority | Source | Characteristics | |------------|----------|--------|-------------------------| | Core Reset | | RST | Core reset from the SIM | # 5.7.2 Description of Reset Operation ## 5.7.2.1 Reset Handshake Timing The ITCN provides the 56800E core with a reset vector address on the VAB pins whenever $\overline{\text{RESET}}$ is asserted from the SIM. The reset vector will be presented until the second rising clock edge after $\overline{\text{RESET}}$ is released. The general timing is shown in Figure 5-22. Figure 5-22 Reset Interface #### 5.7.3 ITCN After Reset After reset, all of the ITCN registers are in their default states. This means all interrupts are disabled, except the core IRQs with fixed priorities: - Illegal Instruction - SW Interrupt 3 - HW Stack Overflow - Misaligned Long Word Access - SW Interrupt 2 - SW Interrupt 1 - SW Interrupt 0 - SW Interrupt LP These interrupts are enabled at their fixed priority levels. # Part 6 System Integration Module (SIM) ## 6.1 Introduction The SIM module is a system catchall for the glue logic that ties together the system-on-chip. It controls distribution of resets and clocks and provides a number of control features. The System Integration Module's functions are discussed in more detail in the following sections. ## 6.2 Features The SIM has the following features: - Chip reset sequencing - Core and peripheral clock control and distribution - Stop/Wait mode control - System status control - Registers containing the JTAG ID of the chip - Controls for programmable peripheral and GPIO connections - Peripheral clocks for TMR and PWM with a high-speed (3X) option - Power-saving clock gating for peripherals - Three power modes (Run, Wait, Stop) to control power utilization - Stop mode shuts down the 56800E core, system clock, and peripheral clock - Wait mode shuts down the 56800E core and unnecessary system clock operation - Run mode supports full device operation - Controls the enable/disable functions of the 56800E core WAIT and STOP instructions with write protection capability - Controls the enable/disable functions of Large Regulator Standby mode with write protection capability - Permits selected peripherals to run in Stop mode to generate Stop recovery interrupts - Controls for programmable peripheral and GPIO connections - Software chip reset - I/O short address base location control - Peripheral protection control to provide runaway code protection for safety-critical applications - Controls output of internal clock sources to CLKO pin - Four general-purpose software control registers are reset only at power-on - Peripherals Stop mode clocking control # 6.3 Register Descriptions A write to an address without an associated register is an NOP. A read from an address without an associated register returns unknown data. Table 6-1 SIM Registers (SIM\_BASE = \$00 F100) | Register<br>Acronym | Base Address + | Register Name | Section<br>Location | |---------------------|----------------|----------------------------------------------------|---------------------| | CTRL | \$0 | Control Register | 6.3.1 | | RSTAT | \$1 | Reset Status Register | 6.3.2 | | SWC0 | \$2 | Software Control Register 0 | 6.3.3 | | SWC1 | \$3 | Software Control Register 1 | 6.3.3 | | SWC2 | \$4 | Software Control Register 2 | 6.3.3 | | SWC3 | \$5 | Software Control Register 3 | 6.3.3 | | MSHID | \$6 | Most Significant Half of JTAG ID | 6.3.4 | | LSHID | \$7 | Least Significant Half of JTAG ID | 6.3.5 | | PWR | \$8 | Power Control Register | 6.3.6 | | | | Reserved | | | CLKOUT | \$A | CLKO Select Register | 6.3.7 | | PCR | \$B | Peripheral Clock Rate Register | 6.3.8 | | PCE0 | \$C | Peripheral Clock Enable Register 0 | 6.3.9 | | PCE1 | \$D | Peripheral Clock Enable Register 0 | 6.3.10 | | SD0 | \$E | Stop Disable Register 0 | 6.3.11 | | SD1 | \$F | Stop Disable Register 1 | 6.3.12 | | IOSAHI | \$10 | I/O Short Address Location High Register | 6.3.13 | | IOSALO | \$11 | I/O Short Address Location Low Register | 6.3.14 | | PROT | \$12 | Protection Register | 6.3.15 | | GPSA0 | \$13 | GPIO Peripheral Select Register 0 for GPIOA | 6.3.16 | | | | Reserved | | | GPSB0 | \$15 | GPIO Peripheral Select Register 0 for GPIOB | 6.3.17 | | GPSB1 | \$16 | GPIO Peripheral Select Register 1 for GPIOB | 6.3.18 | | | | Reserved | | | ISS0 | \$18 | Internal Source Select Register 0 for PWM | 6.3.19 | | ISS1 | \$19 | Internal Source Select Register 1 for DACs | 6.3.20 | | ISS2 | \$1A | Internal Source Select Register 2 for Quad Timer A | 6.3.21 | | | | Reserved | | | \$3 | SIM_<br>CTRL<br>SIM_<br>RSTAT<br>SIM_SWC0 | R<br>W<br>R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | |------|-------------------------------------------|------------------|-------------|-------------|-----------------|--------------|-----------------|------------|--------|--------------|-----------|------------|-------------|--------------|-------------|--------------|------------|--------------| | \$2 | SIM_SWC0 | W | 0 | | | | O O | U | 0 | 0 | 0 | 0 | ONCE<br>EBL | SW<br>RST | STO<br>DISA | OP_<br>ABLE | | AIT_<br>ABLE | | \$3 | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SWR | COP_<br>TOR | COP_<br>LOR | EXTR | POR | 0 | 0 | | | CIM CIMO4 | R<br>W | | | | | | | Softw | are Con | trol Data | 0 | | | | | | | | \$4 | SIM_SWC1 | R<br>W | | | | | | | Softw | are Con | trol Data | 1 | | | | | | | | | SIM_SWC2 | R<br>W | | | | | | | Softw | are Con | trol Data | 2 | | | | | | | | \$5 | SIM_SWC3 | R | | | | | | | Softw | are Con | trol Data | 3 | | | | | | | | \$6 | SIM_MSHID | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | \$7 | SIM_LSHID | R | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | \$8 | SIM_PWR | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | LRS | TDBY | | | Reserved | | | | | | | | | | | | | | | | | | | \$A | SIM_<br>CLKOUT | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | PWM3 | PWM2 | PWM1 | PWM0 | CLK<br>DIS | | C | CLKOSE | L | | | \$B | SIM_PCR | R<br>W | 0 | TMRA_<br>CR | PWM_C<br>R | I2C_<br>CR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$C | SIM_PCE0 | R<br>W | СМРВ | СМРА | DAC1 | DAC0 | 0 | ADC | 0 | 0 | 0 | I2C | 0 | QSCI0 | 0 | QSPI0 | 0 | PWM | | \$D | SIM_PCE1 | R<br>W | 0 | 0 | 0 | PIT0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TA3 | TA2 | TA1 | TA0 | | \$E | SIM_SD0 | R<br>W | CMPB_<br>SD | CMPA_<br>SD | DAC1_<br>SD | DAC0_<br>SD | 0 | ADC_<br>SD | 0 | 0 | 0 | I2C_<br>SD | 0 | QSCI0<br>_SD | 0 | QSPI0<br>_SD | 0 | PWM_<br>SD | | \$F | SIM_SD1 | R<br>W | 0 | 0 | 0 | PIT0_<br>SD | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TA3_<br>SD | TA2_<br>SD | TA1_<br>SD | TA0_<br>SD | | \$10 | SIM_IOSAHI | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ISAL[ | 23:22] | | \$11 | SIM_IOSALO | R<br>W | | | | | | | | ISAL[2 | 1:6] | | | | | | | | | \$12 | SIM_PROT | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PC | EP | GIF | PSP | | \$13 | SIM_GPSA0 | R<br>W | 0 | 0 | 0 | GPS_<br>A6 | GPS. | _A5 | GPS | 5_A4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Reserved | | • | | | | | | | | | | | | | | 0 | | | \$15 | SIM_GPSB0 | R<br>W | 0 | | S_B6 | | S_B5 | | GPS_B4 | | GPS | | GPS | | 0 | GPS_<br>B1 | 0 | GPS_<br>B0 | | \$16 | SIM_GPSB1 | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | GPS_<br>B7 | | \$18 | Reserved SIM_IPS0 | R<br>W | 0 | 0 | IPS0_<br>FAULT2 | 0 | IPS0_<br>FAULT1 | 0 | 0 | IP | S0_PSR | C2 | IPS | S0_PSR | C1 | IPS | S0_PSR | C0 | | \$19 | SIM_IPS1 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | IPS | 1_DSYI | NC0 | | \$1A | SIM_IPS2 | R<br>W | 0 | 0 | 0 | IPS2_<br>TA3 | 0 | 0 | 0 | IPS2_<br>TA2 | 0 | 0 | 0 | IPS2_<br>TA1 | 0 | 0 | 0 | 0 | | | Reserved | | | | | | | | | | | | | | | | | | Figure 6-1 SIM Register Map Summary # 6.3.1 SIM Control Register (SIM\_CTRL) | Base + \$0 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|---|------|-----|------|------|------|------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ONCE | SW | STO | | WA | | | Write | | | | | | | | | | | EBL | RST | DISA | ABLE | DISA | ABLE | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-2 SIM Control Register (SIM CTRL) #### 6.3.1.1 Reserved—Bits 15-6 This bit field is reserved. Each bit must be set to 0. ## 6.3.1.2 OnCE Enable (ONCEEBL)—Bit 5 - 0 = OnCE clock to 56800E core enabled when core TAP is enabled - 1 = OnCE clock to 56800E core is always enabled **Note:** Using default state "0" is recommended. ## 6.3.1.3 Software Reset (SWRST)—Bit 4 - Writing 1 to this field will cause the device to reset - Read is zero ## 6.3.1.4 Stop Disable (STOP DISABLE)—Bits 3-2 - 00 = Stop mode will be entered when the 56800E core executes a STOP instruction - 01 = The 56800E STOP instruction will not cause entry into Stop mode - 10 = Stop mode will be entered when the 56800E core executes a STOP instruction and the STOP DISABLE field is write-protected until the next reset - 11 = The 56800E STOP instruction will not cause entry into Stop mode and the STOP\_DISABLE field is write-protected until the next reset # 6.3.1.5 Wait Disable (WAIT\_DISABLE)—Bits 1-0 - 00 = Wait mode will be entered when the 56800E core executes a WAIT instruction - 01 = The 56800E WAIT instruction will not cause entry into Wait mode - 10 = Wait mode will be entered when the 56800E core executes a WAIT instruction and the WAIT\_DISABLE field is write-protected until the next reset - 11 = The 56800E WAIT instruction will not cause entry into Wait mode and the WAIT\_DISABLE field is write-protected until the next reset # 6.3.2 SIM Reset Status Register (SIM\_RSTAT) This read-only register is updated upon any system reset and indicates the cause of the most recent reset. It indicates whether the COP reset vector or regular reset vector (including Power-On Reset, External Reset, Software Reset) in the vector table is used. This register is asynchronously reset during Power-On Reset and subsequently is synchronously updated based on the precedence level of reset inputs. Only the most recent reset source will be indicated if multiple resets occur. If multiple reset sources assert simultaneously, the highest-precedence source will be indicated. The precedence from highest to lowest is Power-On Reset, External Reset, COP Loss of Reference Reset, COP Time-Out Reset, and Software Reset. Power-On Reset is always set during a Power-On Reset; however, Power-On Reset will be cleared and External Reset will be set if the external reset pin is asserted or remains asserted after the Power-On Reset has deasserted. | Base + \$1 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|-----|-------------|-------------|------|-----|---|---| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SWR | COP_<br>TOR | COP_<br>LOR | EXTR | POR | 0 | 0 | | Write | | | | | | | | | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | Figure 6-3 SIM Reset Status Register (SIM\_RSTAT) #### 6.3.2.1 Reserved—Bits 15–7 This bit field is reserved. Each bit must be set to 0. ## 6.3.2.2 Software Reset (SWR)—Bit 6 When set, this bit indicates that the previous system reset occurred as a result of a software reset (written 1 to SWRST bit in the SIM\_CTRL register). ## 6.3.2.3 COP Time-Out Reset (COP TOR)—Bit 5 When set, this bit indicates that the previous system reset was caused by the Computer Operating Properly (COP) module signaling a COP time-out reset. If COP\_TOR is set as code starts executing, the COP reset vector in the vector table will be used. Otherwise, the normal reset vector is used. # 6.3.2.4 COP Loss of Reference Reset (COP\_LOR)—Bit 4 When set, this bit indicates that the previous system reset was caused by the Computer Operating Properly (COP) module signaling a loss of COP reference clock reset. If COP\_LOR is set as code starts executing, the COP reset vector in the vector table will be used. Otherwise, the normal reset vector is used. # 6.3.2.5 External Reset (EXTR)—Bit 3 When set, this bit indicates that the previous system reset was caused by an external reset. # 6.3.2.6 Power-On Reset (POR)—Bit 2 This bit is set during a Power-On Reset. #### 6.3.2.7 Reserved—Bits 1–0 This bit field is reserved. Each bit must be set to 0. # 6.3.3 SIM Software Control Registers (SIM\_SWC0, SIM\_SWC1, SIM\_SWC2, and SIM\_SWC3) These registers are general-purpose registers. They are reset only at power-on, so they can monitor software execution flow. | Base + \$2 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---------|-----------|-----------|-------|---|---|---|---|---|---| | Read | | | | | | | Softwar | re Contr | ol Data ( | 1 3 | | | | | | | | Write | | | | | | | Softwar | ie Contin | Ji Dala ( | J - J | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-4 SIM Software Control Register 0 (SIM\_SWC0 - 3) ## 6.3.3.1 Software Control Register 0 - 3 (FIELD)—Bits 15–0 This register is reset only by the Power-On Reset (POR). It is intended for use by a software developer to contain data that will be unaffected by the other reset sources (external reset, software reset, and COP reset). # 6.3.4 Most Significant Half of JTAG ID (SIM\_MSHID) This read-only register displays the most significant half of the JTAG ID for the chip. This register reads \$01F2. | Base + \$6 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | Write | | | | | | | | | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | Figure 6-5 Most Significant Half of JTAG ID (SIM\_MSHID) # 6.3.5 Least Significant Half of JTAG ID (SIM\_LSHID) This read-only register displays the least significant half of the JTAG ID for the chip. This register reads \$801D. | Base + \$7 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | Read | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | Write | | | | | | | | | | | | | | | | | | RESET | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | Figure 6-6 Least Significant Half of JTAG ID (SIM LSHID) # 6.3.6 SIM Power Control Register (SIM\_PWR) This register controls the Standby mode of the large on-chip regulator. The large on-chip regulator derives the core digital logic power supply from the IO power supply. At a system bus frequency of 200kHz, the large regulator may be put in a reduced-power standby mode without interfering with device operation to reduce device power consumption. Refer to the overview of power-down modes and the overview of clock generation for more information on the use of large regulator standby. | Base + \$8 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------|------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | LRST | ГDВY | | Write | | | | | | | | | | | | | | | LINO | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-7 SIM Power Control Register (SIM\_PWR) #### 6.3.6.1 Reserved—Bits 15-2 This bit field is reserved. Each bit must be set to 0. ## 6.3.6.2 Large Regulator Standby Mode[1:0] (LRSTDBY)—Bits 1–0 - 00 = Large regulator is in Normal mode - 01 = Large regulator is in Standby (reduced-power) mode - 10 = Large regulator is in Normal mode and the LRSTDBY field is write-protected until the next reset - 11 = Large regulator is in Standby mode and the LRSTDBY field is write-protected until the next reset # 6.3.7 Clock Output Select Register (SIM\_CLKOUT) The Clock Output Select register can be used to multiplex out selected clock sources generated inside the clock generation and SIM modules onto the muxed clock output pins. All functionality is for test purposes only. Glitches may be produced when the clock is enabled or switched. The delay from the clock source to the output is unspecified. The observability of the CLKO clock output signal at an output pad is subject to the frequency limitations of the associated IO cell. GPIOA[3:0] can function as GPIO, PWM, or as clock output pins. If GPIOA[3:0] are programmed to operate as peripheral outputs, then the choice is between PWM and clock outputs. The default state is for the peripheral function of GPIOA[3:0] to be programmed as PWM (selected by bits [9:6] of the Clock Output Select register). GPIOB4 can function as GPIO, or as other peripheral outputs, including clock output (CLKO). If GPIOB4 is programmed to operate as a peripheral output and CLKO is selected in the SIM\_GPSB0 register, bits [4:0] decide if CLKO is enabled or disabled and which clock source is selected if CLKO is enabled. See **Figure 6-8** for details. | Base + \$A | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|----------|----------|----------|------------|-----|---|---|--------|---|---| | Read | 0 | 0 | 0 | 0 | 0 | 0 | PWM3 | PWM2 | PWM1 | PWM0 | CLK | | C | LKOSE | ı | | | Write | | | | | | | 1 441410 | 1 VVIVIZ | . ****** | 1 ******** | DIS | | O | LINOOL | _ | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Figure 6-8 CLKO Select Register (SIM\_CLKOUT) #### 6.3.7.1 Reserved—Bits 15–10 This bit field is reserved. Each bit must be set to 0. ## 6.3.7.2 PWM3—Bit 9 - 0 = Peripheral output function of GPIOA[3] is defined to be $\overline{\text{PWM}}$ 3 - 1 = Peripheral output function of GPIOA[3] is defined to be the Relaxation Oscillator Clock ## 6.3.7.3 PWM2—Bit 8 - 0 = Peripheral output function of GPIOA[2] is defined to be $\overline{\text{PWM}}$ 2 - 1 = Peripheral output function of GPIOA[2] is defined to be the system clock ## 6.3.7.4 PWM1—Bit 7 - 0 = Peripheral output function of GPIOA[1] is defined to be $\overline{\text{PWM}}$ 1 - 1 = Peripheral output function of GPIOA[1] is defined to be 2X system clock ## 6.3.7.5 PWM0—Bit 6 - $0 = \text{Peripheral output function of GPIOA}[0] \text{ is defined to be } \overline{\text{PWM}}0$ - 1 = Peripheral output function of GPIOA[0] is defined to be 3X system clock # 6.3.7.6 Clockout Disable (CLKDIS)—Bit 5 - 0 = CLKOUT output function is enabled and will output the signal indicated by CLKOSEL - 1 = CLKOUT output function is disabled # 6.3.7.7 Clockout Select (CLKOSEL)—Bits 4-0 CLKOSEL selects the clock to be muxed out on the CLKO pin as defined in the following. Internal delay to CLKO output is unspecified. Signal at the output pad is undefined when CLKO signal frequency exceeds the rated frequency of the I/O cell. CLKO may not operate as expected when CLKDIS and CLKOSEL settings are changed. - 00000 = Continuous system clock - 00001 = Continuous peripheral clock - 00010 = 3X system clock - 00100....11111 = Reserved for factory test # 6.3.8 Peripheral Clock Rate Register (SIM\_PCR) By default, all peripherals are clocked at the system clock rate, which has a maximum of 32MHz. Selected peripherals clocks have the option to be clocked at 3X system clock rate, which has a maximum of 96MHz, if the PLL output clock is selected as the system clock. If PLL is disabled, the 3X system clock will not be available. This register is used to enable high-speed clocking for those peripherals that support it. **Note:** Operation is unpredictable if peripheral clocks are reconfigured at runtime, so peripherals should be disabled before a peripheral clock is reconfigured. | Base + \$B | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|------|------|------|----|----|---|---|---|---|---|---|---|---|---|---| | Read | 0 | | PWM_ | I2C_ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | | CR _ | CR | CR | | | | | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-9 Peripheral Clock Rate Register (SIM\_PCR) #### 6.3.8.1 Reserved—Bit 15 This bit field is reserved. It must be set to 0. ## 6.3.8.2 Quad Timer A Clock Rate (TMRA CR)—Bit 14 This bit selects the clock speed for the Quad Timer A module. - 0 = Quad Timer A clock rate equals the system clock rate, to a maximum 32MHz (default) - 1 = Quad Timer A clock rate equals 3X system clock rate, to a maximum 96MHz # 6.3.8.3 Pulse Width Modulator Clock Rate (PWM\_CR)—Bit 13 This bit selects the clock speed for the PWM module. - 0 = PWM module clock rate equals the system clock rate, to a maximum 32MHz (default) - 1 = PWM module clock rate equals 3X system clock rate, to a maximum 96MHz # 6.3.8.4 Inter-Integrated Circuit Run Clock Rate (I2C\_CR)—Bit 12 This bit selects the clock speed for the I<sup>2</sup>C run clock. - $0 = I^2C$ module run clock rate equals the system clock rate, to a maximum 32MHz (default) - $1 = I^2C$ module run clock rate equals 3X system clock rate, to a maximum 96MHz #### 6.3.8.5 Reserved—Bits 11–0 This bit field is reserved. Each bit must be set to 0. # 6.3.9 Peripheral Clock Enable Register 0 (SIM\_PCE0) The Peripheral Clock Enable register enables or disables clocks to the peripherals as a power savings feature. Significant power savings are achieved by enabling only the peripheral clocks that are in use. When a peripheral's clock is disabled, that peripheral is in Stop mode. Accesses made to a module that has its clock disabled will have no effect. The corresponding peripheral should itself be disabled while its clock is shut off. IPBus writes are not possible. Setting the PCE bit does not guarantee that the peripheral's clock is running. Enabled peripheral clocks will still become disabled in Stop mode, unless the peripheral's Stop Disable control in the SDn register is set to 1. | Base + \$C | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|--------|---------|-------|------|----|-----|---|---|---|-----|---|-------|---|--------|---|---------| | Read | СМРВ | CMPA | DAC1 | DAC0 | 0 | ADC | 0 | 0 | 0 | I2C | 0 | QSCI0 | 0 | QSPI0 | 0 | PWM | | Write | OWII B | OIVII 7 | D/(O) | DAOO | | ABO | | | | 120 | | QUOIU | | QOI 10 | | 1 77101 | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-10 Peripheral Clock Enable Register 0 (SIM\_PCE0) ## 6.3.9.1 Comparator B Clock Enable (CMPB)—Bit 15 - 0 = The clock is not provided to the Comparator B module (the Comparator B module is disabled) - 1 = The clock is enabled to the Comparator B module ## 6.3.9.2 Comparator A Clock Enable (CMPA)—Bit 14 - 0 =The clock is not provided to the Comparator A module (the Comparator A module is disabled) - 1 = The clock is enabled to the Comparator A module # 6.3.9.3 Digital-to-Analog Clock Enable 1 (DAC1)—Bit 13 - 0 =The clock is not provided to the DAC1 module (the DAC1 module is disabled) - 1 = The clock is enabled to the DAC1 module # 6.3.9.4 Digital-to-Analog Clock Enable 0 (DAC0)—Bit 12 - 0 = The clock is not provided to the DAC0 module (the DAC0 module is disabled) - 1 = The clock is enabled to the DAC0 module #### 6.3.9.5 Reserved—Bit 11 This bit field is reserved. It must be set to 0. # 6.3.9.6 Analog-to-Digital Converter Clock Enable (ADC)—Bit 10 - 0 = The clock is not provided to the ADC module (the ADC module is disabled) - 1 = The clock is enabled to the ADC module #### 6.3.9.7 Reserved—Bits 9–7 This bit field is reserved. Each bit must be set to 0. # 6.3.9.8 Inter-Integrated Circuit IPBus Clock Enable (I2C)—Bit 6 • $0 = \text{The clock is not provided to the } I^2C \text{ module (the } I^2C \text{ module is disabled)}$ • 1 = The clock is enabled to the $I^2C$ module #### 6.3.9.9 Reserved—Bit 5 This bit field is reserved. It must be set to 0. ## 6.3.9.10 QSCI 0 Clock Enable (QSCI0)—Bit 4 - 0 = The clock is not provided to the QSCI0 module (the QSCI0 module is disabled) - 1 = The clock is enabled to the QSCI0 module #### 6.3.9.11 Reserved—Bit 3 This bit field is reserved. It must be set to 0. ## 6.3.9.12 QSPI 0 Clock Enable (QSPI0)—Bit 2 - 0 = The clock is not provided to the QSPI0 module (the QSPI0 module is disabled) - 1 = The clock is enabled to the QSPI0 module #### 6.3.9.13 Reserved—Bit 1 This bit field is reserved. It must be set to 0. ## 6.3.9.14 PWM Clock Enable (PWM)—Bit 0 - 0 = The clock is not provided to the PWM module (the PWM module is disabled) - 1 = The clock is enabled to the PWM module # 6.3.10 Peripheral Clock Enable Register 1 (SIM\_PCE1) See Section 6.3.9 for general information about Peripheral Clock Enable registers. Figure 6-11 Peripheral Clock Enable Register 1 (SIM\_PCE1) #### 6.3.10.1 Reserved—Bit 15 - 13 This bit field is reserved. Each bit must be set to 0. ## 6.3.10.2 Programmable Interval Timer 0 Clock Enable (PIT0)—Bit 12 - 0 = The clock is not provided to the PIT0 module (the PIT0 module is disabled) - 1 = The clock is enabled to the PIT0 module #### 6.3.10.3 Reserved—Bits 11-4 This bit field is reserved. Each bit must be set to 0. ## 6.3.10.4 Quad Timer A, Channel 3 Clock Enable (TA3)—Bit 3 - 0 = The clock is not provided to the Timer A3 module (the Timer A3 module is disabled) - 1 = The clock is enabled to the Timer A3 module ## 6.3.10.5 Quad Timer A, Channel 2 Clock Enable (TA2)—Bit 2 - 0 = The clock is not provided to the Timer A2 module (the Timer A2 module is disabled) - 1 = The clock is enabled to the Timer A2 module ## 6.3.10.6 Quad Timer A, Channel 1 Clock Enable (TA1)—Bit 1 - 0 = The clock is not provided to the Timer A1 module (the Timer A1 module is disabled) - 1 = The clock is enabled to the Timer A1 module ## 6.3.10.7 Quad Timer A, Channel 0 Clock Enable (TA0)—Bit 0 - 0 =The clock is not provided to the Timer A0 module (the Timer A0 module is disabled) - 1 = The clock is enabled to the Timer A0 module # 6.3.11 Stop Disable Register 0 (SD0) By default, peripheral clocks are disabled during Stop mode in order to maximize power savings. This register will allow an individual peripheral to operate in Stop mode. Since asserting an interrupt causes the system to return to Run mode, this feature is provided so that selected peripherals can be left operating in Stop mode for the purpose of generating a wake-up interrupt. For power-conscious applications, it is recommended that only a minimum set of peripherals be configured to remain operational during Stop mode. Peripherals should be put in a non-operating (disabled) configuration prior to entering Stop mode unless their corresponding Stop Disable control is set to 1. Refer to the **56F802X and 56F803X Peripheral Reference Manual** for further details. Reads and writes cannot be made to a module that has its clock disabled. | Base + \$E | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------|-------|-----|-------|----|------|---|---|---|------|---|--------|---|--------|---|------| | Read | CMPB_ | CMPA_ | | DAC0_ | 0 | ADC_ | 0 | 0 | 0 | I2C_ | 0 | QSCI0_ | 0 | QSPI0_ | 0 | PWM_ | | Write | SD | SD | _SD | SD | | SD | | | | SD | | SD | | SD | | SD | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-12 Stop Disable Register 0 (SD0) # 6.3.11.1 Comparator B Clock Stop Disable (CMPB\_SD)—Bit 15 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register ## 6.3.11.2 Comparator A Clock Stop Disable (CMPA SD)—Bit 14 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register ## 6.3.11.3 Digital-to-Analog Converter 0 Clock Stop Disable (DAC1\_SD)—Bit 13 - 0 = The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register # 6.3.11.4 Digital-to-Analog Converter 0 Clock Stop Disable (DAC0\_SD)—Bit 12 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register #### 6.3.11.5 Reserved—Bit 11 This bit field is reserved. It must be set to 0. ## 6.3.11.6 Analog-to-Digital Converter Clock Stop Disable (ADC\_SD)—Bit 10 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register #### 6.3.11.7 Reserved—Bits 9-7 This bit field is reserved. Each bit must be set to 0. # 6.3.11.8 Inter-Integrated Circuit Clock Stop Disable (I2C\_SD)—Bit 6 - 0 = The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register #### 6.3.11.9 Reserved—Bit 5 This bit field is reserved. It must be set to 0. # 6.3.11.10 QSCI0 Clock Stop Disable (QSCI0\_SD)—Bit 4 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register #### 6.3.11.11 Reserved—Bit 3 This bit field is reserved. It must be set to 0. ## 6.3.11.12 QSPI0 Clock Stop Disable (QSPI0\_SD)—Bit 2 Each bit controls clocks to the indicated peripheral. - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register #### 6.3.11.13 Reserved—Bit 1 This bit field is reserved. It must be set to 0. ## 6.3.11.14 PWM Clock Stop Disable (PWM SD)—Bit 0 - 0 = The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE0 register # 6.3.12 Stop Disable Register 1 (SD1) See Section 6.3.11 for general information about Stop Disable Registers. | Base + \$F | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|-------|----|----|---|---|---|---|---|---|------|------|------|------| | Read | 0 | 0 | 0 | PIT0_ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TA3_ | TA2_ | TA1_ | TA0_ | | Write | | | | SD | | | | | | | | | SD | SD | SD | SD | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-13 Stop Disable Register 1 (SD1) #### 6.3.12.1 Reserved—Bit 15-13 This bit field is reserved. Each bit must be set to 0. # 6.3.12.2 Programmable Interval Timer 0 Clock Stop Disable (PIT0\_SD)—Bit 12 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE1 register #### 6.3.12.3 Reserved—Bits 11-4 This bit field is reserved. Each bit must be set to 0. # 6.3.12.4 Quad Timer A, Channel 3 Clock Stop Disable (TA3\_SD)—Bit 3 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE1 register ## 6.3.12.5 Quad Timer A, Channel 2 Clock Stop Disable (TA2 SD)—Bit 2 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE1 register ## 6.3.12.6 Quad Timer A, Channel 1 Clock Stop Disable (TA1\_SD)—Bit 1 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE1 register # 6.3.12.7 Quad Timer A, Channel 0 Clock Stop Disable (TA0\_SD)—Bit 0 - 0 =The clock is disabled during Stop mode - 1 = The clock is enabled during Stop mode if the clock to this peripheral is enabled in the SIM\_PCE1 register # 6.3.13 I/O Short Address Location Register High (SIM\_IOSAHI) In I/O short address mode, the instruction specifies only 6 LSBs of the effective address; the upper 18 bits are "hard coded" to a specific area of memory. This scheme allows efficient access to a 64-location area in peripheral space with single word instruction. Short address location registers specify the upper 18 bits of I/O address, which are "hard coded". These registers allow access to peripherals using I/O short address mode, regardless of the physical location of the peripheral, as shown in **Figure 6-14**. Figure 6-14 I/O Short Address Determination With this register set, software can set the SIM\_IOSAHI and SIM\_IOSALO registers to point to its peripheral registers and then use the I/O short addressing mode to access them. **Note:** The default value of this register set points to the EOnCE registers. **Note:** The pipeline delay between setting this register set and using short I/O addressing with the new value is five instruction cycles. | Base + \$10 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------|--------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ISAL[: | 23.221 | | Write | | | | | | | | | | | | | | | IO/ (L[/ | 20.22] | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | Figure 6-15 I/O Short Address Location High Register (SIM\_IOSAHI) #### 6.3.13.1 Reserved—Bits 15—2 This bit field is reserved. Each bit must be set to 0. ## 6.3.13.2 Input/Output Short Address Location (ISAL[23:22])—Bits 1–0 This field represents the upper two address bits of the "hard coded" I/O short address. # 6.3.14 I/O Short Address Location Register Low (SIM\_IOSALO) See Section 6.3.13 for general information about I/O short address location registers. Figure 6-16 I/O Short Address Location Low Register (SIM\_IOSALO) # 6.3.14.1 Input/Output Short Address Location (ISAL[21:6])—Bits 15–0 This field represents the lower 16 address bits of the "hard coded" I/O short address. # 6.3.15 Protection Register (SIM\_PROT) This register provides write protection of selected control fields for safety-critical applications. The primary purpose is to prevent unsafe conditions due to the unintentional modification of these fields between the onset of a code runaway and a reset by the COP watchdog. The GPIO and Internal Peripheral Select Protection (GIPSP) field protects the contents of registers in the SIM and GPIO modules that control inter-peripheral signal muxing and GPIO configuration. The Peripheral Clock Enable Protection (PCEP) field protects the SIM registers' contents, which contain peripheral clock controls. Some peripherals provide additional safety features. Refer to the **56F802X and 56F803X Peripheral Reference Manual** for details. Flexibility is provided so that write protection control values may themselves be optionally locked (write-protected). Protection controls in this register have two bit values which determine the setting of the control and whether the value is locked. While a protection control remains unlocked, protection can be disabled and re-enabled by software. Once a protection control is locked, its value can only be altered by a chip reset, which restores its default non-locked value. | Base + \$12 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|----|----|----|---|---|---|---|---|---|----|-----|-----|------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PC | ·FD | GIE | PSP | | Write | | | | | | | | | | | | | | ·L1 | | OI . | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-17 Protection Register (SIM\_PROT) #### 6.3.15.1 Reserved—Bits 15-4 This bit field is reserved. Each bit must be set to 0. ## 6.3.15.2 Peripheral Clock Enable Protection (PCEP)—Bits 3–2 These bits enable write protection of all fields in the PCEn, SDn, and PCR registers in the SIM module. - 00 = Write protection off (default) - 01 = Write protection on - 10 = Write protection off and locked until chip reset - 11 = Write protection on and locked until chip reset ## 6.3.15.3 GPIO and Internal Peripheral Select Protection (GIPSP)—Bits 1–0 These bits enable write protection of GPSn and IPSn registers in the SIM module and write protect all GPIOx PEREN, GPIOx PPOUTM and GPIOx DRIVE registers in GPIO modules. - 00 = Write protection off (default) - 01 = Write protection on - 10 = Write protection off and locked until chip reset - 11 = Write protection on and locked until chip reset **Note:** The PWM fields in the CLKOUT register are also write protected by GIPSP. They are reserved for in-house test only. # 6.3.16 SIM GPIO Peripheral Select Register 0 for GPIOA (SIM\_GPSA0) Most I/O pins have an associated GPIO function. In addition to the GPIO function, I/O can be configured to be one of several peripheral functions. The GPIOx\_PEREN register within the GPIO module controls the selection between peripheral or GPIO control of the I/O pins. The GPIO function is selected when the GPIOx\_PEREN bit for the I/O is 0. When the GPIOx\_PEREN bit of the GPIO is 1, the fields in the GPSn registers select which peripheral function has control of the I/O. **Figure 6-18** illustrates the output path to an I/O pin when an I/O has two peripheral functions. Similar muxing is required on peripheral function inputs to receive input from the properly selected I/O pin. Figure 6-18 Overall Control of Signal Source Using SIM\_GPSnn Control In some cases, the user can choose peripheral function between several I/O, each of which have the option to be programmed to control a specific peripheral function. If the user wishes to use that function, only one of these I/O must be configured to control that peripheral function. If more than one I/O is configured to control the peripheral function, the peripheral output signal will fan out to each I/O, but the peripheral input signal will be the logical OR and AND of all the I/O signals. Complete lists of I/O muxings are provided in Table 2-3. The GPSn setting can be altered during normal operation, but a delay must be inserted between the time when one function is disabled and another function is enabled. **Note:** After reset, all I/O pins are GPIO, except the JTAG pins and the RESET pin. | Base + \$13 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|----------|------|------|------|------|---|---|---|---|---|---|---|---| | Read | 0 | 0 | 0 | GPS_A6 | GPS | : A5 | GPS | : A4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | | | | 0. 0_7.0 | 01 0 | | 01 0 | | | | | | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-19 GPIO Peripheral Select Register 0 for GPIOA (SIM\_GPSA0) #### 6.3.16.1 Reserved—Bits 15–13 This bit field is reserved. Each bit must be set to 0. ## 6.3.16.2 Configure GPIOA6 (GPS A6)—Bit 12 This field selects the alternate function for GPIOA6. - 0 = FAULTO PWM FAULTO Input (default) - 1 = TA0 Timer A0 ## 6.3.16.3 Configure GPIOA5 (GPS\_A5)—Bits 11–10 This field selects the alternate function for GPIOA5. - 00 = PWM5 PWM5 (default) - 01 = FAULT2 PWM FAULT2 Input - 10 = TA3 Timer A3 - 11 = Reserved # 6.3.16.4 Configure GPIOA4 (GPS\_A4)—Bits 9-8 This field selects the alternate function for GPIOA4. - 00 = PWM4 PWM4 (default) - 01 = FAULT1 PWM FAULT1 Input - 10 = TA2 Timer A2 - 11 = Reserved #### 6.3.16.5 Reserved—Bits 7-0 This bit field is reserved. Each bit must be set to 0. # 6.3.17 SIM GPIO Peripheral Select Register 0 for GPIOB (SIM\_GPSB0) See Section 6.3.16 for general information about GPIO Peripheral Select Registers. | Base + \$15 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|------|----|------|------|----|---------|---|------|------|------|--------|---|------|---|------| | Read | 0 | GPS | B6 | GPS | . B5 | | GPS_B4 | | GPS | S_B3 | GPS | <br>B2 | 0 | GPS_ | 0 | GPS_ | | Write | | 0, 0 | | 0, 0 | | | 01 0_D4 | | 0, 0 | | 0, 0 | _52 | | B1 | | B0 | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-20 GPIO Peripheral Select Register 0 for GPIOB (SIM\_GPSB0) #### 6.3.17.1 Reserved—Bit 15 This bit field is reserved. It must be set to 0. # 6.3.17.2 Configure GPIOB6 (GPS\_B6)—Bits 14-13 This field selects the alternate function for GPIOB6. - 00 = RXD0 QSCI0 Receive Data (default) - 01 = SDA I2C Serial - 10 = CLKIN External Clock Input - 11 = Reserved ## 6.3.17.3 Configure GPIOB5 (GPS\_B5)—Bits 12–11 This field selects the alternate function for GPIOB5. - 00 = TA1 Timer A1 (default) - 01 = FAULT3 PWM FAULT3 Input - 10 = CLKIN External Clock Input - 11 = Reserved ## 6.3.17.4 Configure GPIOB4 (GPS B4)—Bits 10-8 This field selects the alternate function for GPIOB4. - 000 = TA0 Timer A0 (default) - 001 = CLKO Clock Output - 010 = Reserved - 011 = TB0 Timer B0 - 100 = PSRC2 PWM4 / PWM5 Pair External Source - 11x = Reserved - 1x1 = Reserved ## 6.3.17.5 Configure GPIOB3 (GPS\_B3)—Bits 7–6 This field selects the alternate function for GPIOB3. - 00 = MOSI0 QSPI0 Master Out/Slave In (default) - 01 = TA3 Timer A3 - 10 = PSRC1 PWM2 / PWM3 Pair External Source - 11 = Reserved # 6.3.17.6 Configure GPIOB2 (GPS\_B2)—Bits 5-4 This field selects the alternate function for GPIOB2. - 00 = MISO0 QSPI0 Master In/Slave Out (default) - 01 = TA2 Timer A2 - 10 = PSRC0 PWM0 / PWM1 Pair External Source - 11 = Reserved #### 6.3.17.7 Reserved—Bit 3 This bit field is reserved. It must be set to 0. # 6.3.17.8 Configure GPIOB1 (GPS\_B1)—Bit 2 This field selects the alternate function for GPIOB1. - $0 = \overline{SS}0$ QSPI0 Slave Select (default) - 1 = SDA I2C Serial Data #### 6.3.17.9 Reserved—Bit 1 This bit field is reserved. It must be set to 0. ## 6.3.17.10 Configure GPIOB0 (GPS\_B0)—Bits 0 This field selects the alternate function for GPIOB0. - 0 = SCLK0 QSPI0 Serial Clock (default) - $1 = SCL I^2C$ Serial Clock # 6.3.18 SIM GPIO Peripheral Select Register 1 for GPIOB (SIM\_GPSB1) See Section 6.3.16 for general information about GPIO Peripheral Select Registers. | Base + \$16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | GPS_ | | Write | | | | | | | | | | | | | | | | В7 | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-21 GPIO Peripheral Select Register 1 for GPIOB (SIM\_GPSB1) #### 6.3.18.1 Reserved—Bits 15-1 This bit field is reserved. Each bit must be set to 0. # 6.3.18.2 Configure GPIOB7 (GPS\_B7)—Bit 0 This field selects the alternate function for GPIOB7. - 0 = TXD0 QSCI0 Transmit Data (default) - $1 = SCL I^2C$ Serial Clock # 6.3.19 Internal Peripheral Source Select Register 0 for Pulse Width Modulator (SIM IPS0) The internal integration of peripherals provides input signal source selection for peripherals where an input signal to a peripheral can be fed from one of several sources. These registers are organized by peripheral type and provide a selection list for every peripheral input signal that has more than one alternative source to indicate which source is selected. If one of the alternative sources is GPIO, the setting in these registers must be made consistently with the settings in the GPSn and GPIOx\_PEREN registers. Specifically, when an IPSn field is configured to select an I/O pin as the source, then GPSn register settings must configure only one I/O pin to feed this peripheral input function. Also, the GPIOx\_PEREN bit for that I/O pin must be set to 1 to enable peripheral control of the I/O. Figure 6-22 Overall Control of Signal Source using SIM\_IPSn Control IPSn settings should not be altered while an affected peripheral is in an enabled (operational) configuration. See the 56F802X and 56F803X Peripheral Reference Manual for details. | Base + \$18 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|--------|----|--------|----|---|-----|--------|-----------|-----|----------|------------|-----|----------|----| | Read | 0 | 0 | IPS0_ | 0 | IPS0_ | 0 | 0 | IP: | S0 PSR | <u> </u> | IPS | SO PSRO | 31 | IPS | 30 PSR | CO | | Write | | | FAULT2 | | FAULT1 | | | | 50_i | <i>52</i> | | 30_1 OIK | <i>3</i> 1 | | JO_1 OIX | 00 | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-23 Internal Peripheral Source Select Register for PWM (SIM\_IPS0) #### 6.3.19.1 Reserved—Bits 15–14 This bit field is reserved. Each bit must be set to 0. # 6.3.19.2 Select Peripheral Input Source for FAULT2 (IPS0 FAULT2)—Bit 13 This field selects the alternate input source signal to feed PWM input FAULT2. - 0 = I/O Pin (External) Use PWM FAULT2 Input Pin (default) - 1 = CMPBO (Internal) Use Comparator B Output #### 6.3.19.3 Reserved—Bit 12 This bit field is reserved. It must be set to 0. # 6.3.19.4 Select Peripheral Input Source for FAULT1 (IPS0\_FAULT1)—Bit 11 This field selects the alternate input source signal to feed PWM input FAULT1. - 0 = I/O pin (External) Use PWM FAULT2 Input Pin (default) - 1 = CMPAO (Internal) Use Comparator A Output #### 6.3.19.5 Reserved—Bits 10-9 This bit field is reserved. Each bit must be set to 0. # 6.3.19.6 Select Peripheral Input Source for PWM4/PWM5 Pair Source (IPS0 PSRC2)—Bits 8–6 This field selects the alternate input source signal to feed PWM input PSRC2 as the PWM4/PWM5 pair source. - 000 = Reserved (default) - 001 = TA3 (Internal) Use Timer A3 output as PWM source - 010 = ADC SAMPLE2 (Internal) Use ADC SAMPLE2 result as PWM source - If the ADC conversion result in SAMPLE2 is greater than the value programmed into the High Limit register HLMT2, then PWM4 is set to 0 and PWM5 is set to 1 - If the ADC conversion result in SAMPLE2 is less than the value programmed into the Low Limit register LLMT2, then PWM4 is set to 1 and PWM5 is set to 0 - 011 = CMPAO (Internal) Use Comparator A output as PWM source - 100 = CMPBO (Internal) Use Comparator B output as PWM source - 11x = Reserved - 1x1 = Reserved # 6.3.19.7 Select Peripheral Input Source for PWM2/PWM3 Pair Source (IPS0\_PSRC1)—Bits 5–3 This field selects the alternate input source signal to feed PWM input PSRC1 as the PWM2/PWM3 pair source. - 000 = I/O pin (External) Use a PSRC1 input pin as PWM source (default) - 001 = TA2 (Internal) Use Timer A2 output as PWM source - 010 = ADC SAMPLE1 (Internal) Use ADC SAMPLE1 result as PWM source - If the ADC conversion result in SAMPLE1 is greater than the value programmed into the High Limit register HLMT1, then PWM2 is set to 0 and PWM3 is set to 1 - If the ADC conversion result in SAMPLE1 is less than the value programmed into the Low Limit register LLMT2, then PWM2 is set to 1 and PWM3 is set to 0 - 011 = CMPAO (Internal) Use Comparator A output as PWM source - 100 = CMPBO (Internal) Use Comparator B output as PWM source - 11x = Reserved - 1x1 = Reserved # 6.3.19.8 Select Peripheral Input Source for PWM0/PWM1 Pair Source (IPS0\_PSRC0)—Bits 2–0 This field selects the alternate input source signal to feed PWM input PSRC0 as the PWM0/PWM1 pair source. - 000 = I/O pin (External) Use a PSRC0 input pin as PWM source (default) - 001 = TA0 (Internal) Use Timer A0 output as PWM source - 010 = ADC SAMPLE0 (Internal) Use ADC SAMPLE0 result as PWM source - If the ADC conversion result in SAMPLE0 is greater than the value programmed into the High Limit register HLMT1, then PWM0 is set to 0 and PWM1 is set to 1 - If the ADC conversion result in SAMPLE0 is less than the value programmed into the Low Limit register LLMT2, then PWM0 is set to 1 and PWM1 is set to 0 - 011 = CMPAO (Internal) Use Comparator A output as PWM source - 100 = CMPBO (Internal) Use Comparator B output as PWM source - 11x = Reserved - 1x1 = Reserved # 6.3.20 Internal Peripheral Source Select Register 1 for Digital-to-Analog Converters (SIM\_IPS1) See Section 6.3.19 for general information about Internal Peripheral Source Select registers. | Base + \$19 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|----|----|----|---|---|---|-----|---------|-----|---|-----|--------|-----| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | IPS | 1 DSYN | IC1 | 0 | IPS | 1 DSYN | VC0 | | Write | | | | | | | | | | | /I_BOTT | .01 | | 0 | | 100 | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-24 Internal Peripheral Source Select Register for DACs (SIM\_IPS1) #### 6.3.20.1 Reserved—Bits 15-7 This bit field is reserved. Each bit must be set to 0. # 6.3.20.2 Select Peripheral Input Source for SYNC Input to DAC 1 (ISS1\_DSYNC1)-Bits 6-4 This field selects the alternate input source signal to feed DAC1 SYNC input. - 000 = PIT0 (Internal) Use Programmable Interval Timer 0 Output as DAC SYNC input (default) - 001 = Reserved - 010 = Reserved - 011 = PWM SYNC (Internal) Use PWM reload synchronization signal as DAC SYNC input - 100 = TA0 (Internal) Use Timer A0 output as DAC SYNC input - 101 = TA1 (Internal) Use Timer A1 output as DAC SYNC input - 11x = Reserved # 6.3.20.3 Select Peripheral Input Source for SYNC Input to DAC 0 (ISS1\_DSYNC0)—Bits 2–0 This field selects the alternate input source signal to feed DAC0 SYNC input. - 000 = PIT0 (Internal) Use Programmable Interval Timer 0 Output as DAC SYNC input (default) - 001 = Reserved - 010 = Reserved - 011 = PWM SYNC (Internal) Use PWM reload synchronization signal as DAC SYNC input - 100 = TA0 (Internal) Use Timer A0 output as DAC SYNC input - 101 = TA1 (Internal) Use Timer A1 output as DAC SYNC input - 11x = Reserved # 6.3.21 Internal Peripheral Source Select Register 2 for Quad Timer A (SIM\_IPS2) See Section 6.3.19 for general information about Internal Peripheral Source Select registers. | Base + \$1A | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|----|-------|----|----|---|-------|---|---|---|-------|---|---|---|---| | Read | 0 | 0 | 0 | IPS2_ | 0 | 0 | 0 | IPS2_ | 0 | 0 | 0 | IPS2_ | 0 | 0 | 0 | 0 | | Write | | | | TA3 | | | | TA2 | | | | TA1 | | | | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 6-25 Internal Peripheral Source Select Register for TMRA (SIM\_IPS2) #### 6.3.21.1 Reserved—Bits 15–13 This bit field is reserved. Each bit must be set to 0. ## 6.3.21.2 Select Peripheral Input Source for TA3 (IPS2 TA3)—Bit 12 This field selects the alternate input source signal to feed Quad Timer A, input 3. - 0 = I/O pin (External) Use Timer A3 input/output pin - 1 = PWM SYNC (Internal) Use PWM reload synchronization signal #### 6.3.21.3 Reserved—Bits 11-9 This bit field is reserved. Each bit must be set to 0. ## 6.3.21.4 Select Input Source for TA2 (ISS2\_TA2)—Bit 8 This field selects the alternate input source signal to feed Quad Timer A, input 2. - 0 = I/O pin (External) Use Timer A2 input/output pin - 1 = CMPBO (Internal) Use Comparator B output #### 6.3.21.5 Reserved—Bits 7-5 This bit field is reserved. Each bit must be set to 0. ## 6.3.21.6 Select Peripheral Input Source for TA1 (IPS2\_TA1)—Bit 4 This field selects the alternate input source signal to feed Quad Timer A, input 1. - 0 = I/O pin (External) Use Timer A1 input/output pin - 1 = CMPAO (Internal) Use Comparator A output #### 6.3.21.7 Reserved—Bits 3-0 This bit field is reserved. Each bit must be set to 0. For Timer A to detect the PWM SYNC signal, the clock rate of both the PWM module and Timer A module must be identical, at either the system clock rate or 3X system clock rate. ## 6.4 Clock Generation Overview The SIM uses the master clock (2X system clock) at a maximum of 64MHz from the OCCS module to produce a system clock at a maximum of 32MHz for the peripheral, core, and memory. It divides the master clock by two and gates it with appropriate power mode and clock gating controls. A 3X system high-speed peripheral clock input from OCCS operates at three times the system clock at a maximum of 96MHz and can be an optional clock for PWM, Timer A, and I<sup>2</sup>C modules. These clocks are generated by gating the 3X system high-speed peripheral clock with appropriate power mode and clock gating controls. The OCCS configuration controls the operating frequency of the SIM's master clocks. In the OCCS, either an external clock (CLKIN), a crystal oscillator, or the relaxation oscillator can be selected as the master clock source (MSTR\_OSC). An external clock can be operated at any frequency up to 64MHz. The crystal oscillator can be operated only at a maximum of 8MHz. The relaxation oscillator can be operated at full speed (8MHz), standby speed (400kHz using ROSB), or powered down (using ROPD). An 8MHz MSTR\_OSC can be multiplied to 196MHz using the PLL and postscaled to provide a variety of high-speed clock rates. Either the postscaled PLL output or MSTR\_OSC signal can be selected to produce the master clocks to the SIM. When the PLL is selected, both the 3X system clock and the 2X system clock are enabled. If the PLL is not selected, the 3X system clock is disabled and the master clock is MSTR\_OSC. In combination with the OCCS module, the SIM provides power modes (see Section 6.5), clock enables, and clock rate controls to provide flexible control of clocking and power utilization. The clock rate controls enable the high-speed clocking option for the two quad timers (TMRA and TMRB) and PWM, but requires the PLL to be on and selected. Refer to the 56F802X and 56F803X Peripheral Reference Manual for further details. The peripheral clock enable controls can be used to disable an individual peripheral clock when it is not used. # 6.5 Power-Saving Modes The 56F8023 operates in one of five Power-Saving modes, as shown in Table 6-2. **Table 6-2 Clock Operation in Power-Saving Modes** | Mode | Core Clocks | Peripheral Clocks | Description | |------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Run | Core and memory clocks enabled | Peripheral clocks enabled | Device is fully functional | | Wait | Core and memory clocks disabled | Peripheral clocks<br>enabled | Core executes WAIT instruction to enter this mode. Typically used for power-conscious applications. Possible recoveries from Wait mode to Run mode are: 1. Any interrupt 2. Executing a Debug mode entry command during the 56800E core JTAG interface 3. Any reset (POR, external, software, COP) | | Stop | Master clock genera<br>remains operational,<br>the generation of sys<br>clocks. | but the SIM disables | Core executes STOP instruction to enter this mode. Possible recoveries from Stop mode to Run mode are: 1. Interrupt from any peripheral configured in the CTRL register to operate in Stop mode (TA0-3, QSCI0, PIT0-1, CAN, CMPA-B) 2. Low-voltage interrupt 3. Executing a Debug mode entry command using the 56800E core JTAG interface 4. Any reset (POR, external, software, COP) | | Standby | The OCCS generate reduced frequency (disabled and the high option is not available peripheral clocks open | h-speed peripheral<br>e. System and | The user configures the OCCS and SIM to select the relaxation oscillator clock source (PRECS), shut down the PLL (PLLPD), put the relaxation oscillator in Standby mode (ROSB), and put the large regulator in Standby (LRSTDBY). The device is fully operational, but operating at a minimum frequency and power configuration. Recovery requires reversing the sequence used to enter this mode (allowing for PLL lock time). | | Power-Down | Master clock genera completely shut dow peripheral clocks are | n. All system and | The user configures the OCCS and SIM to enter Standby mode as shown in the previous description, followed by powering down the oscillator (ROPD). The only possible recoveries from this mode are: 1. External Reset 2. Power-On Reset | The power-saving modes provide additional power management options by disabling the clock, reconfiguring the voltage regulator clock generation to manage power utilization, as shown in **Table 6-2**. Run, Wait, and Stop modes provide methods of enabling/disabling the peripheral and/or core clocking as a group. Stop disable controls for an individual peripheral are provided in the SD*n* registers to override the default behavior of Stop mode. By asserting a peripheral's Stop disable bit, the peripheral clock continues to operate in Stop mode. This is useful to generate interrupts which will recover the device from Stop mode to Run mode. Standby mode provides normal operation but at very low speed and power utilization. It is possible to invoke Stop or Wait mode while in Standby mode for even greater levels of power reduction. A 400kHz external clock can optionally be used in Standby mode to produce the required Standby 200kHz system clock rate. Power-down mode, which selects the ROSC clock source but shuts it off, fully disables the device and minimizes its power utilization but is only recoverable via reset. When the PLL is not selected and the system bus is operating at 200kHz or less, the large regulator can be put into its Standby mode (LRSTDBY) to reduce the power utilization of that regulator. All peripherals, except the COP/watchdog timer, run at the system clock frequency or optional 3X system clock for PWM, Timers, and $I^2C$ . The COP timer runs at OSC\_CLK / 1024. The maximum frequency of operation is 32MHz. ## 6.6 Resets The SIM supports five sources of reset, as shown in **Figure 6-26**. The two asynchronous sources are the external reset pin and the Power-On Reset (POR). The three synchronous sources are the software reset (SW reset), which is generated within the SIM itself by writing the SIM\_CTRL register in **Section 6.3.1**, the COP time-out reset (COP\_TOR), and the COP loss-of-reference reset (COP\_LOR). The reset generation module has three reset detectors, which resolve into four primary resets. These are outlined in **Table 6-3**. The JTAG circuitry is reset by the Power-On Reset. **Reset Sources Reset Signal POR External Software** COP Comments EXTENDED\_POR Χ Stretched version of POR released 64 OSC CLK cycles after POR deasserts CLKGEN RST Χ Χ Χ Χ Released 32 OSC CLK cycles after all reset sources, including EXTENDED POR, have released PERIP RST Χ Х Χ Χ Releases 32 SYS CLK cycles after the CLKGEN RST is released CORE RST Χ Х Χ Χ Releases 32 SYS CLK cycles after PERIP RST is released **Table 6-3 Primary System Resets** **Figure 6-26** provides a graphic illustration of the details in **Table 6-3**. Note that the POR\_Delay blocks use the OSC\_CLK as their time base, since other system clocks are inactive during this phase of reset. Figure 6-26 Sources of RESET Functional Diagram (Test modes not included) POR resets are extended 64 OSC\_CLK clocks to stabilize the power supply and clock source. All resets are subsequently extended for an additional 32 OSC\_CLK clocks and 64 system clocks as the various internal reset controls are released. Given the normal relaxation oscillator rate of 8MHz, the duration of a POR reset from when power comes on to when code is running is 28μS. An external reset generation circuit may also be used. A description of how these resets are used to initialize the clocking system and system modules is included in Section 6.7. # 6.7 Clocks The memory, peripheral and core clocks all operate at the same frequency (32MHz maximum), with the exception of the peripheral clocks for quad timers TMRA and TMRB and the PWM, which have the option to operate at 3X system clock. The SIM is responsible for clock distributions. While the SIM generates the ADC peripheral clock in the same way it generates all other peripheral clocks, the ADC standby and conversion clocks are generated by a direct interface between the ADC and the OCCS module. The deassertion sequence of internal resets coordinates the device start up, including the clocking system start up. The sequence is described in the following steps: - 1. As power is applied, the Relaxation Oscillator starts to operate. When a valid operating voltage is reached, the POR reset will release. - 2. The release of POR reset permits operation of the POR reset extender. The POR extender generates an extended POR reset, which is released 64 OSC\_CLK cycles after POR reset. This provides an additional time period for the clock source and power to stabilize. - 3. A Combined reset consists of the OR of the extended POR reset, the external reset, the COP reset and Software reset. The entire device, except for the POR extender, is held reset as long as Combined reset is asserted. The release of Combined reset permits operation of the CTRL register, the Synchronous reset generator, and the CLKGEN reset extender. - 4. The Synchronous reset generator generates a reset to the Software and COP reset logic. The COP and Software reset logic is released three OSC\_CLK cycles after Combined reset deasserts. This provides a reasonable minimum duration to the reset for these specialized functions. - 5. The CLKGEN reset extender generates the CLKGEN reset used by the clock generation logic. The CLKGEN reset is released 32 OSC\_CLK cycles after Combined reset deasserts. This provides a window in which the SIM stabilizes the master clock inputs to the clock generator. - 6. The release of CLKGEN reset permits operation of the clock generation logic and the Peripheral reset extender. The Peripheral reset extender generates the Peripheral reset, which is released 32 SYS\_CLK cycles after CLKGEN reset. This provides a window in which peripheral and core logic remain clocked, but in reset, so that synchronous resets can be resolved. - 7. The release of Peripheral reset permits operation of the peripheral logic and the Core reset extender. The Core reset extender generates the Core reset, which is released 32 SYS\_CLK cycles after the Peripheral reset. This provides a window in which critical peripheral start-up functions, such as Flash Security in the Flash memory, can be implemented. - 8. The release of Core reset permits execution of code by the 56800E core and marks the end of the system start-up sequence. Figure 6-27 illustrates clock relationships to one another and to the various resets as the device comes out of reset. RST is assumed to be the logical AND of all active-low system resets (for example, POR, external reset, COP and Software reset). In the 56F8023, this signal will be stretched by the SIM for a period of time (up to 96 OSC\_CLK clock cycles, depending upon the status of the POR) to create the clock generation reset signal (CLKGEN\_RST). The SIM should deassert CLKGEN\_RST synchronously with the negative edge of OSC\_CLK in order to avoid skew problems. CLKGEN\_RST is delayed 32 SYS\_CLK cycles to create the peripheral reset signal (PERIP\_RST). PERIP\_RST is then delayed by 32 SYS\_CLK cycles to create CORE\_RST. Both PERIP\_RST and CORE\_RST should be released on the negative edge of SYS\_CLK\_D as shown. This phased releasing of system resets is necessary to give some peripherals (for example, the Flash interface unit) set-up time prior to the 56800E core becoming active. Maximum Delay = 64 OSC\_CLK cycles for POR reset extension and 32 OSC\_CLK cycles for Combined reset extension Figure 6-27 Timing Relationships of Reset Signal to Clocks # 6.8 Interrupts The SIM generates no interrupts. # Part 7 Security Features The 56F8023 offers security features intended to prevent unauthorized users from reading the contents of the Flash Memory (FM) array. The 56F8023's Flash security consists of several hardware interlocks that prevent unauthorized users from gaining access to the Flash array. Note, however, that part of the security must lie with the user's code. An extreme example would be user's code that includes a subroutine to read and transfer the contents of the internal program to QSCI, QSPI or another peripheral, as this code would defeat the purpose of security. At the same time, the user may also wish to put a "backdoor" in his program. As an example, the user downloads a security key through the QSCI, allowing access to a programming routine that updates parameters stored in another section of the Flash. # 7.1 Operation with Security Enabled Once the user has programmed the Flash with his application code, the 56F8023 can be secured by programming the security bytes located in the FM configuration field, which are located at the last nine words of Program Flash. These non-volatile bytes will keep the device secured through reset and through power-down of the device. Only two bytes within this field are used to enable or disable security. Refer to the Flash Memory chapter in the **56F802X and 56F803X Peripheral Reference Manual** for the state of the security bytes and the resulting state of security. When Flash security mode is enabled in accordance with the method described in the Flash Memory module chapter, the 56F8023 will disable the core EOnCE debug capabilities. Normal program execution is otherwise unaffected. ## 7.2 Flash Access Lock and Unlock Mechanisms The 56F8023 has several operating functional and debug modes. Effective Flash security must address operating mode selection and anticipate modes in which the on-chip Flash can be read without explicit user permission. # 7.2.1 Disabling EOnCE Access On-chip Flash can be read by issuing commands across the EOnCE port, which is the debug interface for the 56800E CPU. The TCK, TMS, TDO, and TDI pins comprise a JTAG interface onto which the EOnCE port functionality is mapped. When the 56F8023 boots, the chip-level JTAG TAP (Test Access Port) is active and provides the chip's boundary scan capability and access to the ID register, but proper implementation of Flash security will block any attempt to access the internal Flash memory via the EOnCE port when security is enabled. # 7.2.2 Flash Lockout Recovery Using JTAG If a user inadvertently enables security on the 56F8023, the only lockout recovery mechanism is the complete erasure of the internal Flash contents, including the configuration field, and thus disables security (the protection register is cleared). This does not compromise security, as the entire contents of the user's secured code stored in Flash are erased before security is disabled on the 56F8023 on the next reset or power-up sequence. To start the lockout recovery sequence, the JTAG public instruction (LOCKOUT\_RECOVERY) must first be shifted into the chip-level TAP controller's instruction register. Once the LOCKOUT\_RECOVERY instruction has been shifted into the instruction register, the clock divider value must be shifted into the corresponding 7-bit data register. After the data register has been updated, the user must transition the TAP controller into the RUN-TEST/IDLE state for the lockout sequence to commence. The controller must remain in this state until the erase sequence has completed. Refer to the **56F802X and 56F803X Peripheral Reference Manual** for more details, or contact Freescale. Note: Once the lockout recovery sequence has completed, the user must reset both the JTAG TAP controller (by advancing the TAP state machine to the reset state) and the 56F8023 (by asserting external chip reset) to return to normal unsecured operation. # 7.2.3 Flash Lockout Recovery using CodeWarrior CodeWarrior can unlock a device using the command sequence described in **Section 7.2.2** by selecting the *Debug* menu, then selecting *DSP56800E*, followed by *Unlock Flash*. Another mechanism is also built into CodeWarrior using the device's memory configuration file. The command "Unlock\_Flash\_on\_Connect1" in the .cfg file accomplishes the same task as using the Debug menu. # 7.2.4 Product Analysis The recommended method of unsecuring a programmed 56F8023 for product analysis of field failures is via the backdoor key access. The customer would need to supply Technical Support with the backdoor key and the protocol to access the backdoor routine in the Flash. Additionally, the KEYEN bit that allows backdoor key access must be set. An alternative method for performing analysis on a secured microcontroller would be to mass-erase and reprogram the Flash with the original code, but modify the security bytes. To insure that a customer does not inadvertently lock himself out of the 56F8023 during programming, it is recommended that the user program the backdoor access key first, the application code second, and the security bytes within the FM configuration field last. # Part 8 General-Purpose Input/Output (GPIO) ## 8.1 Introduction This section is intended to supplement the GPIO information found in the 56F802X and 56F803X Peripheral Reference Manual and contains only chip-specific information. This information supersedes the generic information in the 56F802X and 56F803X Peripheral Reference Manual. # 8.2 Configuration There are four GPIO ports defined on the 56F8023. The width of each port, the associated peripheral and reset functions are shown in **Table 8-1**. The specific mapping of GPIO port pins is shown in **Table 8-2**. Additional details are shown in **Tables 2-2** and **2-3**. **Table 8-1 GPIO Ports Configuration** | GPIO Port | Available<br>Pins in<br>56F8023 | Peripheral Function | Reset Function | |-----------|---------------------------------|-------------------------------------------------------|----------------| | А | 8 | PWM, Timer, QSPI, Comparator, Reset | GPIO, RESET | | В | 8 | QSPI, I <sup>2</sup> C, PWM, Clock, Comparator, Timer | GPIO | | С | 6 | ADC, Comparator, QSCI | GPIO | | D | 4 | Clock, Oscillator, JTAG | GPIO, JTAG | **Table 8-2 GPIO External Signals Map** | GPIO Function | Peripheral Function | LQFP<br>Package Pin | Notes | |---------------|---------------------|---------------------|-----------------------------------------------------------------------------------------------| | GPIOA0 | PWM0 | 29 | Defaults to A0 | | GPIOA1 | PWM1 | 28 | Defaults to A1 | | GPIOA2 | PWM2 | 23 | Defaults to A2 | | GPIOA3 | PWM3 | 24 | Defaults to A3 | | GPIOA4 | PWM4 / TA2 / FAULT1 | 22 | SIM register SIM_GPS is used to<br>select between PWM4, TA2, and<br>FAULT1.<br>Defaults to A4 | | GPIOA5 | PWM5 / TA3 / FAULT2 | 20 | SIM register SIM_GPS is used to select between PWM5, TA3, and FAULT2. Defaults to A5 | | GPIOA6 | FAULT0 / TA0 | 18 | SIM register SIM_GPS is used to select between FAULT0 and TA0. Defaults to A6 | | GPIOA7 | RESET | 15 | Defaults to RESET | | GPIOB0 | SCLK0 / SCL | 21 | SIM register SIM_GPS is used to select between SCLK and SCL. Defaults to B0 | | GPIOB1 | SS0 / SDA | 2 | SIM register SIM_GPS is used to select between SS0 and SDA. Defaults to B1 | | GPIOB2 | MISO0 / TA2 / PSRC0 | 17 | SIM register SIM_GPS is used to select between MISO0, TA2, and PSRC0. Defaults to B2 | | GPIOB3 | MOSI0 / TA3 / PSRC1 | 16 | SIM register SIM_GPS is used to select between MOSI0, TA3 and PSRC1. Defaults to B3 | | GPIOB4 | TA0 / CLKO / PSRC2 | 38 | SIM register SIM_GPS is used to select between TA0, CLKO, and PSRC2. Defaults to B4 | **Table 8-2 GPIO External Signals Map (Continued)** | GPIO Function | Peripheral Function | LQFP<br>Package Pin | Notes | |---------------|---------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GPIOB5 | TA1 / FAULT3 / CLKIN | 4 | SIM register SIM_GPS is used to select between TA1, FAULT3, and CLKIN. CLKIN functionality is enabled using the PLL Control Register within the OCCS block. Defaults to B5 | | GPIOB6 | RXD0 / SDA / CLKIN | 1 | SIM register SIM_GPS is used to select between RXD0, SDA, and CLKIN. CLKIN functionality is enabled using the PLL Control Register within the OCCS block. Defaults to B6 | | GPIOB7 | TXD0 / SCL | 3 | SIM register SIM_GPS is used to select between TXD0 and SCL. Defaults to B7 | | GPIOC0 | ANA0 & CMPAI3 | 12 | Defaults to C0 | | GPIOC1 | ANA1 | 11 | Defaults to C1 | | GPIOC2 | ANA2 / V <sub>REFHA</sub> | 10 | SIM register SIM_GPS is used to select between ANA2 and V <sub>REFHA</sub> . Defaults to C2 | | GPIOC4 | ANB0 / CMPBI3 | 5 | SIM register SIM_GPS is used to select between ANB0 and CMPBI3. Defaults to C4 | | GPIOC5 | ANB1 | 6 | Defaults to C5 | | GPIOC6 | ANB2 / V <sub>REFHB</sub> | 7 | SIM register SIM_GPS is used to select between ANB2 and V <sub>REFHB</sub> . Defaults to C6 | | GPIOD0 | TDI | 30 | Defaults to TDI | | GPIOD1 | TDO | 32 | Defaults to TDO | | GPIOD2 | TCK | 14 | Defaults to TCK | | GPIOD3 | TMS | 31 | Defaults to TMS | # 8.3 Reset Values Tables 8-1 and 8-2 detail registers for the 56F8023; Figures 8-1 through 8-4 summarize register maps and reset values. Figure 8-1 GPIOA Register Map Summary 56F8023 Data Sheet, Rev. 3 Figure 8-2 GPIOB Register Map Summary Figure 8-3 GPIOC Register Map Summary 56F8023 Data Sheet, Rev. 3 Figure 8-4 GPIOD Register Map Summary ### Part 9 Joint Test Action Group (JTAG) #### 9.1 56F8023 Information Please contact your Freescale sales representative or authorized distributor for device/package-specific BSDL information. The $\overline{TRST}$ pin is not available in this package. The pin is tied to $V_{DD}$ in the package. The JTAG state machine is reset during POR and can also be reset via a soft reset by holding TMS high for five rising edges of TCK, as described in the 56F802X and 56F803X Peripheral Reference Manual. ### Part 10 Specifications #### 10.1 General Characteristics The 56F8023 is fabricated in high-density CMOS with 5V-tolerant TTL-compatible digital inputs. The term "5V-tolerant" refers to the capability of an I/O pin, built on a 3.3V-compatible process technology, to withstand a voltage up to 5.5V without damaging the device. Many systems have a mixture of devices designed for 3.3V and 5V power supplies. In such systems, a bus may carry both 3.3V- and 5V-compatible I/O voltage levels (a standard 3.3V I/O is designed to receive a maximum voltage of 3.3V $\pm$ 10% during normal operation without causing damage). This 5V-tolerant capability therefore offers the power savings of 3.3V I/O levels, combined with the ability to receive 5V levels without damage. Absolute maximum ratings in **Table 10-1** are stress ratings only, and functional operation at the maximum is not guaranteed. Stress beyond these ratings may affect device reliability or cause permanent damage to the device. Unless otherwise stated, all specifications within this chapter apply over the temperature range of -40°C to 125°C ambient temperature over the following supply ranges: $$V_{SS} = V_{SSA} = 0V$$ , $V_{DD} = V_{DDA} = 3.0-3.6V$ , $CL \le 50pF$ , $f_{OP} = 32MHz$ #### CAUTION This device contains protective circuitry to guard against damage due to high static voltage or electrical fields. However, normal precautions are advised to avoid application of any voltages higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate voltage level. **Table 10-1 Absolute Maximum Ratings** $(V_{SS} = 0V, V_{SSA} = 0V)$ | Characteristic | Symbol | Notes | Min | Max | Unit | |-----------------------------------------------------------------|--------------------|-----------------|-------|-------|------| | Supply Voltage Range | $V_{DD}$ | | -0.3 | 4.0 | V | | Analog Supply Voltage Range | V <sub>DDA</sub> | | - 0.3 | 4.0 | V | | ADC High Voltage Reference | V <sub>REFHx</sub> | | - 0.3 | 4.0 | V | | Voltage difference V <sub>DD</sub> to V <sub>DDA</sub> | $\Delta V_{DD}$ | | - 0.3 | 0.3 | V | | Voltage difference V <sub>SS</sub> to V <sub>SSA</sub> | $\Delta V_{SS}$ | | - 0.3 | 0.3 | V | | Digital Input Voltage Range | V <sub>IN</sub> | Pin Groups 1, 2 | - 0.3 | 6.0 | V | | Oscillator Voltage Range | V <sub>OSC</sub> | Pin Group 4 | - 0.4 | 4.0 | V | | Analog Input Voltage Range | V <sub>INA</sub> | Pin Group 3 | - 0.3 | 4.0 | V | | Input clamp current, per pin (V <sub>IN</sub> < 0) <sup>1</sup> | V <sub>IC</sub> | | _ | -20.0 | mA | | Output clamp current, per pin (V <sub>O</sub> < 0) <sup>1</sup> | V <sub>OC</sub> | | _ | -20.0 | mA | | Output Voltage Range<br>(Normal Push-Pull mode) | V <sub>OUT</sub> | Pin Group 1 | - 0.3 | 4.0 | V | | Output Voltage Range<br>(Open Drain mode) | V <sub>OUTOD</sub> | Pin Group 2 | - 0.3 | 6.0 | ٧ | | Ambient Temperature<br>Industrial | T <sub>A</sub> | | - 40 | 105 | °C | | Storage Temperature Range (Extended Industrial) | T <sub>STG</sub> | | - 55 | 150 | °C | <sup>1.</sup> Continuous clamp current per pin is -2.0 mA #### **Default Mode** Pin Group 1: GPIO, TDI, TDO, TMS, TCK Pin Group 2: RESET, GPIOA7 Pin Group 3: ADC and Comparator Analog Inputs Pin Group 4: XTAL, EXTAL #### 10.1.1 ElectroStatic Discharge (ESD) Model Table 10-2 56F8023 ESD Protection | Characteristic | Min | Тур | Max | Unit | |--------------------------------|------|-----|-----|------| | ESD for Human Body Model (HBM) | 2000 | _ | _ | V | #### Table 10-2 56F8023 ESD Protection | Characteristic | Min | Тур | Max | Unit | |-----------------------------------|-----|-----|-----|------| | ESD for Machine Model (MM) | 200 | _ | _ | V | | ESD for Charge Device Model (CDM) | 750 | _ | _ | V | #### Table 10-3 LQFP Package Thermal Characteristics<sup>6</sup> | Characteristic | Comments | Symbol | Value<br>(LQFP) | Unit | Notes | |-------------------------------------------|-------------------------|-----------------|-----------------|------|-------| | Junction to ambient<br>Natural convection | Single layer board (1s) | $R_{ hetaJA}$ | 41 | °C/W | 2 | | Junction to ambient<br>Natural convection | Four layer board (2s2p) | $R_{ hetaJMA}$ | 34 | °C/W | 1, 2 | | Junction to ambient (@200 ft/min) | Single layer board (1s) | $R_{ hetaJMA}$ | 34 | °C/W | 2 | | Junction to ambient<br>(@200 ft/min) | Four layer board (2s2p) | $R_{ heta JMA}$ | 29 | °C/W | 1, 2 | | Junction to board | | $R_{ heta JB}$ | 24 | °C/W | 4 | | Junction to case | | $R_{ heta JC}$ | 8 | °C/W | 3 | | Junction to package top | Natural Convection | $\Psi_{JT}$ | 2 | °C/W | 5 | - Theta-JA determined on 2s2p test boards is frequently lower than would be observed in an application. Determined on 2s2p thermal test board. - 2. Junction to ambient thermal resistance, Theta-JA (R<sub>θ,JA</sub>), was simulated to be equivalent to the JEDEC specification JESD51-2 in a horizontal configuration in natural convection. Theta-JA was also simulated on a thermal test board with two internal planes (2s2p, where "s" is the number of signal layers and "p" is the number of planes) per JESD51-6 and JESD51-7. The correct name for Theta-JA for forced convection or with the non-single layer boards is Theta-JMA. - 3. Junction to case thermal resistance, Theta-JC (R<sub>0,JC</sub>), was simulated to be equivalent to the measured values using the cold plate technique with the cold plate temperature used as the "case" temperature. The basic cold plate measurement technique is described by MIL-STD 883D, Method 1012.1. This is the correct thermal metric to use to calculate thermal performance when the package is being used with a heat sink. - 4. Junction to board thermal resistance, Theta-JB (R<sub>0JB</sub>), is a metric of the thermal resistance from the junction to the printed circuit board determined per JESD51-8. Board temperature is measured on the top surface of the board near the package. - 5. Thermal Characterization Parameter, Psi-JT (Y<sub>JT</sub>), is the "resistance" from junction to reference point thermocouple on top center of case as defined in JESD51-2. Y<sub>JT</sub> is a useful value to use to estimate junction temperature in steady state customer environments. - 6. Junction temperature is a function of die size, on-chip power dissipation, package thermal resistance, mounting site (board) temperature, ambient temperature, air flow, power dissipation of other components on the board, and board thermal resistance. - 7. See Section 12.1 for more details on thermal design considerations. # Table 10-4 Recommended Operating Conditions $(V_{REFL \ x}=0V,\ V_{SSA}=0V,\ V_{SS}=0V)$ | Characteristic | Symbol | Notes | Min | Тур | Max | Unit | |-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------|-------------------------------|-----|--------------------------------------------------|--------| | Supply voltage | V <sub>DD,</sub><br>V <sub>DDA</sub> | | 3 | 3.3 | 3.6 | V | | ADC Reference Voltage High | V <sub>REFHx</sub> | | 3.0 | | $V_{DDA}$ | V | | Voltage difference V <sub>DD</sub> to V <sub>DDA</sub> | $\Delta V_{DD}$ | | -0.1 | 0 | 0.1 | V | | Voltage difference V <sub>SS</sub> to V <sub>SSA</sub> | $\Delta V_{SS}$ | | -0.1 | 0 | 0.1 | V | | Device Clock Frequency Using relaxation oscillator Using external clock source | FSYSCLK | | 1 0 | | 32<br>32 | MHz | | Input Voltage High (digital inputs) | V <sub>IH</sub> | Pin Groups 1, 2 | 2.0 | | 5.5 | V | | Input Voltage Low (digital inputs) | V <sub>IL</sub> | Pin Groups 1, 2 | -0.3 | | 0.8 | V | | Oscillator Input Voltage High<br>XTAL not driven by an external clock<br>XTAL driven by an external clock source | V <sub>IHOSC</sub> | Pin Group 4 | V <sub>DDA</sub> - 0.8<br>2.0 | | V <sub>DDA</sub> + 0.3<br>V <sub>DDA</sub> + 0.3 | V | | Oscillator Input Voltage Low | V <sub>ILOSC</sub> | Pin Group 4 | -0.3 | | 0.8 | V | | Output Source Current High at V <sub>OH</sub> min.) <sup>1</sup> When programmed for low drive strength When programmed for high drive strength | I <sub>OH</sub> | Pin Group 1<br>Pin Group 1 | | | -4<br>-8 | mA | | Output Source Current Low (at V <sub>OL</sub> max.) <sup>1</sup> When programmed for low drive strength When programmed for high drive strength | I <sub>OL</sub> | Pin Groups 1, 2<br>Pin Groups 1, 2 | | | 4<br>8 | mA | | Ambient Operating Temperature (Extended Industrial) | T <sub>A</sub> | | -40 | | 105 | °C | | Flash Endurance<br>(Program Erase Cycles) | N <sub>F</sub> | T <sub>A</sub> = -40°C to<br>125°C | 10,000 | | _ | cycles | | Flash Data Retention | T <sub>R</sub> | T <sub>J</sub> <= 85°C avg | 15 | | _ | years | | Flash Data Retention with <100 Program/Erase Cycles | t <sub>FLRET</sub> | T <sub>J</sub> <= 85°C avg | 20 | _ | _ | years | <sup>1.</sup> Total chip source or sink current cannot exceed 75mA #### **Default Mode** Pin Group 1: GPIO, TDI, TDO, TMS, TCK Pin Group 2: RESET, GPIOA7 Pin Group 3: ADC and Comparator Analog Inputs Pin Group 4 XTAL, EXTAL #### 10.2 DC Electrical Characteristics #### **Table 10-5 DC Electrical Characteristics** At Recommended Operating Conditions | Characteristic | Symbol | Notes | Min | Тур | Max | Unit | Test<br>Conditions | |-------------------------------------------------------------------------|--------------------|-----------------|-----------------------------------------|----------|-----------------------------------------|------|--------------------------------------| | Output Voltage High | V <sub>OH</sub> | Pin Group 1 | 2.4 | _ | _ | V | I <sub>OH</sub> = I <sub>OHmax</sub> | | Output Voltage Low | V <sub>OL</sub> | Pin Groups 1, 2 | _ | _ | 0.4 | V | I <sub>OL</sub> = I <sub>OLmax</sub> | | Digital Input Current High (a) pull-up enabled or disabled | I <sub>IH</sub> | Pin Groups 1, 2 | _ | 0 | +/- 2.5 | μΑ | V <sub>IN</sub> = 2.4V<br>to 5.5V | | Comparator Input Current High | I <sub>IHC</sub> | Pin Group 3 | _ | 0 | +/- 2 | μΑ | V <sub>IN</sub> = V <sub>DDA</sub> | | Oscillator Input Current High | I <sub>IHOSC</sub> | Pin Group 3 | _ | 0 | +/- 2 | μА | V <sub>IN</sub> = V <sub>DDA</sub> | | Digital Input Current Low <sup>1</sup> pull-up enabled pull-up disabled | I <sub>IL</sub> | Pin Groups 1, 2 | -15<br>— | -30<br>0 | -60<br>+/- 2.5 | μА | V <sub>IN</sub> = 0V | | Comparator Input Current Low | I <sub>ILC</sub> | Pin Group 3 | - | 0 | +/- 2 | μА | V <sub>IN</sub> = 0V | | Oscillator Input Current Low | I <sub>ILOSC</sub> | Pin Group 3 | _ | 0 | +/- 2 | μА | V <sub>IN</sub> = 0V | | DAC Output Voltage Range | V <sub>DAC</sub> | Internal | Typically<br>V <sub>SSA</sub> +<br>40mV | _ | Typically<br>V <sub>SSA</sub> –<br>40mV | V | _ | | Output Current <sup>1</sup> High Impedance State | I <sub>OZ</sub> | Pin Groups 1, 2 | _ | 0 | +/- 2.5 | μΑ | _ | | Schmitt Trigger Input Hysteresis | V <sub>HYS</sub> | Pin Groups 1, 2 | _ | 0.35 | _ | V | _ | | Input Capacitance | C <sub>IN</sub> | | _ | 10 | _ | pF | _ | | Output Capacitance | C <sub>OUT</sub> | | _ | 10 | _ | pF | _ | 1. See **Figure 10-1** #### **Default Mode** Pin Group 1: GPIO, TDI, TDO, TMS, TCK Pin Group 2: RESET, GPIOA7 Pin Group 3: ADC and Comparator Analog Inputs Pin Group 4: XTAL, EXTAL Figure 10-1 $I_{IN}/I_{OZ}$ vs. $V_{IN}$ (Typical; Pull-Up Disabled) **Table 10-6 Current Consumption per Power Supply Pin** | | | Typical @ | 3.3V, 25°C | Maximum@ | ) 3.6V, 25°C | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------|------------------------------|------------------| | Mode | Conditions | I <sub>DD</sub> <sup>1</sup> | I <sub>DDA</sub> | I <sub>DD</sub> <sup>1</sup> | I <sub>DDA</sub> | | RUN | 32MHz Device Clock Relaxation Oscillator on PLL powered on Continuous MAC instructions with fetches from Program Flash All peripheral modules enabled. TMR and PWM using 1X Clock ADC/DAC powered on and clocked Comparator powered on | 48mA | 18.8mA | _ | _ | | WAIT | 32MHz Device Clock Relaxation Oscillator on PLL powered on Processor Core in WAIT state All Peripheral modules enabled. TMR and PWM using 1X Clock ADC/DAC/Comparator powered off | 29mA | 0μΑ | _ | _ | | STOP | 4MHz Device Clock Relaxation Oscillator on PLL powered off Processor Core in STOP state All peripheral module and core clocks are off ADC/DAC/Comparator powered off | 5.4mA | 0μΑ | _ | _ | **Table 10-6 Current Consumption per Power Supply Pin (Continued)** | Mada | O a malistica ma | Typical @ | 3.3V, 25°C | Maximum@ | 3.6V, 25°C | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------|------------------------------|------------------| | Mode | Conditions | I <sub>DD</sub> <sup>1</sup> | I <sub>DDA</sub> | I <sub>DD</sub> <sup>1</sup> | I <sub>DDA</sub> | | STANDBY > STOP | 100kHz Device Clock Relaxation Oscillator in Standby mode PLL powered off Processor Core in STOP state All peripheral module and core clocks are off ADC/DAC/Comparator powered off Voltage regulator in Standby mode | 290μΑ | 0μΑ | 390µА | 1μΑ | | POWERDOWN | Device Clock is off Relaxation Oscillator powered off PLL powered off Processor Core in STOP state All peripheral module and core clocks are off ADC /DAC/Comparator powered off Voltage Regulator in Standby mode | 190μΑ | 0µА | 250μΑ | 1μΑ | No Output Switching All ports configured as inputs All inputs Low No DC Loads **Table 10-7 Power-On Reset Low-Voltage Parameters** | Characteristic | Symbol | Min | Тур | Max | Unit | |----------------------------------------------------|--------------------|------|------|-----|------| | Low-Voltage Interrupt for 3.3V supply <sup>1</sup> | V <sub>EI3.3</sub> | 2.58 | 2.7 | _ | V | | Low-Voltage Interrupt for 2.5V supply <sup>2</sup> | V <sub>E12.5</sub> | _ | 2.15 | _ | V | | Low-Voltage Interrupt Recovery Hysteresis | V <sub>EIH</sub> | | 50 | _ | mV | | Power-On Reset <sup>3</sup> | POR | _ | 1.8 | 1.9 | V | <sup>1.</sup> When V<sub>DD</sub> drops below V<sub>El3.3</sub>, an interrupt is generated. #### 10.2.1 Voltage Regulator Specifications The 56F8023 has two on-chip regulators. One supplies the PLL and relaxation oscillator. It has no external pins and therefore has no external characteristics which must be guaranteed (other than proper operation of the device). The second regulator supplies approximately 2.5V to the 56F8023's core logic. This regulator requires an external $4.4\mu F$ , or greater, capacitor for proper operation. Ceramic and tantalum capacitors tend to provide better performance tolerances. The output voltage can be measured directly on the $V_{CAP}$ pin. The specifications for this regulator are shown in **Table 10-8**. <sup>2.</sup> When $V_{DD}$ drops below $V_{El32.5}$ , an interrupt is generated. <sup>3.</sup> Power-On Reset occurs whenever the internally regulated 2.5V digital supply drops below 1.8V. While power is ramping up, this signal remains active for as long as the internal 2.5V is below 2.15V or the 3.3V $^{1}$ O voltage is below 2.7V, no matter how long the ramp-up rate is. The internally regulated voltage is typically 100mV less than $^{1}$ O during ramp-up until 2.5V is reached, at which time it self-regulates. Table 10-8. Regulator Parameters | Characteristic | Symbol | Min | Typical | Max | Unit | |--------------------------------------------------------------|------------------|-----|---------|-----|---------| | Short Circuit Current | I <sub>SS</sub> | _ | 450 | 650 | mA | | Short Circuit Tolerance (V <sub>CAP</sub> shorted to ground) | T <sub>RSC</sub> | _ | _ | 30 | minutes | #### 10.3 AC Electrical Characteristics Tests are conducted using the input levels specified in **Table 10-5**. Unless otherwise specified, propagation delays are measured from the 50% to the 50% point, and rise and fall times are measured between the 10% and 90% points, as shown in **Figure 10-2**. Note: The midpoint is $V_{IL}$ + $(V_{IH} - V_{IL})/2$ . Figure 10-2 Input Signal Measurement References Figure 10-3 shows the definitions of the following signal states: - Active state, when a bus or signal is driven, and enters a low impedance state - Tri-stated, when a bus or signal is placed in a high impedance state - Data Valid state, when a signal level has reached $V_{OL}$ or $V_{OH}$ - Data Invalid state, when a signal level is in transition between V<sub>OL</sub> and V<sub>OH</sub> Figure 10-3 Signal States #### 10.4 Flash Memory Characteristics **Table 10-9 Flash Timing Parameters** | Characteristic | Symbol | Min | Тур | Max | Unit | |---------------------------|--------|-----|-----|-----|------| | Program time <sup>1</sup> | Tprog | 20 | _ | 40 | μS | | Erase time <sup>2</sup> | Terase | 20 | _ | _ | ms | | Mass erase time | Tme | 100 | _ | _ | ms | There is additional overhead which is part of the programming sequence. See the 56F802X and 56F803X Peripheral Reference Manual for details. #### 10.5 External Clock Operation Timing Table 10-10 External Clock Operation Timing Requirements<sup>1</sup> | Characteristic | Symbol | Min | Тур | Max | Unit | |-------------------------------------------------------------|-------------------|------|-----|-----|------| | Frequency of operation (external clock driver) <sup>2</sup> | f <sub>osc</sub> | 4 | 8 | 8 | MHz | | Clock Pulse Width <sup>3</sup> | t <sub>PW</sub> | 6.25 | _ | _ | ns | | External Clock Input Rise Time <sup>4</sup> | t <sub>rise</sub> | _ | _ | 3 | ns | | External Clock Input Fall Time <sup>5</sup> | t <sub>fall</sub> | _ | _ | 3 | ns | - 1. Parameters listed are guaranteed by design. - 2. See Figure 10-4 for details on using the recommended connection of an external clock driver. - 3. The chip may not function if the high or low pulse width is smaller than 6.25ns. - 4. External clock input rise time is measured from 10% to 90%. - 5. External clock input fall time is measured from 90% to 10%. Note: The midpoint is $V_{IL} + (V_{IH} - V_{IL})/2$ . Figure 10-4 External Clock Timing <sup>2.</sup> Specifies page erase time. There are 512 bytes per page in the Program Flash memory. #### 10.6 Phase Locked Loop Timing #### Table 10-11 PLL Timing | Characteristic | Symbol | Min | Тур | Max | Unit | |----------------------------------------------------------------------------------|------------------------|-----|-----|------|------| | External reference crystal frequency for the PLL <sup>1</sup> | f <sub>osc</sub> | 4 | 8 | _ | MHz | | Internal reference relaxation oscillator frequency for the PLL | f <sub>rosc</sub> | | 8 | _ | MHz | | PLL output frequency <sup>2</sup> (24 x reference frequency) | f <sub>op</sub> | 96 | 192 | _ | MHz | | PLL lock time <sup>3</sup> | t <sub>plls</sub> | _ | 40 | 100 | μs | | Accumulated jitter using an 8MHz external crystal as the PLL source <sup>4</sup> | J <sub>A</sub> | _ | _ | 0.37 | % | | Cycle-to-cycle jitter | t <sub>jitterpll</sub> | _ | 350 | _ | ps | <sup>1.</sup> An externally supplied reference clock should be as free as possible from any phase jitter for the PLL to work correctly. The PLL is optimized for 8MHz input. ### 10.7 Relaxation Oscillator Timing **Table 10-12 Relaxation Oscillator Timing** | Characteristic | Symbol | Minimum | Typical | Maximum | Unit | |----------------------------------------------------------------------------------------------------------------------|-------------------------|---------|--------------|--------------|------------| | Relaxation Oscillator output frequency <sup>1</sup><br>Normal Mode<br>Standby Mode | f <sub>op</sub> | _ | 8.05<br>200 | _ | MHz<br>kHz | | Relaxation Oscillator stabilization time <sup>2</sup> | t <sub>roscs</sub> | _ | 1 | 3 | ms | | Cycle-to-cycle jitter. This is measured on the CLKO signal (programmed prescaler_clock) over 264 clocks <sup>3</sup> | t <sub>jitterrosc</sub> | _ | 400 | - | ps | | Minimum tuning step size | | 1 | .08 | | % | | Maximum tuning step size | | | 40 | | % | | Variation over temperature -40°C to 150°C <sup>4</sup> | | | +1.0 to -1.5 | +3.0 to -3.0 | % | | Variation over temperature 0°C to 105°C <sup>4</sup> | | _ | 0 to +1 | +2.0 to -2.0 | % | <sup>1.</sup> Output frequency after application of 8MHz trim value, at 125°C. <sup>2.</sup> The core system clock will operate at 1/6 of the PLL output frequency. <sup>3.</sup> This is the time required after the PLL is enabled to ensure reliable operation. <sup>4.</sup> This is measured on the CLKO signal (programmed as System clock) over 264 System clocks at 32MHz System clock frequency and using an 8MHz oscillator frequency. <sup>2.</sup> This is the time required from Standby to Normal mode transition. <sup>3.</sup> J<sub>A</sub> is required to meet QSCI requirements. <sup>4.</sup> See Figure 10-5 Figure 10-5 Relaxation Oscillator Temperature Variation (Typical) After Trim at 125°C #### 10.8 Reset, Stop, Wait, Mode Select, and Interrupt Timing **Note:** All address and data buses described here are internal. Table 10-13 Reset, Stop, Wait, Mode Select, and Interrupt Timing 1,2 | Characteristic | Symbol | Typical Min | Typical Max | Unit | See Figure | |-----------------------------------------------------------------------------|------------------|--------------------------|--------------------------|------|------------| | Minimum RESET Assertion Duration | t <sub>RA</sub> | 4T | _ | ns | _ | | Minimum GPIO pin Assertion for Interrupt | t <sub>IW</sub> | 2T | _ | ns | 10-6 | | RESET deassertion to First Address Fetch <sup>3</sup> | t <sub>RDA</sub> | 96T <sub>OSC</sub> + 64T | 97T <sub>OSC</sub> + 65T | ns | _ | | Delay from Interrupt Assertion to Fetch of first instruction (exiting Stop) | t <sub>IF</sub> | _ | 6T | ns | _ | <sup>1.</sup> In the formulas, T = system clock cycle and T<sub>osc</sub> = oscillator clock cycle. For an operating frequency of 32MHz, T = 31.25ns. At 8MHz (used during Reset and Stop modes), T = 125ns. <sup>3.</sup> During Power-On Reset, it is possible to use the 56F8023 internal reset stretching circuitry to extend this period to 2^21T. Figure 10-6 GPIO Interrupt Timing (Negative Edge-Sensitive) <sup>2.</sup> Parameters listed are guaranteed by design. ## 10.9 Serial Peripheral Interface (SPI) Timing Table 10-14 SPI Timing<sup>1</sup> | Characteristic | Symbol | Min | Max | Unit | See Figure | |-------------------------------------------------------------------|------------------|-------------|--------------|----------|----------------------------| | Cycle time<br>Master<br>Slave | t <sub>C</sub> | 125<br>62.5 | | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Enable lead time<br>Master<br>Slave | t <sub>ELD</sub> | —<br>31 | | ns<br>ns | 10-10 | | Enable lag time<br>Master<br>Slave | t <sub>ELG</sub> | <br>125 | Z | ns<br>ns | 10-10 | | Clock (SCK) high time<br>Master<br>Slave | t <sub>CH</sub> | 50<br>31 | | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Clock (SCK) low time<br>Master<br>Slave | t <sub>CL</sub> | 50<br>31 | _ | ns<br>ns | 10-10 | | Data set-up time required for inputs<br>Master<br>Slave | t <sub>DS</sub> | 20<br>0 | _<br>_ | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Data hold time required for inputs<br>Master<br>Slave | t <sub>DH</sub> | 0<br>2 | _<br>_ | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Access time (time to data active from high-impedance state) Slave | t <sub>A</sub> | 4.8 | 15 | ns | 10-10 | | Disable time (hold time to high-impedance state) Slave | t <sub>D</sub> | 3.7 | 15.2 | ns | 10-10 | | Data Valid for outputs<br>Master<br>Slave (after enable edge) | t <sub>DV</sub> | | 4.5<br>20.4 | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Data invalid<br>Master<br>Slave | t <sub>DI</sub> | 0<br>0 | | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Rise time<br>Master<br>Slave | t <sub>R</sub> | <u> </u> | 11.5<br>10.0 | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | | Fall time<br>Master<br>Slave | t <sub>F</sub> | | 9.7<br>9.0 | ns<br>ns | 10-7, 10-8,<br>10-9, 10-10 | Parameters listed are guaranteed by design. Figure 10-7 SPI Master Timing (CPHA = 0) Figure 10-8 SPI Master Timing (CPHA = 1) Figure 10-9 SPI Slave Timing (CPHA = 0) Figure 10-10 SPI Slave Timing (CPHA = 1) ### 10.10 Quad Timer Timing Table 10-15 Timer Timing<sup>1, 2</sup> | Characteristic | Symbol | Min | Max | Unit | See Figure | |--------------------------------|--------------------|--------|-----|------|------------| | Timer input period | P <sub>IN</sub> | 2T + 6 | -() | ns | 10-11 | | Timer input high / low period | P <sub>INHL</sub> | 1T + 3 | _ | ns | 10-11 | | Timer output period | Роит | 125 | - | ns | 10-11 | | Timer output high / low period | P <sub>OUTHL</sub> | 50 | 1 | ns | 10-11 | <sup>1.</sup> In the formulas listed, T = the clock cycle. For 32MHz operation, T = 31.25ns. <sup>2.</sup> Parameters listed are guaranteed by design. Figure 10-11 Timer Timing ### 10.11 Serial Communication Interface (SCI) Timing Table 10-16 SCI Timing<sup>1</sup> | Characteristic | Symbol | Min | Max | Unit | See Figure | |---------------------------------------------------------------------------------------|--------------------------|------------|------------------------|-------------------------------|------------| | Baud Rate <sup>2</sup> | BR | _ | (f <sub>MAX</sub> /16) | Mbps | _ | | RXD <sup>3</sup> Pulse Width | RXD <sub>PW</sub> | 0.965/BR | 1.04/BR | ns | 10-12 | | TXD <sup>4</sup> Pulse Width | TXD <sub>PW</sub> | 0.965/BR | 1.04/BR | ns | 10-13 | | | LIN S | Slave Mode | | | | | Deviation of slave node clock from nominal clock rate before synchronization | F <sub>TOL_UNSYNCH</sub> | -14 | 14 | % | _ | | Deviation of slave node clock relative to the master node clock after synchronization | F <sub>TOL_SYNCH</sub> | -2 | 2 | % | _ | | Minimum break character length | T <sub>BREAK</sub> | 13 | _ | Master<br>node bit<br>periods | _ | | | | 11 | _ | Slave node bit periods | _ | - 1. Parameters listed are guaranteed by design. - 2. $f_{MAX}$ is the frequency of operation of the system clock in MHz, which is 32MHz for the 56F8023 device. - 3. The RXD pin in QSCI0 is named RXD0 and the RXD pin in QSCI1 is named RXD1. - 4. The TXD pin in QSCI0 is named TXD0 and the TXD pin in QSCI1 is named TXD1. ### 10.12 Inter-Integrated Circuit Interface (I<sup>2</sup>C) Timing #### Table 10-17 I<sup>2</sup>C Timing | Charactaristic | Complete | Standa | rd Mode | Fast | Fast Mode | | | |-------------------------------------------------------------------------------------------------------|----------------------|------------------|-------------------|------------------------------------|------------------|------|--| | Characteristic | Symbol | Minimum | Maximum | Minimum | Maximum | Unit | | | SCL Clock Frequency | f <sub>SCL</sub> | 0 | 100 | 0 | 400 | kHz | | | Hold time (repeated)<br>START condition. After<br>this period, the first clock<br>pulse is generated. | t <sub>HD;</sub> STA | 4.0 | _ | 0.6 | | μs | | | LOW period of the SCL clock | t <sub>LOW</sub> | 4.7 | _ | 1.3 | _ | μS | | | HIGH period of the SCL clock | t <sub>HIGH</sub> | 4.0 | _ | 0.6 | | μS | | | Set-up time for a repeated START condition | t <sub>SU; STA</sub> | 4.7 | - | 0.6 | _ | μS | | | Data hold time for I <sup>2</sup> C bus devices | t <sub>HD; DAT</sub> | 01 | 3.45 <sup>2</sup> | 01 | 0.9 <sup>2</sup> | μS | | | Data set-up time | t <sub>SU; DAT</sub> | 250 <sup>3</sup> | - | 100 <sup>3, 4</sup> | | ns | | | Rise time of both SDA and SCL signals | t <sub>r</sub> | . 5 | 1000 | 20 +0.1C <sub>b</sub> <sup>5</sup> | 300 | ns | | | Fall time of both SDA and SCL signals | t <sub>f</sub> | 1-11 | 300 | 20 +0.1C <sub>b</sub> <sup>5</sup> | 300 | ns | | | Set-up time for STOP condition | t <sub>SU; STO</sub> | 4.0 | _ | 0.6 | _ | μS | | | Bus free time between<br>STOP and START<br>condition | t <sub>BUF</sub> | 4.7 | _ | 1.3 | _ | μs | | | Pulse width of spikes that must be suppressed by the input filter | t <sub>SP</sub> | N/A | N/A | 0 | 50 | ns | | <sup>1.</sup> The master mode I<sup>2</sup>C deasserts ACK of an address byte simultaneously with the falling edge of SCL. If no slaves acknowledge this address byte, a negative hold time can result, depending on the edge rates of the SDA and SCL lines. <sup>2.</sup> The maximum t<sub>HD: DAT</sub> must be met only if the device does not stretch the LOW period (t<sub>LOW</sub>) of the SCL signal. <sup>3.</sup> Set-up time in slave-transmitter mode is 1 IPBus clock period, if the TX FIFO is empty. <sup>4.</sup> A Fast mode $I^2C$ bus device can be used in a Standard mode $I^2C$ bus system, but the requirement $t_{SU;\;DAT} > = 250$ ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line $t_{rmax} + t_{SU;\;DAT} = 1000 + 250 = 1250$ ns (according to the Standard mode $I^2C$ bus specification) before the SCL line is released. <sup>5.</sup> C<sub>b</sub> = total capacitance of the one bus line in pF. Figure 10-14 Timing Definition for Fast and Standard Mode Devices on the I<sup>2</sup>C Bus ### 10.13 JTAG Timing **Table 10-18 JTAG Timing** | Characteristic | Symbol | Min | Max | Unit | See Figure | |-----------------------------------------|-----------------|-----|-----------|------|------------| | TCK frequency of operation <sup>1</sup> | f <sub>OP</sub> | DC | SYS_CLK/8 | MHz | 10-15 | | TCK clock pulse width | t <sub>PW</sub> | 50 | _ | ns | 10-15 | | TMS, TDI data set-up time | t <sub>DS</sub> | 5 | _ | ns | 10-16 | | TMS, TDI data hold time | t <sub>DH</sub> | 5 | _ | ns | 10-16 | | TCK low to TDO data valid | t <sub>DV</sub> | _ | 30 | ns | 10-16 | | TCK low to TDO tri-state | t <sub>TS</sub> | _ | 30 | ns | 10-16 | <sup>1.</sup> TCK frequency of operation must be less than 1/8 the processor rate. Figure 10-15 Test Clock Input Timing Diagram Figure 10-16 Test Access Port Timing Diagram ### 10.14 Analog-to-Digital Converter (ADC) Parameters Table 10-19 ADC Parameters<sup>1</sup> | Parameter | Symbol | Min | Тур | Max | Unit | |------------------------------------------------------------------|---------------------|-------------------|------------------|-------------------|--------------------------------------| | DC Specifications | <u> </u> | 1 | | 1 | 1 | | Resolution | R <sub>ES</sub> | 12 | _ | 12 | Bits | | ADC internal clock | f <sub>ADIC</sub> | 0.1 | _ | 5.33 | MHz | | Conversion range | R <sub>AD</sub> | V <sub>REFL</sub> | _ | V <sub>REFH</sub> | V | | ADC power-up time <sup>2</sup> | t <sub>ADPU</sub> | _ | 6 | 13 | t <sub>AIC</sub> cycles <sup>3</sup> | | Recovery from auto standby | t <sub>REC</sub> | _ | 0 | 1 | t <sub>AIC</sub> cycles <sup>3</sup> | | Conversion time | t <sub>ADC</sub> | _ | 6 | | t <sub>AIC</sub> cycles <sup>3</sup> | | Sample time | t <sub>ADS</sub> | _ | 1 | _ | t <sub>AIC</sub> cycles <sup>3</sup> | | Accuracy | | | | | | | Integral non-linearity <sup>4</sup><br>(Full input signal range) | INL | _ | +/- 3 | +/- 5 | LSB <sup>5</sup> | | Differential non-linearity | DNL | _ | +/6 | +/- 1 | LSB <sup>5</sup> | | Monotonicity | | | GUARANTEED | | | | Offset Voltage Internal Ref | V <sub>OFFSET</sub> | | +/- 4 | +/- 9 | mV | | Offset Voltage External Ref | V <sub>OFFSET</sub> | | +/- 6 | +/- 12 | mV | | Gain Error (transfer gain) | E <sub>GAIN</sub> | | .998 to 1.002 | 1.01 to .99 | _ | | ADC Inputs <sup>6</sup> (Pin Group 3) | | | | | • | | Input voltage (external reference) | V <sub>ADIN</sub> | V <sub>REFL</sub> | _ | $V_{REFH}$ | V | | Input voltage (internal reference) | V <sub>ADIN</sub> | V <sub>SSA</sub> | _ | V <sub>DDA</sub> | V | | Input leakage | I <sub>IA</sub> | _ | 0 | +/- 2 | μΑ | | V <sub>REFH</sub> current | I <sub>VREFH</sub> | _ | 0 | _ | μΑ | | Input injection current <sup>7</sup> , per pin | I <sub>ADI</sub> | _ | _ | 3 | mA | | Input capacitance | C <sub>ADI</sub> | _ | See Figure 10-17 | _ | pF | | Input impedance | X <sub>IN</sub> | _ | See Figure 10-17 | _ | Ohms | | AC Specifications | | | | I | 1 | | Signal-to-noise ratio | SNR | 60 | 65 | | dB | | Total Harmonic Distortion | THD | 60 | 64 | | dB | | Spurious Free Dynamic Range | SFDR | 61 | 66 | | dB | | Signal-to-noise plus distortion | SINAD | 58 | 62 | | dB | | Effective Number Of Bits | ENOB | _ | 10.0 | | Bits | <sup>1.</sup> All measurements were made at $V_{DD}$ = 3.3V, $V_{REFH}$ = 3.3V, and $V_{REFL}$ = ground #### 56F8023 Data Sheet, Rev. 3 <sup>2.</sup> Includes power-up of ADC and $V_{\mathsf{REF}}$ <sup>3.</sup> ADC clock cycles <sup>4.</sup> INL measured from $V_{IN} = V_{REFL}$ to $V_{IN} = V_{REFH}$ <sup>5.</sup> LSB = Least Significant Bit = 0.806mV <sup>6.</sup> Pin groups are detailed following Table 10-1. <sup>7.</sup> The current that can be injected or sourced from an unselected ADC signal input without impacting the performance of the ADC. #### 10.15 Equivalent Circuit for ADC Inputs **Figure 10-17** illustrates the ADC input circuit during sample and hold. S1 and S2 are always open/closed at the same time that S3 is closed/open. When S1/S2 are closed and S3 is open, one input of the sample and hold circuit moves to $(V_{REFHx}-V_{REFLx})/2$ , while the other charges to the analog input voltage. When the switches are flipped, the charge on C1 and C2 are averaged via S3, with the result that a single-ended analog input is switched to a differential voltage centered about $(V_{REFHx}-V_{REFLx})/2$ . The switches switch on every cycle of the ADC clock (open one-half ADC clock, closed one-half ADC clock). Note that there are additional capacitances associated with the analog input pad, routing, etc., but these do not filter into the S/H output voltage, as S1 provides isolation during the charge-sharing phase. One aspect of this circuit is that there is an on-going input current, which is a function of the analog input voltage, $V_{REF}$ , and the ADC clock frequency. - 1. Parasitic capacitance due to package, pin-to-pin and pin-to-package base coupling; 1.8pF - 2. Parasitic capacitance due to the chip bond pad, ESD protection devices and signal routing; 2.04pF - 3. Equivalent resistance for the channel select mux; 100 ohms - Sampling capacitor at the sample and hold circuit. Capacitor C1 is normally disconnected from the input and is only connected to it at sampling time; 1.4pF Figure 10-17 Equivalent Circuit for A/D Loading #### 10.16 Comparator (CMP) Parameters **Table 10-20 CMP Parameters** | Characteristic | Conditions/Comments | Symbol | Min | Тур | Max | Unit | |-----------------------------------|---------------------------------------------------------------|---------------------|-----|--------|--------|------| | Input Offset Voltage <sup>1</sup> | Within range of V <sub>DDA</sub> 1V to V <sub>SSA</sub> + .1V | V <sub>OFFSET</sub> | _ | +/- 10 | +/- 20 | mV | | Input Propagation Delay | | t <sub>PD</sub> | _ | 35 | 45 | ns | | Power-up time | | t <sub>CPU</sub> | _ | TBD | TBD | | No guaranteed specification within 0.1V of V<sub>DDA</sub> or V<sub>SSA</sub> ### 10.17 Digital-to-Analog Converter (DAC) Parameters **Table 10-21 DAC Parameters** | Parameter | Conditions/Comments | Symbol | Min | Тур | Max | Unit | |-----------------------------------------|-----------------------------------------------------------------------------------------|---------------------|-----------------------------|------------|---------------------------|------------------| | DC Specifications | | • | | • | • | | | Resolution | | | 12 | | 12 | bits | | Conversion time | | | TBD | _ | 2 | μS | | Conversion rate | | | TBD | _ | 500.000 | conv/sec | | Power-up time | Time from release of PWRDWN signal until DACOUT signal is valid | t <sub>DAPU</sub> | _ | | 11 | μS | | Accuracy | | | | | | | | Integral non-linearity <sup>1</sup> | Range of input digital words:<br>410 to 3891 (\$19A - \$F33)<br>5% to 95% of full range | INL | | +/- 3 | +/- 8.0 | LSB <sup>2</sup> | | Differential non-linearity <sup>1</sup> | Range of input digital words:<br>410 to 3891 (\$19A - \$F33)<br>5% to 95% of full range | DNL | | +/8 | < - 1 | LSB <sup>2</sup> | | Monotonicity | > 6 sigma monotonicity,<br>< 3.4 ppm non-monotonicity | | | guaranteed | | _ | | Offset error <sup>1</sup> | Range of input digital words:<br>410 to 3891 (\$19A - \$F33)<br>5% to 95% of full range | V <sub>OFFSET</sub> | _ | +/- 25 | +/- 40 | mV | | Gain error <sup>1</sup> | Range of input digital words:<br>410 to 3891 (\$19A - \$F33)<br>5% to 95% of full range | E <sub>GAIN</sub> | _ | +/5 | +/- 1.5 | % | | DAC Output | | 1 | | • | • | • | | Output voltage range | Within 40mV of either $V_{REFLX}$ or $V_{REFHX}$ | V <sub>OUT</sub> | V <sub>REFLX</sub><br>+.04V | _ | V <sub>REFHX</sub><br>04V | V | | AC Specifications | | • | | • | • | • | | Signal-to-noise ratio | | SNR | _ | TBD | _ | dB | | Spurious free dynamic range | | SFDR | _ | TBD | | dB | | Effective number of bits | | ENOB | 9 | _ | _ | bits | <sup>1.</sup> No guaranteed specification within 5% of $V_{DDA}$ or $V_{SSA}$ <sup>2.</sup> LSB = 0.806mV #### 10.18 Power Consumption See Section 10.1 for a list of IDD requirements for the 56F8023. This section provides additional detail which can be used to optimize power consumption for a given application. Power consumption is given by the following equation: Total power = A: internal [static component] +B: internal [state-dependent component] +C: internal [dynamic component] +D: external [dynamic component] +E: external [static component] A, the internal [static component], is comprised of the DC bias currents for the oscillator, leakage currents, PLL, and voltage references. These sources operate independently of processor state or operating frequency. B, the internal [state-dependent component], reflects the supply current required by certain on-chip resources only when those resources are in use. These include RAM, Flash memory and the ADCs. C, the internal [dynamic component], is classic C\*V<sup>2</sup>\*F CMOS power dissipation corresponding to the 56800E core and standard cell logic. D, the external [dynamic component], reflects power dissipated on-chip as a result of capacitive loading on the external pins of the chip. This is also commonly described as $C*V^2*F$ , although simulations on two of the I/O cell types used on the 56800E reveal that the power-versus-load curve does have a non-zero Y-intercept. Table 10-22 I/O Loading Coefficients at 10MHz | | Intercept | Slope | |-----------|-----------|-------------| | 8mA drive | 1.3 | 0.11mW / pF | | 4mA drive | 1.15mW | 0.11mW / pF | Power due to capacitive loading on output pins is (first order) a function of the capacitive load and frequency at which the outputs change. **Table 10-22** provides coefficients for calculating power dissipated in the I/O cells as a function of capacitive load. In these cases: $TotalPower = \Sigma((Intercept + Slope*Cload)*frequency/10MHz)$ #### where: - Summation is performed over all output pins with capacitive loads - TotalPower is expressed in mW - Cload is expressed in pF Because of the low duty cycle on most device pins, power dissipation due to capacitive loads was found to be fairly low when averaged over a period of time. E, the external [static component], reflects the effects of placing resistive loads on the outputs of the device. Sum the total of all $V^2/R$ or IV to arrive at the resistive load contribution to power. Assume V=0.5 for the purposes of these rough calculations. For instance, if there is a total of eight PWM outputs driving 10mA into LEDs, then P=8\*.5\*.01=40mW. In previous discussions, power consumption due to parasitics associated with pure input pins is ignored, as it is assumed to be negligible. ### Part 11 Packaging #### 11.1 56F8023 Package and Pin-Out Information This section contains package and pin-out information for the 56F8023. This device comes in a 32-pin Low-profile Quad Flat Pack (LQFP). **Figure 11-1** shows the package outline, **Figure 11-2** shows the mechanical parameters and **Table 11-1** lists the pin-out. Figure 11-1 Top View, 56F8023 32-Pin LQFP Package Table 11-1 56F8023 32-Pin LQFP Package Identification by Pin Number<sup>1</sup> | Pin<br># | Signal Name | Pin<br># | Signal Name | Pin<br># | Signal Name | Pin<br># | Signal Name | |----------|-------------------------------------|----------|--------------------------------------------|----------|-------------------------------|----------|----------------------| | 1 | GPIOB6<br>RXD0 / SDA / CLKIN | 9 | V <sub>SSA</sub> | 17 | GPIOB2<br>MISO0 / TA2 / PSRC0 | 25 | V <sub>CAP</sub> | | 2 | GPIOB1<br>SSO/SDA | 10 | <b>GPIOC2</b><br>ANA2 / V <sub>REFHA</sub> | 18 | GPIOA6<br>FAULTO / TAO | 26 | V <sub>DD</sub> | | 3 | GPIOB7<br>TXD0 / SCL | 11 | GPIOC1<br>ANA1 | 19 | GPIOB4<br>TA0 / CLKO / PSRC2 | 27 | V <sub>SS</sub> | | 4 | GPIOB5<br>TA1 / FAULT3 / CLKIN | 12 | GPIOC0<br>ANA0 & CMPAI3 | 20 | GPIOA5<br>PWM5 / TA3 / FAULT2 | 28 | GPIOA1<br>PWM1 | | 5 | GPIOC4<br>ANB0 & CMPBI3 | 13 | $V_{SS}$ | 21 | GPIOB0<br>SCLK0/SCL | 29 | GPIOA0<br>PWM0 | | 6 | GPIOC5<br>ANB1 | 14 | TCI<br>GPIOD2 | 22 | GPIOA4<br>PWM4/TA2/FAULT1 | 30 | <b>TDI</b><br>GPIOD0 | | 7 | GPIOC6<br>ANB2 / V <sub>REFHB</sub> | 15 | RESET<br>GPIOA7 | 23 | GPIOA2<br>PWM2 | 31 | TMS<br>GPIOD3 | | 8 | V <sub>DDA</sub> | 16 | GPIOB3<br>MOSI0 / TA3 /<br>PSRC1 | 24 | GPIOA3<br>PWM3 | 32 | TDO<br>GPIOD1 | <sup>1.</sup> Alternate signals are in italic - NOTES: 1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982. 2. CONTROLLING DIMENSION: MILLIMETER. 3. DATUM PLANE -AB- IS LOCATED AT BOTTOM OF LEAD AND IS COINCIDENT WITH THE LEAD WHERE THE LEAD EXITS THE PLASTIC BODY AT - THE BOTTOM OF THE PARTING LINE. DATUMS —T. —U., AND —Z.—TO BE DETERMINED AT DATUM PLANE —AB.— DIMENSIONS S AND V TO BE DETERMINED AT DATUM PLANE —AB.— - SEATING PLANE -AC-. 6. DIMENSIONS A AND B DO NOT INCLUDE MOLD - PROTRUSION. ALLOWABLE PROTRUSION IS 0.250 (0.010) PER SIDE. DIMENSIONS A AND B DO INCLUDE MOLD MISMATCH AND ARE - DO INCLOSE MINIMATED AND AND AND DETERMINED AT DATUM PLANE AB –. DIMENSION D DOES NOT INCLUDE DAMBAR PROTRUSION. DAMBAR PROTRUSION SHALL NOT CAUSE THE D DIMENSION TO EXCEED 0.520 (0.020). 8. MINIMUM SOLDER PLATE THICKNESS SHALL BE - 0.0076 (0.0003). 9. EXACT SHAPE OF EACH CORNER MAY VARY - FROM DEPICTION. | | MILLIN | IETERS | INCHES | | | | |-----|--------|--------|-----------|-------|--|--| | DIM | MIN | MAX | MIN | MAX | | | | Α | 7.000 | BSC | 0.276 | BSC | | | | A1 | 3.500 | BSC | 0.138 | BSC | | | | В | 7.000 | BSC | 0.276 BSC | | | | | B1 | 3.500 | BSC | 0.138 | BSC | | | | С | 1.400 | 1.600 | 0.055 | 0.063 | | | | D | 0.300 | 0.450 | 0.012 | 0.018 | | | | Ε | 1.350 | 1.450 | 0.053 | 0.057 | | | | F | 0.300 | 0.400 | 0.012 | 0.016 | | | | G | 0.800 | BSC | 0.031 | BSC | | | | Н | 0.050 | 0.150 | 0.002 | 0.006 | | | | J | 0.090 | 0.200 | 0.004 | 0.008 | | | | K | 0.500 | 0.700 | 0.020 | 0.028 | | | | M | 12° | REF | 12° | REF | | | | N | 0.090 | 0.160 | 0.004 | 0.006 | | | | P | 0.400 | | 0.016 | | | | | Q | 1° | 5° | 1° | 5° | | | | R | 0.150 | 0.250 | 0.006 | 0.010 | | | | S | 9.000 | BSC | 0.354 | BSC | | | | S1 | 4.500 | BSC | 0.177 BSC | | | | | ٧ | 9.000 | BSC | 0.354 BSC | | | | | V1 | 4.500 | BSC | 0.177 | BSC | | | | W | 0.200 | REF | 0.008 | REF | | | | Х | 1.000 | REF | 0.039 | REF | | | Figure 11-2 56F8023 32-Pin LQFP Mechanical Information Please see www.freescale.com for the most current case outline. ### Part 12 Design Considerations #### 12.1 Thermal Design Considerations An estimation of the chip junction temperature, T<sub>I</sub>, can be obtained from the equation: $$T_{J} = T_{A} + (R_{\theta JA} \times P_{D})$$ where: $T_A$ = Ambient temperature for the package ( ${}^{o}$ C) $R_{0,IA}$ = Junction-to-ambient thermal resistance ( ${}^{o}$ C/W) $P_D$ = Power dissipation in the package (W) The junction-to-ambient thermal resistance is an industry-standard value that provides a quick and easy estimation of thermal performance. Unfortunately, there are two values in common usage: the value determined on a single-layer board and the value obtained on a board with two planes. For packages such as the PBGA, these values can be different by a factor of two. Which value is closer to the application depends on the power dissipated by other components on the board. The value obtained on a single layer board is appropriate for the tightly packed printed circuit board. The value obtained on the board with the internal planes is usually appropriate if the board has low-power dissipation and the components are well separated. When a heat sink is used, the thermal resistance is expressed as the sum of a junction-to-case thermal resistance and a case-to-ambient thermal resistance: $$R_{\theta JA} = R_{\theta JC} + R_{\theta CA}$$ where: $R_{\theta JA}$ = Package junction-to-ambient thermal resistance (°C/W) $R_{\theta JC}$ = Package junction-to-case thermal resistance (°C/W) $R_{\theta CA}$ = Package case-to-ambient thermal resistance (°C/W) $R_{\theta JC}$ is device related and cannot be influenced by the user. The user controls the thermal environment to change the case to ambient thermal resistance, $R_{\theta CA}$ . For instance, the user can change the size of the heat sink, the air flow around the device, the interface material, the mounting arrangement on printed circuit board, or change the thermal dissipation on the printed circuit board surrounding the device. To determine the junction temperature of the device in the application when heat sinks are not used, the Thermal Characterization Parameter ( $\Psi_{JT}$ ) can be used to determine the junction temperature with a measurement of the temperature at the top center of the package case using the following equation: $$T_J = T_T + (\Psi_{JT} \times P_D)$$ where: $T_T$ = Thermocouple temperature on top of package ( ${}^{\circ}$ C) $\Psi_{IT}$ = Thermal characterization parameter ( ${}^{\circ}C/W$ ) $P_D$ = Power dissipation in package (W) The thermal characterization parameter is measured per JESD51-2 specification using a 40-gauge type T thermocouple epoxied to the top center of the package case. The thermocouple should be positioned so that the thermocouple junction rests on the package. A small amount of epoxy is placed over the thermocouple junction and over about 1mm of wire extending from the junction. The thermocouple wire is placed flat against the package case to avoid measurement errors caused by cooling effects of the thermocouple wire. When heat sink is used, the junction temperature is determined from a thermocouple inserted at the interface between the case of the package and the interface material. A clearance slot or hole is normally required in the heat sink. Minimizing the size of the clearance is important to minimize the change in thermal performance caused by removing part of the thermal interface to the heat sink. Because of the experimental difficulties with this technique, many engineers measure the heat sink temperature and then back-calculate the case temperature using a separate measurement of the thermal resistance of the interface. From this case temperature, the junction temperature is determined from the junction-to-case thermal resistance #### 12.2 Electrical Design Considerations #### **CAUTION** This device contains protective circuitry to guard against damage due to high static voltage or electrical fields. However, normal precautions are advised to avoid application of any voltages higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate voltage level. Use the following list of considerations to assure correct operation of the 56F8023: - Provide a low-impedance path from the board power supply to each $V_{DD}$ pin on the 56F8023 and from the board ground to each $V_{SS}$ (GND) pin - The minimum bypass requirement is to place 0.01–0.1μF capacitors positioned as close as possible to the package supply pins. The recommended bypass configuration is to place one bypass capacitor on each of the V<sub>DD</sub>/V<sub>SS</sub> pairs, including V<sub>DDA</sub>/V<sub>SSA</sub>. Ceramic and tantalum capacitors tend to provide better tolerances. - Ensure that capacitor leads and associated printed circuit traces that connect to the chip $V_{DD}$ and $V_{SS}$ (GND) pins are as short as possible - Bypass the $V_{DD}$ and $V_{SS}$ with approximately 100 $\mu$ F, plus the number of 0.1 $\mu$ F ceramic capacitors - PCB trace lengths should be minimal for high-frequency signals - Consider all device loads as well as parasitic capacitance due to PCB traces when calculating capacitance. This is especially critical in systems with higher capacitive loads that could create higher transient currents in the V<sub>DD</sub> and V<sub>SS</sub> circuits. - Take special care to minimize noise levels on the V<sub>REF</sub>, V<sub>DDA</sub>, and V<sub>SSA</sub> pins - Using separate power planes for $V_{DD}$ and $V_{DDA}$ and separate ground planes for $V_{SS}$ and $V_{SSA}$ are recommended. Connect the separate analog and digital power and ground planes as close as possible to power supply outputs. If both analog circuit and digital circuit are powered by the same power supply, it is advisable to connect a small inductor or ferrite bead in serial with both $V_{DDA}$ and $V_{SSA}$ traces. - It is highly desirable to physically separate analog components from noisy digital components by ground planes. Do not place an analog trace in parallel with digital traces. It is also desirable to place an analog ground trace around an analog signal trace to isolate it from digital traces. - Because the Flash memory is programmed through the JTAG/EOnCE port, QSPI, QSCI, or I<sup>2</sup>C, the designer should provide an interface to this port if in-circuit Flash programming is desired. - If desired, connect an external RC circuit to the RESET pin. The Resistor value should be in the range of 4.7k—10k; the Capacitor value should be in the range of 0.22μf 4.7μf. - Add a 3.3k external pull-up on the TMS pin of the JTAG port to keep EOnce in a restate during normal operation if JTAG converter is not present. - During reset and after reset but before I/O initialization, all I/O pins are at input state with internal pull-up enable. The typical value of internal pull-up is around 110K. These internal pull-ups can be disabled by software. - To eliminate PCB trace impedance effect, each ADC input should have a 33pf-10 ohm RC filter. - Device GPIOs have only a down (substrate) diode on the GPIO circuit. Devices do not have a positive clamp diode because GPIOs use a floating gate structure to tolerate 5V input. The absolute maximum clamp current is -20mA at V<sub>in</sub> less than 0V. The continuous clamp current is -2mA at V<sub>in</sub> less than 0V. If positive voltage spikes are a concern, a positive clamp is recommended. ### **Part 13 Ordering Information** **Table 13-1** lists the pertinent information needed to place an order. Consult a Freescale Semiconductor sales office or authorized distributor to determine availability and to order devices. Table 13-1 56F8023 Ordering Information | Device | Supply<br>Voltage | Package IVDE | | Frequency<br>(MHz) | Ambient<br>Temperature<br>Range | Order Number | |-----------|-------------------|-----------------------------------|----|--------------------|---------------------------------|---------------| | MC56F8023 | 3.0–3.6 V | Low-Profile Quad Flat Pack (LQFP) | 32 | 32 | -40° to + 105° C | MC56F8023VLC* | <sup>\*</sup> This package is RoHS compliant. ### Part 14 Appendix Register acronyms are revised from previous device data sheets to provide a cleaner register description. A cross reference to legacy and revised acronyms are provided in the following table. **Note:** This table comprises all peripherals used in the 56F803x and 56F802x family; some of the peripherals described here may not be present on this device. **Table 14-1 Legacy and Revised Acronyms** | Register Name | Peripheral Reference<br>Manual | | Data | Sheet | Processor Expert | Memory<br>Address | | | |------------------------------------------|--------------------------------|-------------------|----------------|-------------------|------------------|-------------------|--------|--| | negister Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | Analog-to-Digital Converter (ADC) Module | | | | | | | | | | Control 1 Register | CTRL1 | ADCR1 | ADC_CTRL1 | ADC_ADCR1 | ADC_ADCR1 | 0xF | 080 | | | Control 2 Register | CTRL2 | ADCR2 | ADC_CTRL2 | ADC_ADCR2 | ADC_ADCR2 | 0xF | 081 | | | Zero Crossing Control<br>Register | ZXCTRL | ADZCC | ADC_ZXCTRL | ADC_ADZCC | ADC_ADZCC | 0xF082 | | | | Channel List 1<br>Register | CLIST1 | ADLST1 | ADC_CLIST1 | ADC_ADLST1 | ADC_ADLST1 | 0xF | 083 | | | Channel List 2<br>Register | CLIST2 | ADLST2 | ADC_CLIST2 | ADC_ADLST2 | ADC_ADLST2 | 0xF084 | | | | Channel List 3<br>Register | CLIST3 | | ADC_CLIST3 | ADC_ADCLST3 | ADC_ADCLST3 | 0xF085 | | | | Channel List 4<br>Register | CLIST4 | | ADC_CLIST4 | ADC_ADCLST4 | ADC_ADCLST4 | 0xF086 | | | | Sample Disable<br>Register | SDIS | ADSDIS | ADC_SDIS | ADC_ADSDIS | ADC_ADSDIS | 0xF087 | | | | Status Register | STAT | ADSTAT | ADC_STAT | ADC_ADSTAT | ADC_ADSTAT | 0xF | 088 | | | Conversion Ready<br>Register | RDY | | ADC_CNRDY | ADC_ADCNRDY | ADC_ADCNRDY | 0xF | 0xF089 | | | Limit Status Register | LIMSTAT | ADLSTAT | ADC_LIMSTAT | ADC_ADLSTAT | ADC_ADLSTAT | 0xF | 08A | | | Zero Crossing Status<br>Register | ZXSTAT | ADZCSTAT | ADC_ZXSTAT | ADC_ADZCSTAT | ADC_ADZCSTAT | 0xF | 08B | | | Result 0-7 Registers | RSLT0-7 | ADRSLT0-7 | ADC_RSLT0-7 | ADC_ADRSLT0-7 | ADC_ADRSLT0-7 | 0xF08C | 0XF093 | | | Result 8-15 Registers | RSLT8-15 | | ADC_RSLT8-15 | ADC_ADRSLT8-15 | ADC_ADRSLT8-15 | 0xF094 | 0XF09B | | | Low Limit 0-7<br>Registers | LOLIM0-7 | ADLLMT0-7 | ADC_LOLIM0-7 | ADC_ADLLMT0-7 | ADC_ADLLMT0-7 | 0XF09C | 0XF0A3 | | | High Limit 0-7<br>Registers | HILIM0-7 | ADHLMT0-7 | ADC_HILIM0-7 | ADC_ADHLMT0-7 | ADC_ADHLMT0-7 | 0XF0A4 | 0XF0AB | | | Offset 0-7 Registers | OFFST0-7 | ADOFS0-7 | ADC_OFFST0-7 | ADC_ADOFS0-7 | ADC_ADOFS0-7 | 0XF0AC | 0XF0B3 | | | Power Control<br>Register | PWR | ADPOWER | ADC_PWR | ADC_ADPOWER | ADC_ADPOWER | 0XF | 0B4 | | | Calibration Register | CAL | | ADC_CAL | ADC_ADCAL | ADC_ADCAL | 0XF | 0B5 | | | Register Name | Peripheral<br>Mar | Reference<br>nual | Data | Sheet | Processor Expert | Memory<br>Address | | |------------------|-------------------|-------------------|-----------------------|-------------------|------------------|-------------------|-----| | negister name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Comp | iter Operating Proper | rly (COP) Module | | | | | Control Register | CTRL | COPCTL | COP_CTRL | COPCTL | COPCTL | 0XF | 120 | | Timeout Register | TOUT | COPTO | COP_TOUT | СОРТО | COPTO | 0XF121 | | | Counter Register | CNTR | COPCTR | COP_CNTR | COPCTR | COPCTR | 0XF | 122 | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Register Name | Peripheral Reference<br>Manual | | Data | Sheet | Processor Expert | Mem<br>Addı | - | |-------------------------------------------------------|--------------------------------|-------------------|-------------------------|--------------------------------|------------------|-------------|-----| | Hegister Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Inter-I | ntegrated Circuit Inter | face (I <sup>2</sup> C) Module | | | | | Control Register | CTRL | IBCR | I2C_CTRL | I2C_IBCR | I2C_IBCR | 0xF | 280 | | Target Address<br>Register | TAR | | I2C_TAR | I2CTAR | I2C_TAR | 0xF | 282 | | Slave Address<br>Register | SAR | | I2C_SAR | I2CSAR | 12C_SAR | 0xF | 242 | | Data Buffer &<br>Command Register | DATA | | I2C_DATA | I2C_DATACMD | I2C_DATACMD | 0xF | 288 | | Standard Speed<br>Clock SCL High<br>Count Register | SSHCNT | | I2C_SS_SCL_HCNT | I2C_SS_SCLHCNT | I2C_SS_SCLHCNT | 0xF2 | 28A | | Standard Speed<br>Clock SCL Low Count<br>Register | SSLCNT | | I2C_SS_SOL_LCNT | I2C_SS_SCLLCNT | I2C_SS_SCLLCNT | 0xF2 | 28C | | Fast Speed Clock<br>SCL High Count<br>Register | FSHCNT | | I2C_FS_SCL_HONT | I2C_FS_SCLHCNT | I2C_FS_SCLHCNT | 0xF2 | 28E | | Fast Speed Clock<br>SCL Low Count<br>Register | FSLCNT | | I2C_FS_SCL_LCNT | I2C_FS_SCLLCNT | I2C_FS_SCLLCNT | 0xF | 290 | | Interrupt Status<br>Register | ISTAT | | I2C_INTR_STAT | I2C_INTRSTAT | I2C_INTRSTAT | 0xF | 296 | | Interrupt Mask<br>Register | IENBL | | I2C_INTR_MASK | I2C_INTRMASK | I2C_INTRMASK | 0xF | 298 | | Raw Interrupt Status<br>Register | RISTAT | | I2C_RAW_INTR_STAT | I2C_RAW_INTRSTAT | I2C_RAW_INTRSTAT | 0xF2 | 29A | | Receive FIFO<br>Threshold Level<br>Register | RXFT | | I2C_RXTL | | I2C_RXTL | 0xF2 | 29C | | Transmit FIFO Threshold Level Register | TXFT | | I2C_TXTL | | I2C_TXTL | 0xF2 | 29E | | Clear Combined &<br>Individual Interrupts<br>Register | CLRINT | | I2C_CLRINTR | | I2C_CLRINTR | 0xF2 | 2A0 | | Clear Receive Under<br>Interrupt Register | CLRRXUND | | I2C_CLR_RXUNDER | | I2C_CLR_RXUNDER | 0xF2 | 2A2 | | Clear Receive Over<br>Interrupt Register | CLRRXOVR | | I2C_CLROVER | | I2C_CLROVER | 0xF2 | 2A4 | | Clear Transmit Over<br>Register | CLRTXOVR | | LC_CLR_TXOVER | | I2C_CLR_TXOVER | 0xF2 | 2A6 | | Clear Read Required<br>Interrupt Register | CLRRDREQ | | I2C_CLR_RDREQ | | I2C_CLR_RDREQ | 0xF2 | 2A8 | | Clear Transmit Abort<br>Interrupt Register | CLRTXABRT | | I2C_CLR_TXABRT | | I2C_CLR_TXABRT | 0xF2 | 2AA | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Register Name | Peripheral<br>Mar | | Data 9 | Sheet | Processor Expert | Mem<br>Addr | - | |------------------------------------------|-------------------|-------------------|------------------------|-------------------|------------------|-------------|-----| | negistei Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | Clear Receive Done<br>Interrupt Register | CLRRXDONE | | I2C_CLR_RXDONE | | I2C_CLR_RXDONE | 0xF2 | 2AC | | Clear Activity Interrupt<br>Register | CLRACT | | I2C_CLRACTIVITY | | I2C_CLRACTIVITY | 0xF2 | 2AE | | Clear Stop Detect<br>Interrupt Register | CLRSTPDET | | I2C_CLR_STOPDET | | I2C_CLR_STOPDET | 0xF2 | 2B0 | | Clear Start Detect<br>Interrupt Register | CLRSTDET | | I2C_CLR_STAR_DET | | I2C_CLR_STAR_DET | 0xF2 | 2B2 | | Clear General Call<br>Interrupt Register | CLRGC | | I2C_CLR_GENCALL | | I2C_CLR_GENCALL | 0xF2 | 2B4 | | Enable Register | ENBL | | I2C_ENABLE | | 12C_ENABLE | 0xF2 | 2B6 | | Status Register | STAT | | I2C_STAT | | I2C_STAT | 0xF2 | 2B8 | | Transmit FIFO Level<br>Register | TXFLR | | I2C_TXFLR | | I2C_TXFLR | 0xF2 | 2BA | | Receive FIFO Level<br>Register | RXFLR | | I2C_RXFLR | | I2C_RXFLR | 0xF2 | 2BC | | Transmit Abort<br>Source Register | TXABRTSRC | | I2C_TX_ABRTSRC | | I2C_TX_ABRTSRC | 0xF2 | 2C0 | | Component<br>Parameter 1 Register | COMPARM1 | | I2C_COMPARM1 | | I2C_COMPARM1 | 0xF2 | 2FA | | Component<br>Parameter 2 Register | COMPARM2 | | I2C_COMPARM2 | | I2C_COMPARM2 | 0xF2 | 2FB | | Component Version 1<br>Register | COMVER1 | | I2C_COMVER1 | | I2C_COMVER1 | 0xF2 | 2FC | | Component Version 2<br>Register | COMVER2 | | I2C_COMVER2 | | I2C_COMVER2 | 0xF2 | 2FD | | Component Type 1<br>Register | COMTYP1 | | I2C_COMTYP1 | | I2C_COMTYP1 | 0xF2 | 2FE | | Component Type 2<br>Register | COMTYP2 | | I2C_COMTYP2 | | I2C_COMTYP2 | 0xF2 | 2FF | | | | On-C | Clock Chip Synthesis ( | OCCS) Module | | | | | Control Register | CTRL | PLLCR | OCCS_CTRL | PLLCR | PLLCR | 0xF | 130 | | Divide-By Register | DIVBY | PLLDB | OCCS_DIVBY | PLLDB | PLLDB | 0xF | 131 | | Status Register | STAT | PLLSR | OCCS_STAT | PLLSR | PLLSR | 0xF | 132 | | Oscillator Control<br>Register | OCTRL | OSCTL | OCCS_OCTRL | OSCTL | OSCTL | 0xF | 135 | | Clock Check Register | CLKCHK | | OCCS_CLCHK | PLLCLCHK | OCCS_CLCHK | 0xF | 136 | | Protection Register | PROT | | OCCS_PROT | PLLPROT | OCCS_PROT | 0xF | 137 | | Clock Divider Register | CLKDIV | FMCLKD | FM_CLKDIV | FMCLKD | FMCLKD | 0xF4 | 400 | | Configuration<br>Register | CNFG | FMCR | FM_CNFG | FMCR | FMCR | 0xF4 | 401 | | Security High Half<br>Register | SECHI | FMSECH | FM_SECHI | FMSECH | FMSECH | 0xF4 | 403 | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Dogistar Nama | • | Reference<br>nual | Data | Sheet | Processor Expert | | Memory<br>Address | | |-----------------------------------------|----------------|-------------------|----------------------|-------------------|-----------------------------------------|-----------------------------|-------------------|--| | Register Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | Security Low Half<br>Register | SECLO | FMSECL | FM_SECLO | FMSECL | FMSECL | 0xF | 404 | | | Protection Register | PROT | FMPROT | FM_PROT | FMPROT | FMPROT | 0xF | 410 | | | User Status Register | USTAT | FMUSTAT | FM_USTAT | FMUSTAT | FMUSTAT | 0xF | 413 | | | Command Register | CMD | FMCMD | FM_CMD | FMCMD | FMCMD | 0xF | 414 | | | Data Buffer Register | DATA | FMDATA | FM_DATA | FMDATA | FMDATA | 0xF | 418 | | | Info Optional Data 1<br>Register | OPT1 | FMOPT1 | FM_OPT1 | FMOPT1 | FMOPT1 | 0xF | 41B | | | Test Array Signature<br>Register | TSTSIG | FMTST_SIG | FM_TSTSIG | FMTST_SIG | FMTST_SIG | 0xF4 | 41D | | | | | Genera | l Purpose Input/Outp | ut (GPIO) Module | | | | | | | | | | | <b>x</b> =A( <b>n</b> =0)B( <b>n</b> =1 | )C( <b>n=</b> 2)D( <b>1</b> | <b>1=</b> 3) | | | Pull-Up Enable<br>Register | PUPEN | PUR | GPIOx_PUPEN | GPIOx_PUR | GPIO_x_PUR | 0xF | 1 <i>n</i> 0 | | | Data Register | DATA | DR | GPIOx_DATA | GPIOx_DR | GPIO_x_DR | 0xF1 <i>n</i> 1 | | | | Data Direction<br>Register | DDIR | DDR | GPIOx_DDIR | GPIOx_DDR | GPIO_x_DDR | 0xF | 1 <i>n</i> 2 | | | Peripheral Enable<br>Register | PEREN | PER | GPIOx_PEREN | GPIOx_PER | GPIO_x_PER | 0xF | 1 <i>n</i> 3 | | | Interrupt Assert<br>Register | IASSRT | IAR | GPIOx_IASSRT | GPIOx_IAR | GPIO_x_IAR | 0xF | 1 <i>n</i> 4 | | | Interrupt Enable<br>Register | IEN | IENR | GPIOx_IEN | GPIOx_IENR | GPIO_x_IENR | 0xF | 1 <i>n</i> 5 | | | Interrupt Polarity<br>Register | IPOL | IPOLR | GPIOx_IPOL | GPIOx_IPOLR | GPIO_x_IPOLR | 0xF | 1 <i>n</i> 6 | | | Interrupt Pending<br>Register | IPEND | IPR | GPIOx_IPEND | GPIOx_IPR | GPIO_x_IPR | 0xF | 1 <i>n</i> 7 | | | Interrupt<br>Edge-Sensitive<br>Register | IEDGE | IESR | GPIOx_IEDGE | GPIOx_IESR | GPIO_x_IESR | 0xF | 1 <i>n</i> 8 | | | Push-Pull Mode<br>Registers | PPOUTM | PPMODE | GPIOx_PPOUTM | GPIOx_PPMODE | GPIO_x_PPMODE | 0xF | 1 <i>n</i> 9 | | | Raw Data Input<br>Register | RDATA | RAWDATA | GPIOx_RDATA | GPIOx_RAWDATA | GPIO_x_RAWDATA | 0xF | 1 <i>n</i> A | | | Output Drive Strength<br>Register | DRIVE | DRIVE | GPIOx_DRIVE | GPIOx_DRIVE | GPIO_x_DRIVE | 0xF | 1 <b>n</b> B | | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Devister News | • | l Reference<br>nual | Data | a Sheet | Processor Expert | Men<br>Add | • | |-------------------------------------------|----------------|---------------------|--------------------|----------------------|------------------|------------|--------| | Register Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Puls | e Width Modulator | (PWM) Module | 1 | I | | | Control Register | CTRL | PMCTL | PWM_CTRL | PWM_PMCTL | PWM_PMCTL | 0xF | 0C0 | | Fault Control Register | FCTRL | PMFCTL | PWM_FCTRL | PWM_PMFCTL | PWM_PMFCTL | 0xF | 0C1 | | Fault<br>Status/Acknowledge<br>Regis. | FLTACK | PMFSA | PWM_FLTACK | PWM_PMFSA | PWM_PMFSA | 0xF | 0C2 | | Output Control<br>Register | OUT | PMOUT | PWM_OUT | PWM_PMOUT | PWM_PMOUT | 0xF | 0C3 | | Counter Register | CNTR | PMCNT | PWM_CNTR | PWM_PMCNT | PWM_PMCNT | 0xF | 0C4 | | Counter Modulo<br>Register | CMOD | MCM | PWM_CMOD | PWM_MCM | PWM_MCM | 0xF | 0C5 | | Value 0-5 Registers | VAL0-5 | PMVAL0-5 | PWM_VAL0-5 | PWM_PMVAL0-5 | PWM_PMVAL0-5 | 0xF0C6 | 0xF0CB | | Deadtime 0-1<br>Registers | DTIM0-1 | PMDEADTM0-1 | PWM_DTIM0-1 | PWM_PMDEADTM0-1 | PWM_PMDEADTM0-1 | 0xF0CC | 0xF0CD | | Disable Mapping 1-2<br>Registers | DMAP1-2 | PMDISMAP1-2 | PWM_DMAP1-2 | PWM_PMDISMAP1-2 | PWM_PMDISMAP1-2 | 0xF0CE | 0xF0CF | | Configure Register | CNFG | PMCFG | PWM_CNFG | PWM_PMCFG | PWM_PMCFG | 0xF | 0D0 | | Channel Control<br>Register | CCTRL | PMCCR | PWM_CCTRL | PWM_PMCCR | PWM_PMCCR | 0xF | 0D1 | | Port Register | PORT | PMPORT | PWM_PORT | PWM_PMPORT | PWM_PMPORT | 0xF | 0D2 | | Internal Correction<br>Control Register | ICCTRL | PMICCR | PWM_ICCTRL | PWM_PMICCR | PWM_PMICCR | 0xF | 0D3 | | Source Control<br>Register | SCTRL | PMSRC | PWM_SCTRL | PWM_PMSRC | PWM_PMSRC | 0xF | 0D4 | | Synchronization<br>Window Register | SYNC | | PWM_SYNC | PWM_SYNC | PWM_SYNC | 0xF | 0D5 | | Fault Filter 0-3<br>Register | FFILT0-3 | | PWM_FFILT0-3 | PWM_FFILT0-3 | PWM_FFILT0-3 | 0xF0D6 | 0xF0D9 | | | | Multi-Scalable | Controller Area Ne | etwork (MSCAN) Modul | e | | | | Control 0 Register | CTRL0 | | CAN_CTRL0 | | CANCTRL0 | 0XF | 800 | | Control 1 Register | CTRL1 | | CAN_CTRL1 | | CANCTRL1 | 0XF | 801 | | Bus Timing 0 Register | BTR0 | | CAN_BTR0 | | CANBTR0 | 0XF | 802 | | Bus Timing 1 Register | BTR1 | | CAN_BTR1 | | CANBTR1 | 0XF | 803 | | Receive Flag Register | RFLG | | CAN_RFLG | | CANRFLG | 0XF | 804 | | Receiver Interrupt<br>Enable Register | RIER | | CAN_RIER | | CANRIER | 0XF | 805 | | Transmitter Flag<br>Register | TFLG | | CAN_TFLG | | CANTFLG | 0XF | 806 | | Transmitter Interrupt Enable Register. | TIER | | CAN_TIER | | CANTIER | 0XF | 807 | | Transmitter Msg Abort<br>Request Register | TARQ | | CAN_TARQ | | CANTARQ | 0XF | 808 | | Register Name | • | Reference<br>nual | Data Sheet | | Processor Expert | Memory<br>Address | | |------------------------------------------------------|----------------|-------------------|---------------------|-------------------|------------------|-------------------|--------| | negister Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | Transmitter Message<br>Abort Acknowledge<br>Register | TAAK | | CAN_TAAK | | CANTAAK | 0XF | 809 | | Transmitter FIFO<br>Selection Register | TBSEL | | CAN_TBSEL | | CANTBSEL | 0XF | 80A | | Identifier Acceptance<br>Control Register | IDAC | | CAN_IDAC | | CANIDAC | 0XF | 80B | | Miscellaneous<br>Register | MISC | | CAN_MISC | | CANMISC | 0XF | 80D | | Receive Error<br>Register | RXERR | | CAN_RXERR | | CANRXERR | 0XF | 80E | | Transmit Error<br>Register | TXERR | | CAN_TXERR | | CANTXERR | 0XF | 80F | | Identifier Acceptance<br>0-3 Registers | IDAR0-3 | | CAN_IDAR0-3 | | CANIDAR0-3 | 0xF810 | 0xF813 | | Identifier Mask 0-3<br>Registers | IDMR0-3 | | CAN_IDMR0-3 | | CANIDMR0-3 | 0xF814 | 0xF817 | | Identifier Acceptance<br>4-7 Register | IDAR4-7 | | CAN_IDAR4-7 | | CANIDAR4-7 | 0xF818 | 0xF81B | | Identifier Mask 4-7<br>Registers | IDMR4-7 | | CAN_IDMR4-7 | | CANIDMR4-7 | 0xF81C | 0xF81F | | Foreground Receive FIFO Register | RXFG | | CAN_RXFG | | CANRXFG | 0xF82F | 0xF820 | | Foreground Transmit FIFO Register | TXFG | | CAN_TXFG | | CANTXFG | 0xF830 | 0xF83F | | | | | Power Supervisor (P | S) Module | | | | | Control Register | CTRL | LVICONTROL | PS_CTRL | LVICONTROL | LVICTRL | 0xF | 140 | | Status Register | STAT | LVISTATUS | PS_STAT | LVISTATUS | LVISR | 0xF | 141 | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Register Name | • | l Reference<br>nual | Data | Sheet | Processor Expert | Memory<br>Address | | |------------------------------------------|----------------|---------------------|------------------------|----------------------|----------------------|-------------------|--------------| | negister Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Queued Seria | I Communications I | nterface (QSCI) Modu | ıle | | | | | | | | | <b>n</b> =0,1 | | | | Baud Rate Register | RATE | | QSCI_RATE | | QSCI_SCIBR | 0xF2 | 2 <b>n</b> 0 | | Control 1 Register | CTRL1 | | QSCI_CTRL1 | | QSCI_SCICR | 0xF2 | 2 <b>n</b> 1 | | Control 2 Register | CTRL2 | | QSCI_CTRL2 | | QSCI_SCICR2 | 0xF2 | 2 <b>n</b> 2 | | Status Register | STAT | | QSCI_STAT | | QSCI_SCISR | 0xF2 | 2 <b>n</b> 3 | | Data Register | DATA | | QSCI_DATA | | QSCI_SCIDR | 0xF2 | 2 <b>n</b> 4 | | | | Queued S | erial Peripheral Inter | face (QSPI) Module | | | | | Status and Control<br>Register | SCTRL | | QSPI_SCTRL | | QSPI_SPSCR | 0xF2 | 2 <b>n</b> 0 | | Data Size and Control<br>Register | DSCTRL | | QSPI_DSCTRL | | QSPI_SPDSR | 0xF2 | 2 <i>n</i> 1 | | Data Receive<br>Register | DRCV | | QSPI_DRCV | | QSPI_SPDRR | 0xF2 | 2 <b>n</b> 2 | | Data Transmit<br>Register | DXMIT | | QSPI_DXMIT | | QSPI_SPDTR | 0xF2 | 2 <b>n</b> 3 | | FIFO Control Register | FIFO | | QSPI_FIFO | | QSPI_SPFIFO | 0xF2 | 2 <b>n</b> 4 | | Wait Register | WAIT | | QSPI_WAIT | | QSPI_SPWAIT | 0xF2 | 2 <b>n</b> 5 | | | | | Quad-Timer (TMR) | Module | | | | | | | | | | <b>n</b> =0,1,2,3 | | | | Compare 1 Register | COMP1 | TMRCMP1 | TMR <b>n_</b> COMP1 | TMR <b>n_</b> CMP1 | TMR <b>n_</b> CMP1 | 0xF0 | ) <b>n</b> 0 | | Compare 2 Register | COMP2 | TMRCMP2 | TMRn_COMP2 | TMR <b>n_</b> CMP2 | TMR <b>n_</b> CMP2 | 0xF0 | ) <b>n</b> 1 | | Capture Register | CAPT | TMRCAP | TMR <b>n_</b> CAPT | TMR <b>n_</b> CAP | TMR <b>n_</b> CAP | 0xF0 | ) <b>n</b> 2 | | Load Register | LOAD | TMRLOAD | TMR <i>n</i> _LOAD | TMR <b>n</b> _LOAD | TMR <b>n_</b> LOAD | 0xF0 | ) <b>n</b> 3 | | Hold Register | HOLD | TMRHOLD | TMR <i>n_</i> HOLD | TMR <b>n_</b> HOLD | TMR <b>n_</b> HOLD | 0xF0 | ) <b>n</b> 4 | | Counter Register | CNTR | TMRCNTR | TMR <b>n_</b> CNTR | TMR <b>n_</b> CNTR | TMR <b>n_</b> CNTR | 0xF0 | ) <b>n</b> 5 | | Control Register | CTRL | TMRCTRL | TMR <i>n_</i> CTRL | TMR <b>n_</b> CTRL | TMR <b>n_</b> CTRL | 0xF0 | ) <b>n</b> 6 | | Status and Control<br>Register | SCTRL | TMRSCR | TMR <i>n_</i> SCTRL | TMR <b>n_</b> SCR | TMR <b>n_</b> SCR | 0xF0 | ) <b>n</b> 7 | | Comparator Load 1<br>Register | CMPLD1 | TMRCMPLD1 | TMR <i>n_</i> CMPLD1 | TMR <i>n_</i> CMPLD1 | TMR <i>n_</i> CMPLD1 | 0xF0 | ) <b>n</b> 8 | | Comparator Load 2<br>Register | CMPLD2 | TMRCMPLD2 | TMR <i>n_</i> CMPLD2 | TMRn_CMPLD2 | TMRn_CMPLD2 | 0xF0 | ) <b>n</b> 9 | | Comparator<br>Status/Control<br>Register | CSCTRL | TMRCOMSCR | TMR <i>n_</i> CSCTRL | TMRn_COMSCR | TMRn_COMSCR | 0xF0 | ) <b>n</b> A | | Input Filter Register | FILT | | TMR <i>n_</i> FILT | TMR <i>n_</i> FILT | TMR <i>n</i> _FILT | 0xF0 | ) <b>n</b> B | | Enable Register | ENBL | | TMR <b>n_</b> ENBL | TMR <b>n_</b> ENBL | TMR <b>n</b> _ENBL | 0xF0 | )nF | | | | Vo | oltage Regulator (VR | EG) Module | | | | | See SIM section | | | | | | | | | Register Name | Peripheral Reference<br>Manual | | Data | Sheet | Processor Expert | Memory<br>Address | | |---------------------------|--------------------------------|-------------------|----------------------|-------------------|---------------------------|-------------------|--------------| | negister Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Progr | ammable Interval Tim | ner (PIT) Module | | | | | | | | | | <b>n</b> =0,1,2 | | | | Control Register | CTRL | | PIT <b>n_</b> CTRL | PITCTRL0-2 | PIT <i>n_</i> CTRL | 0xF | 1 <i>n</i> 0 | | Modulo Register | MOD | | PIT <i>n</i> _MOD | PITMOD0-2 | PIT <b>n_</b> MOD | 0xF | 1 <i>n</i> 1 | | Counter Register | CNTR | | PIT <b>n_</b> CNTR | PITCNTR0-2 | PIT <i>n_</i> CNTR | 0xF | 1 <i>n</i> 2 | | | | | | | | | | | | | | | | <b>n</b> =0,1 | | | | Control Register | CTRL | | DAC <i>n_</i> CTRL | DACCTRL0-2 | DAC <i>n</i> _CTRL | 0xF | 1 <i>n</i> 0 | | Data Register | DATA | | DAC <b>n_</b> DATA | DACDATA0-2 | DAC <i>n</i> _DATA | 0xF | 1 <i>n</i> 1 | | Step Register | STEP | | DAC <i>n_</i> STEP | DACSTEP0-2 | DAC <i>n_</i> STEP | 0xF | 1 <i>n</i> 2 | | Minimum Value<br>Register | MINVAL | | DAC <b>n_</b> MINVAL | DACMINVAL0-2 | DAC <i>n_</i> MINVAL | 0xF | 1 <i>n</i> 3 | | Maximum Value<br>Register | MAXVAL | | DAC <b>n_</b> MAXVAL | DACMAXVAL0-2 | DAC <i>n_</i> MAXVAL | 0xF | 1 <i>n</i> 4 | | | | | Comparator (CMP) | Module | | | | | | | | | | <i>Ax</i> =E <i>Bx</i> =F | | | | Control Register | CTRL | | CMP_CTRL | CMPx_CTRL | CMPx_CTRL | 0xF | 1 <i>x</i> 0 | | Status Register | STAT | | CMP_STAT | CMPx_STAT | CMPx_STAT | 0xF | 1 <i>x</i> 1 | | Filter Register | FILT | | CMP_FILT | CMPx_FILT | CMPx_FILT | 0xF | 1 <b>x</b> 2 | **Table 14-1 Legacy and Revised Acronyms (Continued)** | Degister Name | • | Reference<br>nual | Data | Sheet | Processor Expert | Men<br>Add | nory<br>ress | |-----------------------------------------|----------------|-------------------|-------------------------|-------------------|------------------|------------|--------------| | Register Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | | Ir | nterrupt Controller (IT | CN) Module | • | | | | Interrupt Priority 0-4<br>Registers | N/A | N/A | ITCN_IPR0-4 | ITCN_IPR0-4 | INTC_IPR0-4 | 0XF060 | 0XF064 | | Vector Base Address<br>Register | N/A | N/A | ITCN_VBA | ITCN_VBA | INTC_VBA | 0XF | 065 | | Fast Interrupt Match 0<br>Register | N/A | N/A | ITCN_FIM0 | ITCN_FIM0 | INTC_FIM0 | 0XF | 066 | | Fast Interrupt Vector<br>Address Low 0 | N/A | N/A | ITCN_FIVAL0 | ITCN_FIVAL0 | INTC_FIVAL0 | 0XF | 067 | | Fast Interrupt Vector<br>Address High 0 | N/A | N/A | ITCN_FIVAH0 | ITCN_FIVAH0 | INTC_FIVAH0 | 0XF | 068 | | Fast Interrupt Match 1<br>Register | N/A | N/A | ITCN_FIM1 | ITCN_FIM1 | INTC_FIM1 | 0xF | 069 | | Fast Interrupt Vector<br>Address Low 1 | N/A | N/A | ITCN_FIVAL1 | ITCN_FIVAL1 | INTC_FIVAL1 | 0xF | 06A | | Fast Interrupt Vector<br>Address High 1 | N/A | N/A | ITCN_FIVAH1 | ITCN_FIVAH1 | INTC_FIVAH1 | 0xF | 06B | | Interrupt Pending 0<br>Register | N/A | N/A | ITCN_IRQP0 | ITCN_IRQP0 | INTC_IRQP0 | 0xF | 06C | | Interrupt Pending 1<br>Register | N/A | N/A | ITCN_IRQP1 | ITCN_IRQP1 | INTC_IRQP1 | 0xF | 06D | | Interrupt Pending 2<br>Register | N/A | N/A | ITCN_IRQP2 | ITCN_IRQP2 | INTC_IRQP2 | 0xF | 06E | | | | | System Integration M | odule (SIM) | • | | | | Control Register | N/A | N/A | SIM_CTRL | SIM_CONTROL | SIM_CONTROL | 0xF | 100 | | Reset Status Register | N/A | N/A | SIM_RSTAT | SIM_RSTSTS | SIM_RSTSTS | 0xF | 101 | | Software Control 0-3<br>Registers | N/A | N/A | SIM_SWC0-3 | SIM_SCR0-3 | SIM_SCR0-3 | 0xF102 | 0xF105 | | Most Significant Half<br>JTAG ID | N/A | N/A | SIM_MSHID | SIM_MSH_ID | SIM_MSH_ID | 0xF | 106 | | Least Significant Half<br>JTAG ID | N/A | N/A | SIM_LSHID | SIM_LSH_ID | SIM_LSH_ID | 0xF | 107 | | Power Control<br>Register | N/A | N/A | SIM_PWR | SIM_POWER | | 0xF | 108 | | Clock Out Select<br>Register | N/A | N/A | SIM_CLKOUT | SIM_CLKOSR | SIM_CLKOSR | 0xF | 10A | | Peripheral Clock Rate<br>Register | N/A | N/A | SIM_PCR | SIM_PCR | SIM_PCR | 0xF | 10B | | Peripheral Clock<br>Enable 0-1 Register | N/A | N/A | SIM_PCE0-1 | SIM_PCE0-1 | SIM_PCE0-1 | 0xF10C | 0xF10D | | Peripheral Stop<br>Disable 0-1 Register | N/A | N/A | SIM_SD0-1 | SIM_SD0-1 | SIM_SD0-1 | 0xF10E | 0xF10F | | Degister Neme | Peripheral Reference<br>Manual | | Data | Sheet | Processor Expert | | Memory<br>Address | | |----------------------------------------------------|--------------------------------|-------------------|----------------|-------------------|------------------|--------|-------------------|--| | Register Name | New<br>Acronym | Legacy<br>Acronym | New<br>Acronym | Legacy<br>Acronym | Acronym | Start | End | | | I/O Short Address<br>Location High<br>Register | N/A | N/A | SIM_ISALH | SIM_ISALH | SIM_ISALH | 0xF | 110 | | | I/O Short Address<br>Location Low Register | N/A | N/A | SIM_ISALL | SIM_ISALL | SIM_ISALL | 0xF | 111 | | | Protection Register | N/A | N/A | SIM_PROT | SIM_PROT | SIM_PROT | 0xF | 112 | | | GPIOA Peripheral<br>Select 0 Register | N/A | N/A | SIM_GPISA0 | SIM_GPISA0 | SIM_GPISA0 | 0xF | 113 | | | GPIOA Peripheral<br>Select 0 Register | N/A | N/A | SIM_GPSA1 | SIM_GPSA1 | SIM_GPSA1 | 0xF | 114 | | | GPIOB Peripheral<br>Select 0 Register | N/A | N/A | SIM_GPSB0 | SIM_GPSB0 | SIM_GPSB0 | 0xF | 115 | | | GPIOB Peripheral<br>Select 1 Register | N/A | N/A | SIM_GPSB1 | SIM_GPSB1 | SIM_GPSB1 | 0xF | 116 | | | GPIO Perip. Select<br>Register for GPIO C &<br>D | N/A | N/A | SIM_GPSCD | SIM_GPSCD | SIM_GPSCD | 0xF | 117 | | | Internal Peripheral.<br>Select Register for<br>PWM | N/A | N/A | SIM_ISPWM | SIM_ISPWM | SIM_ISPWM | 0xF | 118 | | | Internal Peripheral<br>Select Register for<br>DAC | N/A | N/A | SIM_IPSDAC | SIM_IPSDAC | SIM_IPSDAC | 0xF119 | | | | Internal Peripheral<br>Select Register for<br>TMRA | N/A | N/A | SIM_IPSTMRA | SIM_IPSTMRA | SIM_IPSTMRA | 0xF | 11A | | 56F8023 Data Sheet, Rev. 3 ## How to Reach Us: ### Home Page: www.freescale.com #### E-mail: support@freescale.com ### **USA/Europe or Locations Not Listed:** Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com # Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com ## Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064, Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com ### Asia/Pacific: Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com # For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb-free counterparts. For further information, see <a href="http://www.freescale.com">http://www.freescale.com</a> or contact your Freescale sales representative. For information on Freescale's Environmental Products program, go to <a href="http://www.freescale.com/epp">http://www.freescale.com/epp</a>. Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty. representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part. Freescale ™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. This product incorporates SuperFlash® technology licensed from SST. © Freescale Semiconductor, Inc. 2006. All rights reserved. MC56F8023 Rev. 3 01/2007