mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-16 04:59:19 +08:00
98 lines
4.0 KiB
C
98 lines
4.0 KiB
C
/** @file reg_lin.h
|
|
* @brief LIN Register Layer Header File
|
|
* @date 29.May.2013
|
|
* @version 03.05.02
|
|
*
|
|
* This file contains:
|
|
* - Definitions
|
|
* - Types
|
|
* - Interface Prototypes
|
|
* .
|
|
* which are relevant for the LIN driver.
|
|
*/
|
|
|
|
/* (c) Texas Instruments 2009-2013, All rights reserved. */
|
|
|
|
#ifndef __REG_LIN_H__
|
|
#define __REG_LIN_H__
|
|
|
|
#include "sys_common.h"
|
|
#include "gio.h"
|
|
|
|
|
|
|
|
/* USER CODE BEGIN (0) */
|
|
/* USER CODE END */
|
|
|
|
/* Lin Register Frame Definition */
|
|
/** @struct linBase
|
|
* @brief LIN Base Register Definition
|
|
*
|
|
* This structure is used to access the LIN module registers.
|
|
*/
|
|
/** @typedef linBASE_t
|
|
* @brief LIN Register Frame Type Definition
|
|
*
|
|
* This type is used to access the LIN Registers.
|
|
*/
|
|
|
|
typedef volatile struct linBase
|
|
{
|
|
uint32 GCR0; /**< 0x0000: Global control register 0 */
|
|
uint32 GCR1; /**< 0x0004: Global control register 1 */
|
|
uint32 GCR2; /**< 0x0008: Global control register 2 */
|
|
uint32 SETINT; /**< 0x000C: Set interrupt enable register */
|
|
uint32 CLRINT; /**< 0x0010: Clear interrupt enable register */
|
|
uint32 SETINTLVL; /**< 0x0014: Set interrupt level register */
|
|
uint32 CLRINTLVL; /**< 0x0018: Set interrupt level register */
|
|
uint32 FLR; /**< 0x001C: interrupt flag register */
|
|
uint32 INTVECT0; /**< 0x0020: interrupt vector Offset 0 */
|
|
uint32 INTVECT1; /**< 0x0024: interrupt vector Offset 1 */
|
|
uint32 FORMAT; /**< 0x0028: Format Control Register */
|
|
uint32 BRSR; /**< 0x002C: Baud rate selection register */
|
|
uint32 ED; /**< 0x0030: Emulation register */
|
|
uint32 RD; /**< 0x0034: Receive data register */
|
|
uint32 TD; /**< 0x0038: Transmit data register */
|
|
uint32 FUN; /**< 0x003C: Pin function register */
|
|
uint32 DIR; /**< 0x0040: Pin direction register */
|
|
uint32 DIN; /**< 0x0044: Pin data in register */
|
|
uint32 DOUT; /**< 0x0048: Pin data out register */
|
|
uint32 SET; /**< 0x004C: Pin data set register */
|
|
uint32 CLR; /**< 0x0050: Pin data clr register */
|
|
uint32 ODR; /**< 0x0054: Pin open drain output enable register */
|
|
uint32 PD; /**< 0x0058: Pin pullup/pulldown disable register */
|
|
uint32 PSL; /**< 0x005C: Pin pullup/pulldown selection register */
|
|
uint32 COMP; /**< 0x0060: Compare register */
|
|
uint8 RDx[8U]; /**< 0x0064-0x0068: RX buffer register */
|
|
uint32 MASK; /**< 0x006C: Mask register */
|
|
uint32 ID; /**< 0x0070: Identification Register */
|
|
uint8 TDx[8U]; /**< 0x0074-0x0078: TX buffer register */
|
|
uint32 MBRSR; /**< 0x007C: Maximum baud rate selection register */
|
|
uint32 SL; /**< 0x0080: Pin slew rate register */
|
|
uint32 rsvd1[3U]; /**< 0x0084: Reserved */
|
|
uint32 IODFTCTRL; /**< 0x0090: IODFT loopback register */
|
|
} linBASE_t;
|
|
|
|
|
|
/** @def linREG
|
|
* @brief LIN Register Frame Pointer
|
|
*
|
|
* This pointer is used by the LIN driver to access the lin module registers.
|
|
*/
|
|
#define linREG ((linBASE_t *)0xFFF7E400U)
|
|
|
|
|
|
/** @def linPORT
|
|
* @brief LIN GIO Port Register Pointer
|
|
*
|
|
* Pointer used by the GIO driver to access I/O PORT of LIN
|
|
* (use the GIO drivers to access the port pins).
|
|
*/
|
|
#define linPORT ((gioPORT_t *)0xFFF7E440U)
|
|
|
|
/* USER CODE BEGIN (1) */
|
|
/* USER CODE END */
|
|
|
|
|
|
#endif
|