资料介绍
1 McBSP(Multichannel Buffered Serial Port)串口利用DMA中的多帧(Multi-Frame)方式通信的中断处理
在实际通信应用中,一个突发之后,程序必须为下一个突发作准备。因此一般采用串口的DMA多帧方式但在串口以DMA方式传输数据时却有一些问题要讨论。首先DMA的传输同步事件应设McBSP的传输事件即XEVT,这样一字节传输后会自动准备另一字节(McBSP的READY上升沿触发DMA传输)。中断发生时意味着一个块已传完,这时DMA的使能自动关闭,McBSP的READY将一直保持高状态。但是在下一次突发传输直接使能DMA时却启动不了传输(相信会有许多我遇到此类问题)。这是因为无法产生McBSP触发启动所需的READY上升沿。解决办法是在中断程序中先关闭McBSP的发送,使READY=0,随后在程序中发送使能DMA,再打开McBSP的发送即可。如先打开McBSP的发送后打开DMA,也是不会工作的。因为McBSP的READY已经由0变到1了,无法再产生READY上升沿。
2 关闭DMA与关闭McBSP的区别
在通信领域,为了充分利用DSP的片上外设资源,常常利用DMA把从串口来的数据或要发的数据放入缓冲区,再处理。对DMA而言,只要其在数据缓冲区的指针指向了中断应发生的位置,就产生中断。但此时最后一个数据只是进入了McBSP而并未真正发出去,所以在传送结束的中断程序中只能关闭DMA不能关闭McBSP。因为此时McBSP的发寄存器DXR中还有一个字没有发出。
3 McBSP串口配置的关键时序
主要是寄存器SPCR2的配置:在保持RRST、XRST、FRST各位为0的前提下,配置好其它串口控制寄存器。等待至少2个CLKR/T时钟以确保DSP内部的同步。
(1)可以向DXR装载数据或使能DMA。
(2)使能GRST(GRST=1)(如果需要DSP内部产生采样时钟)。
(3)使能RRST或XRST,注意此时要保证SPCR中仅有此一位发生改变。
(4)使能FRST(FRST=1)(如果需要DSP内部产生帧同步)。
(5)等待2个R/T CLK时钟周期后,收或发端便会有效。
4 汇编语言程序中的变量
汇编语言程序中的公用变量应在文件中定义,如.def carry。汇编语言程序中使用的局部变量不需定义,可直接声明,例如trn_num .word 00h。如果在两个asm文件中有两个都没有定义的同名变量,则编译程序会认为分他们不是同一变量。在汇编程序的开头应有.mmregs宏语句。它一方面表示对默认定义的确认(ah,bh,trn等),另一方面可以对所用寄存器重新定义。如:
mmregs
DMPREC .set 54h ;定义DMA优先和使能寄存器地址在54h
DMSA .set 55h
DMSDN .set 57h
DXR10 .set 23h ;定义串口1的发送寄存器地睛在23h
- github上的pytorch学习资料详细说明 6次下载
- Xilinx的时序设计与约束资料详细说明 32次下载
- 时序分析的优化策略详细说明 17次下载
- 时序分析的优化策略详细说明 19次下载
- PLC的39个应用案例详细说明 67次下载
- Python的知识点总结详细说明 14次下载
- 如何使用Python绘制PDF文件教程详细说明 12次下载
- 使用单片机串口通信控制步进电机的源代码详细说明 26次下载
- 西门子PLC的数字指令教程详细说明 32次下载
- 西门子PLC位指令的教程详细说明 24次下载
- I2C总线的规范详细说明 16次下载
- 如何同时使用51单片机的定时器0和串口使用问题详细说明 27次下载
- 进行单片机串口通信的方式详细说明 1次下载
- Matlab图形绘制经典案例详细说明 7次下载
- Nano 型串口屏的技术参数详细说明 24次下载
- LPC5500_SDK例程:串口DMA发送+中断接收 478次阅读
- CKS32F4xx系列产品串口DMA传输 671次阅读
- STM32串口DMA接收与发送 9493次阅读
- PIC系列单片机程序设计基础知识详细说明 3791次阅读
- C语言和C++的特点与用法详细说明 3967次阅读
- FPGA的入门基础知识详细说明 8664次阅读
- 通过DMA模式控制串口传输的方法 1w次阅读
- 使用AT89S51单片机制作红外遥控器的资料和源代码详细说明 5263次阅读
- 常用稳压二极管的参数表格详细说明 1.2w次阅读
- 电气电缆的最全常用手册详细说明 8081次阅读
- 基于STM32的串口DMA发送 2.1w次阅读
- 友善串口调试助手怎么使用及使用方法说明 12.3w次阅读
- 接收卡升级的详细说明概述图文详解 2.2w次阅读
- 基于AD9854产生MSK调制信号详细说明 4375次阅读
- STM32串口DMA问题详解 7942次阅读
下载排行
本周
- 1UHD智能显示SoC VS680产品简介
- 0.46 MB | 6次下载 | 免费
- 2DC-DC电路(Buck)的设计与仿真
- 0.60 MB | 3次下载 | 2 积分
- 3触摸按键PCB 设计要点V01
- 1.42 MB | 2次下载 | 免费
- 4375W带L6562的FOT-CONTROLLED PFC预调节器应用资料
- 0.14 MB | 2次下载 | 免费
- 5非隔离降压型有源 PFC LED驱动芯片BP2327A数据手册
- 0.42 MB | 2次下载 | 2 积分
- 6高速 PWM控制器UC3823A和UC3823B 以及UC3825A 和 UC3825B系列数据表
- 1.26MB | 1次下载 | 免费
- 7JW7707F杰华特3.4A50V,7mΩ同步整流器-jw7707f参数规格书
- 268.87 KB | 1次下载 | 免费
- 84.5V 至 52V 输入、电流模式升压控制器TPS4021x-Q1数据表
- 2.03MB | 1次下载 | 免费
本月
- 1DCDC原理详解
- 0.98 MB | 83次下载 | 免费
- 2allegro快速入门教程
- 1.98 MB | 39次下载 | 免费
- 3FU-7(807)胆机原理图
- 11.93 MB | 25次下载 | 1 积分
- 4用于汽车应用的高压电源管理IC TPS65311-Q1数据表
- 1.05MB | 22次下载 | 免费
- 5电子元件基础知识介绍
- 8.76 MB | 22次下载 | 2 积分
- 6华为海思Ascend 310芯片的资料说明
- 0.12 MB | 10次下载 | 10 积分
- 7GD32F10x系列MCU用户手册
- 11.5MB | 9次下载 | 免费
- 8UHD智能显示SoC VS680产品简介
- 0.46 MB | 6次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935083次下载 | 免费
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420046次下载 | 免费
- 3Altium DXP2002下载入口
- 未知 | 233067次下载 | 免费
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191308次下载 | 免费
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183310次下载 | 免费
- 6labview8.5下载
- 未知 | 81567次下载 | 免费
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73786次下载 | 免费
- 8NI LabVIEW中实现3D视觉的工具和技术
- 未知 | 70088次下载 | 免费
评论
查看更多