PIC32MX System Bus Matrix
The PIC32MX family of devices incorporates a system bus matrix, which is implemented as a multilayer fabric that allows concurrent transactions by multiple initiators (bus masters) to multiple targets (bus slaves). There are no arbitration delays unless two initiators attempt to access the same target at the same time. Initiators include the CPU, the general-purpose Direct Memory Access (DMA), and the bus master peripherals with dedicated DMA access.
Main Features
- Runs at System Clock (SYSCLK) speed (100 MHz max)
- Multiple initiators talk to multiple targets
- Up to three independent transactions per SYSCLK cycle
- Arbitration takes place for collisions
Initiators & Targets
The bus matrix connects master devices, generically called initiators, to slave devices, generically called targets. The PIC32MX product family can have up to five initiators and three targets (e.g., Flash, RAM, etc.) on the main bus structure, as shown here:
Of the five possible initiators, the CPU Instruction Bus (CPU IS), CPU Data Bus (CPU DS), In-Circuit Debug (ICD) and DMA Controller are the default set of initiators and are always present. The PIC32MX also includes an Initiator Expansion Interface (IXI) to support additional initiators for future expansion.
The bus matrix decodes a general range of addresses that map to a target. The target (memory or peripherals) may provide additional addresses depending on its functionality. The following table lists the targets which the initiators can access:
Some peripherals are grouped together as a single target to form a Peripheral Bus, which shares a target interface in addition to sharing a common peripheral bus clock source (PBCLK).
The System Bus latency is therefore determined by:
- Speed of the target peripheral/bus
- Collisions/Arbitration Policy
System Bus Matrix Arbitration
Since there can be more than one initiator attempting to access the same target, an arbitration scheme must be used to control access to the target. The arbitration modes assign priority levels to all the initiators. The initiator with the higher priority level will always win target access over a lower priority initiator.
A variety of "fixed-priority" arbitration modes are provided. These modes are controlled by the BMXCON BMXARB<2:0> settings. The default setting (0x001) selects Arbitration Mode 1, which enables the following priority assignment:
Bus Error Exceptions
The bus matrix generates a bus error exception on:
- Any attempt to access unimplemented memory
- Any attempt to access an illegal target
- Any attempt to write to program Flash memory
Bus Error Exceptions may be temporarily disabled by clearing the BMXERRxxx bits in the BMXCON register, which is not recommended. The bus matrix disables bus error exceptions for accesses from CPU IS and CPU DS while in DEBUG mode.