SPRUIN7C March 2020 – March 2024 TMS320F280021 , TMS320F280021-Q1 , TMS320F280023 , TMS320F280023-Q1 , TMS320F280023C , TMS320F280025 , TMS320F280025-Q1 , TMS320F280025C , TMS320F280025C-Q1
The cyclic redundancy check (CRC) units monitor CPU buses and compute CRC when the self-test code is executed. This capability aids in achieving simpler, non-intrusive and interruptible self-test mechanisms with Software Test Library (STL). Each CRC unit is used to monitor a different CPU interface. For example, CRC unit 1 is used to monitor the Program Counter, while CRC unit 2 is used to monitor the data read address bus. Table 11-2 identifies the CPU interface monitored by each of the CRC units.
CRC Unit | CPU Interface |
---|---|
CRC Unit 1 | Program Counter Register |
CRC Unit 2 | Data Read Address Bus |
CRC Unit 3 | Data Read Data Bus |
CRC Unit 4 | Data Write Address Bus |
CRC Unit 5 | Data Write Data Bus |
CRC Unit 6 | Instruction Register Value (Unsecured) |
CRC Unit 7 | Instruction Register Value (Secure-Zone 1) |
CRC Unit 8 | Instruction Register Value (Secure-Zone 2) |
The main purpose of the CRC units is to make sure that the CPU functionally remains intact when the CRC unit is executing the same software test library over multiple iterations. This is done by comparing the computed CRC values after each iteration, with a pre-computed golden value.
CRC units 7 and 8 are intended to compute the instruction register values for secure-zone 1 and secure-zone 2 instruction execution. Computed CRC values for the a given secure-zone is available only for accesses originating from that zone.