Functions | |
cy_en_dmac_status_t | Cy_DMAC_Descriptor_Init (cy_stc_dmac_descriptor_t *descriptor, cy_stc_dmac_descriptor_config_t const *config) |
Initializes the descriptor structure in SRAM from a pre-initialized configuration structure. More... | |
void | Cy_DMAC_Descriptor_DeInit (cy_stc_dmac_descriptor_t *descriptor) |
Clears the content of the specified descriptor. More... | |
void | Cy_DMAC_Descriptor_SetNextDescriptor (cy_stc_dmac_descriptor_t *descriptor, cy_stc_dmac_descriptor_t const *nextDescriptor) |
Sets a Next Descriptor parameter for the specified descriptor. More... | |
void | Cy_DMAC_Descriptor_SetDescriptorType (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_descriptor_type_t descriptorType) |
Sets the descriptor's type for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetSrcAddress (cy_stc_dmac_descriptor_t *descriptor, void const *srcAddress) |
Sets the source address parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetDstAddress (cy_stc_dmac_descriptor_t *descriptor, void const *dstAddress) |
Sets the destination address parameter for the specified descriptor. More... | |
void | Cy_DMAC_Descriptor_SetXloopDataCount (cy_stc_dmac_descriptor_t *descriptor, uint32_t xCount) |
Sets the number of data elements to transfer in the X loop for the specified descriptor (for all descriptor types except single transfer). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetYloopDataCount (cy_stc_dmac_descriptor_t *descriptor, uint32_t yCount) |
Sets the number of data elements for the Y loop of the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetXloopSrcIncrement (cy_stc_dmac_descriptor_t *descriptor, int32_t srcXincrement) |
Sets the source increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetXloopDstIncrement (cy_stc_dmac_descriptor_t *descriptor, int32_t dstXincrement) |
Sets the destination increment parameter for the X loop for the specified descriptor (for 1D or 2D descriptors only). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetYloopSrcIncrement (cy_stc_dmac_descriptor_t *descriptor, int32_t srcYincrement) |
Sets the source increment parameter for the Y loop for the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetYloopDstIncrement (cy_stc_dmac_descriptor_t *descriptor, int32_t dstYincrement) |
Sets the destination increment parameter for the Y loop of the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetInterruptType (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_trigger_type_t interruptType) |
Sets the interrupt type parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetTriggerInType (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_trigger_type_t triggerInType) |
Sets the Trigger In Type parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetTriggerOutType (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_trigger_type_t triggerOutType) |
Sets the Trigger Out Type parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetDataSize (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_data_size_t dataSize) |
Sets the Data Element Size parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetSrcTransferSize (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_transfer_size_t srcTransferSize) |
Sets the Source Transfer Size parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetDstTransferSize (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_transfer_size_t dstTransferSize) |
Sets the Destination Transfer Size parameter for the specified descriptor. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetRetrigger (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_retrigger_t retrigger) |
Sets the retrigger value which specifies whether the controller should wait for the input trigger to be deactivated. More... | |
__STATIC_INLINE void | Cy_DMAC_Descriptor_SetChannelState (cy_stc_dmac_descriptor_t *descriptor, cy_en_dmac_channel_state_t channelState) |
Sets the channel state on completion of the specified descriptor. More... | |
cy_stc_dmac_descriptor_t * | Cy_DMAC_Descriptor_GetNextDescriptor (cy_stc_dmac_descriptor_t const *descriptor) |
Returns a next descriptor address of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_descriptor_type_t | Cy_DMAC_Descriptor_GetDescriptorType (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the descriptor's type of the specified descriptor. More... | |
__STATIC_INLINE void * | Cy_DMAC_Descriptor_GetSrcAddress (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the source address of the specified descriptor. More... | |
__STATIC_INLINE void * | Cy_DMAC_Descriptor_GetDstAddress (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the destination address of the specified descriptor. More... | |
uint32_t | Cy_DMAC_Descriptor_GetXloopDataCount (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the number of data elements for the X loop of the specified descriptor (for all descriptor types except single transfer). More... | |
__STATIC_INLINE uint32_t | Cy_DMAC_Descriptor_GetYloopDataCount (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the number of X loops to execute in the Y loop of the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE int32_t | Cy_DMAC_Descriptor_GetXloopSrcIncrement (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the source increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only). More... | |
__STATIC_INLINE int32_t | Cy_DMAC_Descriptor_GetXloopDstIncrement (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the destination increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only). More... | |
__STATIC_INLINE int32_t | Cy_DMAC_Descriptor_GetYloopSrcIncrement (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the source increment parameter for the Y loop of the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE int32_t | Cy_DMAC_Descriptor_GetYloopDstIncrement (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the destination increment parameter for the Y loop of the specified descriptor (for 2D descriptors only). More... | |
__STATIC_INLINE cy_en_dmac_trigger_type_t | Cy_DMAC_Descriptor_GetInterruptType (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Interrupt-Type of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_trigger_type_t | Cy_DMAC_Descriptor_GetTriggerInType (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Trigger In Type of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_trigger_type_t | Cy_DMAC_Descriptor_GetTriggerOutType (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Trigger Out Type of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_data_size_t | Cy_DMAC_Descriptor_GetDataSize (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Data Element Size of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_transfer_size_t | Cy_DMAC_Descriptor_GetSrcTransferSize (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Source Transfer Size of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_transfer_size_t | Cy_DMAC_Descriptor_GetDstTransferSize (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the Destination Transfer Size of the specified descriptor. More... | |
__STATIC_INLINE cy_en_dmac_retrigger_t | Cy_DMAC_Descriptor_GetRetrigger (cy_stc_dmac_descriptor_t const *descriptor) |
Returns a value which specifies whether the controller should wait for the input trigger to be deactivated. More... | |
__STATIC_INLINE cy_en_dmac_channel_state_t | Cy_DMAC_Descriptor_GetChannelState (cy_stc_dmac_descriptor_t const *descriptor) |
Returns the channel state on completion of the specified descriptor. More... | |
cy_en_dmac_status_t Cy_DMAC_Descriptor_Init | ( | cy_stc_dmac_descriptor_t * | descriptor, |
const cy_stc_dmac_descriptor_config_t * | config | ||
) |
Initializes the descriptor structure in SRAM from a pre-initialized configuration structure.
This function initializes only the descriptor and not the channel.
descriptor | The descriptor structure instance. |
config | This is a configuration structure that has all initialization information for the descriptor. |
void Cy_DMAC_Descriptor_DeInit | ( | cy_stc_dmac_descriptor_t * | descriptor | ) |
Clears the content of the specified descriptor.
descriptor | The descriptor structure instance. |
void Cy_DMAC_Descriptor_SetNextDescriptor | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_stc_dmac_descriptor_t const * | nextDescriptor | ||
) |
Sets a Next Descriptor parameter for the specified descriptor.
Based on the descriptor type, the offset of the address for the next descriptor register may vary: For the single and scatter transfer descriptors, this register is at offset 0x0c. For the memory copy descriptor type, this register is at offset 0x10. For the 1D-transfer descriptor type, this register is at offset 0x14. For the 2D-transfer descriptor type, this register is at offset 0x1c.
descriptor | The descriptor structure instance. |
nextDescriptor | The pointer to the next descriptor. For CAT1C devices this pointer needs to point to 32 byte aligned structure. |
void Cy_DMAC_Descriptor_SetDescriptorType | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_descriptor_type_t | descriptorType | ||
) |
Sets the descriptor's type for the specified descriptor.
Moves the next descriptor pointer and X data count values into the proper offset in accordance to the actual descriptor type.
During the descriptor's type change, carefully set up the settings starting from dstAddress and all the rest below in the cy_stc_dmac_descriptor_config_t structure. This is because the content of the descriptor registers might be lost/overridden by other descriptor settings due to the different registers structure for different descriptor types.
descriptor | The descriptor structure instance. |
descriptorType | The descriptor type cy_en_dmac_descriptor_type_t. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetSrcAddress | ( | cy_stc_dmac_descriptor_t * | descriptor, |
void const * | srcAddress | ||
) |
Sets the source address parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
srcAddress | The source address value for the descriptor. For CAT1C devices this pointer needs to point to 32 byte aligned structure. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetDstAddress | ( | cy_stc_dmac_descriptor_t * | descriptor, |
void const * | dstAddress | ||
) |
Sets the destination address parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
dstAddress | The destination address value for the descriptor. For CAT1C devices this pointer needs to point to 32 byte aligned structure. |
void Cy_DMAC_Descriptor_SetXloopDataCount | ( | cy_stc_dmac_descriptor_t * | descriptor, |
uint32_t | xCount | ||
) |
Sets the number of data elements to transfer in the X loop for the specified descriptor (for all descriptor types except single transfer).
Based on the descriptor type, the offset of the address for the xCount register may vary: For the scatter transfer descriptors type, this register is at offset 0x8. For all the rest of the supported descriptor types, this register is at offset 0xc.
descriptor | The descriptor structure instance. |
xCount | The number of data elements to transfer in the X loop. For scatter transfer descriptors the valid range is 1...32768. For all the rest of the descriptors (except single transfer), the valid range is 1...65536. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetYloopDataCount | ( | cy_stc_dmac_descriptor_t * | descriptor, |
uint32_t | yCount | ||
) |
Sets the number of data elements for the Y loop of the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
yCount | The number of X loops to execute in the Y loop. The valid range is 1 ... 65536. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetXloopSrcIncrement | ( | cy_stc_dmac_descriptor_t * | descriptor, |
int32_t | srcXincrement | ||
) |
Sets the source increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only).
descriptor | The descriptor structure instance. |
srcXincrement | The value of the source increment. The valid range is -32768 ... 32767. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetXloopDstIncrement | ( | cy_stc_dmac_descriptor_t * | descriptor, |
int32_t | dstXincrement | ||
) |
Sets the destination increment parameter for the X loop for the specified descriptor (for 1D or 2D descriptors only).
descriptor | The descriptor structure instance. |
dstXincrement | The value of the destination increment. The valid range is -32768 ... 32767. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetYloopSrcIncrement | ( | cy_stc_dmac_descriptor_t * | descriptor, |
int32_t | srcYincrement | ||
) |
Sets the source increment parameter for the Y loop for the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
srcYincrement | The value of the source increment. The valid range is -32768 ... 32767. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetYloopDstIncrement | ( | cy_stc_dmac_descriptor_t * | descriptor, |
int32_t | dstYincrement | ||
) |
Sets the destination increment parameter for the Y loop of the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
dstYincrement | The value of the destination increment. The valid range is -32768 ... 32767. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetInterruptType | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_trigger_type_t | interruptType | ||
) |
Sets the interrupt type parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
interruptType | The interrupt type set for the descriptor. cy_en_dmac_trigger_type_t |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetTriggerInType | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_trigger_type_t | triggerInType | ||
) |
Sets the Trigger In Type parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
triggerInType | The Trigger In Type parameter cy_en_dmac_trigger_type_t |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetTriggerOutType | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_trigger_type_t | triggerOutType | ||
) |
Sets the Trigger Out Type parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
triggerOutType | The Trigger Out Type set for the descriptor. cy_en_dmac_trigger_type_t |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetDataSize | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_data_size_t | dataSize | ||
) |
Sets the Data Element Size parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
dataSize | The Data Element Size cy_en_dmac_data_size_t |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetSrcTransferSize | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_transfer_size_t | srcTransferSize | ||
) |
Sets the Source Transfer Size parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
srcTransferSize | The Source Transfer Size cy_en_dmac_transfer_size_t. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetDstTransferSize | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_transfer_size_t | dstTransferSize | ||
) |
Sets the Destination Transfer Size parameter for the specified descriptor.
descriptor | The descriptor structure instance. |
dstTransferSize | The Destination Transfer Size cy_en_dmac_transfer_size_t. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetRetrigger | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_retrigger_t | retrigger | ||
) |
Sets the retrigger value which specifies whether the controller should wait for the input trigger to be deactivated.
descriptor | The descriptor structure instance. |
retrigger | The cy_en_dmac_retrigger_t parameter specifies whether the controller should wait for the input trigger to be deactivated. |
__STATIC_INLINE void Cy_DMAC_Descriptor_SetChannelState | ( | cy_stc_dmac_descriptor_t * | descriptor, |
cy_en_dmac_channel_state_t | channelState | ||
) |
Sets the channel state on completion of the specified descriptor.
descriptor | The descriptor structure instance. |
channelState | The channel state cy_en_dmac_channel_state_t. |
cy_stc_dmac_descriptor_t* Cy_DMAC_Descriptor_GetNextDescriptor | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns a next descriptor address of the specified descriptor.
Based on the descriptor type, the offset of the address for the next descriptor register may vary: For the single and scatter transfer descriptors, this register is at offset 0x0c. For the memory copy descriptor type, this register is at offset 0x10. For the 1D-transfer descriptor type, this register is at offset 0x14. For the 2D-transfer descriptor type, this register is at offset 0x1c.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_descriptor_type_t Cy_DMAC_Descriptor_GetDescriptorType | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the descriptor's type of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE void * Cy_DMAC_Descriptor_GetSrcAddress | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the source address of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE void * Cy_DMAC_Descriptor_GetDstAddress | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the destination address of the specified descriptor.
descriptor | The descriptor structure instance. |
uint32_t Cy_DMAC_Descriptor_GetXloopDataCount | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the number of data elements for the X loop of the specified descriptor (for all descriptor types except single transfer).
Based on the descriptor type, the offset of the address for the xCount register may vary: For the scatter transfer descriptors type, this register is at offset 0x8. For all the rest supported descriptor types, this register is at offset 0xc.
descriptor | The descriptor structure instance. |
__STATIC_INLINE uint32_t Cy_DMAC_Descriptor_GetYloopDataCount | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the number of X loops to execute in the Y loop of the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
__STATIC_INLINE int32_t Cy_DMAC_Descriptor_GetXloopSrcIncrement | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the source increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only).
descriptor | The descriptor structure instance. |
__STATIC_INLINE int32_t Cy_DMAC_Descriptor_GetXloopDstIncrement | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the destination increment parameter for the X loop of the specified descriptor (for 1D or 2D descriptors only).
descriptor | The descriptor structure instance. |
__STATIC_INLINE int32_t Cy_DMAC_Descriptor_GetYloopSrcIncrement | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the source increment parameter for the Y loop of the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
__STATIC_INLINE int32_t Cy_DMAC_Descriptor_GetYloopDstIncrement | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the destination increment parameter for the Y loop of the specified descriptor (for 2D descriptors only).
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_trigger_type_t Cy_DMAC_Descriptor_GetInterruptType | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Interrupt-Type of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_trigger_type_t Cy_DMAC_Descriptor_GetTriggerInType | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Trigger In Type of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_trigger_type_t Cy_DMAC_Descriptor_GetTriggerOutType | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Trigger Out Type of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_data_size_t Cy_DMAC_Descriptor_GetDataSize | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Data Element Size of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_transfer_size_t Cy_DMAC_Descriptor_GetSrcTransferSize | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Source Transfer Size of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_transfer_size_t Cy_DMAC_Descriptor_GetDstTransferSize | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the Destination Transfer Size of the specified descriptor.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_retrigger_t Cy_DMAC_Descriptor_GetRetrigger | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns a value which specifies whether the controller should wait for the input trigger to be deactivated.
descriptor | The descriptor structure instance. |
__STATIC_INLINE cy_en_dmac_channel_state_t Cy_DMAC_Descriptor_GetChannelState | ( | cy_stc_dmac_descriptor_t const * | descriptor | ) |
Returns the channel state on completion of the specified descriptor.
descriptor | The descriptor structure instance. |