DMAC - DMA 控制器
本文介绍RTOS 中DMA 驱动的接口及使用方法,为DMA 的使用者提供参考。
DMA 主要实现设备与设备、设备与 memory、memory 与 memory 之间的数据搬运与传输;BSP DMA 驱动主要实现设备驱动的底层细节,并为上层提供一套标准的 API 接口以供使用。
文档约定
数据 | 说明 |
---|---|
DRQSRC_XXX | 源 DRQ 号 |
DRQDST_XXX | 目的 DRQ 号 |
模块配置
Drivers Options —>
soc related device drivers —>
DMA Devices —>
[*] enable dma driver
[*] enable dma hal API test command
源码结构
hal/source/dma/ ---- 驱动源码
├── hal_dma.c
├── Kconfig
├── Makefile
├── platform
│ └── dma-sun20iw3.h
├── platform-dma.h
include/hal/ ---- 驱动APIs声明头文件
└── hal_dma.h
驱动框架
模块接口说明
头文件:
#include <hal_dma.h>
#include <sunxi_hal_common.h>
申请 DMA 通道
函数原型:
hal_dma_chan_status_t hal_dma_chan_request(struct sunxi_dma_chan **dma_chan)
参数:
- dma_chan: 存放 DMA 通道的指针变量
返回值:
- HAL_DMA_CHAN_STATUS_BUSY: 申请失败
- HAL_DMA_CHAN_STATUS_FREE: 申请成功
释放 DMA 通道
函数原型:
hal_dma_status_t hal_dma_chan_free(struct sunxi_dma_chan *chan)
参数:
- chan: 要释放的 DMA 通道结构体指针变量
返回值:
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
释放 DMA 通道描述符
函数原型:
hal_dma_status_t hal_dma_chan_desc_free(struct sunxi_dma_chan *chan)
参数:
- chan: 要释放的 DMA 通道结构体指针变量
返回值:
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
初始化环形 DMA 传输
函数原型:
hal_dma_status_t hal_dma_prep_cyclic(struct sunxi_dma_chan *chan, uint32_t buf_addr, uint32_t buf_len, uint32_t period_len, enum dma_transfer_direction dir)
参数:
- chan:DMA 通道结构体指针变量
- buf_addr: 数据缓冲区
- buf_len: 数据缓冲区长度
- period_len: 单次 DMA 搬运长度
- dir:DMA 传输方向
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
初始化 memory to memory DMA 传输
函数原型:
hal_dma_status_t hal_dma_prep_memcpy(struct sunxi_dma_chan *chan, uint32_t dest, uint32_t src, uint32_t len)
参数:
- chan:DMA 通道结构体指针变量
- dest: 目的地址
- src: 源地址
- len: 传输长度
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
初始化通用 DMA 传输
函数原型:
hal_dma_status_t hal_dma_prep_device(struct sunxi_dma_chan *chan, uint32_t dest, uint32_t src, uint32_t len, enum dma_transfer_direction dir)
参数:
- chan:DMA 通道结构体指针变量
- dest: 目的地址
- src: 源 地址
- len: 传输长度
- dir:DMA 传输方向
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
注册 DMA 回调函数
函数原型:
hal_dma_status_t hal_dma_callback_install(struct sunxi_dma_chan *chan, dma_callback callback, void *callback_param)
参数:
- chan:DMA 通道结构体指针变量
- callback: 回调函数 handler
- callback_param: 回调函数传参
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_OK: 成功
配置 DMA 描述符传输信息
函数原型:
hal_dma_status_t hal_dma_slave_config(struct sunxi_dma_chan *chan, struct dma_slave_config *config)
参数:
- chan:DMA 通道结构体指针变量
- config:DMA 描述符结构体指针变量
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_OK: 成功
获取 DMA 发送状态
函数原型:
enum dma_status hal_dma_tx_status(struct sunxi_dma_chan *chan, uint32_t *left_size)
参数:
- chan:DMA 通道结构体指针变
- left_size: 存放剩余长度的指针变量
返回值:
- DMA_INVALID_PARAMETER: 参数非法
- DMA_IN_PROGRESS: 正在进行
- DMA_COMPLETE: 传输完成
启动 DMA 传输
函数原型:
hal_dma_status_t hal_dma_start(struct sunxi_dma_chan *chan)
参数:
- chan:DMA 通道结构体指针变量
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功
停止 DMA 传输
函数原型:
hal_dma_status_t hal_dma_stop(struct sunxi_dma_chan *chan)
参数:
- chan:DMA 通道结构体指针变量
返回值:
- HAL_DMA_STATUS_INVALID_PARAMETER: 参数非法
- HAL_DMA_STATUS_ERROR: 失败
- HAL_DMA_STATUS_OK: 成功