QNX实时操作系统学习笔记之嵌入式系统

上传人:沈*** 文档编号:108170005 上传时间:2022-06-15 格式:DOC 页数:28 大小:197KB
收藏 版权申诉 举报 下载
QNX实时操作系统学习笔记之嵌入式系统_第1页
第1页 / 共28页
QNX实时操作系统学习笔记之嵌入式系统_第2页
第2页 / 共28页
QNX实时操作系统学习笔记之嵌入式系统_第3页
第3页 / 共28页
资源描述:

《QNX实时操作系统学习笔记之嵌入式系统》由会员分享,可在线阅读,更多相关《QNX实时操作系统学习笔记之嵌入式系统(28页珍藏版)》请在装配图网上搜索。

1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateQNX实时操作系统学习笔记之嵌入式系统QNX实时操作系统学习笔记之嵌入式系统QNX实时操作系统学习笔记之嵌入式系统(一)(2011-03-21 08:31:28) 转载一、开发嵌入式系统概述1.简介本节将从整体的角度来介绍开发一个完整的基于Neutrino嵌入式系统的步骤,首先,将会看运行一个Neutrino系统所需要的部件。接下来会看这些部件和他们如何操作,最后,将

2、会学习配置某些部分时要完成的步骤。从软件的角度,当系统启动时下列流程将会发生:(1)处理器开始从复位向量执行代码。初始化程序装载(IPL)会将OS镜像装载并传递控制到镜像中的startup程序。(2)startup程序配置系统并传送控制到neutrino 微内核和进程管理器(procnto)。(3)procnto模块装载附加的驱动和应用程序。2.IPL的角色软件执行的第一步便是装载OS镜像。这是由IPL来完成的。IPL的初始化工作是以最简的方式配置硬件来产生一个允许startup,进而是neutrino微内核程序执行的环境。特别地,这个工作至少包含以下几步:(1)从复位向量开始执行;(2)配置

3、存储控制器,这可能会包含配置芯片选择和(或)PCI控制器(Peripheral Component Interconnect,一种由英特尔(Intel)公司1991年推出的用于定义局部总线的标准)。(3)配置时钟。(4)设置一个堆栈来允许IPL库执行OS认证和启动(镜像下载、扫描、启动、jump)3.IPL的热启动和冷启动IPL有两种类型:热启动和冷启动。热启动IPL是由ROM监视器或BIOS激活,硬件和处理器配置的某些部分已经被启动。另一方面,冷启动IPL则是在任何部分都没有被配置或初始化CPU和硬件刚刚被复位。一般来说,在热启动中需要完成的工作都是在冷启动IPL中的子集。在最后我们将讨论I

4、PL的责任,并描述在镜像的第一个部件启动前全部就绪的状态。根据目标的设计,要完成的步骤可能从0(例如,在一个带有ROM监视器或BIOS的标准平台上运行,并且已经通过disk或network boot完成了IPL热启动;引导ROM已经完成了下面描述的工作)到很多步(例如,一个不带有firmware泛指直接控制硬件的软件,也指固化在硬件中用来控制硬件的软件,比如BIOS的嵌入式系统,镜像是在一个特定的硬件中存储)。最后的状态(镜像的第一个部件开始运行前)具有以下的特性:(1)存储控制器已经配置为允许系统中的存储进入。(2)最基本的硬件配置已经完成(例如,芯片选择EPROM的信息已经被程序化)(3)

5、整个镜像已经被放在线性可寻址的存储空间。(4)镜像的第一部分,startup,现在应该在RAM中(注意到startup代码相对很小,当startup代码完成后RAM区域将被重新声明)不管是IPL或BIOS/ROM监控器代码都负责将镜像传送到线性可寻址存储空间。OS镜像必须以一种IPL或ROM监视器代码能够理解的方式开发,以使它能知道该把镜像放在哪里,镜像装载之后应该把控制送到什么地址。例如,一个IBM PC BIOS系统通常装载一个原始的二进制,然后跳转到第一个地址。其他的系统可能接受ELF格式【 Executable and Linkable Format,可执行连接格式,是UNIX系统实验

6、室(USL)作为应用程序二进制接口(Application Binary Interface,ABI)而开发和发布的。扩展名为elf。】的镜像,用ELF头文件信息来决定镜像和启动地址放置的位置。参考你的硬件资料确定IPL可以接受的镜像格式。一旦IPL已经装载了镜像,整个镜像已经处于线性可寻址存储空间,控制也被传送到startup程序。此时,IPL已经完成了使命。4.startup程序的角色:软件执行的第二步是配置处理器和硬件,检测系统资源,启动OS。这些是由startup程序完成的。当IPL完成了基本的最小配置,使系统到一个startup程序可以运行的状态,startup程序的任务是结束配置。

7、如果IPL检测到不同的资源,它可能与startup程序交流这个信息(这样它就不会重复检测相同的资源)。为了使neutrino能够尽量可配置,我们已经使startup程序可以编写基本定时器、中断控制器、缓存控制器等等程序。它也可以提供kernel callouts,它们是内核可以调用来执行硬件具体化功能的代码片段。例如,当一个硬件中断被激发,代码的一些片段必须决定中断源,而另一些代码片段则必须能清除中断源。注意到startup程序不会配置串口波特率之类的东西。它也不会初始化标准周边设备,例如以太网控制器或EIDE硬件disk控制器这些都留给驱动稍后启动以后来完成。一旦startup代码初始化了系

8、统,并把系统信息放在系统页(一个内核稍后会查看的专用的存储片)后,startup代码负责将控制传送到neutrino内核和过程管理器,它们将完成最后的装载步骤。5.startup的责任:看一下startup代码的完整的任务和流程:(1)复制并解压镜像,如果必要的话。如果镜像不在RAM中的最终目的地址,startup代码就将它复制到那。如果镜像没有被解压,startup代码会自动解压。(2)配置硬件。这儿的主要任务是启动能够决定系统配置的最小配置,然后执行系统配置。(3)决定系统的配置。根据嵌入式系统的特性,可能希望动态地决定startup中的配置,或者(万一是一个深度的嵌入式系统)仅仅是har

9、dcode【指将可变变量用一个固定值来代替的方法】配置信息。抛开信息源不管,startup代码的配置部分需要储存这个信息到一个定义好的数据结构中,之后,当OS启动时会查看它们。所谓系统页区域,这些数据结构包含以下信息:存储配置、硬件设备配置、处理器类型、时间。确定callouts:为了使neutrino内核更加轻便(不仅是对不同的处理器,也是对这些处理器不同的硬件配置),一些callouts必须由startup代码提供。不是所有的callouts都要求你写代码。以下的callouts函数的类由neutrino提供:debug接口、clock/timer接口、中断控制器接口、缓冲控制器接口、电源

10、管理器、miscellaneous(多种多样的,混杂的)。(4)启动内核。startup的最后一步是启动操作系统。startup库:QNX支持的处理器和开发板在bsp_working_dir/src/hardware/startup/boards中找到,或者是QNX文档、BSP文档,如果使用QNX支持的处理器,将会省掉大量的代码编写工作。如果没有标准的嵌入式系统,可以找到最接近的资源,clone合适的功能。6.Neutrino的角色:软件执行的第三步是启动你想要运行的任何可执行程序。OS通过读取和处理存在startup脚本中的信息来完成这个工作,这些信息是在镜像中保存的一系列命令。基本上,OS

11、处理startup脚本文件,它们看起来像是shell脚本。在startup脚本文件中,最好是规定好哪些可执行文件将要被启动以及它们的启动顺序,它们运行时的命令行选项等等。7.硬件因素:从硬件的角度来看,以下的部分组成了系统:处理器、初始化和配置信息的源文件、存储媒介、I/O设备。处理器的选择:支持的处理器家族有ARM(包括XScale)、MIPS、PowerPC、SH-4、x86.初始化和配置信息的源文件:当处理器启动(重启)时,必须能够执行指令。这是通过把一些不挥发的存储媒介放在处理器复位向量完成的。防燃,可以选择由谁来提供这个特殊的软件片:QNX软件系统选择了一个标准的受支持硬件平台。第三

12、方一个BIOS或者ROM监视器或者你一个定制的IPL程序。通常来说,一个最简单的开发系统就是做最少的工作量。如果你已经这样完成了工作,说明你用的是标准的受支持的硬件平台,这样只需要你完成少量的工作。如果第三方只提供BIOS或ROM监视器,你的任务就要增加了,需要写一个软件来启动OS,这就是之前提到的热启动,因为系统已经热身完成,各种设备已经被配置并初始化。如果是你定制一个IPL,你的任务就更多了,要处理硬件的配置。这是冷启动,因为你要做所有的初始化和配置工作。文件系统的选择:已经弄清楚如何启动系统,现在仍然需要决定系统的存储能力:不需要;只读;读写不长久的;读写持久。如果你不需要任何附加的存储

13、器(也就是说你的系统完全是自包含而且运行以后不需要进入其他文件),到这你的工作就完成了。如果需要只读存储器,最简单的文件系统脚本要求进入只读文件。没有工作需要你完成,OS自己会提供这个功能,只需要把你想执行或进入的问津放入镜像,OS便可以进入他们。如果需要写文件,存储器也不必持久(也就是说它不需要经受复位),这个工作OS也会帮你完成。Neutrino允许系统中的RAM被用作RAM-disk,没有任何附加的代码或设备驱动。这个RAM-disk通过进程管理器完整,只需要建立一个进程管理器链接(用ln命令)。例如,要安装/tmp路径作为RAM-disk,执行下列的命令:ln -Ps /dev/shm

14、em/tmp或者将下面一行放在buildfile中:type=link /tmp=/dev/shmem这条指令引导进程管理器把任何文件安置在/tmp下,并且使它们能够共享存储子系统。例如/tmp/AAA4533.tmp成为对/dev/shmem/AAA4533.tmp的请求。如果是要求存储器必须能够经受掉电或处理器复位,就需要运行一个附加的驱动。我们提供了这些文件系统的类:flash文件系统、rotating(循环)disk文件系统、网络文件系统。以上这些文件系统都需要附加的驱动。附录的sample buildfiles讲述了如何建立这些文件系统驱动。flash文件系统和媒介:flash驱动可

15、以接口到全组合总线宽度(8,16,32位)的flsh存储设备(启动程序块块和常规)和插入因素。循环媒介和文件系统:目前neutrino支持几种文件系统,包括DOS,Linux,Macintosh,HFS,HFS Plus,WindowsNT,QNX4,power-safe,universal disk format(UDF)等等。许多面向程序块的设备驱动可以获得。网络媒介和文件系统:可以使某个设备中的文件爱你系统进入到别的设备的文件系统中。I/O设备:串/并行口;网络接口;数据获取/产生;多媒体。在开发时,想法的证明应该是基于以下问题:1.需要多少内存?2.CPU需要的运行速度?3.现有的标准

16、硬件是否能满足?硬件设计:参考附录system design considerationQNX实时操作系统学习笔记之嵌入式系统(二)(2011-03-21 09:00:19) 转载一个BSP一般包括:IPL,startup,默认的buildfile,网络支持,具体开发板设备驱动,系统管理器,公用工程等。一般情况下BSP是以源代码的形式给出的,除非对源代码有限制的,只会以二进制形式给出。一般把安装BSP的路径成为bsp_working_dir,包含以下子路径:src,prebuit,install,images.images路径是最终boot images存放的地址,它包含了运行image(s)

17、的makefile。这个路径中的其他文件包括了custombuildfiles(for flash等),EFS buildfiles,IPL build scripts。prebuilt路径包含prebuilt二进制文件以及和BSP一起的头文件。在BSP被build之前,prebuilt路径中的所有文件都被复制到install路径中,包括路径结构。install路径在BSPbuild过程的开始得到安置,prebuilt中所有的文件都被复制,所有产生的二进制文件在compile的同时都被安装到这。当mikifs执行的时候,install路径中的文件首先被使用。-以上部分是在使用command来编

18、译BSP的时候需要用的。将OS镜像下载到开发板: 编译好OS镜像后,就要将它下载到开发板。可以用IDE通过串口将镜像下载,或者用TFTP网络接口,如果开发板没有ROM监视器,可能就不能使用IDE的下载功能。可以使用别的方式下载,例如JTAGflash文件系统:flash文件系统驱动在NORflash存储设备上补充一个POSIX-like文件系统。对于不同的嵌入式系统硬件例如PCMCIA存储卡,有很多种文件系统驱动的版本。命名方式是devf-系统名。例如devf-800fads驱动就是800FADS PowerPC评估板的驱动。flash文件系统驱动支持一种以上的逻辑闪存驱动。每一种逻辑驱动成为

19、一个socket,由相邻的同类闪存区域组成。例如,在一个在不同的地址中包含两种类型的闪存设备的系统,一个是用来启动镜像,另一个是flash文件系统,每一个闪存设备将会出现在不同的socket中。每个socket可能被分为一个或多个分区。QNX支持两种分区,裸分区(raw partitions)和flash文件系统分区。裸分区是socket中不包含flash文件系统的任意分区,flash文件系统驱动不会识别除了flash文件系统的任何文件系统类型,一个裸分区可能包含了一个镜像文件系统或一些应用专用的数据。flash文件系统分区包含了POSIX-like闪存文件系统,它用QNX专有的格式将文件系统

20、数据保存在flash设备中。这个格式和MicrosoftFFS2或PCMCIA FTL规格是不兼容的。flash文件系统允许文件和路径随意创建删除。它支持所有标准的POSIX公用工程,如ls,mkdir,rm,ln,mv,cp,也有一些用于管理flash文件系统的QNX Neutrino公用工程。flashctl:擦除,格式化和列出flash分区。deflate:压缩flash文件系统的文件。mkefs:创建flash文件系统镜像文件。flash文件系统支持所有标准的POSXI I/O函数,例如open()close()read()write().特殊的功能也是被支持的,例如擦除使用devct

21、l().flash文件系统源:每一个BSP包含了合适的flash文件系统驱动的二进制和源代码,但是QNX软件开发平台包含了相关了头文件和库文件。如何创建一个分区:启动flash文件系统驱动;擦除整个flash;格式化分区;slay(杀死,杀戮)flash文件系统驱动;重启flash文件系统驱动。以下是Renesas Biscayne 开发板的例子,它可以从DMON或flash启动:1.要从DMON开始启动,输入以下的命令启动flash文件系统驱动:devf-generic -s0xe800000,32M &2.要从flash启动,输入以下命令:devf-generic -s0x0,32M现在应该可以看到一个fs0p0入口在/dev下面。3.要为分区准备区域,必须擦除整个flash。输入以下命令:flashctl -p/dev/fs0 -ev4.格式化分区,输入以下命令:flashctl -p/dev/fs0p0 -f5.slay flash文件系统驱动:slay devf-generic6.最后,重启驱动:devf-generic &现在,可以看到以下入口:/dev/fs0p0 OS镜像(32MB)/dev/fs0p1 flash文件系统分区(32MB)-

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!