Datasheet
Message Storage
MC68HC908AZ60A • MC68HC908AS60A • MC68HC908AS60E Data Sheet, Rev. 6
Freescale Semiconductor 269
Above behavior cannot be achieved with a single transmit buffer. That buffer must be reloaded right after 
the previous message has been sent. This loading process lasts a definite amount of time and has to be 
completed within the inter-frame sequence (IFS) to be able to send an uninterrupted stream of messages. 
Even if this is feasible for limited CAN bus speeds, it requires that the CPU reacts with short latencies to 
the transmit interrupt. 
A double buffer scheme would de-couple the re-loading of the transmit buffers from the actual message 
being sent and as such reduces the reactiveness requirements on the CPU. Problems may arise if the 
sending of a message would be finished just while the CPU re-loads the second buffer. In that case, no 
buffer would then be ready for transmission and the bus would be released.
At least three transmit buffers are required to meet the first of the above requirements under all 
circumstances. The MSCAN08 has three transmit buffers.
The second requirement calls for some sort of internal prioritisation which the MSCAN08 implements with 
the “local priority” concept described in 23.4.2 Receive Structures.
23.4.2 Receive Structures
The received messages are stored in a 2-stage input first in first out (FIFO). The two message buffers are 
mapped using a Ping Pong arrangement into a single memory area (see Figure 23-2). While the 
background receive buffer (RxBG) is exclusively associated to the MSCAN08, the foreground receive 
buffer (RxFG) is addressable by the CPU08. This scheme simplifies the handler software, because only 
one address area is applicable for the receive process.
Both buffers have a size of 13 bytes to store the CAN control bits, the identifier (standard or extended), 
and the data content (for details, see 23.12 Programmer’s Model of Message Storage). 
The receiver full flag (RXF) in the MSCAN08 receiver flag register (CRFLG) (see 23.13.5 MSCAN08 
Receiver Flag Register (CRFLG)), signals the status of the foreground receive buffer. When the buffer 
contains a correctly received message with matching identifier, this flag is set. 
On reception, each message is checked to see if it passes the filter (for details see 23.5 Identifier 
Acceptance Filter) and in parallel is written into RxBG. The MSCAN08 copies the content of RxBG into 
RxFG
(1)
, sets the RXF flag, and generates a receive interrupt to the CPU
(2)
. The user’s receive handler 
has to read the received message from RxFG and to reset the RXF flag to acknowledge the interrupt and 
to release the foreground buffer. A new message which can follow immediately after the IFS field of the 
CAN frame, is received into RxBG. The overwriting of the background buffer is independent of the 
identifier filter function.
When the MSCAN08 module is transmitting, the MSCAN08 receives its own messages into the 
background receive buffer, RxBG. It does NOT overwrite RxFG, generate a receive interrupt or 
acknowledge its own messages on the CAN bus. The exception to this rule is in loop-back mode (see 
23.13.2 MSCAN08 Module Control Register 1), where the MSCAN08 treats its own messages exactly like 
all other incoming messages. The MSCAN08 receives its own transmitted messages in the event that it 
loses arbitration. If arbitration is lost, the MSCAN08 must be prepared to become receiver.
1. Only if the RXF flag is not set.
2. The receive interrupt will occur only if not masked. A polling scheme can be applied on RXF also.










