MSPM0G3507外设DMA学习笔记
概述
变量的存储
正常情况下,变量存储在SRAM中,如果要发送该变量的值到外设,需要调用内核操作,使SRAM中的数据送到外设。
此类型操作过多会导致占用CPU高,整体卡顿。
DMA控制概述
- DMA:Direct Memory Access
- 专门用于数据传输,解放CPU
- 对于 DMA,CPU 首先启动传输,然后在传输过程中执行其他操作,最后在操作完成时接收来自 DMA 控制器的中断。
- --->CPU启动,结束后DMA中断标志传输完成。
- DMA传输是双向的,可以从外设传向SRAM,也可以从SRAM传向外设。
- 一般情况下,DMA传输的数据,在外设/SRAM中,地址是连续的---->可以顺序移位寻址,达到依次传输数据的效果。
DMA寄存器相关(通用)
PerAddr(传输外设地址)
SramAddr(传输SRAM地址)
Direction(设置传输方向)
DataSize(传输数据大小)
Sram+(SRAM地址是否移动)
Peri+(外设地址是否移动)
-->一般外设地址是固定不动的
G3507 DMA设置
设置寻址方式
Fixed address to fixed address
固定地址 到 固定地址Fixed address to block of addresses
固定地址 到 地址块Block of addresses to fixed address
地址块 到 地址块Block of addresses to block of addresses
地址块 到 地址块Fill data to block of addresses
填充数据到地址块Data table to specific address
数据表到特定地址
通道设置
- 分为基本通道和全功能通道
- 基本频道仅支持单次或块传输
- FULL通道支持重复单次和重复块传输
- 最高优先级 DMA 通道(从 DMAo 开始)为 FULL 通道,其余优先级通道是基本渠道。
传输模式设置
- 单次传输
- 块传输
- 重复单次传输(仅全功能通道支持)
- 重复块传输(仅全功能通道支持)
模式一:单次传输
- 可定义传输次数
- 可定义两地址是否递加或递减
- 可以设置递加或递减的步长
- 有三个个寄存器会在每次传输后递增或递减-->当其中某个寄存器递减到0时,一个标志寄存器会被置位。同时DMA使能会被清零(即使DMA不工作-->需要再次设置)。
模式二:块传输
- 定义块的大小
- 三个寄存器的值会被存到临时寄存器中,其中两个在每次传输后递减或递加。存在寄存器指示地址到步长。
- 存在寄存器显示递减后剩余的块数。
模式三:重复单次传输
- 特性同单次传输,不过会一直使能,重复单次传输。
模式四:重复块传输
- 特性同块传输,会一直使能,重复块传输。
子模式:跨步传输
- 每次指针不递增一,自定义递增步长---->即跳过部分数据读取或写入。
拓展模式:四个
- 普通模式
- 填充模式
- 表模式
使用
外部DMA通道
- 触发类型选择外部DMA通道
- 再选择触发方式
- 选择寻址模式
- Source Length和Destination Length决定DMA读/写的字节数
->DMA每次从源地址读多少字节的数据和每次向目标地址发送多少字节的数据。
->寻址模式决定DMA每次完成读/写操作后,下次读/写地址是增/减/不变--->指的是块内部寻址增/减/不变。
- 勾选配置传输大小,可配置每次传输数据的大小(只和块传输有关)
-->区分读/写大小和传输大小。可以读多了,慢慢写。
-->Transfer Size决定每次传输多大的块数据。
- 每次传输完成后,对源和目标地址寻址是增/减/不变
- 注:源地址--->DMA--->目标地址,若为块传输模式时:
- DMA中断的触发方式
DMA_block_transfer例程详解
见注释
#include "ti_msp_dl_config.h"
#define DMA_TRANSFER_SIZE_WORDS (16)
//源数据
const uint32_t gSrcData[DMA_TRANSFER_SIZE_WORDS] = {0x00000000, 0x10101010,
0x20202020, 0x30303030, 0x40404040, 0x50505050, 0x60606060, 0x70707070,
0x80808080, 0x90909090, 0xA0A0A0A0, 0xB0B0B0B0, 0xC0C0C0C0, 0xD0D0D0D0,
0xE0E0E0E0, 0xF0F0F0F0};
//目标地址
uint32_t gDstData[DMA_TRANSFER_SIZE_WORDS];
//DMA触发中断标志
volatile bool gChannel0InterruptTaken = false;
//验证结果标志位
volatile bool gVerifyResult = false;
int main(void)
{
SYSCFG_DL_init();
/* Setup interrupts on device */
DL_SYSCTL_disableSleepOnExit();
NVIC_EnableIRQ(DMA_INT_IRQn);
/* Configure DMA source, destination and size */
//设置源地址
DL_DMA_setSrcAddr(DMA, DMA_CH0_CHAN_ID, (uint32_t) &gSrcData[0]);
//设置目的地址
DL_DMA_setDestAddr(DMA, DMA_CH0_CHAN_ID, (uint32_t) &gDstData[0]);
//设置传输大小--->多少个uint32数据
DL_DMA_setTransferSize(DMA, DMA_CH0_CHAN_ID, sizeof(gSrcData) / sizeof(uint32_t));
//使能开启DMA通道
DL_DMA_enableChannel(DMA, DMA_CH0_CHAN_ID);
//开始传输
gChannel0InterruptTaken = false;
DL_DMA_startTransfer(DMA, DMA_CH0_CHAN_ID);
/* 等待块传输完成 */
while (gChannel0InterruptTaken == false)
{
__WFE();
}
//此时已经传输完成,可以验证数据是否正确
gVerifyResult = true;
for (int i = 0; i < DMA_TRANSFER_SIZE_WORDS; i++)
{
/*先比较源数据和目的数据是否相同-->比较出true或false
*再将结果和gVerifyResult进行与运算-->false和任意值进行与运算结果为false
*以此达到验证数组内所有值是否相同的目的*/
gVerifyResult &= gSrcData[i] == gDstData[i];
}
/* 完成传输,使LED灯亮 */
DL_GPIO_clearPins(
GPIO_LEDS_PORT, GPIO_LEDS_USER_LED_1_PIN | GPIO_LEDS_USER_TEST_PIN);
/* 断点检测结果 */
__BKPT(0);
while (1) {
__WFI();
}
}
void DMA_IRQHandler(void)
{
switch (DL_DMA_getPendingInterrupt(DMA))
{
//判断哪个DMA通道产生中断
case DL_DMA_EVENT_IIDX_DMACH0:
gChannel0InterruptTaken = true;
break;
default:
break;
}
}
DMA用到了之前发的SPI通讯里面,在合集里能找到。
MSPM0G3507外设DMA学习笔记的更多相关文章
- STM32学习笔记(七) ADC模数转换测电平(普通和DMA模式)
嵌入式系统在微控制领域(温度,湿度,压力检测,四轴飞行器)中占据着重要地位,这些功能的实现是由微处理器cpu(如stm32)和传感器以及控制器共同完成的,而连接他们,使它们能够互相正常交流的正是本小节 ...
- 1--STM32 ADC1与ADC2 16通道DMA采集笔记(原创)
最近在搞ADC,网上还是很多资源的,以下为参考链接:1.对STM32 ADC单次转换模式 连续转换模式 扫描模式的理解:https://www.cnblogs.com/zhanghankui/p/51 ...
- stm32寄存器版学习笔记06 输入捕获(ETR脉冲计数)
STM32外部脉冲ETR引脚:TIM1-->PA12;TIMER2-->PA0:TIMER3-->PD2;TIMER4-->PE0… 1.TIM2 PA0计数 配置步骤 ①开启 ...
- linux驱动开发之块设备学习笔记
我的博客主要用来存放我的学习笔记,如有侵权,请与我练习,我会立刻删除.学习参考:http://www.cnblogs.com/yuanfang/archive/2010/12/24/1916231.h ...
- IRP IO_STACK_LOCATION 《寒江独钓》内核学习笔记(1)
在学习内核过滤驱动的过程中,遇到了大量的涉及IRP操作的代码,这里有必要对IRP的数据结构和与之相关的API函数做一下笔记. 1. 相关阅读资料 <深入解析 windows 操作系统(第4版,中 ...
- DSP EPWM学习笔记1 - EPWM定时中断
DSP EPWM学习笔记1 - EPWM定时中断 彭会锋 EPWM模块组成 EPWM有7个子模块组成:时间基准 TB.比较功能 CC.动作限定 AQ.死区产生 DB.斩波控制 PC.故障捕获 TZ.事 ...
- AM335x(TQ335x)学习笔记——挂载Ramdisk
上篇文章中我们已经能够通过u-boot启动内核了,但是没有能够启动成功,从内核的log中可以看出,内核启动失败的原因是没有挂载到root文件系统,本文将使用busybox制作根文件系统并打包成ramd ...
- STM32学习笔记之一(初窥STM32)
怎么做好学习笔记? 答:自我感知-->学习知识-->归纳总结-->自我升华(真正属于自己的知识是,抛开书本,运用时,你还能记得的思想) 自我感知--看到知识概念,先自我感觉那应该是个 ...
- STM32学习笔记(一)——点亮一个LED
引言 最近报名了2017全国大学生电子设计竞赛,我们学校是第一次参加这个比赛,由于8/9月份就要比赛了,所以现在准备是比较晚的了,指导老师说只能做控制类的题目了,让我们学习一下STM32单片机,51到 ...
- 基于51单片机IIC通信的PCF8591学习笔记
引言 PCF8591 是单电源,低功耗8 位CMOS 数据采集器件,具有4 个模拟输入.一个输出和一个串行I2C 总线接口.3 个地址引脚A0.A1 和A2 用于编程硬件地址,允许将最多8 个器件连接 ...
随机推荐
- 抖音App动态调试
一.准备工作 1)接上一篇,下载砸过壳的抖音IPA 2)MonkeyDev环境 3)class_dump 二.使用MonkeyDev建立空的工程,拖入IPA到目标文件夹中 1)启动Xcode进行编译执 ...
- 大数据平台搭建手册——hadoop
从0开始 超详细搭建hadoop平台手册 创建三台使用centos7操作系统的虚拟机 基础环境配置 ps:不建议使用DHCP,因为ip地址会变动 配置ip 1.master [root@master ...
- C语言——函数基本知识
什么是函数 函数的定义 函数就是程序中独立的功能.(简单来说就是把代码打包成整体,起个名字,方便以后使用) 函数的使用 定义函数的格式 格式: 返回值类型 函数名(形参1,形参2,...) { 函数体 ...
- ABC351
我多久没更新这个系列了啊 E 把格子分成两类,每一类之间的坐标均可互相走到. 然后将这里面的点都旋转 \(45\) 度,于是这个问题就被转换成曼哈顿距离的问题了. 我们可以把 \(x\) 和 \(y\ ...
- .net core (.net6) 读取配置文件 appsettings.json
.net core (.net6) 读取配置文件 appsettings.json 新建个工具类,方便其它地方使用,代码如下 AppHelper: namespace net6mvc.Utils { ...
- Ubuntu安装VMware tools后不起作用
复制和立即适应客户机不起作用. 解决: 1)不需要卸载 2)命令行执行sudo apt-get install open-vm-tools-desktop 3)可能会提示apt-get update或 ...
- AnkhSVN For Visual Studio 2022
AnkhSVN For VS2022 AnkhSVN 2.9.87 - Visual Studio 2022 support https://github.com/AmpScm/AnkhSVN/rel ...
- nordic的nrf52系列——ADC在使用时如何校准增益误差(基于SDK)
简介:ADC在实际使用的时候都要进行误差校准,那Nordic的nrf52系列如何进行校准,如果不校准又有什么影响尼,接下来我将通过实验进行测试,验证不校准和校准的影响(本测试的基础是,默认输入阻抗和采 ...
- VMware 虚拟机下载
VMware破解版下载地址: https://www.aliyundrive.com/s/CUr4eaMgxGa 提取码:e0c8 激活码: ZF3R0-FHED2-M80TY-8QYGC-NPKYF ...
- 卷积神经网络-AlexNet
AlexNet 一些前置知识 top-1 和top-5错误率 top-1错误率指的是在最后的n哥预测结果中,只有预测概率最大对应的类别是正确答案才算预测正确. top-5错误率指的是在最后的n个预测结 ...