Message RAM
1540
SPRUH22I – April 2012 – Revised November 2019
Copyright © 2012–2019, Texas Instruments Incorporated
M3 Controller Area Network (CAN)
During normal operation, accesses to the Message RAM are performed via the Interface Register sets,
and the CPU cannot directly access the Message RAM.
The Interface register sets IF1 and IF2, provide indirect read/write access from the CPU to the Message
RAM. The IF1 and IF2 register sets can buffer control and user data to be transferred to and from the
message objects.
The third Interface register set IF3 can be configured to automatically receive control and user data from
the Message RAM when a message object has been updated after reception of a CAN message. The
CPU does not need to initiate the transfer from Message RAM to the IF3 register set.
The message handler avoids potential conflicts between concurrent accesses to Message RAM and CAN
frame reception/transmission.
The message RAM can only be accessed in debug mode. The message RAM base address is 0x2000
above the base address of the CAN peripheral.
23.14.1 Structure of Message Objects
shows the structure of a message object.
The grayed fields are those parts of the message object which are represented in dedicated registers. For
example, the transmit request flags of all message objects are represented in centralized transmit request
registers.
Figure 23-17. Structure of a Message Object
Message Object
UMask
Msk[28:0
]
MXtd
MDir
EoB
unused
NewDat
MsgLst
RxIE
TxIE
IntPnd
RmtEn
TxRqst
MsgVal
ID[28:0]
Xtd
Dir
DLC[3:0]
Data 0
Data 1
Data 2
Data 3
Data 4
Data 5
Data 6
Data 7
Table 23-2. Message Object Field Descriptions
Name
Value
Description
MsgVal
Message valid
0
The message object is ignored by the message handler.
1
The message object is to be used by the message handler.
Note: This bit may be kept at level '1' even when the identifier bits ID[28:0], the control bits Xtd, Dir, or the
data length code DLC[3:0] are changed. It should be reset if the Messages Object is no longer required.
UMask
Use Acceptance Mask
0
Mask bits (Msk[28:0], MXtd and MDir) are ignored and not used for acceptance filtering.
1
Mask bits are used for acceptance filtering.
Note: If the UMask bit is set to one, the message object's mask bits have to be programmed during
initialization of the message object before MsgVal is set to one.
ID[28:0]
Message Identifier
ID[28:0]
29-bit ("extended") identifier bits
ID[28:18] 11-bit ("standard") identifier bits
Msk[28:0]
Identifier Mask
0
The corresponding bit in the message identifier is not used for acceptance filtering (don't care).
1
The corresponding bit in the message identifier is used for acceptance filtering.
Note: The bit functionality in the DCAN module is the opposite of the "Local Acceptance Mask" bit
functionality in the eCAN module found in older C28xx devices, where a "1" means the corresponding bit is
NOT used for filtering and "0" means it is used.
Xtd
Extended Identifier
0
The 11-bit ("standard") identifier will be used for this message object.
1
The 29-bit ("extended") identifier will be used for this message object.