0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

开放源代码ROM监控器RedBoot的功能特点及调试技巧分析

牵手一起梦 来源:电子工程网 作者:佚名 2020-10-04 13:37 次阅读

开放源代码ROM监控器RedBoot的功能特点以及配置方法,它可以提供一种下载调试环境,且体积非常小巧。RedBoot也称作红帽(Red Hat)嵌入式调试引导程序,是一种用于嵌入式系统的独立开放源代码引导/装载器,任何人都可以从互联网上下载具有红帽eCos公共许可证的RedBoot源代码。虽然RedBoot使用的是源于eCos实时操作系统RTOS)的软件模块,并且常用于嵌入式Linux系统,但它与这两种操作系统完全无关,RedBoot能够用于任何操作系统或RTOS,甚至没有操作系统也行。

RedBoot自带一个GDB“存根进程(stub)”,可提供目标端通信软件,允许用户通过标准GDB协议命令进行远端调试,这样设计师就能利用RedBoot与运行GNU调试器的主机通过串口或网络连接起来调试设计的嵌入式软件。RedBoot支持多种处理器架构和硬件平台,包括ARM、日立SHx、MIPS、PowerPC、SPARC以及x86等。

结构配置

RedBoot可以在多种不同配置下运行,但一般都是从目标平台的闪存引导区或引导ROM启动。RedBoot设计为系统上电启动,能提供完整的处理器初始化和设备设置,使设计人员能够迅速开始与系统通信。

RedBoot可设为用串口或以太网口(通过Telnet)进行通信,当从某个端口收到第一条命令后,那么随后所有的RedBoot通信都将从那个端口进行,直到系统重新启动。

利用以太网口与RedBoot通信时,一定要清楚目标平台是如何得到其IP地址的。设置目标平台IP地址有两种方法,分别是动态法和静态法。在静态方式下,目标平台的IP地址在编译RedBoot映像前设置(后文还会详细讨论这方面内容),也可通过串口命令设置。

RedBoot还可以采用BOOTP协议动态分配IP地址,BOOTP协议是目前许多网络广泛支持的动态主机配置协议(DHCP)的一个子集,与静态法一样,可在编译时或通过串口命令,使目标平台使用动态网络配置。当然,为了取得IP地址,目标设备必须连到能够访问BOOTP或DHCP服务器的网络上。

当装载的应用软件本身需要IP地址时,切记RedBoot映像不能使用动态IP地址,否则会在以太网端口的IP地址配置中引起冲突,从而造成与RedBoot或应用软件通信错误。在这种情况下,最好给不在动态网络配置协议范围内的RedBoot设置静态IP地址。

RedBoot还能根据与BOOTP响应一起收到的配置信息,用一般文件传输协议(TFTP)自动下载应用软件代码,此时在主机上同样需要TFTP服务器以提供软件映像访问。

命令行语句

RedBoot通过命令行接口(CLI)输入命令,在最小模式下,RedBoot命令行接口建立在目标平台硬件串口上,当有多个串口时,RedBoot可以用其中任何一个建立通信。RedBoot还能利用Telnet协议在以太网端口建立CLI(默认情况下RedBoot将端口9000用于Telnet,不过可以用下面讲到的fconfig命令改变端口号)。

CLI输出的RedBoot初始化信息如图1所示,这些信息提供了有关RedBoot映像的信息,包括映像建立日期、目标硬件平台以及可供RedBoot使用的资源等。当显示出提示符:RedBoot> 后,就表明CLI已经准备好,用户可以开始输入命令。

开放源代码ROM监控器RedBoot的功能特点及调试技巧分析

图1CLI输出的RedBoot初始化信息

RedBoot命令的基本格式是:

命令 [-选项1] [-选项2 参数值] 操作符

命令格式中的选项1和选项2代表可以加到某些命令中的可选参数,用于指示一些特定动作或附加信息,在选项2中还包括一个数值。操作符定义了某些特殊命令所需的附加信息。命令也可以缩写成最短的无歧义字符串,如dump、dum、du和d都是dump命令的有效写法。

RedBoot用load命令下载应用软件映像,映像可以用TFTP协议、X/Y调制解调器协议或直接从目标硬件下载。映像成功下载到目标平台后,就可以用go命令运行软件。

在RedBoot提示符下可键入help命令显示所有可用命令列表,并不是所有命令都能用于各种RedBoot映像,命令是否可用取决于目标平台的资源状况,例如有些命令就不适合用于没有闪存的硬件平台。

首字符是“$”的命令代表执行后会在RedBoot映像中调用GDB stub,一旦进入GDB模式,RedBoot就会一直保持这种模式直到系统重新启动。

有几条RedBoot命令需要在这里重点提一下。首先是闪存映像系统(fis)命令,当硬件平台上配有闪存时,RedBoot提供fis命令作为基本文件系统,这些命令主要用来管理文件系统映像。

另一个有用的命令是基于闪存的配置和控制命令fconfig。图2给出了用fconfig命令查询的输出信息,从中可以看出,配置命令可以设置RedBoot启动顺序。启动配置包括是否在初始化期间运行引导脚本、是否用BOOTP协议获取IP地址以及是否用GDB telnet端口进行调试等。

图2 用fconfig命令查询

RedBoot也支持引导脚本,因此允许用户在上电过程完成后执行所需命令。在产品测试阶段采用RedBoot装载应用软件映像时引导脚本很有好处,用户还可以设置超时参数,在引导脚本执行前按下Ctrl+C中断执行。引导脚本可用fconfig命令进行设置。

构建RedBoot

能够自己重新构建RedBoot对用户来说非常重要,因为随时都可能需要进行代码更新和缺陷更正;如果用户希望定制RedBoot,那么也需要重建RedBoot,比如增加自己的命令或与它的接口。

重建RedBoot映像的第一步是建立主机开发环境,建立RedBoot映像的工具要能运行在Windows或Linux主机平台上。主机开发工具包括GNU二进制应用程序(常称为binutils)、C/C++编译器和调试器。安装完GNU工具后,接着就是确定配置工具,用户可以采用图形化配置工具或命令行工具配置建立RedBoot映像。本文重点讲述图形化配置工具。

配置工具允许进行源代码级设置,从而确保RedBoot映像是专为各个用户应用而开发的,整个源代码知识库和配置工具用元件定义语言(CDL)描述库中的元件及建立软件映像规则。配置工具利用先前设立的GNU工具建立适合特定处理器结构的RedBoot映像,有关配置工具的更多信息可以从网上得到,也可以从帮助菜单中获得。

下面的例子使用的是configtool-2.08-setup.exe,它是目前最新版配置工具,在安装之前最好阅读一下readme.txt文件,一起下载的changes.txt文件则列出了不同版本的变动情况。接下来就是下载RedBoot源代码,RedBoot源代码包含在匿名CVS库中,可以用免费的客户软件访问。连上库以后,最好将包括eCos文件在内的所有源代码都下载,因为RedBoot会使用设备驱动器之类的eCos源文件。在确定建立自己RedBoot映像所需所有文件后,可以删掉其它不必要文件。RedBoot软件结构主要软件模块方框图如图3所示。

图3 主要软件模块方框图

RedBoot软件结构采用分层方法,这样可以装入新的功能和软件组件,RedBoot的基础是eCos硬件抽象层(HAL)和设备驱动器。

让我们看一下RedBoot的源代码目录结构。从匿名CVS库中下载的源代码文件都放在packages子目录下,这个主目录下面是redboot子目录,里面存放全部RedBoot文件。由于所有文件都是从匿名CVS库下载的,因此都位于current子目录下。在redboot子目录下有个名为ChangeLog的文件,它记录了RedBoot源文件的所有修改情况。

配置工具能够非常方便地用图形化方式配置RedBoot映像建立所必需的组件,通过选中或不选中某个特定组件选择框,可以激活或去除相应的配置选项,设置值可在窗口右边的方格中加入。

创建新RedBoot配置有两种方法。第一种方法是在配置工具的Build菜单下选择模板,这时会弹出模板对话框,然后从中选择硬件平台和模板数据包,这里我们的模板数据包选择redboot。这种方法为建立默认配置RedBoot映像提供了一个基本方式,选择菜单Build->Packages,在弹出的Packages对话框中可以添加或删除其它数据包。

第二种创建RedBoot新配置的方法是导入eCos最小配置文件(.ecm)。RedBoot支持的每个硬件平台都包含这样的最小配置文件,这些配置文件一般位于硬件抽象层目录hal下对应于每个结构的misc子目录中。

最小配置文件包含特定硬件平台基本配置信息,将.ecm文件作为出发点,我们就有了作为基础的硬件平台工作配置文件,可改变配置选项支持RedBoot映像所需要的任何修改。

最小配置文件同样使用CDL。图4是一个eCos最小配置文件实例,源自redboot_ROM.ecm文件,适合那些采用PowerPC的Motorola MBX开发板。从图中可以看到,.ecm文件列出了cdl_configuration命令的数据包清单,需要包含在RedBoot配置中。cdl_option命令用来为特定选项设置选项值。

图4 eCos最小配置文件实例

大多数支持平台都包含一个可以导入的ROM和RAM RedBoot.ecm文件作为配置起点,ROM和RAM表明RedBoot映像在目标硬件上的存放位置。一般情况下,RAM配置在最初调试硬件时使用,而ROM配置则在映像调试完成后准备存放进闪存时使用。RAM映像还可用于更新驻留闪存的RedBoot映像。i386 PC目标平台还包含了一个RedBoot FLOPPY配置文件,可供软盘启动RedBoot时使用。

为了导入最小配置文件,需要选择配置工具菜单中的File->Import命令,然后浏览相应的.ecm文件并选中,配置工具利用.ecm文件装载相应数据包并设置对应选项。如果发生因配置选项设置引起的冲突,配置工具会显示一个冲突解决对话框,选择继续按钮就可解决该冲突。

由于RedBoot还依赖其它软件模块如HAL,因此并不是所有的配置选项都包含在RedBoot ROM监控数据包内。在eCos HAL包中就有底层硬件配置选项,其它可能需要配置的数据包还有设备驱动器,例如在包括网络支持的平台上,以太网设备驱动器选项就包含在通用以太网支持包内。

如果想要网络通信,还需要建立RedBoot网络配置选项,这样可以设定目标硬件的默认IP地址,或BOOTP初始化期间使用的配置。

完成RedBoot配置后,最好把最小配置文件保存下来,这一步可以通过选择File->Export并输入文件名完成。

创建RedBoot映像

接下来需要保存当前的配置。为了将当前配置保存为eCos当前配置文件(.ecc),需要选择File菜单中的Save As命令,不妨把文件存为redboot_rom.ecc。这步操作将生成正在创建的RedBoot映像的工作目录结构,所有目录都将以刚才创建的.ecc文件名开头。在本例中,目录名以redboot开始。

正确设置好配置以后,下面就可以开始创建RedBoot映像了。为了执行创建过程,需要采用Build->Library命令,此时配置工具输出窗口将显示相关创建信息。创建过程完成后,生成的RedBoot映像存放在redboot_install\bin子目录中,本例中新的RedBoot映像取名为redboot_rom.bin。

更新目标平台

将RedBoot映像装进非易失性存储器根据目标不同有很多方法,一般情况下,映像必须用软件编进闪存或用设备编程器编入ROM。

RedBoot映像装入闪存后,就可以直接执行缺陷修正或增加功能等映像更新任务,此时需要已有的闪存RedBoot映像和新建立的从RAM运行的RedBoot映像的支持。

首先从闪存启动目标平台并运行旧的RedBoot映像,由于这里采用了闪存映像系统命令将新的RedBoot映像编入闪存,因此需要执行 :RedBoot> fis init ,命令初始化fis系统。该命令用于初始化闪存,使新的映像能用fis命令下载。映像系统初始化完成后,可以用 :RedBoot> fis list ,命令查看闪存中的映像。此时会得到类似于图5的输出,根据实际使用的硬件平台而显示不同的地址、长度和入口地点,同时还能看到RedBoot映像名,该映像名代表的是目前正在闪存中运行的RedBoot映像。

图5 闪存输出图

接着用上述同样的步骤创建一个RedBoot RAM映像redboot_ram.bin。为了建立从RAM运行的映像,需要确保启动类型(CYG_HAL_STARTUP)配置选项设为RAM。因为硬件平台包括ROM和RAM最小配置文件,因此导入并建立RAM配置并不困难,重要的是要记住将RAM和ROM映像存放到不同的工作目录中。

下一步用驻留在闪存中的原有RedBoot映像将新的redboot_ram.bin载入到RAM中,这步操作的命令是:

RedBoot> load redboot_ram.bin

载入命令的执行有好几种方法,如把映像从主机发送到目标硬件的TFTP,具体哪种方法取决于用户实际可用资源情况,fis load命令还能用来通过闪存映像存储系统装载和存储redboot_ram.bin映像。

我们用go命令执行刚载入RAM中的RedBoot映像。RedBoot映像从RAM执行后会产生新的类似于图1的初始化消息,要注意这时是从RAM执行RedBoot映像的。

接着用与上面相同的步骤装载新创建的ROM RedBoot映像,装载redboot_rom.bin映像的命令是:

RedBoot> load redboot_rom.bin -b

命令行中的ram_addr指RAM中的位置(不同的平台有不同的值),这里临时存放着即将编入闪存的redboot_rom.bin映像。

现在就可以用fis命令将新映像写进闪存了。某些平台可以支持闪存的锁定和解锁,如果用户能够解锁闪存,那么用户需要输入的第一条fis命令是:

RedBoot> fis unlock -l

这里flash_addr是需解锁的闪存地址,本例中这项参数对应的是fis list命令中RedBoot映像名称的闪存地址,从fis list命令中还能得到长度。如果平台不支持闪存锁定,那么用户可以跳过这一步。

随后可以用命令:RedBoot> fis create RedBoot -f -b -l -s ,将RAM中的RedBoot新映像写入闪存中。其中flash_addr是RedBoot新映像写入闪存的位置,如fis list命令所示,ram_addr是redboot_ROM.bin文件载入RAM存储器的位置。flash_len同样出现在fis list命令中,代表RedBoot闪存映像的长度,data_len则是将被写进闪存的redboot_rom.bin文件的长度。

在继续下面的操作之前,fis create命令会询问用户是否愿意替换现有名为RedBoot的映像,如果回答“是”则将把新的映像装入闪存。下一步,如果硬件平台允许锁定闪存,那么就可以用:RedBoot> fis lock -f -l ,命令完成闪存锁定。上面讨论的针对所支持平台实际存储位置在RedBoot文档中有详细说明。最后重新启动硬件就可以启用刚才写进闪存的RedBoot新映像了。

发展前景

目前新版RedBoot正计划与eCos v.2同时推出,新版RedBoot增强功能包括DHCP客户机、嵌入式web服务器、USB调试和IDE驱动支持。

即使没有这些功能改善,RedBoot ROM监控器也能提供一种低成本而且容易使用的硬件调试与测试方法。由于RedBoot是开放式源代码,因此用户能够定制RedBoot以满足项目开发和测试阶段遇到的所有特殊需求。RedBoot对GDB的支持甚至可以让用户不再需要昂贵的硬件调试工具。

责任编辑:gt

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 操作系统
    +关注

    关注

    37

    文章

    6727

    浏览量

    123182
  • 代码
    +关注

    关注

    30

    文章

    4741

    浏览量

    68324
  • 监控器
    +关注

    关注

    1

    文章

    265

    浏览量

    26527
收藏 人收藏

    评论

    相关推荐

    开放源代码获得授权许可

    也多种多样,最近的方式是开放源代码。  由于设计者在开发软微处理的软件代码时投入了大量的时间,所以理解相关许可模式的含义非常重要。    
    发表于 06-25 06:25

    开放源代码获得授权许可

    也多种多样,最近的方式是开放源代码。 由于设计者在开发软微处理的软件代码时投入了大量的时间,所以理解相关许可模式的含义非常重要。
    发表于 07-12 07:13

    采用ROM监控器调试技巧是什么?

    采用ROM监控器调试技巧是什么RedBoot命令的基本格式是什么如何构建RedBoot
    发表于 04-27 06:18

    开放源代码数据库系统

    开放源代码数据库系统 摘要: 开放源代码软件的流行推动了计算机软件的发展。本文从几个方面分析并比较了四种开放源代码的数据库系统。
    发表于 02-09 15:34 5次下载

    开放源代码软件的法律探讨

    开放源代码软件的法律探讨 另外应根据 产品质量法》第21条第2款“产品质量认证机构应当依照国家规定对准许使用认证标志的产品进行认证后的跟踪检查:对
    发表于 02-09 16:07 3次下载

    LINUX开放源代码之应用

    LINUX开放源代码之应用 服务端的优势♦ LINUX是一个真正意义上的多用户、多任务系统:一个普通的BBS站使用Linux系统的普通微机,同时上线人数都能达到
    发表于 02-10 13:43 21次下载

    基于开放源代码的硬件设计方法研究

    基于开放源代码的硬件设计方法研究 摘要:可重用性是当今超大规模集成电路设计的必要元素。与传统的封闭源代码付费IP 相比,开源硬件以共享设计文档和IP
    发表于 02-10 13:50 9次下载

    2008开放源代码技术日-MySQL Replication

    2008开放源代码
    发表于 02-10 14:44 2次下载

    开放源代码/开放标准与创新

    开放源代码/开放标准
    发表于 02-10 15:08 3次下载

    开放源代码的全文检索引擎 Lucene

    开放源代码的全文检索引擎 Lucene――介绍、系统结构与源码实现分析 第一节 全文检索系统与Lucene简介 一、           &
    发表于 02-10 15:09 5次下载

    Novell加入开放源代码计划 开放Linux产品

        8月5日国际报道 继对手Red Hat 之后,Novell也计划在下周宣布推动一个开放源代码计划OpenSuse,将Linux 产品开放给外面的程序开发人员。   &nbs
    发表于 03-13 13:09 564次阅读

    开放源代码”是什么?

    开放源代码”是什么?您购买或下载的大多数软件只提供已编译的可运行版本。“已编译”意味着开发人员创建的实际程序代码(称为源代码)已经由一个称为编译的特
    发表于 07-29 09:43 2342次阅读

    Linux开放源代码的操作系统

    作为一个开放源代码的操作系统,Linux附带的源代码库使得广大爱好者有了一个广泛学习、深入钻研的机会,特别是Linux内核的组织极为复杂,同时,又不能像windows平台的程序一样,可
    发表于 04-20 21:00 112次下载

    开放源代码是什么意思?

    开放源代码其实就是当程序员把软件写好后,不仅仅把软件公开给别人使用还把自己写程序时的源代码公开给别人学习、甚至是修改达到不断的升级象最著名的开源软件就是Linux和Unix这两个操作系统。
    发表于 11-16 16:10 2.7w次阅读

    Google计划使用Android开放源代码项目

    常,新的表情符号会随主要系统更新一起提供。用户对其没有太多控制。不过,Google计划使用Android开放源代码项目(ASOP)Gerrit将表情符号的分布更改为操作系统。
    的头像 发表于 11-27 16:11 1844次阅读