5.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.

Bus Matrix Initiators include:
  • 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
Bus Matrix Targets include:
  • Program Flash (data reads)
  • Peripheral Buses (through Bus Splitter)
  • XRAM interface
  • YRAM interface
  • Debug RAM
Note: XRAM and YRAM simultaneous access is supported.

Figure 5-2 shows the typical block diagram of the Bus Matrix.

Figure 5-2. Bus Matrix Initiators and Targets
Note: See Table 5-4 for initiator/target options.