NANO102/112 BSP V3.03.003
The Board Support Package for Nano102/112 Series
pdma.c
Go to the documentation of this file.
1/**************************************************************************/
12#include "Nano1X2Series.h"
13
14
15
38void PDMA_Open(uint32_t u32Mask)
39{
40 PDMAGCR->GCRCSR |= (u32Mask << 8);
41}
42
52void PDMA_Close(void)
53{
54 PDMAGCR->GCRCSR = 0;
55}
56
68void PDMA_SetTransferCnt(uint32_t u32Ch, uint32_t u32Width, uint32_t u32TransCount)
69{
70 PDMA_T *pdma;
71 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
72 pdma->CSR = (pdma->CSR & ~PDMA_CSR_APB_TWS_Msk) | u32Width;
73 switch (u32Width)
74 {
75 case PDMA_WIDTH_32:
76 pdma->BCR = (u32TransCount << 2);
77 break;
78
79 case PDMA_WIDTH_8:
80 pdma->BCR = u32TransCount;
81 break;
82
83 case PDMA_WIDTH_16:
84 pdma->BCR = (u32TransCount << 1);
85 break;
86
87 default:
88 ;
89 }
90}
91
105void PDMA_SetTransferAddr(uint32_t u32Ch, uint32_t u32SrcAddr, uint32_t u32SrcCtrl, uint32_t u32DstAddr, uint32_t u32DstCtrl)
106{
107 PDMA_T *pdma;
108 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
109
110 pdma->SAR = u32SrcAddr;
111 pdma->DAR = u32DstAddr;
112 pdma->CSR = (pdma->CSR & ~(PDMA_CSR_SAD_SEL_Msk|PDMA_CSR_DAD_SEL_Msk)) | (u32SrcCtrl | u32DstCtrl);
113}
114
131void PDMA_SetTransferMode(uint32_t u32Ch, uint32_t u32Peripheral, uint32_t u32ScatterEn, uint32_t u32DescAddr)
132{
133 PDMA_T *pdma;
134 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
135
136 switch (u32Ch)
137 {
138 case 1:
139 PDMAGCR->DSSR0 = (PDMAGCR->DSSR0 & ~DMA_GCR_DSSR0_CH1_SEL_Msk) | (u32Peripheral << DMA_GCR_DSSR0_CH1_SEL_Pos);
140 break;
141 case 2:
142 PDMAGCR->DSSR0 = (PDMAGCR->DSSR0 & ~DMA_GCR_DSSR0_CH2_SEL_Msk) | (u32Peripheral << DMA_GCR_DSSR0_CH2_SEL_Pos);
143 break;
144 case 3:
145 PDMAGCR->DSSR0 = (PDMAGCR->DSSR0 & ~DMA_GCR_DSSR0_CH3_SEL_Msk) | (u32Peripheral << DMA_GCR_DSSR0_CH3_SEL_Pos);
146 break;
147 case 4:
148 PDMAGCR->DSSR1 = (PDMAGCR->DSSR1 & ~DMA_GCR_DSSR1_CH4_SEL_Msk) | u32Peripheral;
149 break;
150 default:
151 ;
152 }
153 if (u32Peripheral == PDMA_MEM)
154 pdma->CSR &= ~PDMA_CSR_MODE_SEL_Msk;
155 else if (u32Peripheral & 0x10)
156 pdma->CSR = (pdma->CSR & ~PDMA_CSR_MODE_SEL_Msk) | 0x4; /* IP to memory */
157 else
158 pdma->CSR = (pdma->CSR & ~PDMA_CSR_MODE_SEL_Msk) | 0x8; /* memory to IP */
159}
160
172void PDMA_SetTimeOut(uint32_t u32Ch, uint32_t u32OnOff, uint32_t u32TimeOutCnt)
173{
174 PDMA_T *pdma;
175 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
176
177 pdma->TCR = (pdma->TCR & ~PDMA_TCR_PDMA_TCR_Msk) | u32TimeOutCnt;
178 pdma->CSR = (pdma->CSR & ~PDMA_CSR_TO_EN_Msk) | (u32OnOff << PDMA_CSR_TO_EN_Pos);
179
180}
181
191void PDMA_Trigger(uint32_t u32Ch)
192{
193 PDMA_T *pdma;
194 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
195
197}
198
209void PDMA_EnableInt(uint32_t u32Ch, uint32_t u32Mask)
210{
211 PDMA_T *pdma;
212 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
213
214 pdma->IER |= u32Mask;
215}
216
227void PDMA_DisableInt(uint32_t u32Ch, uint32_t u32Mask)
228{
229 PDMA_T *pdma;
230 pdma = (PDMA_T *)((uint32_t) PDMA0_BASE + (0x100 * u32Ch));
231
232 pdma->IER &= ~u32Mask;
233}
234
235 /* end of group NANO1X2_PDMA_EXPORTED_FUNCTIONS */
237 /* end of group NANO1X2_PDMA_Driver */
239 /* end of group NANO1X2_Device_Driver */
241
242/*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/
Nano102/112 peripheral access layer header file. This file contains all the peripheral register's def...
#define DMA_GCR_DSSR0_CH1_SEL_Pos
#define PDMA_CSR_TRIG_EN_Msk
#define DMA_GCR_DSSR0_CH3_SEL_Pos
#define PDMA_CSR_TO_EN_Pos
#define PDMA_CSR_PDMACEN_Msk
#define PDMA_CSR_SAD_SEL_Msk
#define PDMA_CSR_DAD_SEL_Msk
#define DMA_GCR_DSSR0_CH2_SEL_Pos
#define PDMA_WIDTH_32
Definition: pdma.h:38
#define PDMA_WIDTH_16
Definition: pdma.h:37
#define PDMA_MEM
Definition: pdma.h:69
#define PDMA_WIDTH_8
Definition: pdma.h:36
void PDMA_SetTransferAddr(uint32_t u32Ch, uint32_t u32SrcAddr, uint32_t u32SrcCtrl, uint32_t u32DstAddr, uint32_t u32DstCtrl)
Set PDMA Transfer Address.
Definition: pdma.c:105
void PDMA_Trigger(uint32_t u32Ch)
Trigger PDMA.
Definition: pdma.c:191
void PDMA_SetTimeOut(uint32_t u32Ch, uint32_t u32OnOff, uint32_t u32TimeOutCnt)
Set PDMA Timeout.
Definition: pdma.c:172
void PDMA_EnableInt(uint32_t u32Ch, uint32_t u32Mask)
Enable Interrupt.
Definition: pdma.c:209
void PDMA_Open(uint32_t u32Mask)
PDMA Open.
Definition: pdma.c:38
void PDMA_Close(void)
PDMA Close.
Definition: pdma.c:52
void PDMA_DisableInt(uint32_t u32Ch, uint32_t u32Mask)
Disable Interrupt.
Definition: pdma.c:227
void PDMA_SetTransferMode(uint32_t u32Ch, uint32_t u32Periphral, uint32_t u32ScatterEn, uint32_t u32DescAddr)
Set PDMA Transfer Mode.
Definition: pdma.c:131
void PDMA_SetTransferCnt(uint32_t u32Ch, uint32_t u32Width, uint32_t u32TransCount)
Set PDMA Transfer Count.
Definition: pdma.c:68
#define PDMAGCR
Pointer to PDMA global control register structure.
#define PDMA0_BASE
PDMA0 register base address.
__IO uint32_t TCR
__IO uint32_t IER
__IO uint32_t CSR
__IO uint32_t SAR
__IO uint32_t DAR
__IO uint32_t BCR