UC/OS和UCLinux比较 点击:5544 | 回复:3



gongkongedit

    
  • 精华:1099帖
  • 求助:0帖
  • 帖子:14392帖 | 54470回
  • 年度积分:0
  • 历史总积分:622
  • 注册:2008年9月08日
发表于:2004-03-01 14:00:00
楼主
uc/os和uclinux操作系统是两种性能优良源码公开且被广泛应用的的免费嵌入 式操作系统,可以作为研究实时操作系统和非实时操作系统的典范。本文通过对 uc/os和uclinux的对比,分析和总结了嵌入式操作系统应用中的若干重要问题, 归纳了嵌入式系统开发中操作系统的选型依据。 两种开源嵌入式操作系统介绍 uc/os和uclinux操作系统,是当前得到广泛应用的两种免费且公开源码的嵌入 式操作系统。uc/os适合小型控制系统,具有执行效率高、占用空间小、实时性 能优良和可扩展性强等特点,最小内核可编译至2k。uclinux则是继承标准linux 的优良特性,针对嵌入式处理器的特点设计的一种操作系统,具有内嵌网络协议、 支持多种文件系统,开发者可利用标准linux先验知识等优势。其编译后目标文 件可控制在几百k量级。 uc/os是一种免费公开源代码、结构小巧、具有可剥夺实时内核的实时操作系统。 其内核提供任务调度与管理、时间管理、任务间同步与通信、内存管理和中断服 务等功能。 uclinux是一种优秀的嵌入式linux版本。uclinux是micro-conrol-linux的缩写。 同标准linux相比,它集成了标准linux操作系统的稳定性、强大网络功能和出 色的文件系统等主要优点。但是由于没有mmu(内存管理单元),其多任务的实 现需要一定技巧。 两种嵌入式操作系统主要性能比较 嵌入式操作系统是嵌入式系统软硬件资源的控制中心,它以尽量合理的有效方法 组织多个用户共享嵌入式系统的各种资源。其中用户指的是系统程序之上的所有 软件。所谓合理有效的方法,指的就是操作系统如何协调并充分利用硬件资源来 实现多任务。复杂的操作系统都支持文件系统,方便组织文件并易于对其规范化 操作。 嵌入式操作系统还有一个特点就是针对不同的平台,系统不是直接可用的,一般 需要经过针对专门平台的移植操作系统才能正常工作。 进程调度、文件系统支持和系统移植是在嵌入式操作系统实际应用中最常见的问 题,下文就从这几个角度入手对uc/os和uclinux进行分析比较。 进程调度 任务调度主要是协调任务对计算机系统内资源(如内存、i/o设备、cpu)的争夺 使用。进程调度又称为cpu调度,其根本任务是按照某种原则为处于就绪状态 的进程分配cpu。由于嵌入式系统中内存和i/o设备一般都和cpu同时归属于 某进程,所以任务调度和进程调度概念相近,很多场合不加区分,下文中提到的 任务其实就是进程的概念。 进程调度可分为"剥夺型调度"和"非剥夺型调度"两种基本方式。所谓"非剥夺型 调度"是指:一旦某个进程被调度执行,则该进程一直执行下去直至该进程结束, 或由于某种原因自行放弃cpu进入等待状态,才将cpu重新分配给其他进程。 所谓"剥夺型调度"是指:一旦就绪状态中出现优先权更高的进程,或者运行的进 程已用满了规定的时间片时,便立即剥夺当前进程的运行(将其放回就绪状态), 把cpu分配给其他进程。 作为实时操作系统,uc/os是采用的可剥夺型实时多任务内核。可剥夺型的实时 内核在任何时候都运行就绪了的最高优先级的任务。uc/os中最多可以支持64 个任务,分别对应优先级0~63,其中0为最高优先级。调度工作的内容可以分 为两部分:最高优先级任务的寻找和任务切换。 其最高优先级任务的寻找是通过建立就绪任务表来实现的。uc/os中的每一个任 务都有独立的堆栈空间,并有一个称为任务控制块tcb(task control block)数据 结构,其中第一个成员变量就是保存的任务堆栈指针。任务调度模块首先用变量 ostcbhighrdy记录当前最高级就绪任务的tcb地址,然后调用os_task_sw() 函数来进行任务切换。 uclinux的进程调度沿用了linux的传统,系统每隔一定时间挂起进程,同时系 统产生快速和周期性的时钟计时中断,并通过调度函数(定时器处理函数)决定进 程什么时候拥有它的时间片。然后进行相关进程切换,这是通过父进程调用fork 函数生成子进程来实现的。 uclinux系统fork调用完成后,要么子进程代替父进程执行(此时父进程已经 sleep),直到子进程调用exit退出;要么调用exec执行一个新的进程,这个时候 产生可执行文件的加载,即使这个进程只是父进程的拷贝,这个过程也不可避免。 当子进程执行exit或exec后,子进程使用wakeup把父进程唤醒,使父进程继续 往下执行。 uclinux由于没有mmu管理存储器,其对内存的访问是直接的,所有程序中访 问的地址都是实际的物理地址。操作系统队内存空间没有保护,各个进程实际上 共享一个运行空间。这就需要实现多进程时进行数据保护,也导致了用户程序使 用的空间可能占用到系统内核空间,这些问题在编程时都需要多加注意,否则容 易导致系统崩溃。 由上述分析可以得知,uc/os内核是针对实时系统的要求设计实现的,相对简单, 可以满足较高的实时性要求。而uclinux则在结构上继承了标准linux的多任务 实现方式,仅针对嵌入式处理器特点进行改良。其要实现实时性效果则需要使系 统在实时内核的控制下运行,rt-linux就是可以实现这一个功能的一种实时内 核。 文件系统 所谓文件系统是指负责存取和管理文件信息的机构,也可以说是负责文件的建 立、撤销、组织、读写、修改、复制及对文件管理所需要的资源(如目录表、存 储介质等)实施管理的软件部分。 uc/os是面向中小型嵌入式系统的,如果包含全部功能(信号量、消息邮箱、消 息队列及相关函数),编译后的uc/os内核仅有6~10kb,所以系统本身并没有 对文件系统的支持。但是uc/os具有良好的扩展性能,如果需要的话也可自行 加入文件系统的内容。 uclinux则是继承了linux完善的文件系统性能。其采用的是romfs文件系统, 这种文件系统相对于一般的ext2文件系统要求更少的空间。空间的节约来自于 两个方面,首先内核支持romfs文件系统比支持ext2文件系统需要更少的代码, 其次romfs文件系统相对简单,在建立文件系统超级块(superblock)需要更少的存 储空间。romfs文件系统不支持动态擦写保存,对于系统需要动态保存的数据采 用虚拟ram盘的方法进行处理(ram盘将采用ext2文件系统)。 uclinux还继承了linux网络操作系统的优势,可以很方便的支持网络文件系统 且内嵌tcp/ip协议,这为uclinux开发网络接入设备提供了便利。 由两种操作系统对文件系统的支持可知,在复杂的需要较多文件处理的嵌入式系 统中uclinux是一个不错的选择。而uc/os则主要适合一些控制系统。 操作系统的移植 嵌入式操作系统移植的目的是指使操作系统能在某个微处理器或微控制器上运 行。uc/os和uclinux都是源码公开的操作系统,且其结构化设计便于把与处理 器相关的部分分离出来,所以被移植到新的处理器上是可能的。 以下对两种系统的移植分别予以说明。 (1)uc/os的移植 要移植uc/os,目标处理器必须满足以下要求; ·处理器的c编译器能产生可重入代码,且用c语言就可以打开和关闭中断; ·处理器支持中断,并能产生定时中断; ·处理器支持足够的ram(几k字节),作为多任务环境下的任务堆栈; ·处理器有将堆栈指针和其他cpu寄存器读出和存储到堆栈或内存中的指令。 在理解了处理器和c编译器的技术细节后,uc/os的移植只需要修改与处理器 相关的代码就可以了。具体有如下内容: ·os_cpu.h中需要设置一个常量来标识堆栈增长方向; ·os_cpu.h中需要声明几个用于开关中断和任务切换的宏; ·os_cpu.h中需要针对具体处理器的字长重新定义一系列数据类型; ·os_cpu_a.asm需要改写4个汇编语言的函数; ·os_cpu_c.c需要用c语言编写6个简单函数; ·修改主头文件include.h,将上面的三个文件和其他自己的头文件加入。 (2)uclinux的移植 由于uclinux其实是linux针对嵌入式系统的一种改良,其结构比较复杂,相对 uc/os,uclinux的移植也复杂得多。一般而言要移植uclinux,目标处理器除了 应满足上述uc/os应满足的条件外,还需要具有足够容量(几百k字节以上)外 部rom和ram。 uclinux的移植大致可以分为3个层次: ·结构层次的移植,如果待移植处理器的结构不同于任何已经支持的处理器结构, 则需要修改linux/arch目录下相关处理器结构的文件。虽然uclinux内核代码的 大部分是独立于处理器和其体系结构的,但是其最低级的代码也是特定于各个系 统的。这主要表现在它们的中断处理上下文、内存映射的维护、任务上下文和初 始化过程都是独特的。这些例行程序位于linux/arch/目录下。由于linux



gongkongedit

  • 精华:1099帖
  • 求助:0帖
  • 帖子:14392帖 | 54470回
  • 年度积分:0
  • 历史总积分:622
  • 注册:2008年9月08日
发表于:2004-03-01 14:00:00
1楼
不错 ~! 小弟 收益匪浅 !

So1o

  • 精华:0帖
  • 求助:0帖
  • 帖子:15帖 | 33回
  • 年度积分:0
  • 历史总积分:83
  • 注册:2002年7月30日
发表于:2004-03-15 00:50:00
2楼
uc/os现在系列现在还有:uc/FS(文件操作) uc/GUI(图形界面) 不过变成收费的了。 他的网站是 http://www.ucos-ii.com/

ttlff

  • 精华:0帖
  • 求助:0帖
  • 帖子:17帖 | 93回
  • 年度积分:0
  • 历史总积分:148
  • 注册:2004年1月14日
发表于:2004-03-15 09:20:00
3楼
其实我觉得最大的差别就是UClinux是以linux为基础的,所以能够使用的资源非常丰富,很多成熟的软件模块都有,具有普适性。而Ucos可能使用的人少一些,专用性更强一些,也正是因为这个系统更简洁,实时性更好。

热门招聘
相关主题

官方公众号

智造工程师