快速嵌入式MCU设计仿真的三大因素浅析

最新更新时间:2013-05-26来源: 互联网关键字:嵌入式  MCU  仿真 手机看文章 扫描二维码
随时随地手机看文章
调试嵌入式应用有很多种方法。设计者利用包含电路内置仿真器(in-circuit emulator,ICE)和电路内置调试器(in-circuit debugger,ICD)的调试工具可以快速构建出系统原型,帮助设计者在建立原型阶段和最终测试阶段查找硬件和软件中的问题。在调试过程中,成本和易用性是人们主要关心的问题,相比ICE工具,设计者可能更喜欢使用仿真器来调试代码段,因为仿真器可以直接在PC上运行,不需要映射到目标硬件上。

  仿真器使用起来非常方便,通过它们开发人员可以了解一款新型的MCU,或者熟悉一套新的集成开发环境(integrated development environment ,IDE)工具包,而不需要接触目标硬件。有的时候,设计者可以免费浏览某个供货商的所有MCU产品。例如,用户可以从官方网站上免费下载到 Microchip的MPLAB IDE 和 MPLAB SIM仿真器(如图1所示)。

  

  图1 很多仿真器(例如Microchip的MPLAB SIM)都为用户提供了快速调试应用程序所需的图形用户界面

  仿真器提供了特殊调试功能

  一般而言,仿真器运行在IDE环境下,并且具有与其他调试引擎类似的功能。用户在开始使用仿真器时通常用它来开发代码,当硬件设计完成后,可以用硬件调试器进行测试工作。仿真器能够实现的基本调试功能包括:执行代码验证其功能是否符合设计规范;复位目标系统重新运行应用程序;在断点处暂停程序执行;检查和修改存储内容与变量。

  最新的仿真器具有某些硬件调试器所不具备的独特功能,利用这一类仿真器可以实现更多的功能。例如,可以轻松实现复杂情况下的中断执行——这是任何ICE和ICD工具都不具备的。通过事件计数和断点执行,用户可以构造出复杂事件。利用这种复杂断点,可以描述出代码行为异常的情况,追踪异常情况下的代码。这种方式相比在代码中设置简单断点和跳步执行,能够更快速地发现bug。

  通过仿真分析代码

  设计者可以利用仿真器响应引脚的输入输出信号,模仿MCU外设部件的行为。为了实现这一功能,有些高级仿真器就提供了能够模拟信号的复杂激励发生器。利用这一功能,用户可以通过向固件模块加载输入信号的方式来测试固件模块,例如,可以产生两个相隔50ns的中断信号。这种模拟信号的方式是利用真正的硬件很难做到的。激励发生器可以向器件引脚或仿真器内的寄存器发送信号。通过使用USART以I/O设备的方式或者使用寄存器日志的方式,可以将仿真器的行为记录到一个log文件中以便于后续分析。

  大多数仿真器支持三种激励源。手动触发可以通过鼠标点击、产生重复波形的循环式激励,以及向引脚、寄存器或者寄存器中的某些位加载数据的连续型激励来产生。这些连续型数据可以输入对话框,或者来自于某个文件。仿真器还可以模拟外设部件,从而诸如A/D转换器、I/O引脚、串行通信设备和定时器等设备就可以被激活。这些外设可以采用仿真波形和模拟数字信号的输入,可以接受手工输入来模拟中断和传感器读数(如图2所示)。

  

  图2 仿真器通常支持三种激励源并且具有方便的定义和配置功能

  提高代码性能

  大多数高级仿真器都能够将应用程序在目标系统上的执行过程与源代码关联起来,使设计者能够单步执行高级语言代码,例如C代码,即使每条C语句可能会生成多行机器代码。同样,文件寄存器中的存储器内容也能够与程序中使用的变量关联起来。因此,如果某个浮点数跨越多个机器文件寄存器,设计者就可以在观察点监测到该寄存器的内容,并以浮点表示形式显示出来。

  利用仿真器还可以优化程序例程,精确测量并调整某些关键代码的执行时间。用户可以使用仿真器的秒表功能对一段代码的执行过程进行计时。根据处理器的频率,就可以对所执行的指令进行秒表计时。

  秒表功能不是仿真器中测量时间的唯一方式。某些应用(例如电机控制)不允许在某个断点处中断运行。在这些情况下,将程序流和寄存器读写结果保存在追踪缓冲器(trace buffer)内就是一种好的替代办法。追踪缓冲器在指令执行的时候将其记录下来,并给每条指令打上一个时间戳。这样,当捕捉到追踪缓冲器内的事件后,就可以对其进行计时了。例如,捕捉到了一系列中断,那么就能够很容易地计算出中断之间的时间间隔,以及每个中断执行所花的总时间。

  仿真器可以将寄存器值的变化情况记录到文件中,用于性能分析。利用仿真器,工程师可以观察出某个算法对多种输入的响应情况,从而对其进行测试或改进。例如,可针对多组已存数据(例如使用目标硬件从A/D转换器结果寄存器中读取的数据)进行快速傅立叶变换(FFT),但是要对所希望看到的数据类型进行总数控制。

关键字:嵌入式  MCU  仿真 编辑:神话 引用地址:快速嵌入式MCU设计仿真的三大因素浅析

上一篇:一种基于DSP的视频监控系统解决方案
下一篇:非易失性存储器主导闪存发展的关键技术

推荐阅读最新更新时间:2023-10-12 20:46

Atmel开始提供Cortex-M7内核MCU,性能业界最高
Atmel供应基于ARM Cortex-M7的MCU,Atmel | SMART SAM S/E系列MCU目标面向物联网和工业市场 Atmel | SMART ARM Cortex-M7 MCU提供广泛的软件生态系统和第三方支持以及先进的内存和连接技术,性能比排名第二的竞争对手高50% 全球微控制器(MCU)及触控技术解决方案领域供应商Atmel公司 (纳斯达克股票交易代码:ATML)今日宣布,公司已开始批量生产市场上性能最高、基于ARM Cortex -M的MCU产品 Atmel | SMART SAM S70和E70系列。 与最接近的竞争对手相比,这些MCU的性能高出 50%,拥有更大
[单片机]
Microchip在线商店现全面供应所有Atmel原有产品
全球领先的整合单片机、混合信号、模拟器件和闪存专利解决方案的供应商——Microchip Technology Inc.(美国微芯科技公司)宣布旗下全业务渠道microchipDIRECT在线商店开始全面供应所有Atmel原有产品。客户首次可以直接从供应商处购买AVR®和 SAM系列单片机及开发工具等产品。   Microchip全球销售副总裁Mitch Little表示:“我们的首要任务是确保microchipDIRECT在线商店覆盖Microchip全系列产品。我们都知道Microchip老客户对microchipDIRECT的评价非常高,我们很高兴它现在能覆盖更多的产品线,为新客户提供这一服务。”   作为Microchip
[半导体设计/制造]
PIC单片机数码管计数器示例程序
P IC   单片机   数码管 计数器示例程序 ;**************************************************   __CONFIG 3F39H;设置配置位中振荡方式为XT,其它全部禁止或关闭 ;************************************************ PCL       EQU    02H  ;定义程序计数器低字节寄存器地址 STATUS    EQU    03H  ;定义状态寄存器地址 PORTA     EQU    05H  ;定义RA口数据寄存器地址 PORTB     EQU    06H  ;定义RB口数据寄存器地址 PORTC  
[单片机]
51单片机led灯渐变PWM调光(渐亮渐灭)C语言和汇编源程序
PWM控制led灯渐亮渐灭程序 适用ME500开发系统 短接JP41-2选用8个LED灯 PWM—PulseWidthModulation(脉冲宽度调制) PWM足?种周期?走而高低电平的rV空比可以调制的方波信兮. 按K2—下,PWM值减小,则占空比增加。 兗度逐渐增加,直到8个LED灯达到高亮,蜂鸣器响。 按K1—下,PWM值增加,则占空比减小。 立度逐渐减弱,直到8个LED灯达到最峭,蜂鸣器响。 单片机汇编语言源程序如下: ; PWM 控制 LED 灯渐亮渐灭程序 ; 适用 ME500 开发系统 ; 晶振为11.0592M ; 利用定时器控制产生占空比可变的 PWM 波 ; 按K1,PWM值增加,则占空比减小,LED 灯渐
[单片机]
基于单片机的A/D数字电压表设计
工作原理: ADDA/ADDB/ADDC 输入3位地址,并使ALE=1,将地址存入地址锁存器中 ALE:地址锁存允许信号接入端,高电平时允许改变CBA的值,低电平时锁死,防止在A/D转换过程中切换通道 地址经译码选通8路模拟输入IN0~IN7之一到比较器,输入与被选通道关系 START端上升沿将逐次逼近寄存器复位,下降沿启动A/D转换 EOC输出信号变低电平,表示正在转换;当A/D转换完成,EOC变为高电平,结果数据已存入锁存器。 OE输入高电平,输出三态门打开,转换结果的数字量输出到数据总线上。 OE=1时,D0-D7引脚上为转换后的数据,当OE=0时,D0-D7为对外呈现高阻状态 p.s. 其他引脚: I
[单片机]
基于<font color='red'>单片机</font>的A/D数字电压表设计
单片机数码管显示-消影问题
看郭天祥的单片机书中数码管部分,使用 P0=0xff 的方法可以消除段选数据对位选的干扰,另外使用我下面的方法可以达到同样的效果。但即便这样数码管仍有影子,这种状况是,当前数码管有下一个数码管的影子,或者当前数码管有前一个数码管的影子。 分析一下产生原因,当我们点亮一个数码管后,总要先将段选或者位选改为下一个数码管的值,而不能同时改变。当先改变段选时,那么当前数码管就会有短暂的时间显示下一个数码管的数字。当先改变位选时,下一个数码管就会有短暂的时间显示当前数码管的数字。 那么解决方法是,先将段选置0送入锁存器,改变位选的值为下一个数码管,最后再改变段选值。同理另一种方法是,先将位选赋值 0xff 即关闭所有数码管,改变段选
[单片机]
单片机程序设计一般步骤
  (1)分析课题,确定解决方案和算法;   (2)分配系统资源及存储单元;   (3)绘制程序流程图;   (4)设计程序,并反复调试和修改。   彩灯循环设计   ORG 0000H   MAIN: MOV P1, #80H ;D7 发光   MOV P1, #40H ;D6 发光   MOV P1, #20H ;D5 发光   MOV P1, #10H ;D4 发光   MOV P1, #08H ;D3 发光   MOV P1, #04H ;D2 发光   MOV P1, #02H ;D1 发光   MOV P1, #01H ;D0 发光   SJMP MAIN
[单片机]
<font color='red'>单片机</font>程序设计一般步骤
基于AT89C2051单片机和GPS技术实现机器人定位模块的设计
1 引言 定位是根据先验的环境信息,结合当前的机器人位置信息以及传感器输入信息,准确地确定机器人位姿的过程。可靠定位是移动机器人研究中备受关注和富有挑战性的一个重要研究主题。 机器人定位技术可分为绝对定位和相对定位技术两类,绝对定位主要采用导航信标、主动或被动标识、地图匹配或卫星导航技术(GPS) 进行定位。相对定位是通过测量机器人相对于初始位置的距离和方向来确定机器人的当前位置,通常也称为测程法。绝对定位和相对定位各有优缺点,具有互补性,将两者结合能形成更加准确可靠的定位系统。本实验模块的设计就是先用测程法进行相对定位,然后利用电子罗盘进行纠正。 2 定位原理及硬件设计 2.1定位原理 本设计对应的机器人是前后轮独立驱动的,
[单片机]
基于AT89C2051<font color='red'>单片机</font>和GPS技术实现机器人定位模块的设计
小广播
最新模拟电子文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved