mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-17 02:53:32 +08:00
225 lines
7.7 KiB
C
225 lines
7.7 KiB
C
/** @file reg_mibspi.h
|
|
* @brief MIBSPI Register Layer Header File
|
|
* @date 29.May.2013
|
|
* @version 03.05.02
|
|
*
|
|
* This file contains:
|
|
* - Definitions
|
|
* - Types
|
|
* - Interface Prototypes
|
|
* .
|
|
* which are relevant for the MIBSPI driver.
|
|
*/
|
|
|
|
/* (c) Texas Instruments 2009-2013, All rights reserved. */
|
|
|
|
#ifndef __REG_MIBSPI_H__
|
|
#define __REG_MIBSPI_H__
|
|
|
|
#include "sys_common.h"
|
|
#include "gio.h"
|
|
|
|
|
|
|
|
/* USER CODE BEGIN (0) */
|
|
/* USER CODE END */
|
|
|
|
/* Mibspi Register Frame Definition */
|
|
/** @struct mibspiBase
|
|
* @brief MIBSPI Register Definition
|
|
*
|
|
* This structure is used to access the MIBSPI module registers.
|
|
*/
|
|
/** @typedef mibspiBASE_t
|
|
* @brief MIBSPI Register Frame Type Definition
|
|
*
|
|
* This type is used to access the MIBSPI Registers.
|
|
*/
|
|
typedef volatile struct mibspiBase
|
|
{
|
|
uint32 GCR0; /**< 0x0000: Global Control 0 */
|
|
uint32 GCR1; /**< 0x0004: Global Control 1 */
|
|
uint32 INT0; /**< 0x0008: Interrupt Register */
|
|
uint32 LVL; /**< 0x000C: Interrupt Level */
|
|
uint32 FLG; /**< 0x0010: Interrupt flags */
|
|
uint32 PCFUN; /**< 0x0014: Function Pin Enable */
|
|
uint32 PCDIR; /**< 0x0018: Pin Direction */
|
|
uint32 PCDIN; /**< 0x001C: Pin Input Latch */
|
|
uint32 PCDOUT; /**< 0x0020: Pin Output Latch */
|
|
uint32 PCSET; /**< 0x0024: Output Pin Set */
|
|
uint32 PCCLR; /**< 0x0028: Output Pin Clr */
|
|
uint32 PCPDR; /**< 0x002C: Open Drain Output Enable */
|
|
uint32 PCDIS; /**< 0x0030: Pullup/Pulldown Disable */
|
|
uint32 PCPSL; /**< 0x0034: Pullup/Pulldown Selection */
|
|
uint32 DAT0; /**< 0x0038: Transmit Data */
|
|
uint32 DAT1; /**< 0x003C: Transmit Data with Format and Chip Select */
|
|
uint32 BUF; /**< 0x0040: Receive Buffer */
|
|
uint32 EMU; /**< 0x0044: Emulation Receive Buffer */
|
|
uint32 DELAY; /**< 0x0048: Delays */
|
|
uint32 CSDEF; /**< 0x004C: Default Chip Select */
|
|
uint32 FMT0; /**< 0x0050: Data Format 0 */
|
|
uint32 FMT1; /**< 0x0054: Data Format 1 */
|
|
uint32 FMT2; /**< 0x0058: Data Format 2 */
|
|
uint32 FMT3; /**< 0x005C: Data Format 3 */
|
|
uint32 INTVECT0; /**< 0x0060: Interrupt Vector 0 */
|
|
uint32 INTVECT1; /**< 0x0064: Interrupt Vector 1 */
|
|
uint32 SRSEL; /**< 0x0068: Slew Rate Select */
|
|
uint32 PMCTRL; /**< 0x006C: Parallel Mode Control */
|
|
uint32 MIBSPIE; /**< 0x0070: Multi-buffer Mode Enable */
|
|
uint32 TGITENST; /**< 0x0074: TG Interrupt Enable Set */
|
|
uint32 TGITENCR; /**< 0x0078: TG Interrupt Enable Clear */
|
|
uint32 TGITLVST; /**< 0x007C: Transfer Group Interrupt Level Set */
|
|
uint32 TGITLVCR; /**< 0x0080: Transfer Group Interrupt Level Clear */
|
|
uint32 TGINTFLG; /**< 0x0084: Transfer Group Interrupt Flag */
|
|
uint32 rsvd1[2U]; /**< 0x0088: Reserved */
|
|
uint32 TICKCNT; /**< 0x0090: Tick Counter */
|
|
uint32 LTGPEND; /**< 0x0090: Last TG End Pointer */
|
|
uint32 TGCTRL[16U]; /**< 0x0098 - 0x00D4: Transfer Group Control */
|
|
uint32 DMACTRL[8U]; /**< 0x00D8 - 0x00F4: DMA Control */
|
|
uint32 DMACOUNT[8U]; /**< 0x00F8 - 0x0114: DMA Count */
|
|
uint32 DMACNTLEN; /**< 0x0118 - 0x0114: DMA Control length */
|
|
uint32 rsvd2; /**< 0x011C: Reserved */
|
|
uint32 UERRCTRL; /**< 0x0120: Multi-buffer RAM Uncorrectable Parity Error Control */
|
|
uint32 UERRSTAT; /**< 0x0124: Multi-buffer RAM Uncorrectable Parity Error Status */
|
|
uint32 UERRADDRRX; /**< 0x0128: RXRAM Uncorrectable Parity Error Address */
|
|
uint32 UERRADDRTX; /**< 0x012C: TXRAM Uncorrectable Parity Error Address */
|
|
uint32 RXOVRN_BUF_ADDR; /**< 0x0130: RXRAM Overrun Buffer Address */
|
|
uint32 IOLPKTSTCR; /**< 0x0134: IO loopback */
|
|
uint32 EXT_PRESCALE1; /**< 0x0138: */
|
|
uint32 EXT_PRESCALE2; /**< 0x013C: */
|
|
} mibspiBASE_t;
|
|
|
|
|
|
/** @def mibspiREG1
|
|
* @brief MIBSPI1 Register Frame Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi module registers.
|
|
*/
|
|
#define mibspiREG1 ((mibspiBASE_t *)0xFFF7F400U)
|
|
|
|
|
|
/** @def mibspiPORT1
|
|
* @brief MIBSPI1 GIO Port Register Pointer
|
|
*
|
|
* Pointer used by the GIO driver to access I/O PORT of MIBSPI1
|
|
* (use the GIO drivers to access the port pins).
|
|
*/
|
|
#define mibspiPORT1 ((gioPORT_t *)0xFFF7F418U)
|
|
|
|
/** @def mibspiREG3
|
|
* @brief MIBSPI3 Register Frame Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi module registers.
|
|
*/
|
|
#define mibspiREG3 ((mibspiBASE_t *)0xFFF7F800U)
|
|
|
|
|
|
/** @def mibspiPORT3
|
|
* @brief MIBSPI3 GIO Port Register Pointer
|
|
*
|
|
* Pointer used by the GIO driver to access I/O PORT of MIBSPI3
|
|
* (use the GIO drivers to access the port pins).
|
|
*/
|
|
#define mibspiPORT3 ((gioPORT_t *)0xFFF7F818U)
|
|
|
|
/** @def mibspiREG5
|
|
* @brief MIBSPI5 Register Frame Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi module registers.
|
|
*/
|
|
#define mibspiREG5 ((mibspiBASE_t *)0xFFF7FC00U)
|
|
|
|
|
|
/** @def mibspiPORT5
|
|
* @brief MIBSPI5 GIO Port Register Pointer
|
|
*
|
|
* Pointer used by the GIO driver to access I/O PORT of MIBSPI5
|
|
* (use the GIO drivers to access the port pins).
|
|
*/
|
|
#define mibspiPORT5 ((gioPORT_t *)0xFFF7FC18U)
|
|
|
|
|
|
/** @struct mibspiRamBase
|
|
* @brief MIBSPI Buffer RAM Definition
|
|
*
|
|
* This structure is used to access the MIBSPI buffer memory.
|
|
*/
|
|
/** @typedef mibspiRAM_t
|
|
* @brief MIBSPI RAM Type Definition
|
|
*
|
|
* This type is used to access the MIBSPI RAM.
|
|
*/
|
|
typedef volatile struct mibspiRamBase
|
|
{
|
|
struct
|
|
{
|
|
#if ((__little_endian__ == 1) || (__LITTLE_ENDIAN__ == 1))
|
|
uint16 data; /**< tx buffer data */
|
|
uint16 control; /**< tx buffer control */
|
|
#else
|
|
uint16 control; /**< tx buffer control */
|
|
uint16 data; /**< tx buffer data */
|
|
#endif
|
|
} tx[128];
|
|
struct
|
|
{
|
|
#if ((__little_endian__ == 1) || (__LITTLE_ENDIAN__ == 1))
|
|
uint16 data; /**< rx buffer data */
|
|
uint16 flags; /**< rx buffer flags */
|
|
#else
|
|
uint16 flags; /**< rx buffer flags */
|
|
uint16 data; /**< rx buffer data */
|
|
#endif
|
|
} rx[128];
|
|
} mibspiRAM_t;
|
|
|
|
|
|
/** @def mibspiRAM1
|
|
* @brief MIBSPI1 Buffer RAM Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiRAM1 ((mibspiRAM_t *)0xFF0E0000U)
|
|
|
|
/** @def mibspiRAM3
|
|
* @brief MIBSPI3 Buffer RAM Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiRAM3 ((mibspiRAM_t *)0xFF0C0000U)
|
|
|
|
/** @def mibspiRAM5
|
|
* @brief MIBSPI5 Buffer RAM Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiRAM5 ((mibspiRAM_t *)0xFF0A0000U)
|
|
|
|
/** @def mibspiPARRAM1
|
|
* @brief MIBSPI1 Buffer RAM PARITY Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiPARRAM1 (*(volatile uint32 *)(0xFF0E0000U + 0x00000400U))
|
|
|
|
/** @def mibspiPARRAM3
|
|
* @brief MIBSPI3 Buffer RAM PARITY Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiPARRAM3 (*(volatile uint32 *)(0xFF0C0000U + 0x00000400U))
|
|
|
|
|
|
/** @def mibspiPARRAM5
|
|
* @brief MIBSPI5 Buffer RAM PARITY Pointer
|
|
*
|
|
* This pointer is used by the MIBSPI driver to access the mibspi buffer memory.
|
|
*/
|
|
#define mibspiPARRAM5 (*(volatile uint32 *)(0xFF0A0000U + 0x00000400U))
|
|
|
|
/* USER CODE BEGIN (1) */
|
|
/* USER CODE END */
|
|
|
|
|
|
#endif
|