TS201的通过外部中断IRQ0控制DMA传输(含参考代码)

news2024/12/24 9:19:25

外部中断控制DMA传输

DMA的原理就不多说了,之前的文章里有写。

  1. 电路中的Interrupt Pin

ADSP-TS201 EZ-KIT Lite评估板上每片DSP含有4个外部中断(IRQ3–0 ),其中IRQ0接到了一个按键上(SW4和SW5)。

在这里插入图片描述

当按键按下时,表现为低电平(可采用高低电平触发中断的模式)。

在这里插入图片描述

  1. Interrupt Pin的寄存器

涉及到中断的主要有以下这几个寄存器:ILAT,IMASK,PMASK,以及SQCTL下的GIE位控制全局中断,和INTCTL控制IRQ3-0的触发方式、TIME1-0的启动。ILAT,IMASK,PMASK这三者“相与”指明了正在执行的中断为哪一个。

ILAT:中断锁存寄存器,只要发生中断相应位置1;
IMASK:中断屏蔽寄存器,只有置1才允许响应相应的中断;
PMASK:锁存正在执行的中断,如果允许中断嵌套,只有在高于目前PMASK位的中断才可以响应。

ILAT IMASK PMASK (H)寄存器

这里要讲的IRQ0就在(H)寄存器中。

在这里插入图片描述

在这里插入图片描述

ILAT IMASK PMASK (L)寄存器

在这里插入图片描述

在这里插入图片描述

INTCTL寄存器

INTCTL控制IRQ3-0的触发方式、TIME1-0的启动。

在这里插入图片描述

SQCTL寄存器

在这里插入图片描述

SQCTL下的SQCTL_GIE位控制全局中断。SQCTL还有两个别名SQCTLST和SQCTLCL。

和一般的单片机如MCS-51,MSP430,以及ARM处理器相比,DSP的中断很独特。它的中断向量表是有专门的寄存器组来存储,而非像ARM处理、单片机那样放在存储器中,更不需要ARM那样复杂的地址映射之类操作。

调试步骤:

1)打开VisualDSP++,并新建一个工程文件,命名为”test3_2”,保存路径选择”D:\DSP\”;

2)新建C语言源程序文件,命名为” DMA_INT.asm”,并将文件添加至工程,并理解程序源代码;

3)新建或选择一个相应的调试会话Session (评估测试模式下的调试会话);

4)检查EZ-KIT板各SW设置是否正确;

5)用USB将PC与EZ-KIT板连接;

6)连接EZ-KIT板电源线,LED1(POWER)点亮、LED8(RESET)点亮,EZ-KIT板开始自动复位,复位完成后LED8熄灭,LED3点亮(USB MONITOR,注意此LED实际位置在USB上方),则表示EZ-KIT板与PC已经正常连接;

7)编译工程,在弹出的处理器选择窗口中,选择处理器A作为本次试验的处理器;手动分配自定义缓存区的存储空间以消除编译中出现的错误;

8)在代码中的SQCTLST=SQCTL_GIE;; 和rti(np)(abs);;两行分别设置断点;

9)打开两个TigerSharc Memory 窗口,观察地址分别设为tx_data和rx_data;

10)运行程序,观察TigerSharc Memory 窗口变化,继续运行程序,按下IRQ_A按键,再次观察TigerSharc Memory 窗口变化,理解程序的执行过程。

调试结果:

按照调试步骤,完成参考代码的运行,并记录现象,进一步认识模拟中断在实验二中控制DMA传输的过程。理解程序的执行过程。

参考源代码:

#include <defts201.h>
#define N 1024 /定义需要传输的32位字的个数=1024/
#define MODIFY 4 /每次传输的数据单元大小,4个字(128位)数据/
.section data1;/声明数据段1,存放对源TCB和目的TCB预先设置的参数/
.var DC0_Source_TCB[4]=
tx_data,
N<<16|MODIFY, /将N左移16位,即移至DX的高16位(计数位)/
0x0,
TCB_INTMEM|TCB_QUAD;/源选择为内部存储器/四字操作数/
.align 4;
.var DC0_Destination_TCB[4]=
rx_data,
N<<16|MODIFY, /将N左移16位,即移至DX的高16位(计数位)/
0x0,
TCB_EXTMEM|TCB_QUAD;/目标为外部存储器/四字操作数/
.section data2;
.var tx_data[N]; /定义内部存储器缓冲区,存储需要传输到外存的数据/
.section sdram0;
.var rx_data[N]; /在SDRAM中定义外部存储器缓冲区,存储从写入的数据/
.section program;
_Initialize_Bus_SDRAM: /初始化SYSCON和SDRCON/
xr0=SYSCON_MP_WID64|SYSCON_MEM_WID64|
SYSCON_MSH_PIPE2|SYSCON_MSH_WT0|SYSCON_MSH_IDLE|
SYSCON_MS1_PIPE1 |SYSCON_MS1_WT0|SYSCON_MS1_IDLE|
SYSCON_MS0_SLOW |SYSCON_MS0_WT3|SYSCON_MS0_IDLE;;
SYSCON=xr0;;
xr0=SDRCON_INIT |SDRCON_RAS2PC5 |SDRCON_PC2RAS2 |
SDRCON_REF3700|SDRCON_PG256 |SDRCON_CLAT2 |
SDRCON_ENBL;;
SDRCON=xr0;;
lc0=N;;
j0=tx_data;;
xr0=1;;
xr1=0;;
_Fill_Tx_Data:
xr1=r1+r0;;
[j0+=1]=xr1;;
if nlc0e,jump _Fill_Tx_Data;;
_Set_IRQ_A: /设置外部中断/
j0=_IRQ0_ISR;;
IVIRQ0=j0;;
xr0=INT_IRQ0;;
IMASKH=xr0;; //外部中断IRQ0使能
SQCTLST=SQCTL_GIE;;
_Wait_For_Interrupt:
.align_code 4;
nop;nop;nop;idle;; //无限等待直到中断发生,然后跳至中断程序_IRQ0_ISR执行
jump _Wait_For_Interrupt;;
_IRQ0_ISR:
_Load_DMA0_TCBs: //将初始值倒入DMA0的传输和接收TCB
j0=DC0_Source_TCB;;
xr3:0=q[j0+j31];; //注意这种传递方式
j0=DC0_Destination_TCB;;
yr3:0=q[j0+j31];;
DCS0=xr3:0;;
DCD0=yr3:0;; //开始进行DMA传输
rti(np)(abs);;

_Done:
nop;nop;nop;nop;;
jump _Done;nop;nop;nop;;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/71790.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

西湖论剑 Flagshop 分析复现

前言 比赛时候没能做出来&#xff0c;其实这道题就是一道pwn题。后面与p w n师傅讨论分析EXP分析还原了解题过程。学到了很多&#xff0c;也希望分享给大家。 任意文件读取 抓包或者看源码就会发现有一个SSRF&#xff0c;但是没有权限读flag&#xff0c;测试发现存在一个readf…

全网惟一面向软件测试人员的Python基础教程-为什么要学Python

全网惟一面向软件测试人员的Python基础教程 起点&#xff1a;python软件测试实战宝典》目录 第一章 为什么软件测试人员要学习Python 文章目录全网惟一面向软件测试人员的Python基础教程前言一、Python是什么&#xff1f;二、为什么要学二、测试人员如何学二、怎么从0开始学Py…

旅行路线可视化研究与实现(Java+Android+Eclipse实现的旅游APP)

目 录 1 概论 1 1.1 研究现状 1 1.2 系统开发意义 1 1.3 系统开发背景 2 2 开发环境以及相关技术 5 2.1 Eclipse 5 2.2 Adroid 5 2.2.1 基本概念 5 2.2.2 简介 6 2.2.3 系统架构 6 2.2.4 四大组件 7 2.3 Java语言 7 2.4 SQLite 7 2.4.1 简介 7 2.4.2 架构 7 2.4.3 特点 8 2.5 F…

《Redis 深度历险:核心原理与应用实践》学习

1、Redis的5种基础数据结构 Redis的5种基础数据结构&#xff1a;string (字符串&#xff09;、list (列表 &#xff09;、hash (字典&#xff09;、 set (集合&#xff09;、zset (有序集合&#xff09;。 Redis所有的数据结构都以唯一的key字符串作为名称&#xff0c; 然后通…

基于粒子群优化算法的边缘链接用于边缘检测(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

艾美捷FLIVO探针:用于细胞活体凋亡检测,助力科研!

细胞凋亡在胚胎发育、造血、免疫系统的成熟以及维护正常组织和器官的细胞恒定与生长平衡&#xff0c;乃至机体衰老方面都起着重要作用。因此&#xff0c;有关凋亡的研究在临床和基础等各个领域已经广泛开展,凋亡细胞的检测方法显得非常重要。 FLIVO(荧光活体)是一种强大的无创检…

首个搭载8MP摄像头的单SoC行泊一体方案来袭,已拿下多家车企定点

行泊一体正在进入前装规模化上车的关键周期&#xff0c;但同时产品的升级战争也在全面爆发。 《高工智能汽车》了解到&#xff0c;国内领先的智能驾驶技术供应商——AutoBrain重磅推出了国内首个搭载800万像素摄像头的单SoC行泊一体方案。据悉&#xff0c;这是全球量产首发搭载…

dubbo消费者访问不到docker里面的生产者

版本 dubbo3.0.7 Docker version 20.10.21, build baeda1f docker zookeeper lastest 背景 一个dubbo的项目&#xff0c;生产者和消费者之间使用zookeeper管理。 现将消者和zookeeper部署到了docker中&#xff0c;二者使用的都是桥接网络。 消费者仍然在idea中编写逻辑。 服…

正片工艺、负片工艺,这两种PCB生产工艺的差异到底是什么?

在前文《什么是加成法、减成法与半加成法&#xff1f;》中&#xff0c;我们提到&#xff1a;减成法仍为当前PCB生产工艺的主流&#xff0c;那么&#xff0c;其中的两大代表工艺——正片工艺、负片工艺&#xff0c;又是怎样的呢&#xff1f; 请看下图&#xff1a; 当然&#xf…

一起用Go做一个小游戏(下)

打包资源使用file2byteslice包我们可以将图片和config.json文件打包进二进制程序中&#xff0c;之后编译生成一个二进制程序。然后拷贝这一个文件即可&#xff0c;不用再拷贝图片和其他配置文件了。golang有很多第三方包可以将打包资源&#xff0c;原理其实很简单——读取资源文…

面试官:使用 RocketMQ 怎么进行灰度发布?

今天来聊一聊 RocketMQ 的灰度方案。 灰度发布是指在黑与白之间&#xff0c;平滑过渡的一种发布方式。在大流量的系统中&#xff0c;如果一次升级改造范围比较大&#xff0c;或者影响内容不太确定&#xff0c;一般会采用切量的方式进行升级&#xff0c;这样可以减少生产变更带…

面试官:MySQL 中 varchar(n) 中 n 最大取值为多少?

前置知识 要回答这个问题&#xff0c;首先我们得先知道 MySQL 存储一条记录的格式长什么样子。 以 Compact 行格式作为例子&#xff0c;它长这样&#xff1a; 可以看到&#xff0c;一条完整的记录分为「记录的额外信息」和「记录的真实数据」两个部分。 这里重点讲讲记录的…

探究L298N模块烧毁的原因

目录 基础介绍 代码思路 基础介绍 L298N电机驱动版主要由两个核心组件构成&#xff1a; L298N 驱动芯片78M05 稳压器型号&#xff1a; L298N封装&#xff1a; Multiwatt15V 描述&#xff1a;电源电压&#xff1a;4.5V~46V 特性&#xff1a;过流保护(OCP)&#xff1b;过热保…

在线教程 | 用「网红项目」DeepSOCIAL 进行社交距离监测

By 超神经 内容一览&#xff1a;YOLO v4 是一个实时的、高精度的目标检测模型&#xff0c;本教程将详细讲解如何基于 YOLO v4 和 SORT 算法&#xff0c;实现在多目标条件下的人群距离检测。 关键词&#xff1a;YOLO v4 SORT 多目标检测 新冠疫情爆发初期&#xff0c;「保持…

VSCODE安装ChatGPT插件

zh1&#xff1a;首先在插件商店搜索ChatGPT中文版 然后点击安装就可以 2&#xff1a;chatGPT插件目前需要登陆账号才能使用&#xff0c;官方介绍下一个版本会有升级(不需要登陆) a:前往 ChatGPT 并登录或注册。 首先要先注册&#xff0c;注册的时候邮箱号可以填国内的也可以用…

利他合作,共赢未来 | 数商云全国渠道代理商招募政策发布

12月2日下午&#xff0c;以“利他合作&#xff0c;共赢未来”为主题的数商云全国渠道代理商招募政策发布会在广州顺利召开&#xff0c;与线上线下来自全国各地区的60家优质厂商共同解读数商云首次公开的招商政策、深入体验数商云全线产品体系&#xff0c;挖掘千亿数字化采购市场…

leecode#有效的电话号码#第十行#上升的温度

题目描述&#xff1a; 给定一个包含电话号码列表&#xff08;一行一个电话号码&#xff09;的文本文件 file.txt&#xff0c;写一个单行 bash 脚本输出所有有效的电话号码。 你可以假设一个有效的电话号码必须满足以下两种格式&#xff1a; (xxx) xxx-xxxx 或 xxx-xxx-xxxx。…

20个有用的Excel数据分析函数(教程含案例)

Microsoft Excel 是一种简单而强大的数据分析工具。Excel 是当今行业中广泛使用的软件应用程序,用于生成报告和业务洞察。Excel 包含超过 450 个函数,并且每年都会添加更多函数。在这里,我们介绍了那些主要用于数据分析的功能。 MAX/MIN MAX和MIN函数顾名思义。MAX将找到范…

零基础CSS入门教程(8)——CSS设置字体

本章目录1.任务目标2.css设置字体3.代码演示4.小结1.任务目标 我们前几个小结学习了&#xff0c;css的选择器&#xff0c;和及基本的改变字体颜色。我们这一小结学习一下设置字体的一些功能 2.css设置字体 (1)font-size这个是设置字体大小&#xff0c;浏览器一般默认字体是1…

剪映专业版常用快捷键(Pr 习惯)

剪映专业版提供了两组常用快捷键&#xff0c;一组适应 Final Cut Pro X 用户的习惯&#xff0c;另一组则是为了适应 Adobe Premiere Pro 用户的习惯。本文列出了剪映专业版&#xff08;v3.6&#xff09;的常用快捷键&#xff0c;以让 Pr 用户快速上手剪映。时间线相关快捷键分割…