Byte Data Link Communications (BDLC)
M68HC12B Family Data Sheet, Rev. 9.1
220
Freescale Semiconductor
15.7.2.2 Data — In-Message Data Bytes
The data bytes contained in the message include the message priority/type, message ID byte (typically,
the physical address of the responder), and any actual data being transmitted to the receiving node. The
message format used by the BDLC is similar to the 3-byte consolidated header message format outlined
by the SAE J1850 document. See SAE J1850 – Class B Data Communications Network Interface
specification for more information about 1- and 3-byte headers.
Messages transmitted by the BDLC onto the J1850 bus must contain at least one data byte, and,
therefore, can be as short as one data byte and one CRC byte. Each data byte in the message is eight
bits in length and is transmitted MSB (most significant bit) to LSB (least significant bit).
15.7.2.3 CRC — Cyclical Redundancy Check Byte
This byte is used by the receiver(s) of each message to determine if any errors have occurred during the
transmission of the message. The BDLC calculates the CRC byte and appends it onto any messages
transmitted onto the J1850 bus. It also performs CRC detection on any messages it receives from the
J1850 bus.
CRC generation uses the divisor polynomial X8 + X4 + X3 + X2 + 1. The remainder polynomial initially is
set to all 1s. Each byte in the message after the start-of-frame (SOF) symbol is processed serially through
the CRC generation circuitry. The one’s complement of the remainder then becomes the 8-bit CRC byte,
which is appended to the message after the data bytes, in MSB-to-LSB order.
When receiving a message, the BDLC uses the same divisor polynomial. All data bytes, excluding the
SOF and end-of-data symbols (EOD) but including the CRC byte, are used to check the CRC. If the
message is error free, the remainder polynomial equals
X7 + X6 + X2 = $C4, regardless of the data contained in the message. If the calculated CRC does not equal
$C4, the BDLC recognizes this as a CRC error and sets the CRC error flag in the BSVR.
15.7.2.4 EOD — End-of-Data Symbol
The EOD symbol is a long 200-
s passive period on the J1850 bus used to signify to any recipients of a
message that the transmission by the originator has completed. No flag is set upon reception of the EOD
symbol.
15.7.2.5 IFR — In-Frame Response Bytes
The IFR section of the J1850 message format is optional. Users desiring further definition of in-frame
response should review the SAE J1850 – Class B Data Communications Network Interface specification.
15.7.2.6 EOF — End-of-Frame Symbol
This symbol is a long 280-
s passive period on the J1850 bus and is longer than an end-of-data (EOD)
symbol, which signifies the end of a message. Since an EOF symbol is longer than a 200-
s EOD symbol,
if no response is transmitted after an EOD symbol, it becomes an EOF, and the message is assumed to
be completed. The EOF flag is set upon receiving the EOF symbol.
15.7.2.7 IFS — Interframe Separation Symbol
The IFS symbol is a 20-
s passive period on the J1850 bus which allows proper synchronization between
nodes during continuous message transmission. The IFS symbol is transmitted by a node after the
completion of the end-of-frame (EOF) period and, therefore, is seen as a 300-
s passive period.