OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3685|回复: 1

AT32 MCU的DMA通道灵活配置

[复制链接]

44

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
175
金钱
175
注册时间
2017-5-6
在线时间
10 小时
发表于 2022-1-8 12:46:23 | 显示全部楼层 |阅读模式
1金钱
AT32 DMA通道灵活配置

概述在使用 Artery 部分系列 MCU 时(如 AT32F413\ AT32F415\ AT32F403A\ AT32F407),可以使用DMA 弹性映射功能。此功能使得 DMA 的通道配置更加灵活,可以将某外设的 DMA 请求通道指定到DMA1 或者 DMA2 共 14 个通道中的任意一个通道。(如:可以将 SPI1 接受数据的 DMA 请求指定到DMA1 的通道 7)。本指南将介绍如何使用 DMA 弹性映射请求,从而使得 DMA 传输变得更加灵活多变。
支持型号
AT32F系列

目录
概述 ......................... 5
配置及使用方法 ................ 6
常规 DMA 使用( DMA 固定映射) ........6
DMA 弹性映射使用 ....................... 6
例程说明 ................................. 9
例程 Data_to_gpio_flexible ......................... 9  
版本历史 12

配置及使用方法
常规 DMA 使用(DMA 固定映射)
常规的 DMA 使用以及配置方式为:外设的 DMA 通道已经固定且不可改变,使用时配置好再使能固定通道即可。这就意味着如果想开启某个外设的 DMA 功能,那么通道是不可改变的,例如想使用SPI1 的 RX DMA 功能,那么就要查看 RM 的手册,如下:

DMA 弹性映射使用
DMA 弹性映射请求功能提供了一种更灵活的使用方式,即外设的 DMA 通道不固定,可选择 DMA1和 DMA2 中,共 14 个通道的任意一个通道。想要使用此功能,需要通过以下几步的设定:1) 开启 DMA 弹性映射功能将 DMA 的通道来源寄存器 1 的第 24bit 写 1,即 DMA_SRC_SEL1 寄存器的 DMA_FLEX_EN 位。向通道设置对应的寄存器中写入相应的硬件 ID 号每个外设的 DMA 请求都分配了一个硬件 ID 号,只要将这个 ID 号写进通道来源寄存器中即可。ID 号可查看 RM 中的表格,以 403A 为例,如下:


上表中的 CHx_SRC 设定值就是硬件 ID 号,将这个 ID 号写进通道来源寄存器中的对应通道 bit 位就可以了。例如:要将 SPI1 的 RX 的 DMA 请求映射到 DMA1 的通道 7,那么就要将 0x09 写入到DMA_SRC_SEL1 寄存器的 CH7_SRC[23:16]。其他配置与常规 DMA 配置相同通过以上 3 步的配置,弹性映射功能即可使用。注:DMA1/2 的 DMA_FLEX_EN 必须要同时设定为 1 或 0 时,DMA1/2 的映像模式必须一致。无法 DMA1 是固定式映像,DMA2 是弹性式映像。
2) DMA 弹性映射库函数使用
以上的配置在BSP中的dma.h\dma.c的库文件中有提供相应的库函数,使用者只需调用库函数即可完成DMA弹性映射模式的配置。库函数说明如下:



最佳答案

查看完整内容[请看2#楼]

谢谢分享,请发分享贴
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2022-1-8 12:46:24 | 显示全部楼层
谢谢分享,请发分享贴
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-26 06:15

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表