AM263x MCU+ SDK  08.05.00
lin/v0/lin.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2021 Texas Instruments Incorporated
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  *
11  * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in the
13  * documentation and/or other materials provided with the
14  * distribution.
15  *
16  * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32 
48 #ifndef LIN_V0_H_
49 #define LIN_V0_H_
50 
51 /* ========================================================================== */
52 /* Include Files */
53 /* ========================================================================== */
54 
55 #include <stdint.h>
56 #include <kernel/dpl/SystemP.h>
57 #include <kernel/dpl/SemaphoreP.h>
58 #include <kernel/dpl/HwiP.h>
59 #include <drivers/hw_include/cslr.h>
60 #include <drivers/hw_include/cslr_soc.h>
61 #include <drivers/hw_include/cslr_lin.h>
62 #include <drivers/hw_include/hw_types.h>
63 
64 #ifdef __cplusplus
65 extern "C" {
66 #endif
67 
68 /* ========================================================================== */
69 /* Macros & Typedefs */
70 /* ========================================================================== */
71 
74 #define LIN_IO_DFT_KEY (0xAU)
75 
78 #define LIN_WAKEUP_KEY (0xF0U)
79 
88 #define LIN_ID0 (0x1U)
89 #define LIN_ID1 (0x2U)
90 #define LIN_ID2 (0x4U)
91 #define LIN_ID3 (0x8U)
92 #define LIN_ID4 (0x10U)
93 #define LIN_ID5 (0x20U)
94 
106 #define LIN_INT_WAKEUP (0x00000002U) /* Wakeup */
107 #define LIN_INT_TO (0x00000010U) /* Time out */
108 #define LIN_INT_TOAWUS (0x00000040U) /* Time out after wakeup signal */
109 #define LIN_INT_TOA3WUS (0x00000080U) /* Time out after 3 wakeup signals */
110 #define LIN_INT_TX (0x00000100U) /* Transmit buffer ready */
111 #define LIN_INT_RX (0x00000200U) /* Receive buffer ready */
112 #define LIN_INT_ID (0x00002000U) /* Received matching identifier */
113 #define LIN_INT_PE (0x01000000U) /* Parity error */
114 #define LIN_INT_OE (0x02000000U) /* Overrun error */
115 #define LIN_INT_FE (0x04000000U) /* Framing error */
116 #define LIN_INT_NRE (0x08000000U) /* No response error */
117 #define LIN_INT_ISFE (0x10000000U) /* Inconsistent sync field error */
118 #define LIN_INT_CE (0x20000000U) /* Checksum error */
119 #define LIN_INT_PBE (0x40000000U) /* Physical bus error */
120 #define LIN_INT_BE (0x80000000U) /* Bit error */
121 #define LIN_INT_ALL (0xFF0023D2U) /* All interrupts */
122 
132 #define LIN_FLAG_BREAK (CSL_LIN_SCIFLR_BRKDT_MASK)
133 #define LIN_FLAG_WAKEUP (CSL_LIN_SCIFLR_WAKEUP_MASK)
134 #define LIN_FLAG_IDLE (CSL_LIN_SCIFLR_IDLE_MASK)
135 #define LIN_FLAG_BUSY (CSL_LIN_SCIFLR_BUSY_MASK)
136 #define LIN_FLAG_TO (CSL_LIN_SCIFLR_TIMEOUT_MASK)
137 #define LIN_FLAG_TOAWUS (CSL_LIN_SCIFLR_TOAWUS_MASK)
138 #define LIN_FLAG_TOA3WUS (CSL_LIN_SCIFLR_TOA3WUS_MASK)
139 #define LIN_FLAG_TXRDY (CSL_LIN_SCIFLR_TXRDY_MASK)
140 #define LIN_FLAG_RXRDY (CSL_LIN_SCIFLR_RXRDY_MASK)
141 #define LIN_FLAG_TXWAKE (CSL_LIN_SCIFLR_TXWAKE_MASK)
142 #define LIN_FLAG_TXEMPTY (CSL_LIN_SCIFLR_TXEMPTY_MASK)
143 #define LIN_FLAG_RXWAKE (CSL_LIN_SCIFLR_RXWAKE_MASK)
144 #define LIN_FLAG_TXID (CSL_LIN_SCIFLR_IDTXFLAG_MASK)
145 #define LIN_FLAG_RXID (CSL_LIN_SCIFLR_IDRXFLAG_MASK)
146 #define LIN_FLAG_PE (CSL_LIN_SCIFLR_PE_MASK)
147 #define LIN_FLAG_OE (CSL_LIN_SCIFLR_OE_MASK)
148 #define LIN_FLAG_FE (CSL_LIN_SCIFLR_FE_MASK)
149 #define LIN_FLAG_NRE (CSL_LIN_SCIFLR_NRE_MASK)
150 #define LIN_FLAG_ISFE (CSL_LIN_SCIFLR_ISFE_MASK)
151 #define LIN_FLAG_CE (CSL_LIN_SCIFLR_CE_MASK)
152 #define LIN_FLAG_PBE (CSL_LIN_SCIFLR_PBE_MASK)
153 #define LIN_FLAG_BE (CSL_LIN_SCIFLR_BE_MASK)
154 
165 #define LIN_VECT_NONE (0x00)
166 #define LIN_VECT_WAKEUP (0x01)
167 #define LIN_VECT_ISFE (0x02)
168 #define LIN_VECT_PE (0x03)
169 #define LIN_VECT_ID (0x04)
170 #define LIN_VECT_PBE (0x05)
171 #define LIN_VECT_FE (0x06)
172 #define LIN_VECT_BREAK (0x07)
173 #define LIN_VECT_CE (0x08)
174 #define LIN_VECT_OE (0x09)
175 #define LIN_VECT_BE (0x0A)
176 #define LIN_VECT_RX (0x0B)
177 #define LIN_VECT_TX (0x0C)
178 #define LIN_VECT_NRE (0x0D)
179 #define LIN_VECT_TOAWUS (0x0E)
180 #define LIN_VECT_TOA3WUS (0x0F)
181 #define LIN_VECT_TO (0x10)
182 
193 #define LIN_ALL_ERRORS (0xF0000000U)
194 #define LIN_BIT_ERROR (0x80000000U)
195 #define LIN_BUS_ERROR (0x40000000U)
196 #define LIN_CHECKSUM_ERROR (0x20000000U)
197 #define LIN_ISF_ERROR (0x10000000U)
198 
209 #define LIN_SCI_ALL_ERRORS (0x7000000U)
210 #define LIN_SCI_FRAME_ERROR (0x4000000U)
211 #define LIN_SCI_PARITY_ERROR (0x2000000U)
212 #define LIN_SCI_BREAK_ERROR (0x1000000U)
213 
225 #define LIN_SCI_INT_BREAK (0x1U)
226 #define LIN_SCI_INT_WAKEUP (0x2U)
227 #define LIN_SCI_INT_TX (0x100U)
228 #define LIN_SCI_INT_RX (0x200U)
229 #define LIN_SCI_INT_TX_DMA (0x10000U)
230 #define LIN_SCI_INT_RX_DMA (0x20000U)
231 #define LIN_SCI_INT_PARITY (0x1000000U)
232 #define LIN_SCI_INT_OVERRUN (0x2000000U)
233 #define LIN_SCI_INT_FRAME (0x4000000U)
234 #define LIN_SCI_INT_ALL (0x7000303U)
235 
237 /* ========================================================================== */
238 /* Structures and Enums */
239 /* ========================================================================== */
240 
243 typedef enum
244 {
246  LIN_LOOPBACK_ANALOG = 1U
248 
251 typedef enum
252 {
255  LIN_ANALOG_LOOP_RX = 1U
257 
260 typedef enum
261 {
263  LIN_COMM_LIN_ID4ID5LENCTL = 0x0001U
265 
268 typedef enum
269 {
271  LIN_COMM_SCI_ADDRBIT = 0x0001U
273 
276 typedef enum
277 {
279  LIN_MODE_LIN_MASTER = 0x1U
281 
286 typedef enum
287 {
289  LIN_INTERRUPT_LINE1 = 0x1U
291 
294 typedef enum
295 {
299 
302 typedef enum
303 {
305  LIN_CHECKSUM_ENHANCED = 0x1U
307 
310 typedef enum
311 {
313  LIN_DEBUG_COMPLETE = 0x1U
315 
318 typedef enum
319 {
325 
328 typedef enum
329 {
331  LIN_SCI_PAR_EVEN = 0x1U
333 
336 typedef enum
337 {
339  LIN_SCI_STOP_TWO = 0x1U
341 
344 typedef enum
345 {
347  LIN_PINTYPE_RX = 0x2U
349 
350 /* ========================================================================== */
351 /* Internal/Private Structure Declarations */
352 /* ========================================================================== */
353 
354 /* None */
355 
356 /* ========================================================================== */
357 /* Global Variables Declarations */
358 /* ========================================================================== */
359 
360 /* None */
361 
362 /* ========================================================================== */
363 /* Function Declarations */
364 /* ========================================================================== */
365 
373 void LIN_initModule(uint32_t base);
374 
383 void LIN_getData(uint32_t base, uint16_t * const data);
384 
393 void LIN_sendData(uint32_t base, uint16_t *data);
394 
395 /* ========================================================================== */
396 /* Static Function Definitions */
397 /* ========================================================================== */
398 
410 static inline Bool
411 LIN_isBaseValid(uint32_t base)
412 {
413  #if defined (SOC_AM263X)
414  return(
415  (base == CSL_LIN0_U_BASE) ||
416  (base == CSL_LIN1_U_BASE) ||
417  (base == CSL_LIN2_U_BASE) ||
418  (base == CSL_LIN3_U_BASE) ||
419  (base == CSL_LIN4_U_BASE)
420  );
421  #else
422  return TRUE;
423  #endif /* defined (SOC_AM263X) */
424 }
425 
438 static inline void
439 LIN_setLINMode(uint32_t base, LIN_LINMode mode)
440 {
441  /* Paramter Validation */
443 
444  /* Program LIN Mode */
445  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_CLK_MASTER_MASK, CSL_LIN_SCIGCR1_CLK_MASTER_SHIFT, mode);
446 }
447 
464 static inline void
465 LIN_setMaximumBaudRate(uint32_t base, uint32_t clock)
466 {
467  /* Parameter Validation */
469 
470  /* Calculate maximum baud rate prescaler */
471  HW_WR_FIELD32_RAW((base + CSL_LIN_MBRSR), CSL_LIN_MBRSR_MBR_MASK, CSL_LIN_MBRSR_MBR_SHIFT, (clock / 20000U));
472 }
473 
486 static inline void
488 {
489  /* Parameter Validation */
491 
492  /* Sets the message filtering type */
493  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_HGENCTRL_MASK, CSL_LIN_SCIGCR1_HGENCTRL_SHIFT, type);
494 }
495 
504 static inline void
505 LIN_enableParity(uint32_t base)
506 {
507  /* Parameter Validation */
509 
510  /* Enable the parity mode */
511  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_PARITYENA_MASK, CSL_LIN_SCIGCR1_PARITYENA_SHIFT, CSL_TRUE);
512 }
513 
522 static inline void
523 LIN_disableParity(uint32_t base)
524 {
525  /* Parameter Validation */
527 
528  /* Enable the parity mode */
529  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_PARITYENA_MASK, CSL_LIN_SCIGCR1_PARITYENA_SHIFT, CSL_FALSE);
530 }
531 
547 static inline uint16_t
548 LIN_generateParityID(uint16_t identifier)
549 {
550  uint16_t p0, p1, parityIdentifier;
551 
552  /* Calculate parity bits and generate updated identifier */
553  p0 = ((identifier & LIN_ID0) ^ ((identifier & LIN_ID1) >> 1U) ^
554  ((identifier & LIN_ID2) >> 2U) ^ ((identifier & LIN_ID4) >> 4U));
555  p1 = !(((identifier & LIN_ID1) >> 1U) ^ ((identifier & LIN_ID3) >> 3U) ^
556  ((identifier & LIN_ID4) >> 4U) ^ ((identifier & LIN_ID5) >> 5U));
557  parityIdentifier = identifier | ((p0 << 6U) | (p1 << 7U));
558 
559  return(parityIdentifier);
560 }
561 
573 static inline void
574 LIN_setIDByte(uint32_t base, uint16_t identifier)
575 {
576  /* Parameter Validation */
578 
579  HW_WR_FIELD32_RAW((base + CSL_LIN_LINID), CSL_LIN_LINID_IDBYTE_MASK, CSL_LIN_LINID_IDBYTE_SHIFT, identifier);
580 }
581 
593 static inline void
594 LIN_setIDSlaveTask(uint32_t base, uint16_t identifier)
595 {
596  /* Parameter Validation */
598 
599  HW_WR_FIELD32_RAW((base + CSL_LIN_LINID), CSL_LIN_LINID_IDSLAVETASKBYTE_MASK, CSL_LIN_LINID_IDSLAVETASKBYTE_SHIFT, identifier);
600 }
601 
611 static inline void
612 LIN_sendWakeupSignal(uint32_t base)
613 {
614  /* Parameter Validation */
616 
617  /* Set key in Byte 0 (MSB) of transmit buffer 0 register */
618  HW_WR_FIELD32_RAW((base + CSL_LIN_LINTD0), CSL_LIN_LINTD0_TD3_MASK, CSL_LIN_LINTD0_TD3_SHIFT, (uint16_t)LIN_WAKEUP_KEY);
619 
620  /* Transmit TDO for wakeup */
621  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_GENWU_MASK, CSL_LIN_SCIGCR2_GENWU_SHIFT, CSL_TRUE);
622 }
623 
638 static inline void
639 LIN_enterSleep(uint32_t base)
640 {
641  /* Parameter Validation */
643 
644  /* Entering Powerdown */
645  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_POWERDOWN_MASK, CSL_LIN_SCIGCR2_POWERDOWN_SHIFT, CSL_TRUE);
646 }
647 
657 static inline void
658 LIN_sendChecksum(uint32_t base)
659 {
660  /* Parameter Validation */
662 
663  /* Setting the Check Sum */
664  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_SC_MASK, CSL_LIN_SCIGCR2_SC_SHIFT, CSL_TRUE);
665 }
666 
676 static inline void
678 {
679  /* Parameter Validation */
681 
682  /* Comparing the Check Sum */
683  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_CC_MASK, CSL_LIN_SCIGCR2_CC_SHIFT, CSL_TRUE);
684 }
685 
697 static inline Bool
698 LIN_isTxReady(uint32_t base)
699 {
700  /* Parameter Validation */
702 
703  /* Check TXRDY BIT */
704  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_TXRDY_MASK) ==
705  CSL_LIN_SCIFLR_TXRDY_MASK);
706 }
707 
720 static inline void
721 LIN_setFrameLength(uint32_t base, uint16_t length)
722 {
723  /* Parameter Validation */
725  DebugP_assert((length > 0U) && (length < 9U));
726 
727  /* Clear and set frame length value */
728  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIFORMAT), CSL_LIN_SCIFORMAT_LENGTH_MASK, CSL_LIN_SCIFORMAT_LENGTH_SHIFT, ((uint32_t)length - (uint32_t)1U));
729 }
730 
745 static inline void
746 LIN_setCommMode(uint32_t base, LIN_CommMode mode)
747 {
748  /* Parameter Validation */
750 
751  /* Write communication mode selection to the appropriate bit. */
752  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_COMMMODE_MASK, CSL_LIN_SCIGCR1_COMMMODE_SHIFT, (uint16_t)mode);
753 }
754 
765 static inline void
766 LIN_setTxMask(uint32_t base, uint16_t mask)
767 {
768  /* Parameter Validation */
770 
771  /* Clear previous mask value and set new mask */
772  HW_WR_FIELD32_RAW((base + CSL_LIN_LINMASK), CSL_LIN_LINMASK_TXIDMASK_MASK, CSL_LIN_LINMASK_TXIDMASK_SHIFT, mask);
773 }
774 
785 static inline void
786 LIN_setRxMask(uint32_t base, uint16_t mask)
787 {
788  /* Parameter Validation */
790 
791  /* Clear previous mask value and set new mask */
792  HW_WR_FIELD32_RAW((base + CSL_LIN_LINMASK), CSL_LIN_LINMASK_RXIDMASK_MASK, CSL_LIN_LINMASK_RXIDMASK_SHIFT, (uint32_t)mask);
793 }
794 
804 static inline uint16_t
805 LIN_getTxMask(uint32_t base)
806 {
807  /* Parameter Validation */
809 
810  /* Get Tx Mask status */
811  return(HW_RD_FIELD32_RAW((base + CSL_LIN_LINMASK), CSL_LIN_LINMASK_TXIDMASK_MASK, CSL_LIN_LINMASK_TXIDMASK_SHIFT));
812 }
813 
825 static inline uint16_t
826 LIN_getRxMask(uint32_t base)
827 {
828  /* Parameter Validation */
830 
831  /* Get Tx Mask status */
832  return(HW_RD_FIELD32_RAW((base + CSL_LIN_LINMASK), CSL_LIN_LINMASK_RXIDMASK_MASK, CSL_LIN_LINMASK_RXIDMASK_SHIFT));
833 }
834 
846 static inline Bool
847 LIN_isRxReady(uint32_t base)
848 {
849  /* Parameter Validation */
851 
852  /* Ready Rx ready flag and return status */
853  return(HW_RD_FIELD32_RAW((base + CSL_LIN_SCIFLR), CSL_LIN_SCIFLR_RXRDY_MASK, CSL_LIN_SCIFLR_RXRDY_SHIFT));
854 }
855 
866 static inline uint16_t
867 LIN_getRxIdentifier(uint32_t base)
868 {
869  /* Parameter Validation */
871 
872  /* Ready Rx ready flag and return status */
873  return(HW_RD_FIELD32_RAW((base + CSL_LIN_LINID), CSL_LIN_LINID_RECEIVEDID_MASK, CSL_LIN_LINID_RECEIVEDID_SHIFT));
874 }
875 
887 static inline Bool
888 LIN_isTxMatch(uint32_t base)
889 {
890  /* Parameter Validation */
892 
893  /* Read Tx ID flag and return status */
894  return(HW_RD_FIELD32_RAW((base + CSL_LIN_SCIFLR), CSL_LIN_SCIFLR_IDTXFLAG_MASK, CSL_LIN_SCIFLR_IDTXFLAG_SHIFT));
895 }
896 
908 static inline Bool
909 LIN_isRxMatch(uint32_t base)
910 {
911  /* Parameter Validation */
913 
914  /* Read Tx ID flag and return status */
915  return(HW_RD_FIELD32_RAW((base + CSL_LIN_SCIFLR), CSL_LIN_SCIFLR_IDRXFLAG_MASK, CSL_LIN_SCIFLR_IDRXFLAG_SHIFT));
916 }
917 
951 static inline void
952 LIN_enableInterrupt(uint32_t base, uint32_t intFlags)
953 {
954  /* Parameter Validation */
956 
957  /* Set Interrupt Flags */
958  HW_WR_REG32_RAW((base + CSL_LIN_SCISETINT), HW_RD_REG32_RAW(base + CSL_LIN_SCISETINT)|intFlags);
959 }
960 
994 static inline void
995 LIN_disableInterrupt(uint32_t base, uint32_t intFlags)
996 {
997  /* Parameter Validation */
999 
1000  /* Clear Interrupt Flags */
1001  HW_WR_REG32_RAW((base + CSL_LIN_SCICLEARINT), intFlags);
1002 }
1003 
1036 static inline void
1037 LIN_clearInterruptStatus(uint32_t base, uint32_t intFlags)
1038 {
1039  /* Parameter Validation */
1041 
1042  /* Clear Status Flags */
1043  HW_WR_REG32_RAW((base + CSL_LIN_SCIFLR), intFlags);
1044 }
1045 
1079 static inline void
1080 LIN_setInterruptLevel0(uint32_t base, uint32_t intFlags)
1081 {
1082  /* Check the arguments. */
1084 
1085  /* Clear Status Flags */
1086  HW_WR_REG32_RAW((base + CSL_LIN_SCICLEARINTLVL), intFlags);
1087 }
1088 
1122 static inline void
1123 LIN_setInterruptLevel1(uint32_t base, uint32_t intFlags)
1124 {
1125  /* Check the arguments. */
1127 
1128  /* Set interrupt levels to 1 */
1129  HW_WR_REG32_RAW((base + CSL_LIN_SCISETINTLVL), HW_RD_REG32_RAW(base + CSL_LIN_SCISETINTLVL)|intFlags);
1130 }
1131 
1149 static inline void
1150 LIN_enableModuleErrors(uint32_t base, uint32_t errors)
1151 {
1152  /* Check the arguments. */
1154 
1155  /* Clear the IO DFT Enable Key & Enable write access*/
1156  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, (uint32_t)LIN_IO_DFT_KEY);
1157 
1158  /* Enable specified error bits */
1159  HW_WR_REG32_RAW((base + CSL_LIN_IODFTCTRL), HW_RD_REG32_RAW(base + CSL_LIN_IODFTCTRL)|errors);
1160 
1161  /* Clear the IO DFT Enable Key */
1162  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, (uint32_t)CSL_FALSE);
1163 }
1164 
1180 static inline void
1181 LIN_disableModuleErrors(uint32_t base, uint32_t errors)
1182 {
1183  /* Check the arguments. */
1185 
1186  /* Clear the IO DFT Enable Key & Enable write access */
1187  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, (uint32_t)LIN_IO_DFT_KEY);
1188 
1189  /* Disable specified error bits */
1190  HW_WR_REG32_RAW((base + CSL_LIN_IODFTCTRL), HW_RD_REG32_RAW(base + CSL_LIN_IODFTCTRL)&~(errors));
1191 
1192  /* Clear the IO DFT Enable Key */
1193  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, (uint32_t)CSL_FALSE);
1194 }
1195 
1208 static inline void
1210 {
1211  /* Check the arguments. */
1213 
1214  /* Specified error bits */
1215  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_ADAPT_MASK, CSL_LIN_SCIGCR1_ADAPT_SHIFT, CSL_TRUE);
1216 }
1217 
1227 static inline void
1229 {
1230  /* Check the arguments. */
1232 
1233  /* Specified error bits */
1234  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_ADAPT_MASK, CSL_LIN_SCIGCR1_ADAPT_SHIFT, CSL_FALSE);
1235 }
1236 
1248 static inline void
1250 {
1251  /* Check the arguments. */
1253 
1254  /* Set stop bit. */
1255  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_STOPEXTFRAME_MASK, CSL_LIN_SCIGCR1_STOPEXTFRAME_SHIFT, CSL_TRUE);
1256 }
1257 
1270 static inline void
1272 {
1273  /* Check the arguments. */
1275 
1276  /* Set stop bit. */
1277  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_STOPEXTFRAME_MASK, CSL_LIN_SCIGCR1_STOPEXTFRAME_SHIFT, type);
1278 }
1279 
1303 static inline void
1304 LIN_setSyncFields(uint32_t base, uint16_t syncBreak, uint16_t delimiter)
1305 {
1306  /* Check the arguments. */
1308  DebugP_assert(syncBreak < 8U);
1309  DebugP_assert((delimiter >= 1U) && (delimiter < 5U));
1310 
1311  /* Clear sync values and set new values */
1312  HW_WR_FIELD32_RAW((base + CSL_LIN_LINCOMP), (CSL_LIN_LINCOMP_SDEL_MASK|CSL_LIN_LINCOMP_SBREAK_MASK),
1313  CSL_LIN_LINCOMP_SDEL_SHIFT, (syncBreak | (delimiter - 1U)));
1314 }
1315 
1324 static inline void
1325 LIN_enableSCIMode(uint32_t base)
1326 {
1327  /* Check the arguments. */
1329 
1330  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_LINMODE_MASK,
1331  CSL_LIN_SCIGCR1_LINMODE_SHIFT, CSL_FALSE);
1332 
1333  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_CLK_MASTER_MASK,
1334  CSL_LIN_SCIGCR1_CLK_MASTER_SHIFT, CSL_TRUE);
1335 
1336  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_TIMINGMODE_MASK,
1337  CSL_LIN_SCIGCR1_TIMINGMODE_SHIFT, CSL_TRUE);
1338 }
1339 
1348 static inline void
1349 LIN_disableSCIMode(uint32_t base)
1350 {
1351  /* Check the arguments. */
1353 
1354  /* Disable SCI communications mode */
1355  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_CLK_MASTER_MASK,
1356  CSL_LIN_SCIGCR1_CLK_MASTER_SHIFT, CSL_FALSE);
1357 
1358  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_TIMINGMODE_MASK,
1359  CSL_LIN_SCIGCR1_TIMINGMODE_SHIFT, CSL_FALSE);
1360 
1361  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_LINMODE_MASK,
1362  CSL_LIN_SCIGCR1_LINMODE_SHIFT, CSL_TRUE);
1363 }
1364 
1378 static inline void
1380 {
1381  /* Check the arguments. */
1383  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1384  0U);
1385 
1386  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_COMMMODE_MASK,
1387  CSL_LIN_SCIGCR1_COMMMODE_SHIFT, mode);
1388 }
1389 
1402 static inline void
1404 {
1405  /* Check the arguments. */
1407  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1408  0U);
1409 
1410  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_PARITYENA_MASK,
1411  CSL_LIN_SCIGCR1_PARITYENA_SHIFT, 1U);
1412 
1413  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_PARITY_MASK,
1414  CSL_LIN_SCIGCR1_PARITY_SHIFT, parity);
1415 }
1416 
1425 static inline void
1426 LIN_disableSCIParity(uint32_t base)
1427 {
1428  /* Check the arguments. */
1430  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1431  0U);
1432 
1433  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_PARITYENA_MASK,
1434  CSL_LIN_SCIGCR1_PARITYENA_SHIFT, 0U);
1435 }
1436 
1449 static inline void
1450 LIN_setSCIStopBits(uint32_t base, LIN_SCIStopBits number)
1451 {
1452  /* Check the arguments. */
1454  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1455  0U);
1456 
1457  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_STOP_MASK,
1458  CSL_LIN_SCIGCR1_STOP_SHIFT, number);
1459 }
1460 
1474 static inline void
1476 {
1477  /* Check the arguments. */
1479  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1480  0U);
1481 
1482  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_SLEEP_MASK,
1483  CSL_LIN_SCIGCR1_SLEEP_SHIFT, CSL_TRUE);
1484 }
1485 
1495 static inline void
1497 {
1498  /* Check the arguments. */
1500  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1501  0U);
1502 
1503  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_SLEEP_MASK,
1504  CSL_LIN_SCIGCR1_SLEEP_SHIFT, CSL_FALSE);
1505 }
1506 
1519 static inline void
1520 LIN_enterSCILowPower(uint32_t base)
1521 {
1522  /* Check the arguments. */
1524  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1525  0U);
1526 
1527  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_POWERDOWN_MASK,
1528  CSL_LIN_SCIGCR2_POWERDOWN_SHIFT, CSL_TRUE);
1529 }
1530 
1539 static inline void
1540 LIN_exitSCILowPower(uint32_t base)
1541 {
1542  /* Check the arguments. */
1544  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1545  0U);
1546 
1547  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR2), CSL_LIN_SCIGCR2_POWERDOWN_MASK,
1548  CSL_LIN_SCIGCR2_POWERDOWN_SHIFT, CSL_FALSE);
1549 }
1550 
1562 static inline void
1563 LIN_setSCICharLength(uint32_t base, uint16_t numBits)
1564 {
1565  /* Check the arguments. */
1567  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1568  0U);
1569  DebugP_assert((numBits > 0U) && (numBits < 9U));
1570 
1571  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIFORMAT), CSL_LIN_SCIFORMAT_CHAR_MASK,
1572  CSL_LIN_SCIFORMAT_CHAR_SHIFT, (uint32_t)(numBits - 1U));
1573 }
1574 
1587 static inline void
1588 LIN_setSCIFrameLength(uint32_t base, uint16_t length)
1589 {
1590  /* Check the arguments. */
1592  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1593  0U);
1594  DebugP_assert((length > 0U) && (length < 9U));
1595 
1596  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIFORMAT), CSL_LIN_SCIFORMAT_LENGTH_MASK,
1597  CSL_LIN_SCIFORMAT_LENGTH_SHIFT, (uint32_t)(length - 1U));
1598 }
1599 
1611 static inline Bool
1613 {
1614  /* Check the arguments. */
1616  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1617  0U);
1618 
1619  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_RXRDY_MASK) == CSL_LIN_SCIFLR_RXRDY_MASK);
1620 }
1621 
1633 static inline Bool
1635 {
1636  /* Check the arguments. */
1638  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1639  0U);
1640 
1641  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_TXRDY_MASK) == CSL_LIN_SCIFLR_TXRDY_MASK);
1642 }
1643 
1665 static inline uint16_t
1666 LIN_readSCICharNonBlocking(uint32_t base, Bool emulation)
1667 {
1668  /* Check the arguments. */
1670  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1671  0U);
1672 
1673  /* Read specific data register */
1674  return(emulation ? (HW_RD_REG32_RAW(base + CSL_LIN_SCIED) & CSL_LIN_SCIED_ED_MASK) :
1675  (HW_RD_REG32_RAW(base + CSL_LIN_SCIRD) & CSL_LIN_SCIRD_RD_MASK));
1676 }
1677 
1697 static inline uint16_t
1698 LIN_readSCICharBlocking(uint32_t base, Bool emulation)
1699 {
1700  /* Check the arguments. */
1702  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1703  0U);
1704 
1705  /* Wait until a character is available in buffer. */
1706  while(!LIN_isSCIDataAvailable(base))
1707  {
1708  }
1709 
1710  /* Read specific data register */
1711  return(emulation ? (HW_RD_REG32_RAW(base + CSL_LIN_SCIED) & CSL_LIN_SCIED_ED_MASK) :
1712  (HW_RD_REG32_RAW(base + CSL_LIN_SCIRD) & CSL_LIN_SCIRD_RD_MASK));
1713 }
1714 
1729 static inline void
1730 LIN_writeSCICharNonBlocking(uint32_t base, uint16_t data)
1731 {
1732  /* Check the arguments. */
1734  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1735  0U);
1736  DebugP_assert(data <= CSL_LIN_SCITD_TD_MASK);
1737 
1738  /* Set the Tx Data */
1739  HW_WR_FIELD32_RAW((base + CSL_LIN_SCITD), CSL_LIN_SCITD_TD_MASK, CSL_LIN_SCITD_TD_SHIFT, data);
1740 }
1741 
1753 static inline void
1754 LIN_writeSCICharBlocking(uint32_t base, uint16_t data)
1755 {
1756  /* Check the arguments. */
1758  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1759  0U);
1760  DebugP_assert(data <= CSL_LIN_SCITD_TD_MASK);
1761 
1762  /* Wait until space is available in the transmit buffer. */
1763  while(!LIN_isSCISpaceAvailable(base))
1764  {
1765  }
1766 
1767  /* Set the Tx Data */
1768  HW_WR_FIELD32_RAW((base + CSL_LIN_SCITD), CSL_LIN_SCITD_TD_MASK, CSL_LIN_SCITD_TD_SHIFT, data);
1769 }
1770 
1789 static inline void
1790 LIN_enableSCIModuleErrors(uint32_t base, uint32_t errors)
1791 {
1792  /* Check the arguments. */
1794  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1795  0U);
1796 
1797  /* Clear the IO DFT Enable Key & Enable write access */
1798  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, LIN_IO_DFT_KEY);
1799 
1800  /* Enable specified error bits */
1801  HW_WR_REG32_RAW((base + CSL_LIN_IODFTCTRL), (HW_RD_REG32_RAW(base + CSL_LIN_IODFTCTRL)|errors));
1802 
1803  /* Clear the IO DFT Enable Key & Enable write access */
1804  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, CSL_FALSE);
1805 }
1806 
1822 static inline void
1823 LIN_disableSCIModuleErrors(uint32_t base, uint32_t errors)
1824 {
1825  /* Check the arguments. */
1827  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1828  0U);
1829 
1830  /* Clear the IO DFT Enable Key & Enable write access */
1831  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, LIN_IO_DFT_KEY);
1832 
1833  /* Disable specified error bits */
1834  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), errors, 0U, CSL_FALSE);
1835 
1836  /* Clear the IO DFT Enable Key & Enable write access */
1837  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, CSL_FALSE);
1838 }
1839 
1867 static inline void
1868 LIN_enableSCIInterrupt(uint32_t base, uint32_t intFlags)
1869 {
1870  /* Check the arguments. */
1872  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1873  0U);
1874 
1875  /* Set specified interrupts */
1876  HW_WR_REG32_RAW((base + CSL_LIN_SCISETINT), (HW_RD_REG32_RAW(base + CSL_LIN_SCISETINT)|intFlags));
1877 }
1878 
1906 static inline void
1907 LIN_disableSCIInterrupt(uint32_t base, uint32_t intFlags)
1908 {
1909  /* Check the arguments. */
1911  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1912  0U);
1913 
1914  /* Set specified interrupts */
1915  HW_WR_REG32_RAW((base + CSL_LIN_SCICLEARINT), (HW_RD_REG32_RAW(base + CSL_LIN_SCICLEARINT)|intFlags));
1916 }
1917 
1944 static inline void
1945 LIN_clearSCIInterruptStatus(uint32_t base, uint32_t intFlags)
1946 {
1947  /* Check the arguments. */
1949  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1950  0U);
1951 
1952  /* Set specified interrupts */
1953  HW_WR_REG32_RAW((base + CSL_LIN_SCIFLR), (HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR)|intFlags));
1954 }
1955 
1983 static inline void
1984 LIN_setSCIInterruptLevel0(uint32_t base, uint32_t intFlags)
1985 {
1986  /* Check the arguments. */
1988  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
1989  0U);
1990 
1991  /* Clear Status Flags */
1992  HW_WR_REG32_RAW((base + CSL_LIN_SCICLEARINTLVL), (HW_RD_REG32_RAW(base + CSL_LIN_SCICLEARINTLVL)|intFlags));
1993 }
1994 
2021 static inline void
2022 LIN_setSCIInterruptLevel1(uint32_t base, uint32_t intFlags)
2023 {
2024  /* Check the arguments. */
2026  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
2027  0U);
2028 
2029  /* Set interrupt levels to 1 */
2030  HW_WR_REG32_RAW((base + CSL_LIN_SCISETINTLVL), HW_RD_REG32_RAW(base + CSL_LIN_SCISETINTLVL)|intFlags);
2031 }
2032 
2044 static inline Bool
2046 {
2047  /* Check the arguments. */
2049  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
2050  0U);
2051 
2052  /* Read Rx Idle flag and return status */
2053  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_IDLE_MASK) == 0U);
2054 }
2055 
2068 static inline Bool
2070 {
2071  /* Check the arguments. */
2073  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
2074  0U);
2075 
2076  /* Read Rx Idle flag and return status */
2077  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_WAKEUP_MASK) == CSL_LIN_SCIFLR_WAKEUP_MASK);
2078 }
2079 
2092 static inline Bool
2094 {
2095  /* Check the arguments. */
2097  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
2098  0U);
2099 
2100  /* Read Rx Idle flag and return status */
2101  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_RXWAKE_MASK) == CSL_LIN_SCIFLR_RXWAKE_MASK);
2102 }
2103 
2115 static inline Bool
2117 {
2118  /* Check the arguments. */
2120  DebugP_assert((HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1) & CSL_LIN_SCIGCR1_LINMODE_MASK) ==
2121  0U);
2122 
2123  /* Read Rx Idle flag and return status */
2124  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_BRKDT_MASK) == CSL_LIN_SCIFLR_BRKDT_MASK);
2125 }
2126 
2138 static inline void
2139 LIN_enableModule(uint32_t base)
2140 {
2141  /* Check the arguments. */
2143 
2144  /* Set reset bit. */
2145  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR0), CSL_LIN_SCIGCR0_RESET_MASK, CSL_LIN_SCIGCR0_RESET_SHIFT, CSL_TRUE);
2146 
2147  /* Enable TX and RX pin control functionality. */
2148  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIPIO0), CSL_LIN_SCIPIO0_RXFUNC_MASK, CSL_LIN_SCIPIO0_RXFUNC_SHIFT, CSL_TRUE);
2149  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIPIO0), CSL_LIN_SCIPIO0_TXFUNC_MASK, CSL_LIN_SCIPIO0_TXFUNC_SHIFT, CSL_TRUE);
2150 }
2151 
2163 static inline void
2164 LIN_disableModule(uint32_t base)
2165 {
2166  /* Check the arguments. */
2168 
2169  /* Disable TX and RX pin control functionality. */
2170  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIPIO0), CSL_LIN_SCIPIO0_RXFUNC_MASK, CSL_LIN_SCIPIO0_RXFUNC_SHIFT, CSL_FALSE);
2171  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIPIO0), CSL_LIN_SCIPIO0_TXFUNC_MASK, CSL_LIN_SCIPIO0_TXFUNC_SHIFT, CSL_FALSE);
2172 
2173  /* Reset reset bit. */
2174  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR0), CSL_LIN_SCIGCR0_RESET_MASK, CSL_LIN_SCIGCR0_RESET_SHIFT, CSL_FALSE);
2175 }
2176 
2192 static inline void
2193 LIN_setBaudRatePrescaler(uint32_t base, uint32_t prescaler,
2194  uint32_t divider)
2195 {
2196  /* Check the arguments. */
2198  DebugP_assert(prescaler <= (CSL_LIN_BRSR_SCI_LIN_PSL_MASK | CSL_LIN_BRSR_SCI_LIN_PSH_MASK));
2199  DebugP_assert(divider <= (CSL_LIN_BRSR_M_MASK >> CSL_LIN_BRSR_M_SHIFT));
2200 
2201  /* Set baud rate prescaler and divider. */
2202  HW_WR_REG32_RAW((base + CSL_LIN_BRSR), (prescaler | (divider << CSL_LIN_BRSR_M_SHIFT)));
2203 }
2204 
2214 static inline void
2216 {
2217  /* Check the arguments. */
2219 
2220  /* Enable transmit bit. */
2221  HW_WR_REG32_RAW((base + CSL_LIN_SCIGCR1), HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1)|CSL_LIN_SCIGCR1_TXENA_MASK);
2222 }
2223 
2233 static inline void
2235 {
2236  /* Check the arguments. */
2238 
2239  /* Enable transmit bit. */
2240  HW_WR_REG32_RAW((base + CSL_LIN_SCIGCR1), HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1)&~(CSL_LIN_SCIGCR1_TXENA_MASK));
2241 }
2242 
2252 static inline void
2254 {
2255  /* Check the arguments. */
2257 
2258  /* Enable receive bit. */
2259  HW_WR_REG32_RAW((base + CSL_LIN_SCIGCR1), HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1)|CSL_LIN_SCIGCR1_RXENA_MASK);
2260 }
2261 
2271 static inline void
2273 {
2274  /* Check the arguments. */
2276 
2277  /* Disable receive bit. */
2278  HW_WR_REG32_RAW((base + CSL_LIN_SCIGCR1), HW_RD_REG32_RAW(base + CSL_LIN_SCIGCR1)&~(CSL_LIN_SCIGCR1_RXENA_MASK));
2279 }
2280 
2294 static inline void
2296 {
2297  /* Check the arguments. */
2299 
2300  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_SWNRST_MASK, CSL_LIN_SCIGCR1_SWNRST_SHIFT, CSL_TRUE);
2301 }
2302 
2317 static inline void
2319 {
2320  /* Check the arguments. */
2322 
2323  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_SWNRST_MASK, CSL_LIN_SCIGCR1_SWNRST_SHIFT, CSL_FALSE);
2324 }
2325 
2338 static inline void
2340 {
2341  /* Check the arguments. */
2343 
2344  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_SWNRST_MASK, CSL_LIN_SCIGCR1_SWNRST_SHIFT, CSL_TRUE);
2345 }
2346 
2358 static inline Bool
2359 LIN_isBusBusy(uint32_t base)
2360 {
2361  /* Check the arguments. */
2363 
2364  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_BUSY_MASK) == CSL_LIN_SCIFLR_BUSY_MASK);
2365 }
2366 
2378 static inline Bool
2379 LIN_isTxBufferEmpty(uint32_t base)
2380 {
2381  /* Check the arguments. */
2383 
2384  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR) & CSL_LIN_SCIFLR_TXEMPTY_MASK) == CSL_LIN_SCIFLR_TXEMPTY_MASK);
2385 }
2386 
2408 static inline void
2409 LIN_enableExtLoopback(uint32_t base, LIN_LoopbackType loopbackType,
2410  LIN_AnalogLoopback path)
2411 {
2412  /* Check the arguments. */
2414 
2415  /* Clear the IO DFT Enable Key */
2416  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, LIN_IO_DFT_KEY);
2417 
2418  /* Set loopback Type */
2419  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_LPBENA_MASK, CSL_LIN_IODFTCTRL_LPBENA_SHIFT, loopbackType);
2420 
2421  /* Set Analog Loopback Path */
2422  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_RXPENA_MASK, CSL_LIN_IODFTCTRL_RXPENA_SHIFT, path);
2423 }
2424 
2436 static inline void
2438 {
2439  /* Check the arguments. */
2441 
2442  /* Set loopback Type */
2443  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_LPBENA_MASK, CSL_LIN_IODFTCTRL_LPBENA_SHIFT, CSL_FALSE);
2444 
2445  /* Set Analog Loopback Path */
2446  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_RXPENA_MASK, CSL_LIN_IODFTCTRL_RXPENA_SHIFT, CSL_FALSE);
2447 }
2448 
2458 static inline void
2460 {
2461  /* Check the arguments. */
2463 
2464  /* Set loopback Type */
2465  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_LOOPBACK_MASK, CSL_LIN_SCIGCR1_LOOPBACK_SHIFT, CSL_TRUE);
2466 }
2467 
2477 static inline void
2479 {
2480  /* Check the arguments. */
2482 
2483  /* Set loopback Type */
2484  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_LOOPBACK_MASK, CSL_LIN_SCIGCR1_LOOPBACK_SHIFT, CSL_FALSE);
2485 }
2486 
2520 static inline uint32_t
2522 {
2523  /* Check the arguments. */
2525 
2526  /* Read and return the flag register */
2527  return(HW_RD_REG32_RAW(base + CSL_LIN_SCIFLR));
2528 }
2529 
2541 static inline uint32_t
2543 {
2544  /* Check the arguments. */
2546 
2547  /* Read and return the flag register */
2548  return(HW_RD_REG32_RAW(base + CSL_LIN_SCISETINTLVL));
2549 }
2550 
2586 static inline uint16_t
2588 {
2589  /* Check the arguments. */
2591 
2592  /* Read and return the flag register */
2593  return(HW_RD_REG32_RAW(base + CSL_LIN_SCIINTVECT0) & CSL_LIN_SCIINTVECT0_INTVECT0_MASK);
2594 }
2595 
2631 static inline uint16_t
2633 {
2634  /* Check the arguments. */
2636 
2637  /* Read and return the flag register */
2638  return(HW_RD_REG32_RAW(base + CSL_LIN_SCIINTVECT1) & CSL_LIN_SCIINTVECT1_INTVECT1_MASK);
2639 }
2640 
2649 static inline void
2651 {
2652  /* Check the arguments. */
2654 
2655  /* Read and return the flag register */
2656  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_MBUFMODE_MASK, CSL_LIN_SCIGCR1_MBUFMODE_SHIFT, CSL_TRUE);
2657 }
2658 
2667 static inline void
2669 {
2670  /* Check the arguments. */
2672 
2673  /* Read and return the flag register */
2674  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_MBUFMODE_MASK, CSL_LIN_SCIGCR1_MBUFMODE_SHIFT, CSL_FALSE);
2675 }
2676 
2690 static inline void
2691 LIN_setTransmitDelay(uint32_t base, uint16_t delay)
2692 {
2693  /* Check the arguments. */
2695  DebugP_assert(delay < 8U);
2696 
2697  /* Clear and Set the IO DFT Enable Key */
2698  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, LIN_IO_DFT_KEY);
2699 
2700  /* Set the delay value */
2701  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_TXSHIFT_MASK, CSL_LIN_IODFTCTRL_TXSHIFT_SHIFT, delay);
2702 
2703  /* Clear the IO DFT Enable Key */
2704  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, CSL_FALSE);
2705 }
2706 
2723 static inline void
2725 {
2726  /* Check the arguments. */
2728 
2729  /* Clear and Set the IO DFT Enable Key */
2730  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, LIN_IO_DFT_KEY);
2731 
2732  /* Set the delay value */
2733  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_PINSAMPLEMASK_MASK, CSL_LIN_IODFTCTRL_PINSAMPLEMASK_SHIFT, mask);
2734 
2735  /* Clear the IO DFT Enable Key */
2736  HW_WR_FIELD32_RAW((base + CSL_LIN_IODFTCTRL), CSL_LIN_IODFTCTRL_IODFTENA_MASK, CSL_LIN_IODFTCTRL_IODFTENA_SHIFT, CSL_FALSE);
2737 }
2738 
2754 static inline void
2756 {
2757  /* Check the arguments. */
2759 
2760  /* Clear and Set the IO DFT Enable Key */
2761  HW_WR_FIELD32_RAW((base + CSL_LIN_SCIGCR1), CSL_LIN_SCIGCR1_CONT_MASK, CSL_LIN_SCIGCR1_CONT_SHIFT, mode);
2762 }
2763 
2778 static inline void
2780 {
2781  /* Check the arguments. */
2783 
2784  HW_WR_REG32_RAW((base + CSL_LIN_LIN_GLB_INT_EN), HW_RD_REG32_RAW(base + CSL_LIN_LIN_GLB_INT_EN)|(CSL_LIN_LIN_GLB_INT_FLG_INT0_FLG_MASK<<(uint16_t)line));
2785 }
2786 
2801 static inline void
2803 {
2804  /* Check the arguments. */
2806 
2807  HW_WR_REG32_RAW((base + CSL_LIN_LIN_GLB_INT_EN), HW_RD_REG32_RAW(base + CSL_LIN_LIN_GLB_INT_EN)&(~(CSL_LIN_LIN_GLB_INT_FLG_INT0_FLG_MASK<<(uint16_t)line)));
2808 }
2809 
2824 static inline void
2826 {
2827  /* Check the arguments. */
2829 
2830  HW_WR_REG32_RAW((base + CSL_LIN_LIN_GLB_INT_CLR), (CSL_LIN_LIN_GLB_INT_FLG_INT0_FLG_MASK<<(uint16_t)line));
2831 }
2832 
2849 static inline Bool
2851 {
2852  /* Check the arguments. */
2854 
2855  return((HW_RD_REG32_RAW(base + CSL_LIN_LIN_GLB_INT_FLG) & (CSL_LIN_LIN_GLB_INT_FLG_INT0_FLG_MASK<<(uint16_t)line))
2856  == (CSL_LIN_LIN_GLB_INT_FLG_INT0_FLG_MASK<<(uint16_t)line));
2857 }
2858 
2872 static inline Bool
2873 LIN_getPinStatus(uint32_t base, LIN_PinType pin)
2874 {
2875  /* Check the arguments. */
2877 
2878  return((HW_RD_REG32_RAW(base + CSL_LIN_SCIPIO2) & pin) == pin);
2879 }
2880 
2881 #ifdef __cplusplus
2882 }
2883 #endif
2884 
2885 #endif /* #ifndef LIN_V0_H_ */
2886 
LIN_MSG_FILTER_IDBYTE
@ LIN_MSG_FILTER_IDBYTE
Definition: lin/v0/lin.h:296
LIN_sendData
void LIN_sendData(uint32_t base, uint16_t *data)
This function sends the data.
LIN_MessageFilter
LIN_MessageFilter
The following are defines for the type parameter of the LIN_setMessageFiltering() function.
Definition: lin/v0/lin.h:295
LIN_LOOPBACK_DIGITAL
@ LIN_LOOPBACK_DIGITAL
Digital Loopback Mode.
Definition: lin/v0/lin.h:245
LIN_disableParity
static void LIN_disableParity(uint32_t base)
Disable Parity mode.
Definition: lin/v0/lin.h:523
LIN_enableInterrupt
static void LIN_enableInterrupt(uint32_t base, uint32_t intFlags)
Enable interrupts.
Definition: lin/v0/lin.h:952
LIN_disableModule
static void LIN_disableModule(uint32_t base)
Disable the LIN module.
Definition: lin/v0/lin.h:2164
LIN_isSCISpaceAvailable
static Bool LIN_isSCISpaceAvailable(uint32_t base)
Check if Space is available in SCI Transmit Buffer.
Definition: lin/v0/lin.h:1634
LIN_DebugMode
LIN_DebugMode
The following are defines for the mode parameter of the LIN_setDebugSuspendMode() function.
Definition: lin/v0/lin.h:311
LIN_COMM_LIN_USELENGTHVAL
@ LIN_COMM_LIN_USELENGTHVAL
Definition: lin/v0/lin.h:262
LIN_setSyncFields
static void LIN_setSyncFields(uint32_t base, uint16_t syncBreak, uint16_t delimiter)
Set Sync Break Extend and Delimiter.
Definition: lin/v0/lin.h:1304
LIN_enterSCILowPower
static void LIN_enterSCILowPower(uint32_t base)
Enter SCI Local Low-Power Mode.
Definition: lin/v0/lin.h:1520
LIN_disableModuleErrors
static void LIN_disableModuleErrors(uint32_t base, uint32_t errors)
Disable Module Errors for Testing.
Definition: lin/v0/lin.h:1181
LIN_MSG_FILTER_IDSLAVE
@ LIN_MSG_FILTER_IDSLAVE
Definition: lin/v0/lin.h:297
LIN_triggerChecksumCompare
static void LIN_triggerChecksumCompare(uint32_t base)
Trigger Checksum Compare.
Definition: lin/v0/lin.h:677
LIN_disableExtLoopback
static void LIN_disableExtLoopback(uint32_t base)
Disable External Loopback mode for self test.
Definition: lin/v0/lin.h:2437
LIN_setMessageFiltering
static void LIN_setMessageFiltering(uint32_t base, LIN_MessageFilter type)
Set Message filtering Type.
Definition: lin/v0/lin.h:487
LIN_disableAutomaticBaudrate
static void LIN_disableAutomaticBaudrate(uint32_t base)
Disable Automatic Baudrate Adjustment.
Definition: lin/v0/lin.h:1228
LIN_isBaseValid
static Bool LIN_isBaseValid(uint32_t base)
Checks a LIN base address.
Definition: lin/v0/lin.h:411
LIN_enableIntLoopback
static void LIN_enableIntLoopback(uint32_t base)
Enable Internal Loopback mode for self test.
Definition: lin/v0/lin.h:2459
LIN_ChecksumType
LIN_ChecksumType
The following are defines for the type parameter of the LIN_setChecksumType() function.
Definition: lin/v0/lin.h:303
LIN_performSoftwareReset
static void LIN_performSoftwareReset(uint32_t base)
Perform software reset.
Definition: lin/v0/lin.h:2295
LIN_SCI_PAR_ODD
@ LIN_SCI_PAR_ODD
Definition: lin/v0/lin.h:330
LIN_LOOPBACK_ANALOG
@ LIN_LOOPBACK_ANALOG
Analog Loopback Mode.
Definition: lin/v0/lin.h:246
LIN_getTxMask
static uint16_t LIN_getTxMask(uint32_t base)
Gets the transmit ID mask.
Definition: lin/v0/lin.h:805
LIN_IO_DFT_KEY
#define LIN_IO_DFT_KEY
LIN IO DFT Key which when written in IODFTENA enables the User and Previledge mode Writes.
Definition: lin/v0/lin.h:74
LIN_enableDataReceiver
static void LIN_enableDataReceiver(uint32_t base)
Enable Receive Data Transfer.
Definition: lin/v0/lin.h:2253
SystemP.h
LIN_setTxMask
static void LIN_setTxMask(uint32_t base, uint16_t mask)
Sets the transmit ID mask.
Definition: lin/v0/lin.h:766
LIN_sendChecksum
static void LIN_sendChecksum(uint32_t base)
Send Checksum Byte.
Definition: lin/v0/lin.h:658
LIN_PinSampleMask
LIN_PinSampleMask
The following are defines for the mask parameter of the LIN_setPinSampleMask() function.
Definition: lin/v0/lin.h:319
LIN_setSCIStopBits
static void LIN_setSCIStopBits(uint32_t base, LIN_SCIStopBits number)
Set the number of stop bits for SCI.
Definition: lin/v0/lin.h:1450
LIN_SCIParityType
LIN_SCIParityType
The following are defines for the parity parameter of the LIN_enableSCIParity() function.
Definition: lin/v0/lin.h:329
LIN_enableModuleErrors
static void LIN_enableModuleErrors(uint32_t base, uint32_t errors)
Enable Module Errors for Testing.
Definition: lin/v0/lin.h:1150
LIN_COMM_SCI_IDLELINE
@ LIN_COMM_SCI_IDLELINE
Definition: lin/v0/lin.h:270
LIN_InterruptLine
LIN_InterruptLine
The following are defines for the line parameter of the LIN_enableGlobalInterrupt(),...
Definition: lin/v0/lin.h:287
LIN_isRxMatch
static Bool LIN_isRxMatch(uint32_t base)
Checks for Rx ID Match Received.
Definition: lin/v0/lin.h:909
LIN_isSCIBreakDetected
static Bool LIN_isSCIBreakDetected(uint32_t base)
Check if SCI Detected a Break Condition.
Definition: lin/v0/lin.h:2116
LIN_setTransmitDelay
static void LIN_setTransmitDelay(uint32_t base, uint16_t delay)
Set Transmit Pin Delay.
Definition: lin/v0/lin.h:2691
LIN_setRxMask
static void LIN_setRxMask(uint32_t base, uint16_t mask)
Sets the receive ID mask.
Definition: lin/v0/lin.h:786
LIN_setInterruptLevel0
static void LIN_setInterruptLevel0(uint32_t base, uint32_t intFlags)
Set interrupt level to 0.
Definition: lin/v0/lin.h:1080
LIN_readSCICharBlocking
static uint16_t LIN_readSCICharBlocking(uint32_t base, Bool emulation)
Reads a SCI character with Blocking.
Definition: lin/v0/lin.h:1698
LIN_SCI_PAR_EVEN
@ LIN_SCI_PAR_EVEN
Definition: lin/v0/lin.h:331
LIN_setSCIInterruptLevel1
static void LIN_setSCIInterruptLevel1(uint32_t base, uint32_t intFlags)
Set interrupt level to 1.
Definition: lin/v0/lin.h:2022
LIN_SCIStopBits
LIN_SCIStopBits
The following are defines for the number parameter of the LIN_setSCIStopBits() function.
Definition: lin/v0/lin.h:337
LIN_DEBUG_FROZEN
@ LIN_DEBUG_FROZEN
Freeze module during debug.
Definition: lin/v0/lin.h:312
LIN_disableSCIMode
static void LIN_disableSCIMode(uint32_t base)
Disable SCI Mode.
Definition: lin/v0/lin.h:1349
LIN_disableMultibufferMode
static void LIN_disableMultibufferMode(uint32_t base)
Disable Multi-buffer Mode.
Definition: lin/v0/lin.h:2668
LIN_enterSleep
static void LIN_enterSleep(uint32_t base)
Entering LIN sleep signal.
Definition: lin/v0/lin.h:639
LIN_LINMode
LIN_LINMode
The following are defines for the mode parameter of the LIN_setLINMode() function.
Definition: lin/v0/lin.h:277
LIN_ID5
#define LIN_ID5
Definition: lin/v0/lin.h:93
SemaphoreP.h
LIN_setSCICharLength
static void LIN_setSCICharLength(uint32_t base, uint16_t numBits)
Set SCI character length.
Definition: lin/v0/lin.h:1563
LIN_disableIntLoopback
static void LIN_disableIntLoopback(uint32_t base)
Disable Internal Loopback mode for self test.
Definition: lin/v0/lin.h:2478
LIN_CommMode
LIN_CommMode
The following are defines for the mode parameter of the LIN_setCommMode() function.
Definition: lin/v0/lin.h:261
LIN_getRxIdentifier
static uint16_t LIN_getRxIdentifier(uint32_t base)
Get last received identifier.
Definition: lin/v0/lin.h:867
LIN_setBaudRatePrescaler
static void LIN_setBaudRatePrescaler(uint32_t base, uint32_t prescaler, uint32_t divider)
Set Baud Rate Prescaler.
Definition: lin/v0/lin.h:2193
LIN_setSCIInterruptLevel0
static void LIN_setSCIInterruptLevel0(uint32_t base, uint32_t intFlags)
Set interrupt level to 0.
Definition: lin/v0/lin.h:1984
LIN_enableExtLoopback
static void LIN_enableExtLoopback(uint32_t base, LIN_LoopbackType loopbackType, LIN_AnalogLoopback path)
Enable External Loopback mode for self test.
Definition: lin/v0/lin.h:2409
LIN_ANALOG_LOOP_RX
@ LIN_ANALOG_LOOP_RX
Analog loopback through receive pin.
Definition: lin/v0/lin.h:255
LIN_MODE_LIN_MASTER
@ LIN_MODE_LIN_MASTER
Definition: lin/v0/lin.h:279
LIN_INTERRUPT_LINE1
@ LIN_INTERRUPT_LINE1
Definition: lin/v0/lin.h:289
LIN_PINTYPE_TX
@ LIN_PINTYPE_TX
Definition: lin/v0/lin.h:346
LIN_isRxReady
static Bool LIN_isRxReady(uint32_t base)
Gets the receive ID mask.
Definition: lin/v0/lin.h:847
LIN_MODE_LIN_SLAVE
@ LIN_MODE_LIN_SLAVE
Definition: lin/v0/lin.h:278
LIN_enableMultibufferMode
static void LIN_enableMultibufferMode(uint32_t base)
Enable Multi-buffer Mode.
Definition: lin/v0/lin.h:2650
LIN_disableGlobalInterrupt
static void LIN_disableGlobalInterrupt(uint32_t base, LIN_InterruptLine line)
Disables a LIN global interrupt.
Definition: lin/v0/lin.h:2802
LIN_disableSCISleepMode
static void LIN_disableSCISleepMode(uint32_t base)
Disable SCI Sleep mode.
Definition: lin/v0/lin.h:1496
LIN_ANALOG_LOOP_NONE
@ LIN_ANALOG_LOOP_NONE
Default path for digital loopback mode.
Definition: lin/v0/lin.h:253
LIN_enableSCIParity
static void LIN_enableSCIParity(uint32_t base, LIN_SCIParityType parity)
Enable SCI Parity mode.
Definition: lin/v0/lin.h:1403
LIN_disableInterrupt
static void LIN_disableInterrupt(uint32_t base, uint32_t intFlags)
Disable interrupts.
Definition: lin/v0/lin.h:995
LIN_clearSCIInterruptStatus
static void LIN_clearSCIInterruptStatus(uint32_t base, uint32_t intFlags)
Clear SCI interrupt status.
Definition: lin/v0/lin.h:1945
LIN_disableDataTransmitter
static void LIN_disableDataTransmitter(uint32_t base)
Disable Transmit Data Transfer.
Definition: lin/v0/lin.h:2234
LIN_isTxMatch
static Bool LIN_isTxMatch(uint32_t base)
Checks for Tx ID Match Received.
Definition: lin/v0/lin.h:888
LIN_readSCICharNonBlocking
static uint16_t LIN_readSCICharNonBlocking(uint32_t base, Bool emulation)
Reads a SCI character without Blocking.
Definition: lin/v0/lin.h:1666
LIN_stopExtendedFrame
static void LIN_stopExtendedFrame(uint32_t base)
Stops LIN Extended Frame Communication.
Definition: lin/v0/lin.h:1249
LIN_disableSCIParity
static void LIN_disableSCIParity(uint32_t base)
Disable SCI Parity mode.
Definition: lin/v0/lin.h:1426
LIN_getRxMask
static uint16_t LIN_getRxMask(uint32_t base)
Gets the receive ID mask.
Definition: lin/v0/lin.h:826
LIN_getData
void LIN_getData(uint32_t base, uint16_t *const data)
This function reads the received data.
LIN_isSCIReceiverIdle
static Bool LIN_isSCIReceiverIdle(uint32_t base)
Check if SCI Receiver is Idle.
Definition: lin/v0/lin.h:2045
LIN_setSCICommMode
static void LIN_setSCICommMode(uint32_t base, LIN_SCICommMode mode)
Set SCI communication mode.
Definition: lin/v0/lin.h:1379
HwiP.h
LIN_getSCITxFrameType
static Bool LIN_getSCITxFrameType(uint32_t base)
Gets the SCI Transmit Frame Type.
Definition: lin/v0/lin.h:2069
LIN_isTxReady
static Bool LIN_isTxReady(uint32_t base)
Check Tx buffer ready flag.
Definition: lin/v0/lin.h:698
LIN_clearGlobalInterruptStatus
static void LIN_clearGlobalInterruptStatus(uint32_t base, LIN_InterruptLine line)
Clears a LIN global interrupt flag.
Definition: lin/v0/lin.h:2825
LIN_ID2
#define LIN_ID2
Definition: lin/v0/lin.h:90
LIN_generateParityID
static uint16_t LIN_generateParityID(uint16_t identifier)
Generate Parity Identifier.
Definition: lin/v0/lin.h:548
LIN_setSCIFrameLength
static void LIN_setSCIFrameLength(uint32_t base, uint16_t length)
Set SCI Frame Length.
Definition: lin/v0/lin.h:1588
LIN_setMaximumBaudRate
static void LIN_setMaximumBaudRate(uint32_t base, uint32_t clock)
Set Maximum Baud Rate Prescaler.
Definition: lin/v0/lin.h:465
LIN_INTERRUPT_LINE0
@ LIN_INTERRUPT_LINE0
Definition: lin/v0/lin.h:288
LIN_LoopbackType
LIN_LoopbackType
The following are defines for the type parameter of the LIN_enableExtLoopback() function.
Definition: lin/v0/lin.h:244
LIN_enableParity
static void LIN_enableParity(uint32_t base)
Enable Parity mode.
Definition: lin/v0/lin.h:505
LIN_PINMASK_NONE
@ LIN_PINMASK_NONE
Definition: lin/v0/lin.h:320
LIN_getGlobalInterruptStatus
static Bool LIN_getGlobalInterruptStatus(uint32_t base, LIN_InterruptLine line)
Returns a LIN global interrupt flag status.
Definition: lin/v0/lin.h:2850
LIN_ID4
#define LIN_ID4
Definition: lin/v0/lin.h:92
LIN_isTxBufferEmpty
static Bool LIN_isTxBufferEmpty(uint32_t base)
Check if the Transmit Buffer is Empty.
Definition: lin/v0/lin.h:2379
LIN_enableSCIMode
static void LIN_enableSCIMode(uint32_t base)
Enable SCI Mode.
Definition: lin/v0/lin.h:1325
LIN_setIDSlaveTask
static void LIN_setIDSlaveTask(uint32_t base, uint16_t identifier)
Set ID-SlaveTask.
Definition: lin/v0/lin.h:594
LIN_enterSoftwareReset
static void LIN_enterSoftwareReset(uint32_t base)
Put LIN into its reset state.
Definition: lin/v0/lin.h:2318
LIN_enableGlobalInterrupt
static void LIN_enableGlobalInterrupt(uint32_t base, LIN_InterruptLine line)
Enables a LIN global interrupt.
Definition: lin/v0/lin.h:2779
LIN_setPinSampleMask
static void LIN_setPinSampleMask(uint32_t base, LIN_PinSampleMask mask)
Set Pin Sample Mask.
Definition: lin/v0/lin.h:2724
LIN_getInterruptLine1Offset
static uint16_t LIN_getInterruptLine1Offset(uint32_t base)
Gets the Interrupt Vector Offset for Line 1.
Definition: lin/v0/lin.h:2632
LIN_disableDataReceiver
static void LIN_disableDataReceiver(uint32_t base)
Disable Receive Data Transfer.
Definition: lin/v0/lin.h:2272
LIN_enableSCIInterrupt
static void LIN_enableSCIInterrupt(uint32_t base, uint32_t intFlags)
Enable SCI interrupts.
Definition: lin/v0/lin.h:1868
LIN_CHECKSUM_ENHANCED
@ LIN_CHECKSUM_ENHANCED
Definition: lin/v0/lin.h:305
LIN_COMM_SCI_ADDRBIT
@ LIN_COMM_SCI_ADDRBIT
Definition: lin/v0/lin.h:271
LIN_writeSCICharBlocking
static void LIN_writeSCICharBlocking(uint32_t base, uint16_t data)
Sends a SCI character with blocking.
Definition: lin/v0/lin.h:1754
LIN_WAKEUP_KEY
#define LIN_WAKEUP_KEY
LIN/SCI Wakeup signal is sent by sending an byte with value 0xF0.
Definition: lin/v0/lin.h:78
LIN_ID1
#define LIN_ID1
Definition: lin/v0/lin.h:89
LIN_setLINMode
static void LIN_setLINMode(uint32_t base, LIN_LINMode mode)
Sets the LIN mode.
Definition: lin/v0/lin.h:439
LIN_enableDataTransmitter
static void LIN_enableDataTransmitter(uint32_t base)
Enable Transmit Data Transfer.
Definition: lin/v0/lin.h:2215
LIN_setCommMode
static void LIN_setCommMode(uint32_t base, LIN_CommMode mode)
Set LIN communication mode.
Definition: lin/v0/lin.h:746
LIN_setIDByte
static void LIN_setIDByte(uint32_t base, uint16_t identifier)
Set ID Byte.
Definition: lin/v0/lin.h:574
LIN_isBusBusy
static Bool LIN_isBusBusy(uint32_t base)
Check if Bus is Busy.
Definition: lin/v0/lin.h:2359
LIN_exitSCILowPower
static void LIN_exitSCILowPower(uint32_t base)
Exit SCI Local Low-Power Mode.
Definition: lin/v0/lin.h:1540
LIN_getInterruptStatus
static uint32_t LIN_getInterruptStatus(uint32_t base)
Get Interrupt Flags Status.
Definition: lin/v0/lin.h:2521
LIN_getInterruptLine0Offset
static uint16_t LIN_getInterruptLine0Offset(uint32_t base)
Gets the Interrupt Vector Offset for Line 0.
Definition: lin/v0/lin.h:2587
LIN_SCI_STOP_ONE
@ LIN_SCI_STOP_ONE
Definition: lin/v0/lin.h:338
LIN_COMM_LIN_ID4ID5LENCTL
@ LIN_COMM_LIN_ID4ID5LENCTL
Definition: lin/v0/lin.h:263
LIN_writeSCICharNonBlocking
static void LIN_writeSCICharNonBlocking(uint32_t base, uint16_t data)
Sends a SCI character without Blocking.
Definition: lin/v0/lin.h:1730
LIN_SCICommMode
LIN_SCICommMode
The following are defines for the mode parameter of the LIN_setSCICommMode() function.
Definition: lin/v0/lin.h:269
LIN_exitSoftwareReset
static void LIN_exitSoftwareReset(uint32_t base)
Put LIN into its ready state.
Definition: lin/v0/lin.h:2339
LIN_getPinStatus
static Bool LIN_getPinStatus(uint32_t base, LIN_PinType pin)
Get the Status of LIN TX/RX Pin status.
Definition: lin/v0/lin.h:2873
LIN_CHECKSUM_CLASSIC
@ LIN_CHECKSUM_CLASSIC
Definition: lin/v0/lin.h:304
LIN_setChecksumType
static void LIN_setChecksumType(uint32_t base, LIN_ChecksumType type)
Set Checksum Type.
Definition: lin/v0/lin.h:1271
LIN_ID3
#define LIN_ID3
Definition: lin/v0/lin.h:91
LIN_SCI_STOP_TWO
@ LIN_SCI_STOP_TWO
Definition: lin/v0/lin.h:339
LIN_ID0
#define LIN_ID0
Definition: lin/v0/lin.h:88
LIN_AnalogLoopback
LIN_AnalogLoopback
The following are defines for the path parameter of the LIN_enableExtLoopback() function.
Definition: lin/v0/lin.h:252
LIN_enableAutomaticBaudrate
static void LIN_enableAutomaticBaudrate(uint32_t base)
Enable Automatic Baudrate Adjustment.
Definition: lin/v0/lin.h:1209
LIN_PINTYPE_RX
@ LIN_PINTYPE_RX
Definition: lin/v0/lin.h:347
LIN_getSCIRxFrameType
static Bool LIN_getSCIRxFrameType(uint32_t base)
Gets the SCI Receiver Frame Type.
Definition: lin/v0/lin.h:2093
DebugP_assert
#define DebugP_assert(expression)
Function to call for assert check.
Definition: DebugP.h:159
LIN_disableSCIModuleErrors
static void LIN_disableSCIModuleErrors(uint32_t base, uint32_t errors)
Disable SCI Module Errors for Testing.
Definition: lin/v0/lin.h:1823
LIN_getInterruptLevel
static uint32_t LIN_getInterruptLevel(uint32_t base)
Get the Interrupt Level.
Definition: lin/v0/lin.h:2542
LIN_isSCIDataAvailable
static Bool LIN_isSCIDataAvailable(uint32_t base)
Check if new SCI data is ready to be read.
Definition: lin/v0/lin.h:1612
LIN_clearInterruptStatus
static void LIN_clearInterruptStatus(uint32_t base, uint32_t intFlags)
Clear interrupt status.
Definition: lin/v0/lin.h:1037
LIN_setDebugSuspendMode
static void LIN_setDebugSuspendMode(uint32_t base, LIN_DebugMode mode)
Set the Debug Suspended Mode.
Definition: lin/v0/lin.h:2755
LIN_sendWakeupSignal
static void LIN_sendWakeupSignal(uint32_t base)
Send LIN wakeup signal.
Definition: lin/v0/lin.h:612
LIN_PINMASK_CENTER_SCLK
@ LIN_PINMASK_CENTER_SCLK
Definition: lin/v0/lin.h:322
LIN_PINMASK_CENTER_2SCLK
@ LIN_PINMASK_CENTER_2SCLK
Definition: lin/v0/lin.h:323
LIN_ANALOG_LOOP_TX
@ LIN_ANALOG_LOOP_TX
Analog loopback through transmit pin.
Definition: lin/v0/lin.h:254
LIN_setInterruptLevel1
static void LIN_setInterruptLevel1(uint32_t base, uint32_t intFlags)
Set interrupt level to 1.
Definition: lin/v0/lin.h:1123
LIN_PINMASK_CENTER
@ LIN_PINMASK_CENTER
Definition: lin/v0/lin.h:321
LIN_enableSCISleepMode
static void LIN_enableSCISleepMode(uint32_t base)
Enable SCI Sleep mode.
Definition: lin/v0/lin.h:1475
LIN_initModule
void LIN_initModule(uint32_t base)
This function initializes the LIN module.
LIN_disableSCIInterrupt
static void LIN_disableSCIInterrupt(uint32_t base, uint32_t intFlags)
Disable SCI interrupts.
Definition: lin/v0/lin.h:1907
LIN_setFrameLength
static void LIN_setFrameLength(uint32_t base, uint16_t length)
Set LIN Frame Length.
Definition: lin/v0/lin.h:721
LIN_DEBUG_COMPLETE
@ LIN_DEBUG_COMPLETE
Complete Tx/Rx before Freezing.
Definition: lin/v0/lin.h:313
LIN_enableModule
static void LIN_enableModule(uint32_t base)
Enables the LIN module.
Definition: lin/v0/lin.h:2139
LIN_enableSCIModuleErrors
static void LIN_enableSCIModuleErrors(uint32_t base, uint32_t errors)
Enable SCI Module Errors for Testing.
Definition: lin/v0/lin.h:1790
LIN_PinType
LIN_PinType
The following are defines for the pin parameter of the LIN_getPinStatus() function.
Definition: lin/v0/lin.h:345