当前位置:首页 > 单片机 > 单片机
[导读]1 引 言  许多单片机控制系统中,信息的实时处理往往需要数据的批量传送。不管是采用软件查询,还是采用中断技术,它们都是依靠程序控制,每次传送数据都需要单片机执行若干条指令,因而传输速率受单片机指令运行

1 引 言  

许多单片机控制系统中,信息的实时处理往往需要数据的批量传送。不管是采用软件查询,还是采用中断技术,它们都是依靠程序控制,每次传送数据都需要单片机执行若干条指令,因而传输速率受单片机指令运行速度的限制。例如,51系列单片机将外设某一数据存入片外RAM,至少要运行2周期指令MOVX和更改地址指针DPTR指令各两次,若采用12MHz时钟,则需4μs。可见,即使不考虑单片机的其它运算,其数据传送速度也只能达到 250Kbyte/s。对于象高速数据采集等需要成批交换数据的场合,速度实在是太慢了。为了实现单片机与高速外设的数据交换,应用接口扩展电路和DMA 控制器,在几乎不占用单片机资源的情况下,实现了单片机控制系统的DMA数据传送。

2 几点说明  

对于单片机控制系统中简单的DMA数据传送,只要应用双向RAM作为外存储器或应用简单的门控电路就可实现。但对于复杂的单片机控制系统,要解决高速外设和低速CPU之间的矛盾,就不能象微机那样通过出借系统总线来实现数据的DMA传送,更不能因数据传送而中断CPU的工作。为此要求:

(1)当单片机控制系统需与高速外设交换数据时,单片机只能作简单的响应,不能长时间中断工作。解决的办法是采用扩展数据存储器系统,数据交换时CPU只出借扩展数据存储器作为DMA数据交换的存储器。

(2)为便于单片机控制系统与高速数据采集或软磁盘驱动器等外设的连接,其DMA控制方式应具有一致性,符合通用接口标准。

信号线共6条,即:
    DMA请求信号DREQ;
    DMA响应回答信号DACK;
    DMA传送过程结束信号
    输入/输出设备读写信号线
    输入/输出设备准备就绪信号线READY。

(3)DMA传送控制与接口尽量不占用单片机的前处理任务的缓急情况,相应对DMA请求作出应答,对DMA请求的应答并不占用单片机的资源。

3 电路实现原理

3.1 存储器扩展电路 

51系列单片机的外部存储容量只有64K,在高速数据采集等情况下,其容量明显不足。若以采样率50KS/s计算,只能容纳1s多的采样量,况且要求 DMA传送期间CPU要照常工作,包括对外部数据存储器的访问。这就要求对存储容量进行扩展。将扩展的存储器用于DMA,原有的存储器继续作为工作存储器。下面以图3—1所示存储器扩展电路为例说明存储器扩展的原理。为说明问题的方便,省去了编码电路,只以单片机的P2.7和P2.6作为片选线,下一节的DMA控制电路也简单以P2.5作片选线。因而特此说明,原理电路中各寄存器的端口地址不惟一。

8155芯片内具有256字节的RAM,2个8位(PA和PB)、1个6位(PC)可编程I/O口。编程设定PB口和PC口为输出口,用于为6264提供地址;PA口为双向输入输出口,作为6264的数据口。其地址分配为:

读写扩展存储器6264时,在PB口送入6264的低8位地址,PC口送入另5位地址(PC口的另外1位作为单片机对DMA请求的应答线)。通过读写 PA口即可完成扩展存储器的读写。虽然存取一次数据要用3条外部RAM读写指令,但这样不但扩展了存储器容量,而且更重要的是在保证CPU不中断工作的条件下,为数据的DMA传送创造了条件。

另外,这种存储器扩展方式,通过选用不同的扩展芯片或选用多个扩展芯片,可大大扩展存储器的容量,如采用8255并口扩展芯片,即可扩展64K的存储容量。

3.2 DMA控制电路

利用通用DMA控制器构成了图3—2所示的单片机数据DMA传送通道,它提供了4通道标准的DMA传送接口信号,其工作过程为:

3.2.1 初始化

单片机控制系统开机后,首先要对8155和8237初始化。

8155初始化。8155只有1个状态寄存器,通过对地址3F00H赋值,即可设定PB口和PC口为输出口,用于为6264提供地址;PA口为双向输入输出口,作为6264的数据口,存数据时,3F00H的值为0DH;取数据时,3F00H的值为0CH。

8237初始化。将8155的PC5位置0,2片4066组成的门控电路使8237处于非DMA状态。此时,8237的端口读写控制线与单片机的读写线分别接通。通过对地址5F00H~5FFFH(8237的内部寄存器端口地址)的设定,完成8237的初始化。

针对单片机控制系统的特点,通常初始化8237的内容包括:
    (1)决定DMA的工作通道;
    (2)数据按成组方式传送;
    (3)确定访存首地址及地址的增减变化;
    (4)传送字节数;
    (5)确定请求信号和应答信号的有效电平;
    (6)屏蔽。

3.2.2 DMA传送

系统完成初始化之后即进入正常工作状态。若有DMA请求,即可进行DMA传送过程。

(1)8237接收到DMA请求信号DREQ后,输出“总线”请求信号HOLD,引起单片机中断,中断响应程序包括:解除8237的屏蔽功能;保持P2.6、P2.5置0,使能6264、8237;
  P2.7置1,使8155空闲;6264脱离单片机控制。

8155的PC5由0变1;门控电路使8237的存储器读写线与6264的读写线接通,完成DMA通道的连接。同时,8155的PC5作为CPU对DMA请求的回应,启动了DMA传送过程。

(2)8237输出DACK回答信号,开始DMA传送。

(3)传送结束,8237输出信号,单片机检测到2次中断的发生,使8155的PC5置0,恢复控制系统的原有工作状态。同时为下次DMA传送作好了准备,并通知外设本次DMA传送结束。

4 结 论

通过存储器扩展,在仅占用单片机几十个存储空间和一个中断源的情况下,实现了单片机控制系统的数据DMA传送,保证了单片机能在DMA传送期间的正常工作。实践证明,该系统可方便用于信号的高速采集,并可作为单片机控制系统与软盘驱动器的接口。

[参考文献]
[1] 朱长清.单片机与CRT显示器的接口[J].电子技术,2000(2).
[2] 阎慧娟,张金烈.微型计算机接口技术[M].中国人事出版社,1994.
[3] 何立民.单片机应用系统设计[M].北京航空航天大学出版社,1990.
[4] 赵依军,胡戎.单片微机接口技术[M].人民邮电出版社,1989.

 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭