Partial SSC registers
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@3017 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
1cf064bc91
commit
0dfbc35804
@ -48,15 +48,147 @@
|
||||
|
||||
/* Register offsets *****************************************************************/
|
||||
|
||||
#warning "Missing logic"
|
||||
#define AVR32_SSC_CR_OFFSET 0x00 /* Control Register */
|
||||
#define AVR32_SSC_CMR_OFFSET 0x04 /* Clock Mode Register */
|
||||
#define AVR32_SSC_RCMR_OFFSET 0x10 /* Receive Clock Mode Register */
|
||||
#define AVR32_SSC_RFMR_OFFSET 0x14 /* Receive Frame Mode Register */
|
||||
#define AVR32_SSC_TCMR_OFFSET 0x18 /* Transmit Clock Mode Register */
|
||||
#define AVR32_SSC_TFMR_OFFSET 0x1c /* Transmit Frame Mode Register */
|
||||
#define AVR32_SSC_RHR_OFFSET 0x20 /* Receive Holding Register */
|
||||
#define AVR32_SSC_THR_OFFSET 0x24 /* Transmit Holding Register */
|
||||
#define AVR32_SSC_RSHR_OFFSET 0x30 /* Receive Synchronization Holding Register */
|
||||
#define AVR32_SSC_TSHR_OFFSET 0x34 /* Transmit Synchronization Holding Register */
|
||||
#define AVR32_SSC_RC0R_OFFSET 0x38 /* Receive Compare 0 Register */
|
||||
#define AVR32_SSC_RC1R_OFFSET 0x3c /* Receive Compare 1 Register */
|
||||
#define AVR32_SSC_SR_OFFSET 0x40 /* Status Register */
|
||||
#define AVR32_SSC_IER_OFFSET 0x44 /* Interrupt Enable Register */
|
||||
#define AVR32_SSC_IDR_OFFSET 0x48 /* Interrupt Disable Register */
|
||||
#define AVR32_SSC_IMR_OFFSET 0x4c /* Interrupt Mask Register */
|
||||
|
||||
/* Register Addresses ***************************************************************/
|
||||
|
||||
#warning "Missing logic"
|
||||
#define AVR32_SSC_CR (AVR32_SSC_BASE+AVR32_SSC_CR_OFFSET)
|
||||
#define AVR32_SSC_CMR (AVR32_SSC_BASE+AVR32_SSC_CMR_OFFSET)
|
||||
#define AVR32_SSC_RCMR (AVR32_SSC_BASE+AVR32_SSC_RCMR_OFFSET)
|
||||
#define AVR32_SSC_RFMR (AVR32_SSC_BASE+AVR32_SSC_RFMR_OFFSET)
|
||||
#define AVR32_SSC_TCMR (AVR32_SSC_BASE+AVR32_SSC_TCMR_OFFSET)
|
||||
#define AVR32_SSC_TFMR (AVR32_SSC_BASE+AVR32_SSC_TFMR_OFFSET)
|
||||
#define AVR32_SSC_RHR (AVR32_SSC_BASE+AVR32_SSC_RHR_OFFSET)
|
||||
#define AVR32_SSC_THR (AVR32_SSC_BASE+AVR32_SSC_THR_OFFSET)
|
||||
#define AVR32_SSC_RSHR (AVR32_SSC_BASE+AVR32_SSC_RSHR_OFFSET)
|
||||
#define AVR32_SSC_TSHR (AVR32_SSC_BASE+AVR32_SSC_TSHR_OFFSET)
|
||||
#define AVR32_SSC_RC0R (AVR32_SSC_BASE+AVR32_SSC_RC0R_OFFSET)
|
||||
#define AVR32_SSC_RC1R (AVR32_SSC_BASE+AVR32_SSC_RC1R_OFFSET)
|
||||
#define AVR32_SSC_SR (AVR32_SSC_BASE+AVR32_SSC_SR_OFFSET)
|
||||
#define AVR32_SSC_IER (AVR32_SSC_BASE+AVR32_SSC_IER_OFFSET)
|
||||
#define AVR32_SSC_IDR (AVR32_SSC_BASE+AVR32_SSC_IDR_OFFSET)
|
||||
#define AVR32_SSC_IMR (AVR32_SSC_BASE+AVR32_SSC_IMR_OFFSET)
|
||||
|
||||
/* Register Bit-field Definitions ***************************************************/
|
||||
|
||||
#warning "Missing logic"
|
||||
/* Control Register Bit-field Definitions */
|
||||
|
||||
#define SSC_CR_RXEN (1 << 0) /* Bit 0: Receive Enable */
|
||||
#define SSC_CR_RXDIS (1 << 1) /* Bit 1: Receive Disable */
|
||||
#define SSC_CR_TXEN (1 << 8) /* Bit 8: Transmit Enable */
|
||||
#define SSC_CR_TXDIS (1 << 9) /* Bit 9: Transmit Disable */
|
||||
#define SSC_CR_SWRST (1 << 15) /* Bit 15: Software Reset */
|
||||
|
||||
/* Clock Mode Register Bit-field Definitions */
|
||||
|
||||
#define SSC_CMR_DIV_SHIFT (0) /* Bits 0-11: Clock Divider */
|
||||
#define SSC_CMR_DIV_MASK (0xfff << SSC_CMR_DIV_SHIFT)
|
||||
|
||||
/* Receive Clock Mode Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RCMR_PERIOD_SHIFT (24) /* Bits 24-31: Receive Period Divider Selection */
|
||||
#define SSC_RCMR_PERIOD_MASK (0xff << SSC_RCMR_PERIOD_SHIFT)
|
||||
#define SSC_RCMR_STTDLY_SHIFT (16) /* Bits 16-23: Receive Start Delay */
|
||||
#define SSC_RCMR_STTDLY_MASK (0xff << SSC_RCMR_STTDLY_SHIFT)
|
||||
#define SSC_RCMR_STOP (1 << 12) /* Bit 12: Receive Stop Selection */
|
||||
#define SSC_RCMR_START_SHIFT (8) /* Bits 8-11: Receive Start Selection */
|
||||
#define SSC_RCMR_START_MASK (15 << SSC_RCMR_START_SHIFT)
|
||||
# define SSC_RCMR_START_CONT (0 << SSC_RCMR_START_SHIFT) /* Continuous */
|
||||
# define SSC_RCMR_START_XMTSTART (1 << SSC_RCMR_START_SHIFT) /* Transmit start */
|
||||
# define SSC_RCMR_START_LOW (2 << SSC_RCMR_START_SHIFT) /* RX_FRAME_SYNC low */
|
||||
# define SSC_RCMR_START_HIGH (3 << SSC_RCMR_START_SHIFT) /* RX_FRAME_SYNC high */
|
||||
# define SSC_RCMR_START_FALLING (4 << SSC_RCMR_START_SHIFT) /* Falling RX_FRAME_SYNC */
|
||||
# define SSC_RCMR_START_RISING (5 << SSC_RCMR_START_SHIFT) /* Rising RX_FRAME_SYNC */
|
||||
# define SSC_RCMR_START_CHANGE (6 << SSC_RCMR_START_SHIFT) /* RX_FRAME_SYNC change */
|
||||
# define SSC_RCMR_START_BOTH (7 << SSC_RCMR_START_SHIFT) /* Any edge RX_FRAME_SYNC */
|
||||
# define SSC_RCMR_START_CMP0 (8 << SSC_RCMR_START_SHIFT) /* Compare 0 */
|
||||
#define SSC_RCMR_CKG_SHIFT (6) /* Bits 6-7: Receive Clock Gating Selection */
|
||||
#define SSC_RCMR_CKG_MASK (3 << SSC_RCMR_CKG_SHIFT)
|
||||
# define SSC_RCMR_CKG_NONE (0 << SSC_RCMR_CKG_SHIFT) /* None, continous clock */
|
||||
# define SSC_RCMR_CKG_LOW (1 << SSC_RCMR_CKG_SHIFT) /* Enable if RX_FRAME_SYNC low */
|
||||
# define SSC_RCMR_CKG_HIGH (2 << SSC_RCMR_CKG_SHIFT) /* Enable if RX_FRAME_SYNC high */
|
||||
#define SSC_RCMR_CKI (1 << 5) /* Bit 5: Receive Clock Inversion */
|
||||
#define SSC_RCMR_CKO_SHIFT (2) /* Bits 2-4: Receive Clock Output Mode Selection */
|
||||
#define SSC_RCMR_CKO_MASK (7 << SSC_RCMR_CKO_SHIFT)
|
||||
# define SSC_RCMR_CKO_NONE (0 << SSC_RCMR_CKO_SHIFT) /* None Input-only */
|
||||
# define SSC_RCMR_CKO_CONT (1 << SSC_RCMR_CKO_SHIFT) /* Continuous receive clock Output */
|
||||
# define SSC_RCMR_CKO_XFR (2 << SSC_RCMR_CKO_SHIFT) /* Receive clock only during data transfers Output */
|
||||
#define SSC_RCMR_CKS_SHIFT (0) /* Bits 0-1: Receive Clock Selection */
|
||||
#define SSC_RCMR_CKS_MASK (3 << SSC_RCMR_CKS_SHIFT)
|
||||
# define SSC_RCMR_CKS_DIVCLK (0 << SSC_RCMR_CKS_SHIFT) /* Divided clock */
|
||||
# define SSC_RCMR_CKS_TXCLK (1 << SSC_RCMR_CKS_SHIFT) /* TX_CLOCK clock signal */
|
||||
# define SSC_RCMR_CKS_RXCLK (2 << SSC_RCMR_CKS_SHIFT) /* RX_CLOCK pin */
|
||||
|
||||
/* Receive Frame Mode Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RFMR_
|
||||
|
||||
/* Transmit Clock Mode Register Bit-field Definitions */
|
||||
|
||||
#define SSC_TCMR_
|
||||
|
||||
/* Transmit Frame Mode Register Bit-field Definitions */
|
||||
|
||||
#define SSC_TFMR_
|
||||
|
||||
/* Receive Holding Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RHR_
|
||||
|
||||
/* Transmit Holding Register Bit-field Definitions */
|
||||
|
||||
#define SSC_THR_
|
||||
|
||||
/* Receive Synchronization Holding Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RSHR_
|
||||
|
||||
/* Transmit Synchronization Holding Register Bit-field Definitions */
|
||||
|
||||
#define SSC_TSHR_
|
||||
|
||||
/* Receive Compare 0 Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RC0R_
|
||||
|
||||
/* Receive Compare 1 Register Bit-field Definitions */
|
||||
|
||||
#define SSC_RC1R_
|
||||
|
||||
/* Status Register Bit-field Definitions */
|
||||
|
||||
#define SSC_SR_
|
||||
|
||||
/* Interrupt Enable Register Bit-field Definitions */
|
||||
|
||||
#define SSC_IER_
|
||||
|
||||
/* Interrupt Disable Register Bit-field Definitions */
|
||||
|
||||
#define SSC_IDR_
|
||||
|
||||
/* Interrupt Mask Register Bit-field Definitions */
|
||||
|
||||
#define SSC_IMR_
|
||||
|
||||
(1 << xxx) /* Bit xxx:
|
||||
_SHIFT (xx) /* Bits xx-xx:
|
||||
_MASK (xx << xx)
|
||||
|
||||
/************************************************************************************
|
||||
* Public Types
|
||||
|
Loading…
Reference in New Issue
Block a user