180
Atmel ATmega16/32/64/M1/C1 [DATASHEET]
7647K–AVR–12/13
17.4.6.3 Rx and TX Response Functions
These functions are initiated by the slave task of a LIN node. They must be used after sending an header (master task) or after
receiving an header (considered as belonging to the slave task). When the TX response order is sent, the transmission begins.
A Rx response order can be sent up to the reception of the last serial bit of the first byte (before the stop-bit).
In LIN 1.3, the header slot configures the LINDLR register. In LIN 2.1, the user must configure the LINDLR register, either
LRXDL[3..0] for Rx Response either LTXDL[3..0] for Tx Response.
When the command starts, the controller checks the LIN13 bit of the LINCR register to apply the right rule for computing the
checksum. Checksum calculation over the DATA bytes and the PROTECTED IDENTIFIER byte is called enhanced checksum
and it is used for communication with LIN 2.1 slaves. Checksum calculation over the DATA bytes only is called classic
checksum and it is used for communication with LIN 1.3 slaves. Note that identifiers 60 (0x3C) to 63 (0x3F) shall always use
classic checksum.
At the end of this reception or transmission, the controller automatically returns to Rx Header / LIN Abort state
(i.e. LCMD[1..0] = 00) after setting the appropriate flags.
If an LIN error occurs, the reception or the transmission is stopped, the appropriate flags are set and the LIN bus is left to
recessive state.
during these functions, the controller is responsible for:
●
The initialization of the checksum operator,
●
The transmission or the reception of ‘n’ data with the update of the checksum calculation,
●
The transmission or the checking of the CHECKSUM field,
●
The checking of the Frame_Time_Out,
●
The checking of the LIN communication integrity.
While the controller is sending or receiving a response, BREAK and SYNCH fields can be detected and the identifier of this new
header will be recorded. Of course, specific errors on the previous response will be maintained with this identifier reception.
17.4.6.4 Handling Data of LIN response
A FIFO data buffer is used for data of the LIN response. After setting all parameters in the LINSEL register, repeated accesses
Note that LRXDL[3..0] and LTXDL[3..0] are not linked to the data access.
17.4.7 UART Commands
Setting the LCMD[2] bit in LINENR register enables UART commands.
●
Byte transfer: the UART is selected but both Rx and Tx services are disabled,
●
Rx Byte: only the Rx service is enable but Tx service is disabled,
●
Tx Byte: only the Tx service is enable but Rx service is disabled,
●
Full duplex: the UART is selected and both Rx and Tx services are enabled.
17.4.7.1 Data Handling
The FIFO used for LIN communication is disabled during UART accesses. LRXDL[3..0] and LTXDL[3..0] values of LINDLR
register are then irrelevant. LINDAT register is then used as data register and LINSEL register is not relevant.
17.4.7.2 Rx Service
Once this service is enabled, the user is warned of an in-coming character by the LRXOK flag of LINSIR register. Reading
LINDAT register automatically clears the flag and makes free the second stage of the buffer. If the user considers that the in-
coming character is irrelevant without reading it, he directly can clear the flag (see specific flag management described in
The intrinsic structure of the Rx service offers a 2-byte buffer. The fist one is used for serial to parallel conversion, the second
one receives the result of the conversion. This second buffer byte is reached reading LINDAT register. If the 2-byte buffer is full,
a new in-coming character will overwrite the second one already recorded. An OVRERR error in LINERR register will then
accompany this character when read. A FERR error in LINERR register will be set in case of framing error.