MINI51DE_BSP V3.02.004
The Board Support Package for Mini51DE Series MCU
spi.c
Go to the documentation of this file.
1/**************************************************************************/
12#include "Mini51Series.h"
39uint32_t SPI_Open(SPI_T *spi,
40 uint32_t u32MasterSlave,
41 uint32_t u32SPIMode,
42 uint32_t u32DataWidth,
43 uint32_t u32BusClock)
44{
45 uint32_t u32Pclk, u32Div;
46
47 if(u32DataWidth == 32)
48 u32DataWidth = 0;
49
50 spi->CNTRL = u32MasterSlave | (u32DataWidth << SPI_CNTRL_TX_BIT_LEN_Pos) | (u32SPIMode);
51
52 u32Pclk = CLK_GetHCLKFreq();
53
54 u32Div = 0xffff;
56
57 if(u32BusClock !=0 )
58 {
59 u32Div = (((u32Pclk / u32BusClock) + 1) >> 1) - 1;
60 if(u32Div > 0xFFFF)
61 u32Div = 0xFFFF;
62 spi->DIVIDER = (spi->DIVIDER & ~0xffff) | u32Div;
63 }
64 else
65 spi->DIVIDER = 0;
66
67 return ( u32Pclk / ((u32Div+1)*2) );
68}
69
75void SPI_Close(SPI_T *spi)
76{
77 /* Reset SPI */
78 SYS->IPRSTC2 |= SYS_IPRSTC2_SPI_RST_Msk;
79 SYS->IPRSTC2 &= ~SYS_IPRSTC2_SPI_RST_Msk;
80}
81
88{
90}
91
98{
100}
101
108{
109 spi->SSR &= ~SPI_SSR_AUTOSS_Msk;
110}
111
119void SPI_EnableAutoSS(SPI_T *spi, uint32_t u32SSPinMask, uint32_t u32ActiveLevel)
120{
121 spi->SSR = (spi->SSR & ~(SPI_SSR_SS_LVL_Msk | SPI_SSR_SSR_Msk)) | (u32SSPinMask | u32ActiveLevel) | SPI_SSR_AUTOSS_Msk;
122}
123
130uint32_t SPI_SetBusClock(SPI_T *spi, uint32_t u32BusClock)
131{
132 uint32_t u32ClkSrc = CLK_GetHCLKFreq();
133 uint32_t u32Div;
134
135 if(u32BusClock > u32ClkSrc)
136 u32BusClock = u32ClkSrc;
137
138 if(u32BusClock != 0 )
139 {
140 u32Div = (((u32ClkSrc / u32BusClock) + 1) >> 1) - 1;
141 if(u32Div > SPI_DIVIDER_DIVIDER_Msk)
143 }
144 else
145 return 0;
146
147 spi->DIVIDER = (spi->DIVIDER & ~SPI_DIVIDER_DIVIDER_Msk) | u32Div;
148 return ( u32ClkSrc / ((u32Div+1)*2) );
149}
150
158void SPI_EnableFIFO(SPI_T *spi, uint32_t u32TxThreshold, uint32_t u32RxThreshold)
159{
161 (u32TxThreshold << SPI_FIFO_CTL_TX_THRESHOLD_Pos) |
162 (u32RxThreshold << SPI_FIFO_CTL_RX_THRESHOLD_Pos));
163
165}
166
173{
174 spi->CNTRL &= ~SPI_CNTRL_FIFO_Msk;
175}
176
182uint32_t SPI_GetBusClock(SPI_T *spi)
183{
184 uint32_t u32Div;
185 uint32_t u32ApbClock;
186
187 u32ApbClock = CLK_GetHCLKFreq();
188 u32Div = spi->DIVIDER & 0xff;
189 return ((u32ApbClock >> 1) / (u32Div + 1));
190}
191
202void SPI_EnableInt(SPI_T *spi, uint32_t u32Mask)
203{
204 if((u32Mask & SPI_IE_MASK) == SPI_IE_MASK)
205 spi->CNTRL |= SPI_CNTRL_IE_Msk;
206
209
212
215
218
221}
222
233void SPI_DisableInt(SPI_T *spi, uint32_t u32Mask)
234{
235 if((u32Mask & SPI_IE_MASK) == SPI_IE_MASK)
236 spi->CNTRL &= ~SPI_CNTRL_IE_Msk;
237
239 spi->CNTRL2 &= ~SPI_CNTRL2_SSTA_INTEN_Msk;
240
242 spi->FIFO_CTL &= ~SPI_FIFO_CTL_TX_INTEN_Msk;
243
245 spi->FIFO_CTL &= ~SPI_FIFO_CTL_RX_INTEN_Msk;
246
248 spi->FIFO_CTL &= ~SPI_FIFO_CTL_RXOV_INTEN_Msk;
249
251 spi->FIFO_CTL &= ~SPI_FIFO_CTL_TIMEOUT_INTEN_Msk;
252}
253 /* end of group MINI51_SPI_EXPORTED_FUNCTIONS */
255 /* end of group MINI51_SPI_Driver */
257 /* end of group MINI51_Device_Driver */
259
260/*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/
Mini51 series peripheral access layer header file. This file contains all the peripheral register's d...
#define SPI_FIFO_CTL_RX_THRESHOLD_Pos
#define SPI_CNTRL_FIFO_Msk
#define SPI_FIFO_CTL_TX_THRESHOLD_Msk
#define SPI_FIFO_CTL_RXOV_INTEN_Msk
#define SPI_FIFO_CTL_TX_THRESHOLD_Pos
#define SPI_SSR_SS_LTRIG_Msk
#define SPI_SSR_SSR_Msk
#define SPI_FIFO_CTL_TX_INTEN_Msk
#define SPI_SSR_AUTOSS_Msk
#define SPI_CNTRL_IE_Msk
#define SPI_FIFO_CTL_TX_CLR_Msk
#define SPI_CNTRL2_SSTA_INTEN_Msk
#define SPI_CNTRL_TX_BIT_LEN_Pos
#define SPI_DIVIDER_DIVIDER_Msk
#define SYS_IPRSTC2_SPI_RST_Msk
#define SPI_FIFO_CTL_TIMEOUT_INTEN_Msk
#define SPI_SSR_SS_LVL_Msk
#define SPI_FIFO_CTL_RX_INTEN_Msk
#define SPI_FIFO_CTL_RX_CLR_Msk
#define SPI_FIFO_CTL_RX_THRESHOLD_Msk
uint32_t CLK_GetHCLKFreq(void)
This function get HCLK frequency. The frequency unit is Hz.
Definition: clk.c:114
#define SYS
Pointer to SYS register structure.
#define SPI_FIFO_TIMEOUT_INTEN_MASK
Definition: spi.h:50
#define SPI_FIFO_RX_INTEN_MASK
Definition: spi.h:48
#define SPI_SSTA_INTEN_MASK
Definition: spi.h:46
#define SPI_FIFO_TX_INTEN_MASK
Definition: spi.h:47
#define SPI_FIFO_RXOV_INTEN_MASK
Definition: spi.h:49
#define SPI_IE_MASK
Definition: spi.h:45
void SPI_DisableInt(SPI_T *spi, uint32_t u32Mask)
Disable FIFO related interrupts specified by u32Mask parameter.
Definition: spi.c:233
void SPI_DisableFIFO(SPI_T *spi)
Disable FIFO mode.
Definition: spi.c:172
void SPI_EnableInt(SPI_T *spi, uint32_t u32Mask)
Enable FIFO related interrupts specified by u32Mask parameter.
Definition: spi.c:202
void SPI_EnableAutoSS(SPI_T *spi, uint32_t u32SSPinMask, uint32_t u32ActiveLevel)
Enable the automatic slave select function. Only available in Master mode.
Definition: spi.c:119
void SPI_EnableFIFO(SPI_T *spi, uint32_t u32TxThreshold, uint32_t u32RxThreshold)
Enable FIFO mode with user-specified Tx FIFO threshold and Rx FIFO threshold configurations.
Definition: spi.c:158
void SPI_DisableAutoSS(SPI_T *spi)
Disable the automatic slave select function.
Definition: spi.c:107
uint32_t SPI_SetBusClock(SPI_T *spi, uint32_t u32BusClock)
Set the SPI bus clock. Only available in Master mode.
Definition: spi.c:130
void SPI_Close(SPI_T *spi)
Reset SPI module and disable SPI peripheral clock.
Definition: spi.c:75
void SPI_ClearTxFIFO(SPI_T *spi)
Clear Tx FIFO buffer.
Definition: spi.c:97
uint32_t SPI_Open(SPI_T *spi, uint32_t u32MasterSlave, uint32_t u32SPIMode, uint32_t u32DataWidth, uint32_t u32BusClock)
This function make SPI module be ready to transfer. By default, the SPI transfer sequence is MSB firs...
Definition: spi.c:39
uint32_t SPI_GetBusClock(SPI_T *spi)
Get the actual frequency of SPI bus clock. Only available in Master mode.
Definition: spi.c:182
void SPI_ClearRxFIFO(SPI_T *spi)
Clear Rx FIFO buffer.
Definition: spi.c:87
__IO uint32_t CNTRL
__IO uint32_t CNTRL2
__IO uint32_t FIFO_CTL
__IO uint32_t SSR
__IO uint32_t DIVIDER