ImageVerifierCode 换一换
格式:PPT , 页数:54 ,大小:1,021.50KB ,
资源ID:447430      下载积分:12 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-447430.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第13章AT89S51单片机的应用设计与调试.ppt)为本站会员(ga****84)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

第13章AT89S51单片机的应用设计与调试.ppt

1、1,第15章 单片机应用系统的设计 与调试,1,2,第15章 单片机应用系统的设计与调试 15.1 单片机应用系统的设计步骤15.2 单片机应用系统设计 15.2.1 硬件设计应考虑的问题 15.2.2 典型的单片机应用系统 15.2.3 系统设计中的总线驱动 15.2.4 软件设计考虑的问题 15.2.5 软件的总体框架设计15.3 单片机应用系统的仿真开发与调试,2,3,【内容概要】 本章介绍单片机应用系统的设计,内容主要包括:应用系统的设计步骤和方法,应用系统的硬件设计以及应用程序的总体框架设计。此外,还介绍了目前流行的单片机应用系统的仿真开发工具以及如何利用仿真开发工具对单片机应用系统

2、进行开发调试。,4,15.1 单片机应用系统的设计步骤 单片机应用系统的设计工作,首先要经过深入细致的需求分析,周密而科学的方案论证才能使系统设计工作顺利完成。一个单片机应用系统设计,一般可分为4个阶段。(1)明确任务和需求分析以及拟定设计方案阶段 明确系统所要完成的任务十分重要,它是设计工作的基础,设计方案正确性的保证。 需求分析的内容主要包括:被测控参数的形式(电量、非电量、模拟量、数字量等)、被测控参数的范围、性能指标、系统功能、工作环境、显示、报警、打印要求等。,5,拟定设计方案是根据任务的需求分析,先确定大致方向和准备采用的手段。注意,在进行设计方案确定的时候,简单的方法往往可以解决

3、大问题,切忌“将简单的问题复杂化”(2)硬件和软件设计阶段 根据拟定的设计方案,设计出相应的系统硬件电路。硬件设计的前提是必须能够完成系统的要求和保证可靠性。在硬件设计时,如果能够将硬件电路设计与软件设计结合起来考虑效果会更好。因为当有些问题在硬件电路中无法完成时,可直接由软件来完成(如某些软件滤波、校准功能等);当软件编写程序很麻烦的时候,通过稍稍改动硬件电路(或尽可能不改动)可能会使软件变得十分简单。另外在一些要求,5,6,系统实时性强、响应速度快的场合,则往往必须用硬件代替软件来完成某些功能。所以在硬件电路设计时,最好能够与软件的设计结合起来,统一考虑,合理地安排软、硬件的比例,使系统具

4、有最佳的性/价比。当硬件电路设计完成后,就可进行硬件电路板的绘制和焊接工作了。 接下来的工作就是软件设计。正确的编程方法就是根据需求分析,先绘制出软件的流程图,该环节十分重要。流程图的绘制往往不能一次成功,通常需要进行多次的修改。流程图的绘制可按照由简到繁的方式再逐步细化,先绘制系统大体上需要执行的程序模块,然后将这些模块按照要求组合在一起,在大方向没有问题后,再将每个模块进行细化,最后形成软件流程,6,7,图,这样程序的编写速度就会很快,同时程序流程图还会为后面的调试工作带来很多方便,如程序调试中某个模块不正常,就可以通过流程图来查找问题的原因。软件编写者一定要克服不绘制流程图直接在计算机上

5、编写程序的习惯。 设计者也可以先使用虚拟仿真开发工具Proteus来进行单片机系统的仿真设计。使用Proteus完成的单片机系统设计与用户样机在硬件上无任何联系,这是一种完全用软件手段来对单片机硬件电路和软件来进行设计、开发与仿真调试的开发工具。如果一个单片机的软硬件系统,先使用软件虚拟仿真工具进行系统设计并仿真调试通过,虽然还不能完全说,7,8,明实际系统就完全通过,但至少在逻辑上是行得通的。系统虚拟仿真通过后,再进行实际的软硬件设计与实现,可大大减少设计上所走的弯路,软件编写调试可与硬件设计同步进行,可大大提高设计效率,这也是目前世界上广泛流行的一种开发设计方法。(3)硬件与软件联合调试阶

6、段 上述的软硬件系统虚拟设计仿真调试通过后,再使用硬件仿真开发工具(在线仿真器)与用户样机来进行实际调试,具体的调试方法和过程,将在本章的后面进行介绍。所有的软件和硬件电路全部调试通过,并不意味着单片机系统的设计成功,还需要通过实际运行来调整系统的运行状,8,9,态,例如系统中的A/D转换结果是否正确,如果不正确,是否要调零和调整基准电压等。(4)资料与文件整理编制阶段 当系统全部调试通过后,就进入资料与文件整理编制阶段。资料与文件包括:任务描述、设计的指导思想及设计方案论证、性能测定及现场试用报告与说明、使用指南、软件资料(流程图、子程序使用说明、地址分配、程序清单)、硬件资料(电原理图、元

7、件布置图及接线图、接插件引脚图、线路板图、注意事项)。文件不仅是设计工作的结果,而且是以后使用、维修以及进一步再设计的依据。因此,一定要精心编写,描述清楚,使数据及资料齐全。,9,10,15.2 单片机应用系统设计 本节介绍如何进行单片机应用系统的设计。主要从硬件设计和软件设计两个方面考虑。 15.2.1 硬件设计应考虑的问题 在硬件设计时,应重点首先考虑以下几个问题。1尽可能采用高集成度功能强的芯片(1)单片机的选型。随着集成电路技术的飞速发展,单片机的集成度越来越高,许多外围部件都已集成在芯片内,有许多单片机本身就是一个系统,这样可以省去许多外围部件的扩展工作,使设计工作大大简化。在第1章

8、中,已经介绍,10,11,了目前较为流行的各种单片机机型,用户可根据任务的需求,选择合适的机型。例如,目前市场上较为流行的美国 Cygnal公司的C8051F020 8位单片机,片内集成有8通道A/D、两路D/A、两路电压比较器,内置温度传感器、定时器、可编程数字交叉开关和64个通用I/O口、电源监测、看门狗、多种类型的串行总线(两个UART、SPI)等。使用1片C8051F020 8位单片机,就构成了一个应用系统。再如,如果系统需要较大的I/O驱动能力和较强的抗干扰能力,可考虑选用PIC单片机或AVR单片机。(2)优先选用片内带有较大容量Flash存储器的产品。例如,使用ATMEL公司的AT

9、89S52/AT89S53/ AT89S54/,11,12,AT89S55系列产品,PHILIPS公司的89C58(内有32KB的Flash存储器)等,可省去扩展片外程序存储器的工作,减少芯片数量,缩小系统的体积。(3)RAM容量的考虑。大多数单片机片内的RAM单元有限,当需增强软件数据处理功能时,往往觉得不足,这时可选用片内具有较大RAM容量的单片机,例如PIC18F452。(4)对I/O端口留有余地。在用户样机研制出来进行现场试用时,往往会发现一些被忽视的问题,而这些问题是不能单靠软件措施来解决的。如有些新的信号需要采集,就必须增加输入检测端;有些物理量需要控制,就必须增加输出端。如果在,

10、12,13,硬件设计之初就多设计留有一些I/O端口,这些问题就会迎刃而解了。(5)预留A/D和D/A通道。与上述的I/O端口同样的原因,留出一些A/D和D/A通道将来可能会解决大问题。2以软代硬 原则上,只要软件能做到且能满足性能要求,就不用硬件。硬件多了不但增加成本,而且系统故障率也会提高。以软件代硬件的实质,就是以时间换空间,软件执行过程需要消耗时间,因此这种替代带来的问题是实时性下降。在实时性满足要求的场合,以软代硬是合算的。,13,14,3工艺设计 工艺设计包括机箱、面板、配线、接插件等。必须考虑到安装、调试、维修的方便。另外,硬件抗干扰措施(将在本章的后面介绍)也必须在硬件设计时一并

11、考虑进去。15.2.2 典型的单片机应用系统 典型的单片机应用系统框图如图15-1所示。 典型的单片机应用系统主要由单片机基本部分、输入部分和输出部分组成。(1)单片机基本部分 基本部分由单片机及其扩展的外设及芯片,如键盘、显示器、打印机、数据存储器、程序存储器以及数字I/O等组成。,14,15,图15-1 单片机典型应用系统框图,16,(2)输入部分 这是“测”的部分,被“测”的信号类型有:数字量、模拟量和开关量。模拟量输入检测的主要包括信号调理电路以及A/D转换器。A/D转换器中都集成了包括多路切换、采样保持、A/D转换等电路,A/D转换器或者直接集成在单片机片内。 连接传感器与A/D转换

12、器之间的桥梁是信号调理电路,传感器输出的模拟信号要经过信号调理电路对信号进行放大、滤波、隔离、量程调整等,变换成适合A/D转换的电压信号。信号放大通常由单片式仪表放大器承担。仪表放大器对信号进行放大比普通运算放大器具有更优异的性能。如何根据不同的传感器,16,17,正确地选择仪表放大器来进行信号调理电路的设计,请读者参阅有关资料和文献。(3)输出部分 这部分是应用系统“控”的部分,包括数字量、开关量控制信号的输出和模拟量控制信号(常用于伺服控制)的输出。15.2.3 系统设计中的总线驱动 一个AT89S52单片机应用系统有时往往是多芯片系统,如何实现AT89S52单片机对多片芯片的驱动的问题。

13、,17,18,在AT89S52单片机扩展多片芯片时,要注意AT89S52单片机4个并行双向口的P0P3口的驱动能力。下面首先讨论这个问题。 AT89S52的P0、P2口通常作为总线端口,当系统扩展的芯片较多时,可能造成负载过重,致使驱动能力不够,系统不能可靠地工作,所以通常要附加总线驱动器或其他驱动电路。因此在多芯片应用系统设计中首先要估计总线的负载情况,以确定是否需要对总线的驱动能力进行扩展。 图15-2为AT89S52单片机总线驱动扩展原理图。P2口需要单向驱动,常见的单向总线驱动器为74LS244。,18,19,图15-2 AT89S52单片机总线驱动扩展原理图,20,图15-3为74L

14、S244引脚图和逻辑图。8个三态驱动器分成两组,分别由1G*和2G*控制。 P0口作为数据总线,是双向传输,驱动器应为双向驱动、三态输出,并由两个控制端来控制数据传送方向。如图15-2所示,数据输出允许控制端DBEO有效时,数据总线输入为高阻态,输出为开通状态;数据输入允许控制端DBEI有效时,则状态与上相反。常见的双向驱动器为74LS245,图15-4为其引脚和逻辑图。16个三态门中每两个三态门组成一路双向驱动。驱动方向由G* 、DIR两个控制端控制驱动器有效或高阻态,在控制端有效(G*=0)时,DIR控制端控制驱动器的驱动方向,DIR=0时驱动方向为从B至A,DIR=1时则相反。,20,2

15、1,21,图15-3 单向驱动器74LS244引脚图和逻辑图,22,图15-4 74LS245的引脚图和逻辑图,23,图15-5所示为AT89S52单片机应用系统总线驱动扩展电路图。P0口的双向驱动采用74LS245,如图15-5(a)所示;P2口的单向驱动器采用74LS244,如图15-5(b)所示。P0口的双向驱动器74LS245的G*接地,保证芯片一直处于工作状态,而输入/输出的方向控制由单片机的数据存储器的“读”控制引脚(RD*)和程序存储器的取指控制引脚(PSEN*)通过与门控制DIR引脚实现。这种连接方法无论是“读”数据存储器中数据(RD*有效)还是从程序存储器中取指令(PSEN*

16、有效),都能保证对P0口的输入驱动;除此以外的时间( RD*及PSEN*均无效),保证对P0口的输出驱动。对于P2口,因为只用作单向的地址输出,故74LS244的驱动门控制端1G* 、2G*接地。,23,24,24,图15-5 AT89S52单片机应用系统中的总线驱动扩展电路图,25,15.2.4 软件设计考虑的问题 在进行应用系统的总体设计时,软件设计和硬件设计应统一考虑,相互结合进行。当系统的硬件电路设计定型后,软件的任务也就明确了。 一般来说,软件的功能分为两大类。一类是执行软件,它能完成各种实质性的功能,如测量、计算、显示、打印、输出控制等;另一类是监控软件,它是专门用来协调各执行模块

17、和操作者的关系,在系统软件中充当组织调度的角色。设计人员在进行程序设计时应从以下几个方面加以考虑。 (1)根据软件功能要求,将系统软件分成若干相对独立的部分,设计出合理的软件总体结构,使其清晰、简洁、流程合理。,25,26,(2)各功能程序实行模块化、子程序化。既便于调试、链接,又便于移植、修改。(3)在编写应用软件之前,应绘制出程序流程图。多花一些时间来设计程序流程图,就可以节约几倍于源程序的编辑和调试时间。(4)要合理分配系统资源,包括ROM、RAM、定时器/计数器、中断源等。其中最关键的是片内RAM分配。对AT89S52单片机来讲,片内RAM指00HFFH单元,这256个字节的功能不完全

18、相同,分配时应充分发挥其特长,做到物尽其用。例如,在工作寄存器的8个单元中,R0和R1具有指针功能,是编程的重要角色,避免作为它用;20H2FH这16个字节,26,27,具有位寻址功能,用来存放各种标志位、逻辑变量、状态变量等;设置堆栈区时应事先估算出子程序和中断嵌套深度及程序中堆栈操作指令使用情况,其大小应留有余量。若系统中扩展了RAM存储器,应把使用频率最高的数据缓冲器安排在片内RAM中,以提高处理速度。当RAM资源规划好后,应列出一张详细的RAM资源分配表,以备编程时查用方便。15.2.5 软件的总体框架设计 设计者在软件设计时,感觉比较困难的是如何进行系统软件的总体框架设计。下面给出一

19、个典型的例子,供读者在软件设计时参考。,27,28,【例15-1】有一个AT89S52单片机的应用系统,假设6个中断源都已用到,应用系统的程序框架如下:,28,29,29,30,31,31,上述程序框架仅供参考,当然在实际设计中,6个中断源也未必全用。,32,15.3 单片机应用系统的仿真开发与调试 当一个单片机应用系统(用户样机)完成了硬件和软件设计,全部元器件安装完毕后,在用户样机的程序存储器中放入编写好的应用程序,系统即可运行。但应用程序运行一次性成功几乎是不可能的,多少会存在一些软件、硬件上的错误,这就需要借助单片机的仿真开发工具(在线仿真器)进行调试,发现错误并加以改正。AT89S5

20、2单片机只是一个芯片,既没有键盘,又没有CRT、LED显示器,也无法进行软件的开发(如编辑、汇编、调试程序等),因此,必须借助仿真开发工具所提供的开发手段来进行。 一般来说,仿真开发工具应具有如下最基本的功能。,32,33,(1)用户样机程序的输入与修改。(2)程序的运行、调试(单步运行、设置断点运行)、排错、状态查询等功能。(3)用户样机硬件电路的诊断与检查。(4)有较全的开发软件。用户可用汇编语言或C语言编制应用程序;由开发系统编译连接生成目标文件、可执行文件。配有反汇编软件,能将目标程序转换成汇编语言程序;有丰富的子程序可供用户选择调用。(5)将调试正确的程序写入到程序存储器中。 下面介

21、绍常用的仿真开发工具。,33,34,1. 仿真开发系统简介 通用机仿真开发系统是目前设计者使用最多的一类开发装置,由在线仿真器与PC机上运行的仿真开发软件两部分组成。这是一种通过PC机的USB口,外加在线仿真器的在线仿真开发系统,如图15-6所示。 在调试用户程序时,在线仿真器一侧与PC机的USB口相连,另一侧的仿真插头插入到用户样机的单片机插座上,来对样机上的单片机进行“仿真”。从仿真插头向在线仿真器看去,看到的就是一个“单片机”。 这个“单片机”是“出借”给用户样机的,暂时代替用户样机上的单片机。仿真开发系统除了“出借”,35,图15-6 通用机仿真开发系统,36,单片机外,还“出借”仿真

22、用的RAM,来暂收代替用户样机上的程序存储器,存放待调试的用户程序。但是这个“单片机”片内程序的运行是可以跟踪、修改和调试的。由于有PC机上强大的仿真开发软件支持,可在PC机的其屏幕上观察用户程序的运行情况,当按照图15-6将仿真开发系统与PC机联机后,用户可利用PC机上的仿真开发软件,在PC机上编辑、修改源程序,然后通过翻译软件(汇编语言编程翻译软件为汇编程序,C51语言编程翻译软件为相应的编译程序)将其汇编成机器代码,传送到在线仿真器中的“仿真RAM”中,这时用户可使用在线仿真器,采用单步、断点、跟踪、全速等手段,36,37,调试用户程序,并进行修改和查找软、硬件故障,将系统状态实时地显示

23、在屏幕上。待程序调试通过后,再使用仿真开发系统提供的编程器或专用编程器,把调试完毕的程序写入到单片机片内的Flash程序存储器中。此类仿真开发系统配置不同的在线仿真器,可仿真开发各种单片机。 但是随着ISP技术的普及,对于AT89S5x单片机也可不使用在线仿真器以及编程器,用户只需要在PC机上修改程序,然后将修改的程序直接写入用户样机的单片机的Flash存储器中,运行程序观察运行结果,如有问题可在PC机上修改程序,重新在线写入,直至运行结果满意为止。这样可省去在线仿真器和编程器,但不足的是,不能对用户程序进行硬件单步、断点、跟踪、全速等手段来调试。,37,38,在工业现场,往往没有PC机的支持

24、,此时可使用独立型仿真器。该类仿真器采用模块化结构,配有不同外设,如外存板、打印机、键盘/显示器等,用户可根据需要选用。由于没有PC机,这时使用独立型仿真器来进行的仿真调试工作,要输入机器码,稍显麻烦一些。2. 软件仿真开发工具Proteus 使用软件虚拟仿真开发工具Proteus进行单片机系统的设计与仿真,不需要在线仿真器,也不需要用户样机,直接就可以在PC机上进行。调试完毕的软件可将其机器代码写入到片内Flash程序存储器中,一般能直接投入运行。 但Proteus是软件模拟器是使用纯软件来对用户系统仿真,,38,39,不能进行用户样机硬件部分的诊断与实时在线仿真。因此在系统的开发中,一般是

25、先用Proteus仿真软件设计出系统的虚拟的硬件原理电路,编写程序,在Proteus环境下仿真调试通过。然后再依照仿真的结果,完成实际的硬件设计,再将仿真调试通过的程序写入到用户样机的Flash存储器中,观察运行结果,如果有问题,再连接硬件仿真器去分析、调试。3. 用户样机的源程序调试 下面介绍如何使用仿真开发工具进行汇编语言源程序编写、调试以及与用户样机硬件联调工作。用户源程序调试过程如图15-7所示,可分为以下4个步骤。,39,40,图15-7 用户样机软件设计、调试的过程,41,41,(1)输入用户源程序。用户使用编辑软件,按照汇编语言源程序要求的格式、语法规定,把源程序输入到PC机中,

26、并保存在磁盘上。(2)在PC机上,利用汇编程序对用户源程序进行汇编,直至语法错误全部纠正为止。如无语法错误,则进入下一个步骤。(3)动态在线调试。这一步对用户的源程序进行调试。上述的步骤(1)、步骤(2)是一个纯粹的软件运行过程,而在这一步,必须要有在线仿真器配合,才能对用户源程序进行调试。用户程序中分为与用户样机硬件无关以及与用户样机紧密相关的程序。,42,42,对于与用户样机硬件无关的程序,如计算程序,虽然已经没有语法错误,但可能存在逻辑错误,使计算结果不正确,此时必须借助于在线仿真器的动态在线调试手段,如单步运行、设置断点等,发现逻辑错误,然后返回到步骤(1)修改,直至逻辑错误纠正为止。

27、 对于与用户样机硬件紧密相关的程序段(如接口驱动程序),一定要先把在线仿真器的仿真插头插入用户样机的单片机插座中(见图15-6),进行在线仿真调试,利用仿真开发系统提供单步、设置断点等调试手段,来进行系统的调试。 有关部分程序段运行有可能不正常,可能是软件逻辑上有问题,也可能是硬件有故障,必须先通过在线仿真调试程序提,43,43,供的调试手段,把硬件故障排除以后,再与硬件配合,对用户程序进行动态在线调试。对于软件的逻辑错误,则返回到第一步进行修改,直至逻辑错误消除为止。在调试这类程序时,硬件调试与软件调试是不能完全分开的。许多硬件错误是通过软件的调试而发现和纠正的。(4)将调试完毕的用户程序通

28、过编程器或ISP写入,固化在程序存储器中。4用户样机的硬件调试 当用户样机全部焊接完毕,就可对用户样机的硬件进行调试。首先进行静态调试,静态调试的目的是排除明显的硬件故障。,44,44,(1)用户样机的静态调试 静态调试工作分为两步。 第一步是在样机加电之前,根据硬件逻辑设计图,先用万用表等工具,仔细检查样机线路是否连接正确,并核对元器件的型号、规格和安装是否符合要求,应特别注意电源系统的检查,以防止电源的短路和极性错误,并重点检查系统总线(地址总线、数据总线、控制总线)是否存在相互之间短路或与其他信号线的短路。 第二步是加电后检查各芯片插座上有关引脚的电位,仔细测量各点电平是否正常,尤其应注

29、意AT89S52插座的各点电位,若有高压,与在线仿真器联机调试时,将会损坏在线仿真器。,45,45,具体步骤如下。 电源检查。当用户样机板连接或焊接完成之后,先不插主要元器件,通上电源。通常用+5V直流电源(这是TTL电源),用万用表电压档测试各元器件插座上相应电源引脚电压数值是否正确,极性是否符合。如有错误,要及时检查、排除,以使每个电源引脚的数值都符合要求。 各元器件电源检查。断开电源,按正确的元器件方向插上元器件。最好是分别插入,分别通电,并逐一检查每个元器件上的电源是否正确,直到最后全部插上元器件。通电后,每个元器件上电源值应正确无误。,46,检查相应芯片的逻辑关系。检查相应芯片逻辑关

30、系通常采用静态电平检查法,即在一个芯片信号的输入端加入一个相应电平,检查输出电平是否正确。单片机系统大都是数字逻辑电路,使用电平检查法可首先检查出逻辑设计是否正确,选用的元器件是否符合要求,逻辑关系是否匹配,元器件连接关系是否符合要求等。(2)用户样机的在线仿真调试 在静态调试中,对用户样机硬件进行初步调试,只能排除一些明显的静态故障。 用户样机中的硬件故障(如各个部件内部存在的故障和部件之间连接的逻辑错误)主要是靠联机在线仿真来排除的。,46,47,47,在断电情况下,除AT89S52单片机外,插上所有的元器件,并把在线仿真器的仿真插头插入样机上AT89S52单片机的插座(见图15-6),然

31、后分别打开用户样机和仿真器电源后便可开始联机在线仿真调试。 前面已经介绍,硬件调试和软件调试是不能完全分开的,许多硬件错误是在软件调试中发现和被纠正的。所以,在之前介绍的有关用户样机软件调试的第(3)步的动态在线调试中,即包括联机仿真、硬件在线动态调试以及硬件故障的排除。 下面介绍在仿真开发机上如何利用简单调试程序检查用户样机。,48,利用仿真开发系统对用户样机进行硬件检查,常常按其功能及I/O通道分别编写相应简短的实验程序,来检查各部分功能及逻辑是否正确,下面做简单介绍。 检查各地址译码输出 通常,地址译码输出是一个低电平有效信号。因此在选到某一个芯片时(无论是内存还是外设),其片选信号用示

32、波器检查应该是一个负脉冲信号。 下面讨论如何检查地址译码器输出。例如,一片RAM 6116存储芯片地址为200027FFH,则在开发系统上执行如下程序:LOOP:MOV DPTR,#2000H MOVX A,DPTR SJMP LOOP,49,程序执行后,应该从6116存储器芯片的片选端看到等间隔的一串负脉冲,说明该芯片片选信号连接是正确的,即使不插入该存储器芯片,只测量插座相应片选引脚也会有上述结果。 用同样方法,可将各内存及外设接口芯片的片选信号逐一进行检查。如出现不正确的现象,就要检查片选线连线是否正确,有无接触不良或错线、断线问题。 检查RAM存储器 检查RAM存储器时可编写程序,对R

33、AM存储器进行写入,然后再读出,将写入和读出的数据进行比较,发现错误,立即停止。将存储器芯片插上,执行如下程序:,50,50,51,51,如一片RAM 芯片的每个单元都出现问题,则有可能是某些控制信号连接不正确;如一片RAM芯片中一个或几个单元出现问题,则有可能是这一芯片本身是不好的,可换一片再测试一下。 检查I/O扩展接口 对可编程接口芯片,如82C55,首先要对该接口芯片进行初始化,再对其I/O端口进行I/O操作。初始化要按系统设计要求进行,这个初始化程序调试好后就可作为正式编程的相应内容。程序初始化后,可对其端口进行读/写。对开关量I/O来讲,在用户样机板上可利用钮子开关和发光二极管进行

34、模拟,也可直接接上驱动板进行检查。一般情况下,,52,52,用户样机板先调试,驱动板单独进行调试,这样故障排除更方便些。 如用自动程序检查端口状态不易观察时,可用开发系统的单步功能,单步执行程序,检查内部寄存器的有关内容或外部相应信号的状态,并确定开关量输入/输出通道连接是否正确。 若外扩一片82C55芯片,端口地址为B000B003H,A口为方式0输入,B口、C 口都为方式0输出,则可用下述程序进行检查:,53,53,54,54,对于锁存器和缓冲器,可直接对其端口进行读/写,不存在初始化的问题。 通过上面介绍的调试用户样机过程,读者可以体会到离开仿真开发系统就根本不可能进行用户样机的软硬件的联调,而调试的关键步骤动态在线仿真调试,又完全依赖于开发系统中的在线仿真器。所以,开发系统的性能优劣,主要取决于在线仿真器的性能优劣,在线仿真器所能提供的仿真开发手段,直接影响设计者的设计、调试工作的效率。所以,对于设计者来说,在了解目前的开发系统的种类和性能之后,选择一个性/价比高的仿真开发系统,并能够熟练地使用它来调试用户样机是十分重要的。,

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。