Parity Check Mechanism
1078
SPNU503C – March 2018
Copyright © 2018, Texas Instruments Incorporated
Controller Area Network (DCAN) Module
23.15 Parity Check Mechanism
The DCAN provides a parity check mechanism to ensure data integrity of Message RAM data. For each
word (32 bits) in Message RAM, one parity bit will be calculated. The formation of the different words is
according to the Message RAM representation in RDA mode (see
Parity information is stored in the Message RAM on write accesses and will be checked against the stored
parity bit from Message RAM on read accesses.
The parity check functionality can be enabled or disabled by PMD bit field in CAN Control Register.
In case of disabled parity check, the parity bits in message RAM will be left unchanged on write access to
data area and no check will be done on read access.
If parity checking is enabled, parity bits will be automatically generated and checked by the DCAN. The
parity bits could be read in Debug/Suspend mode (see
) or in RDA mode (see
). However, direct write access to the parity bits is only possible in this two modes with
parity check disabled.
A parity bit will be set, if the modulo-2-sum of the data bits is 1. This definition is equivalent to: The parity
bit will be set, if the number of 1 bits in the data is odd.
NOTE:
Parity scheme can be changed via the System module DEV Parity Control Register1 on
device basis for all peri RAMs.
23.15.1 Behavior on Parity Error
On any read access to Message RAM (for example, during start of a CAN frame transmission), the parity
of the message object will be checked. If a parity error is detected, the PER bit in Error and Status
Register will be set. If error interrupts are enabled, also an interrupt would be generated. In order to avoid
the transmission of invalid data over the CAN bus, the d bit of the message object will be reset.
The message object data can be read by the host CPU, independently of parity errors. Thus, the
application has to ensure that the read data is valid, for example, by immediately checking the Parity Error
Code register on parity error interrupt.
NOTE:
During RAM initialization, no parity check will be done.
23.15.2 Parity Testing
Testing the parity mechanism can be done by enabling the bit RDA (RamDirectAccess) and manually
writing the parity bits directly to the dedicated RAM locations. With this, data and parity bits could be
checked when reading directly from RAM.
NOTE:
If parity check was disabled, the application has to ensure correct parity bit handling in order
to prevent parity errors later on when parity check is enabled.