4.2.3 Bus Matrix
The Bus Matrix (BMX) arbitrates memory accesses in the event two independent initiators are trying to access the same targets. Initiators are a set of modules that can initiate a read or write transaction to other modules called “Targets.” The BMX connects the initiator to targets and determines which initiator gets priority (based on fixed priority scheme and the SFR priority). The type of access, program or data, is determined by the initiator bus. It supports concurrent accesses by different initiators as long as they have independent targets. For example, CPU to SFR could be concurrent with DMA to RAM.
- Initiator 0 – CPU X Data Bus (CPU XDS)
- Initiator 1 – CPU Y Data Bus (CPU YDS)
- Initiator 2 – DMA
- Initiator 3 – CPU Instruction Bus (CPU IS)
- Initiator 4 – Crypto
- Initiator 5 – CAN 1
- Initiator 6 – CAN 2
- Initiator 7 – Nonvolatile Memory Controller
- Initiator 8 – In-Circuit Debugger
- Program Flash (data reads)
- Peripheral Buses (through Bus Splitter)
- XRAM interface
- YRAM interface
- Debug RAM
Figure 4-2 shows the typical block diagram of the Bus Matrix.
