微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > Multisim 10中的MCU模块如何进行单片机协同仿真

Multisim 10中的MCU模块如何进行单片机协同仿真

时间:09-10 来源:电子发烧友 点击:

调试程序

选择菜单MCU→MCU 8051 U1→Debug View,可以看到文本区上面有下拉菜单并有两种选择,对应反汇编(disassembly)和列表汇编(listing assembly),简单的说,前者是由ROM的内容得到,后者是源文件编译后的结果。双击"设计工具箱"的main.asm,在源文件编辑窗口右键单击语句为"MOVC A,@A+DPTR"的一行,选择"设置/清除断点"(Toggle Breakpoint),在左侧会出现一个实心圆,点击"运行",程序将停在该行,只不过是在"调试视图"(Debug View)的列表汇编窗口下,同时在实心圆上多出了一个黄色箭头。点击MCU-> MCU 8051 U1->Memory View,打开MCU存储器视图,在该视图可以查看特殊函数寄存器(SFR),内部RAM(IRAM),内部ROM(IROM),外部RAM(XRAM)。在SFR表格内观察ACC的值,此时应该为"00",在IRAM里观察地址为21H的值,因为"MOV SP,#20H"语句将21H作为堆栈的第一个存储字节的地址,断点的前一处语句"PUSH ACC"使该字节存储ACC的值,此时也为"00"。再点"运行",程序第二次停在断点处,观察SFR中的ACC和IRAM中的21H,如图9所示应,两个单元格里的值都应为"01",你还可以双击该单元格进行修改,该值也正是七段数码管即将显示的下一个数。点击MCU菜单,可以看到除了设置断点以外还可单步进入(Step into),遇到函数时进入函数内部;跳过(Step over),即不进入函数;跳出(Step out),即跳出函数到调用函数的下一条语句。    

图9 MCU存储器视图

结束语

本文以一个简单的电路介绍了在NI Multisim下如何进行SPICE模型(这里主要指C1和R1)和8051 MCU的协同仿真。NI Multisim10不但有多种编译和调试功能,还提供了RAM,ROM,键盘,液晶屏等外设,是初学单片机的理想工具。掌握了基本的硬件结构,汇编指令和调试方法后,读者可以利用Multisim开发更复杂的系统并仿真,为下一步设计实际的硬件电路做准备。

说明:因为单片机的电流是有限制的,不能太大,否则会烧毁单片机的。所以应在数码管的CA端和VCC端之间接一个限流电阻(100欧姆);或者在单片机与数码管之间接入一个排阻(7个)也可以,这样仿真时就不会烧毁单片机了。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top