UC/OS和uClinux的比较

随着现代计算机技术的飞速发展和互联网技术的广泛应用,从PC时代过渡到了以个人数字助理、手持个人电脑和信息家电为代表的3C(计算机、通信、消费电子)一体的后PC时代。后PC时代里,嵌入式系统扮演了越来越重要的角色,被广泛应用于信息电器、移动设备、网络设备和工控仿真等领域。

嵌入式系统是以嵌入式计算机为核心,面向用户、面向产品、面向应用,软硬件可裁减的,适用于对功能、可靠性、体积、成本、功耗等综合性能有严格要求的计算机系统。随着嵌入式系统的广泛应用,传统的前/后台程序开发机制已经不能满足日益复杂和荷记得的实现要求,因而现场常常采用嵌入式产时操作系统PROS(Real Time Operation System)开发实时多任务系统。嵌入式实时操作系统一般可以提供多任务的任务调度、时间管理、任务间通信和同步以及内存管理MMU(Memory Manager Unit)等重要服务,使得嵌入式应用程序易于设计和扩展。采用RTOS可以使嵌入式产品更可靠、开发周期更短。在嵌入式应用中使用RTOS已经成为当前嵌入式应用的一个热点。

完成简单功能的嵌入式系统一般不需要操作系统。如,以前许多MCS51系列单片机组成的小系统就只是利用软件实现简单的控制环路;但是随着所谓后PC时代的来临,嵌入式系统设计日趋复杂,嵌入式操作系统就必不可少了。

嵌入式RTOS在系统实时高效性、硬件的相关依赖性、软件固化以及应用的专业性等方面具有较为突出的优势。一般而言,嵌入式操作系统不同于一般意义的计算机操作系统,它有占用空间小、执行效率高、方便进行个性化定制和软件要求固化存储等特点。

从20世纪80年代起,国际上就有一些IT组织、公司,开始进行商用嵌入式操作系统和专用操作系统的研发。这其中涌现了一些著名的嵌入式操作系统,如Microsoft公司的WinCE和WindRiver System公司的VxWorks就分别是非实时和实时嵌入式操作系统的代表。但是商用产品的造价都十分昂贵,用于一般用途会提高产品成本从而失去竞争力。

UC/OS和uClinux操作系统是用两种性能优良、源码公开且被广泛应用的免费嵌入式操作系统,可以作为研究实时操作系统和非实时操作系统的典范。本文通过uC/OS和uClinux的对比,分析和总结嵌入式操作系统应用中的若干重要问题,归纳嵌入式系统开发中操作系统的选型依据。

1 两种开源嵌入式操作系统介绍

uC/OS和uClinux操作系统,是当前得到广泛应用的两种免费且公开源码的嵌入式操作系统。UC/OS适合小型控制系统,具有执行效率高、占用空间小、实时性能优良和可扩展性强等特点,最小内核可编译至2KB。UClinux则是继承标准Linux的优良特性,针对嵌入式处理器的特点设计的一种操作系统,具有内嵌网络协议、支持多种文件系统,开发者可利用标准Linux先验知识等优势。其编译后目标文件可控制在几百KB量级。

UC/OS是一种免费公开源代码、结构小巧、具有可剥夺实时内核的实时操作系统。其内核提供任务调度与管理、时间管理、任务间同步与通信、内存管理和中断服务等功能。

UClinux是一种优秀的嵌入式Linux版本。uClinux是Micro-Conrol-Linux的缩写。同标准Linux相比,它集成了标准Linux操作系统的稳定性、强大网络功能和出色的文件系统等主要优点。但是由于没有MMU(内存管理单元),其多任务的实现需要一定技巧。

2 两种嵌入式操作系统主要性能比较

嵌入式操作系统是嵌入式系统软硬件资源的控制中心,它以尽量合理的有效方法组织多个用户共享嵌入式系统的各种资源。其中用户指的是系统程序之上的所有软件。所谓合理有效的方法,指的就是操作系统如何协调并充分利用硬件资源来实现多任务。复杂的操作系统都支持文件系统,方便组织文件并易于对其规范化操作。

嵌入式操作系统还有一个特点是,针对不同的平台,系统不是直接可用的,一般需要经过针对专门平台的移植操作系统才能正常工作。

进程调度、文件系统支持和系统移植是在嵌入式操作系统实际应用中最常见的问题。下文就从这几个角度入手对uC/OS和uClinux进行分析比较。

2.1 进程调度

任务调度主要是协调任务对计算机系统资源(如内存、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调用完成后,要么子进程代替父进程执行(此时父进程已经休眠),直到子进程调用exit退出;要么调用exec执行一个新的进程,这时产生可执行文件的加载,即使这个进程只是父进程的拷贝,这个过程也不可避免。当子进程执行exit或exec后,子进程使用wakeup把父进程唤醒,使父进程继续往下执行。

uClinux由于没有MMU管理存储器,其对内存的访问是直接的,所有程序中访问的地址都是实际的物理地址。操作系统对内存空间没有保护,各个进程实际上共享一个运行空间。这就需要实现多进程时进行数据保护,也导致了用户程序使用的空间可能占用到系统内核空间。这些问题在编程时都需要多加注意,否则容易导致系统崩溃。

由上述分析可以得知,uC/OS内核是针对实时系统的要求设计实现的,相对简单,可以满足较高的实时性要求;而uClinux则在结构上继承了标准Linux的多任务实现方式,仅针对嵌入式处理器特点进行改良。其要实现实时性效果则需要使系统在实时内核的控制下运行。RT-Linux就是可以实现这一功能的一种实时内核。

2.2 文件系统

所谓文件系统是反映负责存取和管理文件信息的机构,也可以说是负责文件的建立、撤销、组织、读写、修改、复制及对文件管理所需要的资源(如目录表、存储介质等)实施管理的软件部分。

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则主要适合一些控制系统。

2.3 操作系统的移植

嵌入式操作系统移植的目的是指使操作系统能在某个微处理器或微控制器上运行。UC/OS和uClinux都是源码公开的操作系统,且其结构化设计便于把与处理器相关的部分分离出来,所以被移植到新的处理器上是可能的。以下对两种系统的移植分别予以说明。

(1)uC/OS的移植

要移植uC/OS,目标处理器必须满足以下要求:

*处理器的C编译器能产生可重入代码,且用C语言就可以打开和关闭中断;

*处理器支持中断,并能产生定时中断;

*处理器支持足够的RAM(几KB),作为多任务环境下的任务堆栈;

*处理器有将堆栈指针和其它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应满足的条件外,还需要具有足够容量(几百KB以上)外部ROM和RAM。

uClinux的移植大致可以分为3个层次。

*结构层次的移植。如果待移植处理器的结构不同于任何已经支持的处理器结构,则需要修改linux/arch目录下相关处理器结构的文件。虽然uClinux内核代码的大部分是独立于处理器和其体系结构的,但是其最低级的代码也是特定于各个系统的。这主要表现在它们的中断处理上下文、内核映射的维护、任务上下文和初始化过程都是独特的。这些例行程序位于lunux/arch/目录下。由于Linux所支持体系结构的种类繁多,所以对一个新型的体系,其低级例程可以模仿与其相似的体系例程编写。

*平台层次的移植。如果待移植处理器是某种uClinux已支持体系的处理器,则需要在相关体系结构目录下建立相应目录并编写相应代码。如MC68EZ328就是基于无MMU的m68k内核的。此时的移植需要创建的linux/arch/m68knommu/platform/MC68EZ328目录下,并在其下编写跟踪程序(实现用户程序到内核函数的接口等功能)、中断控制调度程序和向量初始化程序等。

*极级移植。如果所用处理器已被uClinux支持,就只需要板级移植了。板级移植需要在linux/arch/?platform/中建立一个相应板的目录,再在其中建立相应的启动代码crt0_rom.s或crt0_ram.s和键接描述文档rom.ld或ram.ld就可以了。板级移植还包括驱动程序的编写和环境变量设置等内容。

结语

通过对uC/OS和uClinux的比较可以看出,这两种操作系统在应用方面各有优劣。uC/OS占用空间少、执行效率高、实时性能优良,且针对新处理器的移植相对简单。UClinux则占用空间相对较大,实时性能一般,针对新处理器的移植相对复杂。但是,uClinux具有对多种文件系统的支持能力、内嵌了TCP/IP协议,可以借鉴Linux丰富的资源,对一些复杂的应用,uClinux具有相当优势。例如,CISCO公司的2500/3000/4000路由器就是基于uClinux操作系统开发的。总之,操作系统的选择是由嵌入式系统的需求决定的。简单地说就是,小型控制系统可充分利用uC/OS小巧且实时性强的优势;如果开发PDA和互联网连接终端等较和为复杂的系统,则uClinux是不错的选择。

时间: 2024-12-04 23:08:33

UC/OS和uClinux的比较的相关文章

cortex m3 uc os-cortex m3移植uC/OS后程序运行一段时间停止或者跑飞

问题描述 cortex m3移植uC/OS后程序运行一段时间停止或者跑飞 鄙人最近需要在Atmel sam3x8e开发板上移植uC/OS操作系统,移植成功之后发现系统运行一段时间后总是会跑飞或者停止.经调试发现在pendsv处理任务切换的中断服务函数的BX LR这一条汇编语句之前是好的,但是执行了这个语句之后发现程序停止运行或者不知道跑哪去了.需要注意的是是在系统正常运行一段时间之后才会发生上述情况.由于不能单步调试,所以最后也不知道程序最终bx到哪执行去了,求大神指点,万分感谢!!! 程序代码

uc/os-ARM 移植UC/os信号量创建失败

问题描述 ARM 移植UC/os信号量创建失败 各位大神,麻烦问一下,我将uc/os一直到ARM中,最多只能创建8个信号量,超过8个后面创建的就会失败,所以想咨询一下该如何解决,如果uc/os中可以配置的话,在哪里,怎么配置,谢谢 解决方案 sfsfsdfsf 解决方案二: sfsfsdfsf

ARM微处理器的uC/OS的移植设计

概述 嵌入式操作系统μC/OS-II是一个公开源代码的占先式多任务的微内核RTOS,其特点可以概括为以下几个方面:公开源代码,代码结构清晰.明了,注释详尽,组织有条理,可移植性好,可裁剪,可固化.内核属于抢占式,最多可以管理60个任务.目前国内对μC/OS-II的研究和应用都很多.只要买一本书就可获得源代码,对学校和教育的使用完全免费,商业应用的费用相对也很低.所以对μC/OS-II实时操作系统的学习研究.开发.应用具有重要意义. 大部分的μC/OS-II代码是使用ANSI C语言书写的,因此μ

嵌入式软件开发之我见

自己从事嵌入式系统开发有好多年了,在此想与大家分享我对于嵌入式开发的一点心得与体会.   先大致说一说我的工作经历.97年毕业后做了两年的电气与电子设计与开发,这一时期,我做过电路原理图的设计和PCB板的设计.从99年开始,我进入了软件行业.第一次做嵌入式开发是在2000年,在随后的六年多的时间里,我差不多做过整个操作系统的组件.一开始用的是uC/OS RTOS,熟悉它的人知道,它是一个微内核,提供了任务的调度.Mutex.Semaphore等基本的功能,但是像TCP协议栈.文件系统.堆管理(指

【.Net Micro Framework PortingKit – 15】移植总结(兼谈MF未来发展)

从元旦开始,便利用业余时间从事基于Cortex-M3内核上的.Net Micro Framework的移植工作.虽然到现在算起来有一个多月的时间,但是我平日的正常工作时间大部分都花在和同事一起做WiFi驱动的开发上了,除去写这一系列文章的用时,真正在Cortex-M3内核上移植时间最多也就十几天.这并不说明我在嵌入式方面的功底多么深厚,虽说我PC平台上的软件开发时间有十几年的历史,但是做真正嵌入式的开发才是最近一两年的时间(以前虽说开发过PLC程序和WinCE平台上的组态软件,但充其量仅仅算是嵌

LINUX网络嵌入式设备

  这不是什么新鲜东西,无线路由器很早前就开始使用了,不过最近才慢慢理解其原理.现在网络嵌入式设备的功能越来越强大了,各芯片厂商的解决方法支持着这种复杂性.最近公司实习,做一个家庭网关的项目.下面的内容应该不算泄密吧,写得随意一点. 1.一个网络芯片架构 大家应该看得出来,这是一个DSL芯片.其网络部分由一个switch core构成核心,对外有3个交换口(粉红色的):左侧为以太网MAC,可外接以太网芯片MAC或PHY,称为LAN端;右侧为DSL的TPS子层,按照DSL标准传输ATM/PTM数据

HIT CS科班对计算机专业knowledge的compilation

[题记]Great minds discuss ideas. Average minds discuss events. Small minds discuss people. [前面的话]本文首发于某留学论坛,并可以随意转载.有任何建议.意见,都可以给我发邮件,hitzzy at gmail dot com. 作为计算机科班.系统方向,谈谈我对计算机专业素养的理解,希望对大家有所帮助. 所谓,知之者不如好之者,好之者不如乐之者,计算机专业也不例外.虽然本科是被选到计算机专业,但大一因为C语言老

发表第一篇博文

在 M+ 的推荐下,我注册了云栖帐户.希望在这里与大家一起见证一个时代的成长.我专业是计算机科学与技术,嵌入式方向.毕业时就从事嵌入式软件开发工作.从单片机上的裸机程序,到ARM上带uC/OS的程序,再转到上层嵌入式Linux软件开发.开发语言由开始的C转到了C++.物联网的时代已经来临,我在上年就竟无反顾地拒绝了互联网的Offer,投入到物联网这个领域.我坚信,我也能飞!

嵌入式无线局域网设备的设计与实现

1 嵌入式系统简介 嵌入式系统是指以计算机技术为基础.以应用为中心.软件硬件可裁剪,功能.可靠性.功耗.体积.成本有着严格要求的专用计算机系统.追求"短.小.轻.薄,省电.快.成本低"的目标.嵌入式系统设备已广泛应用于制造工业.过程控制.仪器仪表.军事装备.消费类产品等领域.嵌入式系统由软硬件组成,一般分为五个部分:处理器.存储器.输入输出.操作系统和应用软件.如图1所示: 嵌入式系统最初的应用是基于单片机的,它只是使用8位的芯片执行一些简单的单进程的程序,没有多进程的任务调度,还谈不