mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-25 01:07:21 +08:00
343 lines
13 KiB
C
343 lines
13 KiB
C
/**
|
|
*********************************************************************************
|
|
*
|
|
* @file ald_dma.h
|
|
* @brief DMA module Library.
|
|
*
|
|
* @version V1.0
|
|
* @date 16 Feb. 2023
|
|
* @author AE Team
|
|
* @note
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 16 Feb. 2023 AE Team The first version
|
|
*
|
|
* Copyright (C) Shanghai Eastsoft Microelectronics Co. Ltd. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the License); you may
|
|
* not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
**********************************************************************************
|
|
*/
|
|
|
|
#ifndef __ALD_DMA_H__
|
|
#define __ALD_DMA_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif /* __cplusplus */
|
|
|
|
#include "ald_utils.h"
|
|
|
|
/** @addtogroup ES32VF2264_ALD
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup DMA
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @defgroup DMA_Public_Macros DMA Public Macros
|
|
* @{
|
|
*/
|
|
#define ALD_DMA_CH_COUNT 7U
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @defgroup DMA_Public_Types DMA Public Types
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @brief Input source to DMA channel
|
|
*/
|
|
typedef enum {
|
|
ALD_DMA_MSEL_NONE = 0x0U, /**< NONE */
|
|
ALD_DMA_MSEL_GPIO = 0x1U, /**< GPIO */
|
|
ALD_DMA_MSEL_ADC = 0x2U, /**< ADC */
|
|
ALD_DMA_MSEL_CRC = 0x3U, /**< CRC */
|
|
ALD_DMA_MSEL_EUART0 = 0x4U, /**< EUART0 */
|
|
ALD_DMA_MSEL_EUART1 = 0x5U, /**< EUART1 */
|
|
ALD_DMA_MSEL_CUART0 = 0x6U, /**< CUART0 */
|
|
ALD_DMA_MSEL_CUART1 = 0x7U, /**< CUART1 */
|
|
ALD_DMA_MSEL_CUART2 = 0x8U, /**< CUART2 */
|
|
ALD_DMA_MSEL_SPI0 = 0x9U, /**< SPI0 */
|
|
ALD_DMA_MSEL_SPI1 = 0xAU, /**< SPI1 */
|
|
ALD_DMA_MSEL_I2C0 = 0xBU, /**< I2C0 */
|
|
ALD_DMA_MSEL_I2C1 = 0xCU, /**< I2C1 */
|
|
ALD_DMA_MSEL_AD16C4T = 0xDU, /**< AD16C4T */
|
|
ALD_DMA_MSEL_GP16C4T0= 0xEU, /**< GP16C4T0 */
|
|
ALD_DMA_MSEL_GP16C4T1= 0xFU, /**< GP16C4T1 */
|
|
ALD_DMA_MSEL_GP16C4T2= 0x10U, /**< GP16C4T2 */
|
|
ALD_DMA_MSEL_PIS = 0x11U, /**< PIS */
|
|
ALD_DMA_MSEL_BS16T = 0x12U, /**< BS16T */
|
|
} ald_dma_msel_t;
|
|
|
|
/**
|
|
* @brief Input signal to DMA channel
|
|
*/
|
|
typedef enum {
|
|
ALD_DMA_MSIGSEL_NONE = 0x0U, /**< NONE */
|
|
ALD_DMA_MSIGSEL_EXTI_0 = 0x0U, /**< External interrupt 0 */
|
|
ALD_DMA_MSIGSEL_EXTI_1 = 0x1U, /**< External interrupt 1 */
|
|
ALD_DMA_MSIGSEL_EXTI_2 = 0x2U, /**< External interrupt 2 */
|
|
ALD_DMA_MSIGSEL_EXTI_3 = 0x3U, /**< External interrupt 3 */
|
|
ALD_DMA_MSIGSEL_EXTI_4 = 0x4U, /**< External interrupt 4 */
|
|
ALD_DMA_MSIGSEL_EXTI_5 = 0x5U, /**< External interrupt 5 */
|
|
ALD_DMA_MSIGSEL_EXTI_6 = 0x6U, /**< External interrupt 6 */
|
|
ALD_DMA_MSIGSEL_EXTI_7 = 0x7U, /**< External interrupt 7 */
|
|
ALD_DMA_MSIGSEL_EXTI_8 = 0x8U, /**< External interrupt 8 */
|
|
ALD_DMA_MSIGSEL_EXTI_9 = 0x9U, /**< External interrupt 9 */
|
|
ALD_DMA_MSIGSEL_EXTI_10 = 0xAU, /**< External interrupt 10 */
|
|
ALD_DMA_MSIGSEL_EXTI_11 = 0xBU, /**< External interrupt 11 */
|
|
ALD_DMA_MSIGSEL_EXTI_12 = 0xCU, /**< External interrupt 12 */
|
|
ALD_DMA_MSIGSEL_EXTI_13 = 0xDU, /**< External interrupt 13 */
|
|
ALD_DMA_MSIGSEL_EXTI_14 = 0xEU, /**< External interrupt 14 */
|
|
ALD_DMA_MSIGSEL_EXTI_15 = 0xFU, /**< External interrupt 15 */
|
|
ALD_DMA_MSIGSEL_ADC = 0x0U, /**< ADC mode */
|
|
ALD_DMA_MSIGSEL_CRC = 0x0U, /**< CRC */
|
|
ALD_DMA_MSIGSEL_UART_RNR = 0x0U, /**< UART reveive */
|
|
ALD_DMA_MSIGSEL_UART_TXEMPTY = 0x1U, /**< UART transmit */
|
|
ALD_DMA_MSIGSEL_SPI_RNR = 0x0U, /**< SPI receive */
|
|
ALD_DMA_MSIGSEL_SPI_TXEMPTY = 0x1U, /**< SPI transmit */
|
|
ALD_DMA_MSIGSEL_I2C_RNR = 0x0U, /**< I2C receive */
|
|
ALD_DMA_MSIGSEL_I2C_TXEMPTY = 0x1U, /**< I2C transmit */
|
|
ALD_DMA_MSIGSEL_TIMER_CH1 = 0x0U, /**< TIM channal 1 */
|
|
ALD_DMA_MSIGSEL_TIMER_CH2 = 0x1U, /**< TIM channal 2 */
|
|
ALD_DMA_MSIGSEL_TIMER_CH3 = 0x2U, /**< TIM channal 3 */
|
|
ALD_DMA_MSIGSEL_TIMER_CH4 = 0x3U, /**< TIM channal 4 */
|
|
ALD_DMA_MSIGSEL_TIMER_TRI = 0x4U, /**< TIM trigger */
|
|
ALD_DMA_MSIGSEL_TIMER_COMP = 0x5U, /**< TIM compare */
|
|
ALD_DMA_MSIGSEL_TIMER_UPDATE = 0x6U, /**< TIM update */
|
|
ALD_DMA_MSIGSEL_PIS_CH0 = 0x0U, /**< PIS channal 0 */
|
|
ALD_DMA_MSIGSEL_PIS_CH1 = 0x1U, /**< PIS channal 1 */
|
|
ALD_DMA_MSIGSEL_PIS_CH2 = 0x2U, /**< PIS channal 2 */
|
|
ALD_DMA_MSIGSEL_PIS_CH3 = 0x3U, /**< PIS channal 3 */
|
|
ALD_DMA_MSIGSEL_PIS_CH4 = 0x4U, /**< PIS channal 4 */
|
|
ALD_DMA_MSIGSEL_PIS_CH5 = 0x5U, /**< PIS channal 5 */
|
|
ALD_DMA_MSIGSEL_PIS_CH6 = 0x6U, /**< PIS channal 6 */
|
|
ALD_DMA_MSIGSEL_PIS_CH7 = 0x7U, /**< PIS channal 7 */
|
|
ALD_DMA_MSIGSEL_BSTIM = 0x0U, /**< BSTIM */
|
|
} ald_dma_msigsel_t;
|
|
|
|
/**
|
|
* @brief Priority of DMA channel
|
|
*/
|
|
typedef enum
|
|
{
|
|
ALD_DMA_LOW_PRIORITY = 0,
|
|
ALD_DMA_MEDIUM_PRIORITY = 1,
|
|
ALD_DMA_HIGH_PRIORUTY = 2,
|
|
ALD_DMA_HIGHEST_PRIORITY = 3
|
|
} ald_dma_priority_t;
|
|
|
|
/**
|
|
* @brief data increment
|
|
*/
|
|
typedef enum
|
|
{
|
|
ALD_DMA_DATA_INC_DISABLE = 0x0U,
|
|
ALD_DMA_DATA_INC_ENABLE = 0x1U,
|
|
} ald_dma_data_inc_t;
|
|
|
|
/**
|
|
* @brief Data size
|
|
*/
|
|
typedef enum {
|
|
ALD_DMA_DATA_SIZE_BYTE = 0x0U, /**< Byte */
|
|
ALD_DMA_DATA_SIZE_HALFWORD = 0x1U, /**< Halfword */
|
|
ALD_DMA_DATA_SIZE_WORD = 0x2U, /**< Word */
|
|
} ald_dma_data_size_t;
|
|
|
|
/**
|
|
* @brief Interrupt flag trigger mode
|
|
*/
|
|
typedef enum
|
|
{
|
|
ALD_DMA_IT_FLAG_TC = 0x0U, /**< DMA transfer complete interrupt */
|
|
ALD_DMA_IT_FLAG_HT = 0x1U, /**< DMA transfer half complete interrupt */
|
|
} ald_dma_it_flag_t;
|
|
|
|
/**
|
|
* @brief Control how many DMA transfers can occur
|
|
* before the controller re-arbitrates
|
|
*/
|
|
typedef enum {
|
|
ALD_DMA_R_POWER_1 = 0x0U, /**< Arbitrates after each DMA transfer */
|
|
ALD_DMA_R_POWER_2 = 0x1U, /**< Arbitrates after 2 DMA transfer */
|
|
ALD_DMA_R_POWER_4 = 0x2U, /**< Arbitrates after 4 DMA transfer */
|
|
ALD_DMA_R_POWER_8 = 0x3U, /**< Arbitrates after 8 DMA transfer */
|
|
ALD_DMA_R_POWER_16 = 0x4U, /**< Arbitrates after 16 DMA transfer */
|
|
ALD_DMA_R_POWER_32 = 0x5U, /**< Arbitrates after 32 DMA transfer */
|
|
ALD_DMA_R_POWER_64 = 0x6U, /**< Arbitrates after 64 DMA transfer */
|
|
ALD_DMA_R_POWER_128 = 0x7U, /**< Arbitrates after 128 DMA transfer */
|
|
ALD_DMA_R_POWER_256 = 0x8U, /**< Arbitrates after 256 DMA transfer */
|
|
ALD_DMA_R_POWER_512 = 0x9U, /**< Arbitrates after 512 DMA transfer */
|
|
ALD_DMA_R_POWER_1024 = 0xAU, /**< Arbitrates after 1024 DMA transfer */
|
|
} ald_dma_arbiter_config_t;
|
|
|
|
/**
|
|
* @brief Callback function pointer and param
|
|
*/
|
|
typedef struct {
|
|
void (*cplt_tc_cbk)(void *arg); /**< DMA transfers complete callback */
|
|
void (*cplt_ht_cbk)(void* arg); /**< DMA transfers half complete callback */
|
|
void *cplt_tc_arg; /**< The parameter of cplt_tc_cbk() */
|
|
void *cplt_ht_arg; /**< The parameter of cplt_ht_cbk() */
|
|
} ald_dma_call_back_t;
|
|
|
|
/**
|
|
* @brief DMA channal configure structure
|
|
*/
|
|
typedef struct {
|
|
void *src; /**< Source data begin pointer */
|
|
void *dst; /**< Destination data begin pointer */
|
|
uint16_t size; /**< The total number of DMA transfers that DMA cycle contains */
|
|
ald_dma_data_size_t src_data_width; /**< Source data width */
|
|
ald_dma_data_size_t dst_data_width; /**< Dest data width */
|
|
ald_dma_data_inc_t src_inc; /**< Source increment type */
|
|
ald_dma_data_inc_t dst_inc; /**< Destination increment type */
|
|
ald_dma_arbiter_config_t R_power; /**< Control how many DMA transfers can occur before re-arbitrates */
|
|
ald_dma_priority_t priority; /**< High priority or default priority */
|
|
TypeFunc mem_to_mem; /**< Enable/disable memory to memory mode */
|
|
TypeFunc circle_mode; /**< Enable/disable circular mode */
|
|
ald_dma_msel_t msel; /**< Input source to DMA channel */
|
|
ald_dma_msigsel_t msigsel; /**< Input signal to DMA channel */
|
|
uint8_t channel; /**< Channel index */
|
|
} ald_dma_config_t;
|
|
|
|
/** @defgroup ALD_DMA_Public_Constants DMA Public Constants
|
|
* @{
|
|
*/
|
|
/**
|
|
* brief ALD_DMA_CHANNEL DMA channel
|
|
*/
|
|
#define ALD_DMA_CH_0 0x0U /**< Channel 0 */
|
|
#define ALD_DMA_CH_1 0x1U /**< Channel 1 */
|
|
#define ALD_DMA_CH_2 0x2U /**< Channel 2 */
|
|
#define ALD_DMA_CH_3 0x3U /**< Channel 3 */
|
|
#define ALD_DMA_CH_4 0x4U /**< Channel 4 */
|
|
#define ALD_DMA_CH_5 0x5U /**< Channel 5 */
|
|
#define ALD_DMA_CH_6 0x6U /**< Channel 6 */
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @brief DMA handle structure definition
|
|
*/
|
|
typedef struct {
|
|
DMA_TypeDef *perh; /**< DMA registers base address */
|
|
ald_dma_config_t config; /**< Channel configure structure. @ref dma_config_t */
|
|
void (*cplt_tc_cbk)(void *arg); /**< DMA transfers complete callback */
|
|
void (*cplt_ht_cbk)(void *arg); /**< DMA transfers half complete callback */
|
|
void *cplt_tc_arg; /**< The parameter of cplt_tc_cbk() */
|
|
void *cplt_ht_arg; /**< The parameter of cplt_ht_cbk() */
|
|
} ald_dma_handle_t;
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @defgroup DMA_Private_Macros DMA Private Macros
|
|
* @{
|
|
*/
|
|
#define IS_DMA_MSEL_TYPE(x) ((x) <= ALD_DMA_MSEL_BS16T)
|
|
#define IS_DMA_MSIGSEL_TYPE(x) ((x) <= ALD_DMA_MSIGSEL_EXTI_15)
|
|
#define IS_DMA_DATAINC_TYPE(x) (((x) == ALD_DMA_DATA_INC_DISABLE) || \
|
|
((x) == ALD_DMA_DATA_INC_ENABLE))
|
|
#define IS_DMA_DATASIZE_TYPE(x) (((x) == ALD_DMA_DATA_SIZE_BYTE) || \
|
|
((x) == ALD_DMA_DATA_SIZE_HALFWORD) || \
|
|
((x) == ALD_DMA_DATA_SIZE_WORD))
|
|
#define IS_DMA_ARBITERCONFIG_TYPE(x) (((x) == ALD_DMA_R_POWER_1) || \
|
|
((x) == ALD_DMA_R_POWER_2) || \
|
|
((x) == ALD_DMA_R_POWER_4) || \
|
|
((x) == ALD_DMA_R_POWER_8) || \
|
|
((x) == ALD_DMA_R_POWER_16) || \
|
|
((x) == ALD_DMA_R_POWER_32) || \
|
|
((x) == ALD_DMA_R_POWER_64) || \
|
|
((x) == ALD_DMA_R_POWER_128) || \
|
|
((x) == ALD_DMA_R_POWER_256) || \
|
|
((x) == ALD_DMA_R_POWER_512) || \
|
|
((x) == ALD_DMA_R_POWER_1024))
|
|
#define IS_DMA_PRIORITY_TYPE(x) (((x) == ALD_DMA_LOW_PRIORITY) || \
|
|
((x) == ALD_DMA_MEDIUM_PRIORITY) || \
|
|
((x) == ALD_DMA_HIGH_PRIORUTY) || \
|
|
((x) == ALD_DMA_HIGHEST_PRIORITY))
|
|
#define IS_DMA_IT_TYPE(x) (((x) == ALD_DMA_IT_FLAG_TC) || \
|
|
((x) == ALD_DMA_IT_FLAG_HT))
|
|
#define IS_DMA(x) ((x) == DMA)
|
|
#define IS_DMA_CHANNEL(x) ((x) <= ALD_DMA_CH_6)
|
|
#define IS_DMA_DATA_SIZE(x) ((x) <= 65535)
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @addtogroup DMA_Public_Functions
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup DMA_Public_Functions_Group1
|
|
* @{
|
|
*/
|
|
/* Initialization functions */
|
|
extern void ald_dma_config_base(ald_dma_config_t *config);
|
|
extern void ald_dma_config_basic(ald_dma_handle_t *hperh);
|
|
extern void ald_dma_config_basic_easy(void *src, void *dst, uint16_t size, ald_dma_msel_t msel,
|
|
ald_dma_msigsel_t msigsel, uint8_t channel, void (*cbk)(void *arg));
|
|
extern void ald_dma_irq_handler(void);
|
|
extern void ald_dma_reset(void);
|
|
extern void ald_dma_init(void);
|
|
extern void ald_dma_config_struct(ald_dma_config_t *p);
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
|
|
/** @addtogroup DMA_Public_Functions_Group2
|
|
* @{
|
|
*/
|
|
/* DMA control functions */
|
|
extern void ald_dma_channel_config(uint8_t channel, type_func_t state);
|
|
void ald_dma_interrupt_config(uint8_t channel, ald_dma_it_flag_t it, type_func_t state);
|
|
extern it_status_t ald_dma_get_it_status(uint8_t channel, ald_dma_it_flag_t it);
|
|
extern flag_status_t ald_dma_get_flag_status(uint8_t channel, ald_dma_it_flag_t it);
|
|
extern void ald_dma_clear_flag_status(uint8_t channel, ald_dma_it_flag_t it);
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
#endif /*__ALD_DMA_H__ */
|