PIC32MX Exception Mechanism
On MIPS-based CPUs, such as the PIC32MX family of processors, peripheral/external interrupts, traps, system calls, and everything else that can disrupt the normal flow of execution are called "exceptions" and are handled by a single mechanism.
Exceptions are classified into two major types: expected and unexpected:
- Expected - Resulting from normal (i.e., expected) operations, such as:
- Peripheral/External Interrupts
- WDT wakeup
- Debug breakpoints
- System calls
- Unexpected - Resulting from error (i.e., unexpected) conditions such as:
- Hardware-detected errors, such as integer overflow or divide-by-zero
- Illegal user-mode operations
- Bus error (addresses generated beyond physically implemented memory)
The main difference between expected/unexpected exceptions is that an unexpected exception cannot be enabled/disabled (similar to a traditional Non-Maskable Interrupt (NMI)), while an expected exception can be.
All exceptions are handled similarly, in that, the current instruction flow is changed temporarily to execute special procedures to handle the exception.
When an exception is detected, the CPU Execution Unit does the following:
- The address of the next instruction to execute after the handler returns is saved into the EPC register of Coprocessor0 (CP0).
- The CP0 CauseEXCCODE bit-field is updated to reflect the reason for an exception or interrupt.
- The CP0 StatusEXL or StatusERL bit is set to cause Kernel mode execution.
- An exception handler entry point address is obtained based on the type of exception and the current state of the processor (CP0 Statusxxx bits).
- Processor starts execution from the exception handler's entry point address.
Interrupt Controller
The PIC32MX hardware generates interrupt exception requests in response to interrupt events coming from the peripheral modules of the CPU Core (Core Timer, Performance Counter, Fast Debug Channel).
The Interrupt Controller module exists external to the CPU Execution Unit and prioritizes the interrupt requests before presenting one of them to the CPU. The module includes the following features:
- Up to 96 interrupt sources
- Up to 64 interrupt vectors
- Single and Multi-Vector mode operations
- Up to five external interrupts with edge polarity control
- Interrupt proximity timer
- Seven user-selectable priority levels for each vector
- Four user-selectable sub-priority levels within each priority
- Dedicated shadow register set for user-selected priority level (this feature is not available on all devices; refer to the “Interrupt Controller” chapter in the specific device data sheet for availability)
- Software can generate any interrupt
- User-configurable Interrupt Vector Table (IVT) location
- User-configurable interrupt vector spacing
Learn More
The following references cover various aspects of the PIC32MX Exception Mechanism:
- MIPS®32 M4K® Processor Core Software User's Manual
- See MIPs Run (Chapter 5 - Exceptions, Interrupts and Initialization)
- Section 2. CPU for Devices with M4K® Core
- Section 8. Interrupts
- PIC32MX5XX/6XX/7XX 32-bit Microcontrollers (up to 512 KB Flash and 128 KB SRAM) with Graphics Interface, USB, CAN, and Ethernet
- MPLAB® XC32 C/C++ Compiler User’s Guide