This file contains the prototype of EDMA driver APIs.
Please find the below detailed description of edma dal.
Go to the source code of this file.
Data Structures | |
struct | __attribute__ |
EDMA Parameter RAM Set in User Configurable format This is a mapping of the EDMA PaRAM set provided to the user for ease of modification of the individual fields. More... | |
struct | EDMA_ResourceObject |
EDMA resource allocation structure. More... | |
struct | EDMA_InitParams |
EDMA initialization structure used for EDMAInitialize. More... | |
struct | EDMA_Params |
EDMA open parameters passed to EDMA_open() function. More... | |
struct | Edma_IntrObject |
EDMA interrupt configuration object. The object is passed to the EDMA_registerIntr() function. This is held by the driver till the EDMA_unregisterIntr() function is called with this obect. The application should not modify this object in between. More... | |
struct | EDMA_Object |
EDMA driver object. More... | |
struct | EDMA_Attrs |
EDMA instance attributes - used during init time. More... | |
struct | EDMA_Config |
EDMA Instance Configuration. Pointer to this object is returned as handle by driver open. More... | |
Macros | |
#define | EDMA_SET_ALL_BITS ((uint32_t) 0xFFFFFFFFU) |
#define | EDMA_CLR_ALL_BITS ((uint32_t) 0x00000000U) |
#define | EDMACC_COMPL_HANDLER_RETRY_COUNT ((uint32_t) 10U) |
#define | EDMACC_ERR_HANDLER_RETRY_COUNT ((uint32_t) 10U) |
EDMA Queue Number Configuration. | |
#define | EDMACC_DMAQNUM_CLR(chNum) (~((uint32_t) 0x7U << (((chNum) % 8U) * 4U))) |
#define | EDMACC_DMAQNUM_SET(chNum, queNum) (((uint32_t) 0x7U & (queNum)) << (((chNum) % 8U) * 4U)) |
#define | EDMACC_QDMAQNUM_CLR(chNum) (~((uint32_t) 0x7U << ((chNum) * 4U))) |
#define | EDMACC_QDMAQNUM_SET(chNum, queNum) (((uint32_t) 0x7U & (queNum)) << ((chNum) * 4U)) |
EDMA Qdma Channel mapping Configuration. | |
#define | EDMACC_QCHMAP_PAENTRY_CLR ((uint32_t) (~((uint32_t)EDMA_TPCC_QCHMAPN_PAENTRY_MASK))) |
#define | EDMACC_QCHMAP_PAENTRY_SET(paRAMId) |
#define | EDMACC_QCHMAP_TRWORD_CLR ((uint32_t) (~((uint32_t)EDMA_TPCC_QCHMAPN_TRWORD_MASK))) |
#define | EDMACC_QCHMAP_TRWORD_SET(paRAMId) |
EDMA PaRAM BIDX configuration helper macros. | |
#define | EDMA_PARAM_BIDX(val) (val & 0xFFFF) |
#define | EDMA_PARAM_BIDX_EXT(val) ((val & 0xFF0000) >> 16) |
EDMA Trigger Mode Configuration. | |
#define | EDMA_TRIG_MODE_MANUAL ((uint32_t) 0U) |
#define | EDMA_TRIG_MODE_QDMA ((uint32_t) 1U) |
#define | EDMA_TRIG_MODE_EVENT ((uint32_t) 2U) |
EDMA channel type definitions. | |
#define | EDMA_CHANNEL_TYPE_DMA ((uint32_t) 0U) |
Values that can be used for parameter chType in API's. More... | |
#define | EDMA_CHANNEL_TYPE_QDMA ((uint32_t) 1U) |
EDMA event status definitions. | |
#define | EDMA_XFER_COMPLETE ((uint32_t) 0U) |
Values that can be used to specify different event status. More... | |
#define | EDMA_CC_DMA_EVT_MISS ((uint32_t) 1U) |
#define | EDMA_CC_QDMA_EVT_MISS ((uint32_t) 2U) |
EDMA transfer type definitions. | |
#define | EDMA_SYNC_A ((uint32_t) 0U) |
Values that can be used to specify different synchronization events. More... | |
#define | EDMA_SYNC_AB ((uint32_t) 1U) |
EDMA addressing modes definitions. | |
#define | EDMA_ADDRESSING_MODE_LINEAR ((uint32_t) 0U) |
Values that can be used to specify different addressing modes (relevant for SAM and DAM sub-fields in OPT field). More... | |
#define | EDMA_ADDRESSING_MODE_FIFO_WRAP ((uint32_t) 1U) |
EDMA FIFO width definitions. | |
#define | EDMA_FIFO_WIDTH_8BIT ((uint32_t) EDMA_TPCC_OPT_FWID_FIFOWIDTH8BIT) |
Values that can be used to specify different FIFO widths (FWID in OPT field). More... | |
#define | EDMA_FIFO_WIDTH_16BIT ((uint32_t) EDMA_TPCC_OPT_FWID_FIFOWIDTH16BIT) |
#define | EDMA_FIFO_WIDTH_32BIT ((uint32_t) EDMA_TPCC_OPT_FWID_FIFOWIDTH32BIT) |
#define | EDMA_FIFO_WIDTH_64BIT ((uint32_t) EDMA_TPCC_OPT_FWID_FIFOWIDTH64BIT) |
#define | EDMA_FIFO_WIDTH_128BIT ((uint32_t) EDMA_TPCC_OPT_FWID_FIFOWIDTH128BIT) |
#define | EDMA_FIFO_WIDTH_256BIT ((uint32_t) DMA_TPCC_OPT_FWID_FIFOWIDTH256BIT) |
EDMA Clear Channel controller Error. | |
#define | EDMACC_CLR_TCCERR ((uint32_t) EDMA_TPCC_CCERRCLR_TCERR_MASK) |
Values that can be used to Clear any Channel controller Errors. More... | |
#define | EDMACC_CLR_QTHRQ0 ((uint32_t) EDMA_TPCC_CCERRCLR_QTHRXCD0_MASK) |
#define | EDMACC_CLR_QTHRQ1 ((uint32_t) EDMA_TPCC_CCERRCLR_QTHRXCD1_MASK) |
EDMA Param OPT fields. | |
#define | EDMA_OPT_TCCHEN_MASK ((uint32_t) EDMA_TPCC_OPT_TCCHEN_MASK) |
Values that are used to Chain two specified channels. More... | |
#define | EDMA_OPT_ITCCHEN_MASK ((uint32_t) EDMA_TPCC_OPT_ITCCHEN_MASK) |
#define | EDMA_OPT_TCINTEN_MASK ((uint32_t) EDMA_TPCC_OPT_TCINTEN_MASK) |
#define | EDMA_OPT_ITCINTEN_MASK ((uint32_t) EDMA_TPCC_OPT_ITCINTEN_MASK) |
#define | EDMA_OPT_TCC_MASK ((uint32_t) EDMA_TPCC_OPT_TCC_MASK) |
#define | EDMA_OPT_TCC_SHIFT ((uint32_t) EDMA_TPCC_OPT_TCC_SHIFT) |
#define | EDMA_OPT_SYNCDIM_MASK ((uint32_t) EDMA_TPCC_OPT_SYNCDIM_MASK) |
#define | EDMA_OPT_SYNCDIM_SHIFT ((uint32_t) EDMA_TPCC_OPT_SYNCDIM_SHIFT) |
#define | EDMA_OPT_STATIC_MASK ((uint32_t) EDMA_TPCC_OPT_STATIC_MASK) |
#define | EDMA_OPT_STATIC_SHIFT ((uint32_t) EDMA_TPCC_OPT_STATIC_SHIFT) |
#define | EDMACC_OPT_TCC_CLR ((uint32_t) (~EDMA_TPCC_OPT_TCC_MASK)) |
#define | EDMACC_OPT_TCC_SET(tcc) |
#define | EDMA_OPT_SAM_MASK ((uint32_t) EDMA_TPCC_OPT_SAM_MASK) |
#define | EDMA_OPT_SAM_SHIFT ((uint32_t) EDMA_TPCC_OPT_SAM_SHIFT) |
#define | EDMA_OPT_DAM_MASK ((uint32_t) EDMA_TPCC_OPT_DAM_SHIFT) |
#define | EDMA_OPT_DAM_SHIFT ((uint32_t) EDMA_TPCC_OPT_DAM_SHIFT) |
EDMA Param fields. | |
#define | EDMACC_PARAM_ENTRY_OPT ((uint32_t) 0x0U) |
PaRAMEntry Fields. More... | |
#define | EDMACC_PARAM_ENTRY_SRC ((uint32_t) 0x1U) |
#define | EDMACC_PARAM_ENTRY_ACNT_BCNT ((uint32_t) 0x2U) |
#define | EDMACC_PARAM_ENTRY_DST ((uint32_t) 0x3U) |
#define | EDMACC_PARAM_ENTRY_SRC_DST_BIDX ((uint32_t) 0x4U) |
#define | EDMACC_PARAM_ENTRY_LINK_BCNTRLD ((uint32_t) 0x5U) |
#define | EDMACC_PARAM_ENTRY_SRC_DST_CIDX ((uint32_t) 0x6U) |
#define | EDMACC_PARAM_ENTRY_CCNT ((uint32_t) 0x7U) |
#define | EDMACC_PARAM_FIELD_OFFSET ((uint32_t) 0x4U) |
#define | EDMACC_PARAM_ENTRY_FIELDS ((uint32_t) 0x8U) |
#define | EDMA_NUM_TCC ((uint32_t) SOC_EDMA_NUM_DMACH) |
EDMA resource type definition used for resource allocation and freeing. | |
#define | EDMA_RESOURCE_TYPE_DMA ((uint32_t) 0U) |
Values that can be used for parameter resType in API's. More... | |
#define | EDMA_RESOURCE_TYPE_QDMA ((uint32_t) 1U) |
#define | EDMA_RESOURCE_TYPE_TCC ((uint32_t) 2U) |
#define | EDMA_RESOURCE_TYPE_PARAM ((uint32_t) 3U) |
#define | EDMA_RESOURCE_ALLOC_ANY ((uint32_t) 0xFFFFU) |
Typedefs | |
typedef struct Edma_IntrObject_t * | Edma_IntrHandle |
EDMA interrupt handle returned from EDMA_registerIntr() function. More... | |
typedef void(* | Edma_EventCallback) (Edma_IntrHandle intrHandle, void *appData) |
EDMA interrupt callback function prototype. More... | |
typedef void * | EDMA_Handle |
A handle that is returned from a EDMA_open() call. More... | |
Functions | |
void | EDMA_initParamsInit (EDMA_InitParams *initParam) |
Structure initialization function for EDMA_InitParams. More... | |
void | EDMA_ccPaRAMEntry_init (EDMACCPaRAMEntry *paramEntry) |
Clear a PaRAM Set . More... | |
void | EDMA_enableChInShadowRegRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chType, uint32_t chNum) |
Enable channel to Shadow region mapping. More... | |
void | EDMA_disableChInShadowRegRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chType, uint32_t chNum) |
Disable channel to Shadow region mapping. More... | |
void | EDMA_channelToParamMap (uint32_t baseAddr, uint32_t channel, uint32_t paramSet) |
This function maps DMA channel to any of the PaRAM sets in the PaRAM memory map. More... | |
void | EDMA_mapChToEvtQ (uint32_t baseAddr, uint32_t chType, uint32_t chNum, uint32_t evtQNum) |
Map channel to Event Queue. More... | |
void | EDMA_unmapChToEvtQ (uint32_t baseAddr, uint32_t chType, uint32_t chNum) |
Remove Mapping of channel to Event Queue. More... | |
void | EDMA_mapQdmaChToPaRAM (uint32_t baseAddr, uint32_t chNum, const uint32_t *paRAMId) |
Enables the user to map a QDMA channel to PaRAM set This API Needs to be called before programming the paRAM sets for the QDMA Channels.Application needs to maitain the paRAMId provided by this API.This paRAMId is used to set paRAM and get paRAM. Refer corresponding API's for more details. More... | |
uint32_t | EDMA_getMappedPaRAM (uint32_t baseAddr, uint32_t chNum, uint32_t chType, uint32_t *paramId) |
Returns the PaRAM associated with the DMA/QDMA channel. More... | |
void | EDMA_setQdmaTrigWord (uint32_t baseAddr, uint32_t chNum, uint32_t trigWord) |
Assign a Trigger Word to the specified QDMA channel. More... | |
void | EDMA_clrMissEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to Clear any missed event. More... | |
void | EDMA_qdmaClrMissEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to Clear any QDMA missed event. More... | |
void | EDMA_clrCCErr (uint32_t baseAddr, uint32_t flags) |
Enables the user to Clear any Channel controller Errors. More... | |
void | EDMA_setEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to Set an event. This API helps user to manually set events to initiate DMA transfer requests. More... | |
void | EDMA_clrEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to Clear an event. More... | |
void | EDMA_enableDmaEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to enable an DMA event. More... | |
void | EDMA_disableDmaEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to Disable an DMA event. More... | |
void | EDMA_enableQdmaEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to enable an QDMA event. More... | |
void | EDMA_disableQdmaEvtRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to disable an QDMA event. More... | |
uint32_t | EDMA_getIntrStatusRegion (uint32_t baseAddr, uint32_t regionId) |
This function returns interrupts status of those events which is less than 32. More... | |
void | EDMA_enableEvtIntrRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to enable the transfer completion interrupt generation by the EDMACC for all DMA/QDMA channels. More... | |
void | EDMA_disableEvtIntrRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum) |
Enables the user to clear CC interrupts. More... | |
void | EDMA_clrIntrRegion (uint32_t baseAddr, uint32_t regionId, uint32_t value) |
Enables the user to Clear an Interrupt. More... | |
uint32_t | EDMA_getEnabledIntrRegion (uint32_t baseAddr, uint32_t regionId) |
This function returns interrupt enable status of events which are less than 32. More... | |
uint32_t | EDMA_getEnabledIntrHighRegion (uint32_t baseAddr, uint32_t regionId) |
This function returns interrupt enable status of events which are more than 32. More... | |
void | EDMA_getPaRAM (uint32_t baseAddr, uint32_t paRAMId, EDMACCPaRAMEntry *currPaRAM) |
Retrieve existing PaRAM set associated with specified logical channel (DMA/Link). More... | |
void | EDMA_qdmaGetPaRAM (uint32_t baseAddr, uint32_t paRAMId, EDMACCPaRAMEntry *currPaRAM) |
Retrieve existing PaRAM set associated with specified logical channel (QDMA). More... | |
void | EDMA_setPaRAM (uint32_t baseAddr, uint32_t paRAMId, const EDMACCPaRAMEntry *newPaRAM) |
Copy the user specified PaRAM Set onto the PaRAM Set associated with the logical channel (DMA/Link). More... | |
void | EDMA_qdmaSetPaRAM (uint32_t baseAddr, uint32_t paRAMId, const EDMACCPaRAMEntry *newPaRAM) |
Copy the user specified PaRAM Set onto the PaRAM Set associated with the logical channel (QDMA only). More... | |
void | EDMA_qdmaSetPaRAMEntry (uint32_t baseAddr, uint32_t paRAMId, uint32_t paRAMEntry, uint32_t newPaRAMEntryVal) |
Set a particular PaRAM set entry of the specified PaRAM set. More... | |
uint32_t | EDMA_qdmaGetPaRAMEntry (uint32_t baseAddr, uint32_t paRAMId, uint32_t paRAMEntry) |
Get a particular PaRAM entry of the specified PaRAM set. More... | |
void | EDMA_dmaSetPaRAMEntry (uint32_t baseAddr, uint32_t paRAMId, uint32_t paRAMEntry, uint32_t newPaRAMEntryVal) |
Set a particular PaRAM set entry of the specified PaRAM set. More... | |
uint32_t | EDMA_dmaGetPaRAMEntry (uint32_t baseAddr, uint32_t paRAMId, uint32_t paRAMEntry) |
Get a particular PaRAM entry of the specified PaRAM set. More... | |
uint32_t | EDMA_configureChannelRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chType, uint32_t chNum, uint32_t tccNum, uint32_t paramId, uint32_t evtQNum) |
Request a DMA/QDMA/Link channel. More... | |
uint32_t | EDMA_freeChannelRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chType, uint32_t chNum, uint32_t trigMode, uint32_t tccNum, uint32_t evtQNum) |
Free the specified channel (DMA/QDMA/Link) and its associated resources (PaRAM Set, TCC etc) and removes various mappings. More... | |
uint32_t | EDMA_enableTransferRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum, uint32_t trigMode) |
Start EDMA transfer on the specified channel. More... | |
uint32_t | EDMA_disableTransferRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum, uint32_t trigMode) |
Disable DMA transfer on the specified channel. More... | |
void | EDMA_clearErrorBitsRegion (uint32_t baseAddr, uint32_t regionId, uint32_t chNum, uint32_t evtQNum) |
Clears Event Register and Error Register for a specific DMA channel and brings back EDMA to its initial state. More... | |
uint32_t | EDMA_getCCErrStatus (uint32_t baseAddr) |
This returns EDMA CC error status. More... | |
uint32_t | EDMA_getErrIntrStatus (uint32_t baseAddr) |
This returns error interrupt status for those events whose event number is less than 32. More... | |
uint32_t | EDMA_qdmaGetErrIntrStatus (uint32_t baseAddr) |
This returns QDMA error interrupt status. More... | |
uint32_t | EDMA_peripheralIdGet (uint32_t baseAddr) |
This API return the revision Id of the peripheral. More... | |
uint32_t | EDMA_intrStatusHighGetRegion (uint32_t baseAddr, uint32_t regionId) |
This function returns interrupt status of those events which are greater than 32. More... | |
uint32_t | EDMA_readIntrStatusRegion (uint32_t baseAddr, uint32_t regionId, uint32_t tccNum) |
This function reads interrupt status. More... | |
uint32_t | EDMA_getEventStatus (uint32_t baseAddr) |
This function returns status of those events which are less than 32. More... | |
uint32_t | EDMA_getEventStatusHigh (uint32_t baseAddr) |
This function returns status of those events which are greater than 32. More... | |
uint32_t | EDMA_readEventStatusRegion (uint32_t baseAddr, uint32_t chNum) |
This function reads Event pending status. More... | |
uint32_t | EDMA_errIntrHighStatusGet (uint32_t baseAddr) |
This returns error interrupt status for those events whose event number is greater than 32. More... | |
void | EDMA_chainChannel (uint32_t baseAddr, uint32_t paRAMId1, uint32_t chId2, uint32_t chainOptions) |
Chain the two specified channels. More... | |
void | EDMA_linkChannel (uint32_t baseAddr, uint32_t paRAMId1, uint32_t paRAMId2) |
Link two channels. More... | |
void | EDMA_init (void) |
This function initializes the EDMA driver object and controller. More... | |
void | EDMA_deinit (void) |
This function Deinitializes the EDMA driver object and controller. More... | |
uint32_t | EDMA_isInitialized (EDMA_Handle handle) |
Function to check if EDMA is enabled or not. More... | |
EDMA_Handle | EDMA_open (uint32_t index, const EDMA_Params *prms) |
This function opens a given EDMA instance. More... | |
EDMA_Handle | EDMA_getHandle (uint32_t index) |
This function returns the handle of an open EDMA Instance from the instance index. More... | |
void | EDMA_close (EDMA_Handle handle) |
Function to close a EDMA peripheral specified by the EDMA handle. More... | |
uint32_t | EDMA_isInterruptEnabled (EDMA_Handle handle) |
Function to check if EDMA interrupt is enabled. More... | |
int32_t | EDMA_registerIntr (EDMA_Handle handle, Edma_IntrObject *intrObj) |
Function to register callback function for a TCC. More... | |
int32_t | EDMA_unregisterIntr (EDMA_Handle handle, Edma_IntrObject *intrObj) |
Function to unregister callback function for a TCC. More... | |
uint32_t | EDMA_getBaseAddr (EDMA_Handle handle) |
Function to get the edma base address. More... | |
uint32_t | EDMA_getRegionId (EDMA_Handle handle) |
Function to get the edma region. More... | |
int32_t | EDMA_allocDmaChannel (EDMA_Handle handle, uint32_t *dmaCh) |
Function to allocate the Dma Channel. More... | |
int32_t | EDMA_allocQdmaChannel (EDMA_Handle handle, uint32_t *qdmaCh) |
Function to allocate the Dma Channel. More... | |
int32_t | EDMA_allocTcc (EDMA_Handle handle, uint32_t *tcc) |
Function to allocate the Qdma Channel. More... | |
int32_t | EDMA_allocParam (EDMA_Handle handle, uint32_t *param) |
Function to allocate the TCC. More... | |
int32_t | EDMA_freeDmaChannel (EDMA_Handle handle, uint32_t *dmaCh) |
Function to free the Dma Channel. More... | |
int32_t | EDMA_freeQdmaChannel (EDMA_Handle handle, uint32_t *qdmaCh) |
Function to free the Qdma Channel. More... | |
int32_t | EDMA_freeTcc (EDMA_Handle handle, uint32_t *tcc) |
Function to free the tcc Channel. More... | |
int32_t | EDMA_freeParam (EDMA_Handle handle, uint32_t *param) |
Function to free the Param. More... | |
Variables | |
EDMA_Config | gEdmaConfig [] |
Externally defined driver configuration array. More... | |
uint32_t | gEdmaConfigNum |
Externally defined driver configuration array size. More... | |
EDMA_InitParams | gEdmaInitParams [] |
Externally defined driver init parameters array. More... | |