Kinetis SDK v.2.0 API Reference Manual
Rev. 0
Freescale Semiconductor, Inc.
|
The KSDK provides a peripheral driver for the enhanced Direct Memory Access of Kinetis devices.
Files | |
file | fsl_edma.h |
Data Structures | |
struct | edma_config_t |
eDMA global configuration structure. More... | |
struct | edma_transfer_config_t |
eDMA transfer configuration More... | |
struct | edma_channel_Preemption_config_t |
eDMA channel priority configuration More... | |
struct | edma_minor_offset_config_t |
eDMA minor offset configuration More... | |
struct | edma_tcd_t |
eDMA TCD. More... | |
struct | edma_handle_t |
eDMA transfer handle structure More... | |
Macros | |
#define | DMA_DCHPRI_INDEX(channel) (((channel) & ~0x03U) | (3 - ((channel)&0x03U))) |
Compute the offset unit from DCHPRI3. | |
#define | DMA_DCHPRIn(base, channel) ((volatile uint8_t *)&(base->DCHPRI3))[DMA_DCHPRI_INDEX(channel)] |
Get the pointer of DCHPRIn. | |
Typedefs | |
typedef void(* | edma_callback )(struct _edma_handle *handle, void *userData, bool transferDone, uint32_t tcds) |
Define Callback function for eDMA. More... | |
Driver version | |
#define | FSL_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 0)) |
eDMA driver version More... | |
eDMA initialization and De-initialization | |
void | EDMA_Init (DMA_Type *base, const edma_config_t *config) |
Initializes eDMA peripheral. More... | |
void | EDMA_Deinit (DMA_Type *base) |
Deinitializes eDMA peripheral. More... | |
void | EDMA_GetDefaultConfig (edma_config_t *config) |
Gets the eDMA default configuration structure. More... | |
eDMA Channel Operation | |
void | EDMA_ResetChannel (DMA_Type *base, uint32_t channel) |
Sets all TCD registers to a default value. More... | |
void | EDMA_SetTransferConfig (DMA_Type *base, uint32_t channel, const edma_transfer_config_t *config, edma_tcd_t *nextTcd) |
Configures the eDMA transfer attribute. More... | |
void | EDMA_SetMinorOffsetConfig (DMA_Type *base, uint32_t channel, const edma_minor_offset_config_t *config) |
Configures the eDMA minor offset feature. More... | |
static void | EDMA_SetChannelPreemptionConfig (DMA_Type *base, uint32_t channel, const edma_channel_Preemption_config_t *config) |
Configures the eDMA channel preemption feature. More... | |
void | EDMA_SetChannelLink (DMA_Type *base, uint32_t channel, edma_channel_link_type_t type, uint32_t linkedChannel) |
Sets the channel link for the eDMA transfer. More... | |
void | EDMA_SetBandWidth (DMA_Type *base, uint32_t channel, edma_bandwidth_t bandWidth) |
Sets the bandwidth for the eDMA transfer. More... | |
void | EDMA_SetModulo (DMA_Type *base, uint32_t channel, edma_modulo_t srcModulo, edma_modulo_t destModulo) |
Sets the source modulo and destination modulo for eDMA transfer. More... | |
static void | EDMA_EnableAutoStopRequest (DMA_Type *base, uint32_t channel, bool enable) |
Enables an auto stop request for the eDMA transfer. More... | |
void | EDMA_EnableChannelInterrupts (DMA_Type *base, uint32_t channel, uint32_t mask) |
Enables the interrupt source for the eDMA transfer. More... | |
void | EDMA_DisableChannelInterrupts (DMA_Type *base, uint32_t channel, uint32_t mask) |
Disables the interrupt source for the eDMA transfer. More... | |
eDMA TCD Operation | |
void | EDMA_TcdReset (edma_tcd_t *tcd) |
Sets all fields to default values for the TCD structure. More... | |
void | EDMA_TcdSetTransferConfig (edma_tcd_t *tcd, const edma_transfer_config_t *config, edma_tcd_t *nextTcd) |
Configures the eDMA TCD transfer attribute. More... | |
void | EDMA_TcdSetMinorOffsetConfig (edma_tcd_t *tcd, const edma_minor_offset_config_t *config) |
Configures the eDMA TCD minor offset feature. More... | |
void | EDMA_TcdSetChannelLink (edma_tcd_t *tcd, edma_channel_link_type_t type, uint32_t linkedChannel) |
Sets the channel link for eDMA TCD. More... | |
static void | EDMA_TcdSetBandWidth (edma_tcd_t *tcd, edma_bandwidth_t bandWidth) |
Sets the bandwidth for the eDMA TCD. More... | |
void | EDMA_TcdSetModulo (edma_tcd_t *tcd, edma_modulo_t srcModulo, edma_modulo_t destModulo) |
Sets the source modulo and destination modulo for eDMA TCD. More... | |
static void | EDMA_TcdEnableAutoStopRequest (edma_tcd_t *tcd, bool enable) |
Sets the auto stop request for the eDMA TCD. More... | |
void | EDMA_TcdEnableInterrupts (edma_tcd_t *tcd, uint32_t mask) |
Enables the interrupt source for the eDMA TCD. More... | |
void | EDMA_TcdDisableInterrupts (edma_tcd_t *tcd, uint32_t mask) |
Disables the interrupt source for the eDMA TCD. More... | |
eDMA Channel Transfer Operation | |
static void | EDMA_EnableChannelRequest (DMA_Type *base, uint32_t channel) |
Enables the eDMA hardware channel request. More... | |
static void | EDMA_DisableChannelRequest (DMA_Type *base, uint32_t channel) |
Disables the eDMA hardware channel request. More... | |
static void | EDMA_TriggerChannelStart (DMA_Type *base, uint32_t channel) |
Starts the eDMA transfer by software trigger. More... | |
eDMA Channel Status Operation | |
uint32_t | EDMA_GetRemainingBytes (DMA_Type *base, uint32_t channel) |
Gets the Remaining bytes from the eDMA current channel TCD. More... | |
static uint32_t | EDMA_GetErrorStatusFlags (DMA_Type *base) |
Gets the eDMA channel error status flags. More... | |
uint32_t | EDMA_GetChannelStatusFlags (DMA_Type *base, uint32_t channel) |
Gets the eDMA channel status flags. More... | |
void | EDMA_ClearChannelStatusFlags (DMA_Type *base, uint32_t channel, uint32_t mask) |
Clears the eDMA channel status flags. More... | |
eDMA Transactional Operation | |
void | EDMA_CreateHandle (edma_handle_t *handle, DMA_Type *base, uint32_t channel) |
Creates the eDMA handle. More... | |
void | EDMA_InstallTCDMemory (edma_handle_t *handle, edma_tcd_t *tcdPool, uint32_t tcdSize) |
Installs the TCDs memory pool into eDMA handle. More... | |
void | EDMA_SetCallback (edma_handle_t *handle, edma_callback callback, void *userData) |
Installs a callback function for the eDMA transfer. More... | |
void | EDMA_PrepareTransfer (edma_transfer_config_t *config, void *srcAddr, uint32_t srcWidth, void *destAddr, uint32_t destWidth, uint32_t bytesEachRequest, uint32_t transferBytes, edma_transfer_type_t type) |
Prepares the eDMA transfer structure. More... | |
status_t | EDMA_SubmitTransfer (edma_handle_t *handle, const edma_transfer_config_t *config) |
Submits the eDMA transfer request. More... | |
void | EDMA_StartTransfer (edma_handle_t *handle) |
eDMA start transfer. More... | |
void | EDMA_StopTransfer (edma_handle_t *handle) |
eDMA stop transfer. More... | |
void | EDMA_AbortTransfer (edma_handle_t *handle) |
eDMA abort transfer. More... | |
void | EDMA_HandleIRQ (edma_handle_t *handle) |
eDMA IRQ handler for current major loop transfer complete. More... | |
struct edma_config_t |
Data Fields | |
bool | enableContinuousLinkMode |
Enable (true) continuous link mode. More... | |
bool | enableHaltOnError |
Enable (true) transfer halt on error. More... | |
bool | enableRoundRobinArbitration |
Enable (true) round robin channel arbitration method, or fixed priority arbitration is used for channel selection. | |
bool | enableDebugMode |
Enable(true) eDMA debug mode. More... | |
bool edma_config_t::enableContinuousLinkMode |
Upon minor loop completion, the channel activates again if that channel has a minor loop channel link enabled and the link channel is itself.
bool edma_config_t::enableHaltOnError |
Any error causes the HALT bit to set. Subsequently, all service requests are ignored until the HALT bit is cleared.
bool edma_config_t::enableDebugMode |
When in debug mode, the eDMA stalls the start of a new channel. Executing channels are allowed to complete.
struct edma_transfer_config_t |
This structure configures the source/destination transfer attribute. This figure shows the eDMA's transfer model:
| Transfer Size | | Minor Loop |_______________| Major loop Count 1 | Bytes | Transfer Size | | ____________|_______________|____________________|–> Minor loop complete
| | | |_______________| Major Loop Count 2 | | | | |_______________|____________________|–> Minor loop Complete
------------------------------------------------------—> Transfer complete
Data Fields | |
uint32_t | srcAddr |
Source data address. More... | |
uint32_t | destAddr |
Destination data address. More... | |
edma_transfer_size_t | srcTransferSize |
Source data transfer size. More... | |
edma_transfer_size_t | destTransferSize |
Destination data transfer size. More... | |
int16_t | srcOffset |
Sign-extended offset applied to the current source address to form the next-state value as each source read is completed. More... | |
int16_t | destOffset |
Sign-extended offset applied to the current destination address to form the next-state value as each destination write is completed. More... | |
uint16_t | minorLoopBytes |
Bytes to transfer in a minor loop. | |
uint32_t | majorLoopCounts |
Major loop iteration count. More... | |
uint32_t edma_transfer_config_t::srcAddr |
uint32_t edma_transfer_config_t::destAddr |
edma_transfer_size_t edma_transfer_config_t::srcTransferSize |
edma_transfer_size_t edma_transfer_config_t::destTransferSize |
int16_t edma_transfer_config_t::srcOffset |
int16_t edma_transfer_config_t::destOffset |
uint32_t edma_transfer_config_t::majorLoopCounts |
struct edma_channel_Preemption_config_t |
Data Fields | |
bool | enableChannelPreemption |
If true: channel can be suspended by other channel with higher priority. | |
bool | enablePreemptAbility |
If true: channel can suspend other channel with low priority. | |
uint8_t | channelPriority |
Channel priority. | |
struct edma_minor_offset_config_t |
Data Fields | |
bool | enableSrcMinorOffset |
Enable(true) or Disable(false) source minor loop offset. More... | |
bool | enableDestMinorOffset |
Enable(true) or Disable(false) destination minor loop offset. More... | |
uint32_t | minorOffset |
Offset for minor loop mapping. More... | |
bool edma_minor_offset_config_t::enableSrcMinorOffset |
bool edma_minor_offset_config_t::enableDestMinorOffset |
uint32_t edma_minor_offset_config_t::minorOffset |
struct edma_tcd_t |
This structure is same as TCD register which is described in reference manual, and is used to configure scatter/gather feature as a next hardware TCD.
Data Fields | |
__IO uint32_t | SADDR |
SADDR register, used to save source address. | |
__IO uint16_t | SOFF |
SOFF register, save offset bytes every transfer. | |
__IO uint16_t | ATTR |
ATTR register, source/destination transfer size and modulo. | |
__IO uint32_t | NBYTES |
Nbytes register, minor loop length in bytes. | |
__IO uint32_t | SLAST |
SLAST register. | |
__IO uint32_t | DADDR |
DADDR register, used for destination address. | |
__IO uint16_t | DOFF |
DOFF register, used for destination offset. | |
__IO uint16_t | CITER |
CITER register, current minor loop numbers, for unfinished minor loop. More... | |
__IO uint32_t | DLAST_SGA |
DLASTSGA register, next stcd address used in scatter-gather mode. | |
__IO uint16_t | CSR |
CSR register, for TCD control status. | |
__IO uint16_t | BITER |
BITER register, begin minor loop count. More... | |
__IO uint16_t edma_tcd_t::CITER |
__IO uint16_t edma_tcd_t::BITER |
struct edma_handle_t |
Data Fields | |
edma_callback | callback |
Callback function for major count exhausted. More... | |
void * | userData |
Callback function parameter. More... | |
DMA_Type * | base |
eDMA peripheral base address. More... | |
edma_tcd_t * | tcdPool |
Pointer to memory stored TCDs. More... | |
uint8_t | channel |
eDMA channel number. More... | |
volatile int8_t | header |
The first TCD index. More... | |
volatile int8_t | tail |
The last TCD index. More... | |
volatile int8_t | tcdUsed |
The number of used TCD slots. More... | |
volatile int8_t | tcdSize |
The total number of TCD slots in the queue. More... | |
uint8_t | flags |
The status of the current channel. More... | |
edma_callback edma_handle_t::callback |
void* edma_handle_t::userData |
DMA_Type* edma_handle_t::base |
edma_tcd_t* edma_handle_t::tcdPool |
uint8_t edma_handle_t::channel |
volatile int8_t edma_handle_t::header |
volatile int8_t edma_handle_t::tail |
volatile int8_t edma_handle_t::tcdUsed |
volatile int8_t edma_handle_t::tcdSize |
uint8_t edma_handle_t::flags |
#define FSL_EDMA_DRIVER_VERSION (MAKE_VERSION(2, 0, 0)) |
Version 2.0.0.
typedef void(* edma_callback)(struct _edma_handle *handle, void *userData, bool transferDone, uint32_t tcds) |
enum edma_transfer_size_t |
enum edma_modulo_t |
enum edma_bandwidth_t |
enum edma_transfer_type_t |
void EDMA_Init | ( | DMA_Type * | base, |
const edma_config_t * | config | ||
) |
This function ungates the eDMA clock and configure eDMA peripheral according to the configuration structure.
base | eDMA peripheral base address. |
config | Pointer to configuration structure, see "edma_config_t". |
void EDMA_Deinit | ( | DMA_Type * | base | ) |
This function gates the eDMA clock.
base | eDMA peripheral base address. |
void EDMA_GetDefaultConfig | ( | edma_config_t * | config | ) |
This function sets the configuration structure to a default value. The default configuration is set to the following value:
config | Pointer to eDMA configuration structure. |
void EDMA_ResetChannel | ( | DMA_Type * | base, |
uint32_t | channel | ||
) |
This function sets TCD registers for this channel to default value.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
void EDMA_SetTransferConfig | ( | DMA_Type * | base, |
uint32_t | channel, | ||
const edma_transfer_config_t * | config, | ||
edma_tcd_t * | nextTcd | ||
) |
This function configure the transfer attribute, including source address, destination address, transfer size, address offset, and so on. It also configures the scatter gather feature if the user supplies the TCD address. Example:
base | eDMA peripheral base address. |
channel | eDMA channel number. |
config | Pointer to eDMA transfer configuration structure. |
nextTcd | Point to TCD structure. It can be NULL if user do not want to enable scatter/gather feature. |
void EDMA_SetMinorOffsetConfig | ( | DMA_Type * | base, |
uint32_t | channel, | ||
const edma_minor_offset_config_t * | config | ||
) |
Minor offset means signed-extended value added to source address or destination address after each minor loop.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
config | Pointer to Minor offset configuration structure. |
|
inlinestatic |
This function configures the channel preemption attribute and the priority of the channel.
base | eDMA peripheral base address. |
channel | eDMA channel number |
config | Pointer to channel preemption configuration structure. |
void EDMA_SetChannelLink | ( | DMA_Type * | base, |
uint32_t | channel, | ||
edma_channel_link_type_t | type, | ||
uint32_t | linkedChannel | ||
) |
This function configures minor link or major link mode. The minor link means that the channel link is triggered every time CITER decreases by 1. The major link means that the channel link is triggered when the CITER is exhausted.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
type | Channel link type, it can be one of:
|
linkedChannel | The linked channel number. |
void EDMA_SetBandWidth | ( | DMA_Type * | base, |
uint32_t | channel, | ||
edma_bandwidth_t | bandWidth | ||
) |
In general, because the eDMA processes the minor loop, it continuously generates read/write sequences until the minor count is exhausted. The bandwidth forces the eDMA to stall after the completion of each read/write access to control the bus request bandwidth seen by the crossbar switch.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
bandWidth | Bandwidth setting, it can be one of:
|
void EDMA_SetModulo | ( | DMA_Type * | base, |
uint32_t | channel, | ||
edma_modulo_t | srcModulo, | ||
edma_modulo_t | destModulo | ||
) |
This function defines a specific address range specified to be the value after (SADDR + SOFF)/(DADDR + DOFF) calculation is performed or the original register value. It provides the ability to implement a circular data queue easily.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
srcModulo | Source modulo value. |
destModulo | Destination modulo value. |
|
inlinestatic |
If enabling the auto stop request, the eDMA hardware automatically disables the hardware channel request.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
enable | The command for enable (true) or disable (false). |
void EDMA_EnableChannelInterrupts | ( | DMA_Type * | base, |
uint32_t | channel, | ||
uint32_t | mask | ||
) |
base | eDMA peripheral base address. |
channel | eDMA channel number. |
mask | The mask of interrupt source to be set. User need to use the defined edma_interrupt_enable_t type. |
void EDMA_DisableChannelInterrupts | ( | DMA_Type * | base, |
uint32_t | channel, | ||
uint32_t | mask | ||
) |
base | eDMA peripheral base address. |
channel | eDMA channel number. |
mask | The mask of interrupt source to be set. Use the defined edma_interrupt_enable_t type. |
void EDMA_TcdReset | ( | edma_tcd_t * | tcd | ) |
This function sets all fields for this TCD structure to default value.
tcd | Pointer to the TCD structure. |
void EDMA_TcdSetTransferConfig | ( | edma_tcd_t * | tcd, |
const edma_transfer_config_t * | config, | ||
edma_tcd_t * | nextTcd | ||
) |
TCD is a transfer control descriptor. The content of the TCD is the same as hardware TCD registers. STCD is used in scatter-gather mode. This function configures the TCD transfer attribute, including source address, destination address, transfer size, address offset, and so on. It also configures the scatter gather feature if the user supplies the next TCD address. Example:
tcd | Pointer to the TCD structure. |
config | Pointer to eDMA transfer configuration structure. |
nextTcd | Pointer to the next TCD structure. It can be NULL if user do not want to enable scatter/gather feature. |
void EDMA_TcdSetMinorOffsetConfig | ( | edma_tcd_t * | tcd, |
const edma_minor_offset_config_t * | config | ||
) |
Minor offset is a signed-extended value added to the source address or destination address after each minor loop.
tcd | Point to the TCD structure. |
config | Pointer to Minor offset configuration structure. |
void EDMA_TcdSetChannelLink | ( | edma_tcd_t * | tcd, |
edma_channel_link_type_t | type, | ||
uint32_t | linkedChannel | ||
) |
This function configures either a minor link or a major link. The minor link means the channel link is triggered every time CITER decreases by 1. The major link means that the channel link is triggered when the CITER is exhausted.
tcd | Point to the TCD structure. |
type | Channel link type, it can be one of:
|
linkedChannel | The linked channel number. |
|
inlinestatic |
In general, because the eDMA processes the minor loop, it continuously generates read/write sequences until the minor count is exhausted. Bandwidth forces the eDMA to stall after the completion of each read/write access to control the bus request bandwidth seen by the crossbar switch.
tcd | Point to the TCD structure. |
bandWidth | Bandwidth setting, it can be one of:
|
void EDMA_TcdSetModulo | ( | edma_tcd_t * | tcd, |
edma_modulo_t | srcModulo, | ||
edma_modulo_t | destModulo | ||
) |
This function defines a specific address range specified to be the value after (SADDR + SOFF)/(DADDR + DOFF) calculation is performed or the original register value. It provides the ability to implement a circular data queue easily.
tcd | Point to the TCD structure. |
srcModulo | Source modulo value. |
destModulo | Destination modulo value. |
|
inlinestatic |
If enabling the auto stop request, the eDMA hardware automatically disables the hardware channel request.
tcd | Point to the TCD structure. |
enable | The command for enable(ture) or disable(false). |
void EDMA_TcdEnableInterrupts | ( | edma_tcd_t * | tcd, |
uint32_t | mask | ||
) |
tcd | Point to the TCD structure. |
mask | The mask of interrupt source to be set. User need to use the defined edma_interrupt_enable_t type. |
void EDMA_TcdDisableInterrupts | ( | edma_tcd_t * | tcd, |
uint32_t | mask | ||
) |
tcd | Point to the TCD structure. |
mask | The mask of interrupt source to be set. User need to use the defined edma_interrupt_enable_t type. |
|
inlinestatic |
This function enables the hardware channel request.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
|
inlinestatic |
This function disables the hardware channel request.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
|
inlinestatic |
This function starts a minor loop transfer.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
uint32_t EDMA_GetRemainingBytes | ( | DMA_Type * | base, |
uint32_t | channel | ||
) |
This function checks the TCD (Task Control Descriptor) status for a specified eDMA channel and returns the the number of bytes that have not finished.
base | eDMA peripheral base address. |
channel | eDMA channel number. |
|
inlinestatic |
base | eDMA peripheral base address. |
uint32_t EDMA_GetChannelStatusFlags | ( | DMA_Type * | base, |
uint32_t | channel | ||
) |
base | eDMA peripheral base address. |
channel | eDMA channel number. |
void EDMA_ClearChannelStatusFlags | ( | DMA_Type * | base, |
uint32_t | channel, | ||
uint32_t | mask | ||
) |
base | eDMA peripheral base address. |
channel | eDMA channel number. |
mask | The mask of channel status to be cleared. User need to use the defined _edma_channel_status_flags type. |
void EDMA_CreateHandle | ( | edma_handle_t * | handle, |
DMA_Type * | base, | ||
uint32_t | channel | ||
) |
This function is called if using transaction API for eDMA. This function initializes the internal state of eDMA handle.
handle | eDMA handle pointer. The eDMA handle stores callback function and parameters. |
base | eDMA peripheral base address. |
channel | eDMA channel number. |
void EDMA_InstallTCDMemory | ( | edma_handle_t * | handle, |
edma_tcd_t * | tcdPool, | ||
uint32_t | tcdSize | ||
) |
This function is called after the EDMA_CreateHandle to use scatter/gather feature.
handle | eDMA handle pointer. |
tcdPool | Memory pool to store TCDs. It must be 32 bytes aligned. |
tcdSize | The number of TCD slots. |
void EDMA_SetCallback | ( | edma_handle_t * | handle, |
edma_callback | callback, | ||
void * | userData | ||
) |
This callback is called in eDMA IRQ handler. Use the callback to do something after the current major loop transfer completes.
handle | eDMA handle pointer. |
callback | eDMA callback function pointer. |
userData | Parameter for callback function. |
void EDMA_PrepareTransfer | ( | edma_transfer_config_t * | config, |
void * | srcAddr, | ||
uint32_t | srcWidth, | ||
void * | destAddr, | ||
uint32_t | destWidth, | ||
uint32_t | bytesEachRequest, | ||
uint32_t | transferBytes, | ||
edma_transfer_type_t | type | ||
) |
This function prepares the transfer configuration structure according to the user input.
config | The user configuration structure of type edma_transfer_t. |
srcAddr | eDMA transfer source address. |
srcWidth | eDMA transfer source address width(bytes). |
destAddr | eDMA transfer destination address. |
destWidth | eDMA transfer destination address width(bytes). |
bytesEachRequest | eDMA transfer bytes per channel request. |
transferBytes | eDMA transfer bytes to be transferred. |
type | eDMA transfer type. |
status_t EDMA_SubmitTransfer | ( | edma_handle_t * | handle, |
const edma_transfer_config_t * | config | ||
) |
This function submits the eDMA transfer request according to the transfer configuration structure. If the user submits the transfer request repeatedly, this function packs an unprocessed request as a TCD and enables scatter/gather feature to process it in the next time.
handle | eDMA handle pointer. |
config | Pointer to eDMA transfer configuration structure. |
kStatus_EDMA_Success | It means submit transfer request succeed. |
kStatus_EDMA_QueueFull | It means TCD queue is full. Submit transfer request is not allowed. |
kStatus_EDMA_Busy | It means the given channel is busy, need to submit request later. |
void EDMA_StartTransfer | ( | edma_handle_t * | handle | ) |
This function enables the channel request. User can call this function after submitting the transfer request or before submitting the transfer request.
handle | eDMA handle pointer. |
void EDMA_StopTransfer | ( | edma_handle_t * | handle | ) |
This function disables the channel request to pause the transfer. User can call EDMA_StartTransfer() again to resume the transfer.
handle | eDMA handle pointer. |
void EDMA_AbortTransfer | ( | edma_handle_t * | handle | ) |
This function disables the channel request and clear transfer status bits. User can submit another transfer after calling this API.
handle | DMA handle pointer. |
void EDMA_HandleIRQ | ( | edma_handle_t * | handle | ) |
This function clears the channel major interrupt flag and call the callback function if it is not NULL.
handle | eDMA handle pointer. |