UCOS-Ⅱ在51XA上的移植应用
uCOS51移植心得
uCOS51移植心得
移植uCOS-III到8051平台需要做以下几个步骤:
1.选择适合的uCOS版本:由于8051平台资源有限,需要选择适合的uCOS版本。
一般来说,uCOS-II更适合8051平台,因为它的代码量较小,资源要求较低。
2.编写硬件抽象层(HAL):8051平台的硬件资源和处理能力较弱,需要在uCOS上面进行硬件抽象,提供与8051硬件相关的接口函数。
这些接口函数包括时钟、中断、任务切换等操作。
3.适配任务堆栈:uCOS需要为每个任务分配一块堆栈空间,因此需要针对8051的内存结构进行适配,保证每个任务的堆栈空间不会超出8051的寄存器能力。
4.适配时钟节拍:uCOS需要一个定时器来提供时钟节拍,因此需要适配8051的定时器,并编写中断处理函数来触发uCOS的任务调度。
5.适配中断处理:8051的中断机制与其他平台有所不同,需要编写中断处理函数来处理8051的中断事件,并将其与uCOS的任务调度结合起来。
6.测试和调试:移植完成后,需要进行测试和调试,验证移植的正确性和稳定性。
在移植过程中,需要具备8051平台的硬件知识和uCOS的软件知识,同时需要具备较强的调试能力,以确保移植的成功和稳定性。
uCOS-Ⅱ C51移植笔记
uCOS-Ⅱ C51移植笔记(1)实时系统和前/后台系统;前/后台系统:一个大循环,循环查询各种标志位。
如果标志位置位,就执行相应的服务程序。
标志位就是标志事件的发生,事件响应延时处于不可预测状态。
最坏的情况是循环中所有其他的事件服务程序执行完,才响应当前事件。
中断服务虽然能即时/优先响应,但是它们和主循环的通讯,也是通过置主循环中相应的标志位来完成的。
实时系统(uCOS):整个程序分成一个个看起来好象是并行的任务,每个任务都在等待事件的发生。
除了最低优先级任务(在uCOS中是IDLE任务)是死循环以外,其他的任务都不能死循环,只能在驱动事件驱动下工作。
任何驱动事件的产生,都使优先级最高的就绪任务运行。
任务和任务/任务和中断的通讯,是通过相应事件驱动来完成的。
驱动事件:不论是什么系统,CPU不可能一直在工作。
CPU的工作是在各种驱动事件的驱动下工作的。
CPU在完成一次驱动事件事件服务程序以后,进入IDLE模式等待新的驱动事件的发生。
包括实时系统和前/后台系统都是在驱动事件的驱动下运行的。
按照uCOS中的观点,驱动事件分为三类:1、事件(Event)。
包括信号量(Semaphores)、事件标志组(Flag)、邮箱(Message Box)、邮箱队列(Message Queue)。
2、时间(Time Tick)。
包括时间延时和事件超时。
3、中断(Interrupt)。
可以发出各种event。
由于第1种事件,通常都是在第2、3种状态下发出的,所以其实事件的驱动只有两种:时间(定时)和中断(各种异步中断)。
时间实际上也是中断的一种,可以说程序的驱动事件只有一种,就是:中断。
前/后台系统中还有一种驱动事件的产生,在主循环中不断的查询。
有别与一般的定时查询,这种查询是为了将事件的响应时间降到最低,也可以将其归纳于定时(时间)事件。
(2)uCOS C51移植的准备工作;2004年8月份,我在书城买了一本《uCOS-Ⅱ 第2版》,准备学习RTOS。
UCOSII在51单片机运行成功
UCOSII在51单片机运行成功以下是我的移植过程:1、新建一个文件夹aduc845ucosii来存放整个工程,再在aduc845ucosii下建立两个目录:os和out。
os存放所有源代码,out存放编译链接产生的中间文件和最终的输出文件。
2、建立KEILC工程,芯片选择ADUC845并且加入默认的启动代码START_AD.A513、把所有用到的源文件都复制到OS文件夹内,也就是现在在OS 内所有文件。
4、在KEIL的WORKSPACE下Source Group 1右击,把OS文件夹内以下文件加入源码:uCOS_II.C、OS_CPU_C.C、OS_CPU_A.ASM、test.c、serial.c、serial.h。
然后还得把KEIL安装目录下的XX\KEIL\C51\LIB下的C51BFPC.LIB和C51L.LIB加入源码组。
这里要解释一下:uCOS_II.C是内核文件,OS_CPU_C.C、OS_CPU_A.ASM是移植文件,test.c是main函数文件,serial.c、serial.h是test.c里用到串口才把它们加进源码,而C51BFPC.LIB和C51L.LIB这两个文件据果子说是因为用到了浮点运算,要加入这两个库文件。
加入的文件最好是按顺序加入,特别是两个库文件,如果反了,就可能出现运行不了或者不正确。
5、打开Options for Target "Target 1",切换到Target选项卡,把Memory Model改为Large: variables in XDATA。
再切换到Output选项卡,点击"Select Folder for Objects",选择out文件夹,勾选Create hex File,按OK确定,再切换到Listing选项卡,点击"Select Folder for Listings",选择out文件夹,按OK确定。
μC/OS-Ⅱ在MCS-51上的移植
境的支持下 , 编写 了移植代码和测试程序 , 成功地 将 I / S 1移 植 到 了 MC -1上 ,  ̄ O 一1 C S5 使得 MC -1的 S5
程序 开发 建 立 在 操 作 系 统 的支 持 下 . 用 程 序 开 应 发基 于任 务进 行 , 易于 实 现模 块 化 设 计 ; 务 之 间 任
在传统的电子技术领域有 着广泛的应用. 一般来 讲 , C - 的应用 软件是一个无 限循环 , 的特 MS1 5 它 点是底层性 的 、 与对象系统 的紧耦合. 由于缺少计 算机工程设计方法和软件工程设计方法的指导 ,
软件 编制 随意性 较 大. 随着 应 用 需求 的 1益 复杂 , 3 这种 软件设 计 方 法 显 得 力 不从 心 , 切 需 要 实 时 迫
要: 在分析 实时多任 务 内核 I / S Ⅱ原理 和移植 方 法的基 础上 , t / S Ⅱ移植 到 了 MC ・1 片机  ̄ O・ C 将 x O・ C S5 单
上, 并在 K iC开发环境 下 编制 了测 试软 件 。结 果表 明: 移植 的操 作 系统 能很 好 地 工作 在 MC -1上 , e l 所 S5 为
创建、 除 、 删 优先权 改变 、 起/ 醒等 )并 有 存储 挂 唤 ,
写一些与处理器相关的代码. 比如 ,C O . 在读 I / S1  ̄ I 写 处理 器寄存 器 时 , 只能 通 过 汇编 语 言 实 现. 由于
I / S 1在设 计之 初 就 已充 分 考 虑 了可 移 植 性 ,  ̄ O -I C 所 以 I / S 1 移 植 还 是 比 较 容 易 的 . 使  ̄ O .I的 C 要 I / S 1正常工 作 ,  ̄ O- C I 处理 器必 须满 足如 下要 求 : ( ) 理器 的 C编译 器 能产 生可重 人 代码 1处
ucos-II移植到51单片机的解决办法
ucos-II移植到51单片机的解决办法本文主要是关于ucos-II的相关介绍,并着重对ucos-II移植到51单片机进行了详尽的阐述。
ucos-IIμC/OS-II由Micrium公司提供,是一个可移植、可固化的、可裁剪的、占先式多任务实时内核,它适用于多种微处理器,微控制器和数字处理芯片(已经移植到超过100种以上的微处理器应用中)。
同时,该系统源代码开放、整洁、一致,注释详尽,适合系统开发。
μC/OS-II已经通过联邦航空局(FAA)商用航行器认证,符合航空无线电技术委员会(RTCA)DO-178B标准。
μC/OS-II被广泛应用于微处理器、微控制器和数字信号处理器。
μC/OS-II 的前身是μC/OS,最早出自于1992 年美国嵌入式系统专家Jean brosse 在《嵌入式系统编程》杂志的5 月和6 月刊上刊登的文章连载,并把μC/OS 的源码发布在该杂志的B B S 上。
μC/OS 和μC/OS-II 是专门为计算机的嵌入式应用设计的,绝大部分代码是用C语言编写的。
CPU 硬件相关部分是用汇编语言编写的、总量约200行的汇编语言部分被压缩到最低限度,为的是便于移植到任何一种其它的CPU 上。
用户只要有标准的ANSI 的C交叉编译器,有汇编器、连接器等软件工具,就可以将μC/OS-II嵌入到开发的产品中。
μC/OS-II 具有执行效率高、占用空间小、实时性能优良和可扩展性强等特点,最小内核可编译至2KB 。
μC/OS-II 已经移植到了几乎所有知名的CPU 上。
严格地说uC/OS-II只是一个实时操作系统内核,它仅仅包含了任务调度,任务管理,时间管理,内存管理和任务间的通信和同步等基本功能。
没有提供输入输出管理,文件系统,网络等额外的服务。
但由于uC/OS-II良好的可扩展性和源码开放,这些非必须的功能完全可以由用户自己根据需要分别实现。
uC/OS-II目标是实现一个基于优先级调度的抢占式的实时内核,并在这个内核之上提供最基本的系统服务,如信号量,邮箱,消息队列,内存管理,中断管理等。
UCOS-II在51单片机上的移植
UCOS-II在51单片机上的移植做操作系统的移植首先明白什么是移植,操作系统是一种鱼硬件(处理器)相关的软件,根据某一种处理器来设计的操作系统通常不能运行在那其他处理器。
所谓的移植是指修改操作系统,然后加载到一个处理器上。
本文只讲解步骤,至于理论知识,需要大家自己学习。
步骤:1,在UCOS-II的官网上下载,操作系统。
2,在网上找到或者自己建三四个文件:OS_CPU_A.ASSMOS_CPU.HOS_CPU_C.COS_CFG.H以上文件需要修改3,移植源码的编写和修改❖OS_CPU.H1)定义与编译器有关的数据类型typedef unsigned char BOOLEAN; /* 不能使用bit定义,结构中无法使用*/typedef unsigned char INT8U; /* 无符号8位数*/typedef unsigned char INT8S; /* 有符号8位数*/typedef unsigned int INT16U; /* 无符号16位数*/typedef signed int INT16S; /* 有符号16位数*/typedef unsigned long INT32U; /* 无符号32位数*/typedef signed long INT32S; /* 有符号32位数*/typedef float FP32; /* 单精度浮点数*/typedef double FP64; /* 双精度浮点数*/typedef unsigned char OS_STK; /* 定义堆栈入口宽度为8位*/typedef unsigned char OS_CPU_SR; /* 定义CPU状态字的宽度为8位*/2)定义堆栈增长方向#define OS_STK_GROWTH 0 /* MCS-51堆栈从下往上增长,1=向下,0=向上*/3)定义任务级的任务切换宏#define OS_TASK_SW() OSCtxSw() /* 任务级的任务切换宏*/4)定义临界段宏:#define OS_ENTER_CRITICAL() EA=0#define OS_EXIT_CRITICAL() EA=1❖OS_CPU_C.C①初始化任务栈void *OSTaskStkInit(void(*task)(void *pd), void *ppdata, void *ptos, INT16U opt) REENTRANT{O S_STK *stk;p pdata=ppdata; //pata data 为52文件关键字o pt =opt; /* opt没被用到,保留此语句防止警告产生 */s tk =(OS_STK *)ptos; /* 任务堆栈最低有效地址*/*stk++=15; /* 任务堆栈长度*/ *stk++=(INT16U)task & 0xFF; /* 任务代码地址低8位*/*stk++=(INT16U)task >> 8; /* 任务代码地址高8位*//* 处理器是按特定的顺序将寄存器存入堆栈的,所以用户在将寄存器存入堆栈的时候也要依照这一顺序 */*stk++=0x00; /* PSW*/*stk++=0x0A; /* ACC*/*stk++=0x0B; /* B */ *stk++=0x00; /* DPL*/*stk++=0x00; /* DPH*/*stk++=0x00; /* R0 */ *stk++=0x01; /* R1 */ *stk++=0x02; /* R2 */ *stk++=0x03; /* R3 */ *stk++=0x04; /* R4 */ *stk++=0x05; /* R5 */ *stk++=0x06; /* R6 */ *stk++=0x07; /* R7 */ /* 不用保存SP,任务切换时根据用户堆栈长度计算得出*/*stk++=(INT16U)(ptos+MAX_STK_SIZE) >> 8; /* ?C_XBP 仿真堆栈指针高8位 */*stk++=(INT16U)(ptos+MAX_STK_SIZE) & 0xFF; /* ?C_XBP 仿真堆栈低8位*/r eturn ((void *)ptos); /* 返回最低地址,这里不用弹出栈顶指针是为了提高计算效率 */}②初始化定时器void InitTimer0(void) REENTRANT{TMOD=TMOD&0xF0; //屏蔽高四位TMOD=TMOD|0x01; /* 模式1(16位定时器),仅受TR0控制 */ TH0=TIMER_20MS_TH0;TL0=TIMER_20MS_TL0;E A=0; /* EA和ET0,51上电缺省值为0,EA将在OSStartHighRdy()中打开*/ET0=0; /* 满足在OSStart()前不产生时钟中断的要求,系统启动后第一时间开定时器T0中断 */TR0=1;}❖OS_CPU_A.ASM编写4个函数OSStartHighRdy()OSCtxSw()OSIntCtxSw()OSTickISR()❖OS_CFG.H主要为参数和使能的宏定义#define MAX_STK_SIZE 1024 /* 最大堆栈大小为1k*/#define OS_MAX_EVENTS 5 /* 应用程序中事件控制块的最大数量(必须大于零)*/#define OS_MAX_FLAGS 2 /* 应用程序中事件标志组的最大数目(必须大于零)*/#define OS_MAX_MEM_PART 5 /* 内存分区的最大数目(必须大于零)*/#define OS_MAX_QS 2 /* 应用程序中队列控制块的最大数目(必须大于零)*/#define OS_MAX_TASKS 11 /* 应用程序中任务的最大数目(必须大于2)*/#define TASK_START_PRIO 2 /* 应用程序开始优先级*/#define OS_LOWEST_PRIO 12 /* 定义可分配的最低优先级(必须大于63)*/#define TASK_STK_SIZE 512 /* 默认任务堆栈大小*/#define OS_TICKS_PER_SEC 50 /* 设置每秒节拍数*/#define TIMER_20MS_TH0 0x70 /* CPU=22.1184MHz, OS_TICKS_PER_SEC=50, TH0=0x70 */#define TIMER_20MS_TL0 0x00 /* CPU=22.1184MHz, OS_TICKS_PER_SEC=50, TL0=0x00 */晶振频率为22.1184MHz时才有OS_TICKS_PER_SEC=50,OS_TICKS_PER_SEC=50。
uCOS-II在51单片机上的移植
功能
处理临界段方式选择 堆栈增长方向 进入临界区 退出临界区 就绪态最高优先级任务运行 任务级任务切换 中断级任务切换 时钟节拍 任务堆栈初始化
表7-1 需要修改的关键函数和宏定义
6
7.1.6 INCLUDES.H
* * * * * * 文件名 : INCLUDES.H * 作者 : Jean J. Labrosse ****************************************************************************/
9
7.1.8 OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()
临界代码的概念。 uC/OS-II定义的两个宏。
{ OS_ENTER_CRITICAL(); /* µC/OS-II 临界代码段 */ OS_EXIT_CRITICAL(); }
#define OS_ENTER_CRITICAL() EA=0 #define OS_EXIT_CRITICAL() EA=1 #define OS_ENTER_CRITICAL() \
例如,任务A和任务B都要调用函数Swap(), 而该函数又使用了全局变量temp。于是当任 务A调用Swap()函数期间,系统发生了任务 切换而使任务B也调用了Swap(),那么任务B 将要改变全局变量temp的值,使任务A传递 给全局变量temp的值丢失而出现错误。
一般来说,一个可重入函数应该在函数中只 使用局部变量,因为函数的局部变量存储在 任务的堆栈中,所以可保证不同的任务在调 用同一个函数时不会发生冲突。
/ ******************* 与处理器相关的代码 ********************/ #define OS_CRITICAL_METHOD ?? #if OS_CRITICAL_METHOD = = 1 #define OS_ENTER_CRITICAL() ?? #define OS_EXIT_CRITICAL() ?? #endif
_C_OS_在51系列单片机上的移植
2004年第6期总第273期 导弹与航天运载技术M ISSIL ES AND SPACE V EHICL ES No.62004Sum No.273文章编号:100427182(2004)0620036207收稿日期:2003207209作者简介:董余红(19792),男,硕士研究生,研究方向为导弹与运载火箭信息系统总体设计μC/OS -Ⅱ在51系列单片机上的移植董余红,阎俊武(北京宇航系统工程设计部,北京,100076)摘要:介绍了嵌入式实时操作系统内核μC/OS -Ⅱ在51系列单片机上的移植的详细步骤。
关键词:单片机;嵌入式实时操作系统;内核;μC/OS -Ⅱ;移植中图分类号:TP316.2 文献标识码:APorting μC/OS -Ⅱto 512Family MicroprocessorDong Yuhong ,Yan J unwu(Beijing Institute of Astronautical Systems Engineering ,Beijing ,100076)Abstract :The steps to porting the embedded real time operating system kernel μC/OS -Ⅱto 512family microprocessor are described detailedly and relevant source code are provided in this paper.K ey Words :microprocessor ;Embedded real time operating system ;K ernel ;μC/OS -Ⅱ;Port1 简 介μC/OS -Ⅱ由美国工程师Jean brosse 设计,是一个优秀的源代码公开的嵌入式实时操作系统内核,可以比较容易地移植到各种不同的微处理器上。
现在,μC/OS -Ⅱ的2.52版已经通过了非常严格的测试,并且得到了美国航空管理局(Federal Aviation Administration )的安全认证,可以用在飞行器上。
uCOS-II在51单片机上的移植
uC\OS-II在51单片机上的移植戴国强、史培杰(安阳工学院计算机科学与信息工程系)摘要:uC\OS-II以其结果清晰、性能稳定、源码公开等特点,受到广大嵌入式开发人员的青睐,已作为嵌入式实时操作系统被移植到许多微处理器上,在国防、航空航天、交通、能源、工业控制、通信以及人们日常生活等各个领域得到了广泛应用。
关键字:嵌入式实时操作系统、uC\OS-II、移植、MCS-51单片机Abstract: Based on the advantage of clear structure,stable capability and free sound code,the uC\OS-II comes in for lots of people's like who empolder the embedded system.As a embedded real-time operation system,the uC\OS-II has been repoted on lots of MCU,and has widely used an plays a very important role in many fields, such as national defence,spacenavigation,traffic,energy sources,industry control,communications,and civil living.Key words: the embedded real-time operationsystem,uC\OS-II,transplant,Single Chip Computer of MCS-51随着电子技术与软件技术的飞速发展,嵌入式系统技术已经成了最热门的技术之一。
嵌入式实时操作系统是嵌入式应用软件的基础和开发平台,其中涉及到软件和硬件两方面的问题。
μC/OS-II在51单片机上的移植
μC/OS-II在51单片机上的移植摘要:针对在51 单片机上移植实时操作系统μC/OS-II 的目的,以μC/OS-II 工作原理为基础,结合51 单片机堆栈空间少的情况,采用改变堆栈指针到不同任务寄存器组的方法,通过改变堆栈指针的实验,得出在堆栈空间较少的情况下,也能够实现μC/OS-II 在51 单片机上的运行的结论。
关键词:μC/OS;单片机;实时操作系统;堆栈μC/OS-II 是一种公开源代码、结构小巧、具有可剥夺实时内核的嵌入式开发系统,代码简短、条理清晰、实时性及安全性能很高,绝大部分代码用C 编写,现已被移植到多种处理器的构架中。
随着51 单片机片内资源的日益丰富,在51 单片机上移植μC/OS-II 已成为可能,植入系统后,由系统来管理软件与硬件资源,简化应用程序的设计,并且使应用系统功能更加完善。
因此在51 单片机上移植μC/OS-II 具有十分重要的意义。
1 μC/OS 实时操作系统概述μC/OS-II 实时操作系统是一种可移植、可固化、可裁剪即可剥夺型的多任务实时内核,适用于各种微处理器和微控制器。
μC/OS-II 主要包括任务调度、时间管理、内存管理、事件管理(信号量、邮箱、消息队列)4 大部分。
它的移植与4 个文件相关:汇编文件(OS_CPU_A.A SM)、处理器相关C 文件(OS_CPU.H、OS_CPU_C.C)和配置文件(OS_CFG.H)。
有64 个优先级,系统占用8 个,用户可创建56 任务,不支持时间片轮转。
它的基本思路就是近似地每时每刻总是让优先级最高的就绪任务处于运行状态。
为了保证这一点,它在调用系统函数、中断结束、定时中断结束时总是执行调度算法。
原作者通过事先计算好数据,简化了运算量,通过精心设计就绪表结构,使得延时可预知。
μCOS-II操作系统在各种处理器上的移植
μC/OS-Ⅱ操作系统在各种处理器上的移植长江大学杨青胜徐爱钧摘要介绍μC/OS-II操作系统的应用和移植条件;阐述μC/OS-Ⅱ操作系统在普通的51单片机,NXP公司的LPC2210,ALTERA公司的Nios II 三种处理器上的移植。
关键字μC/OS-II移植51单片机LPC2210 Nios IIPortingμC/ OS - Ⅱto Various processorYangtze University Yang Qingsheng Xu Aijun Abstract :Introduced the μC/OS-II operating system applicationand transplant conditions;Explained the μC/OS-II operating system on 51 common microprocessor ,NXP's LPC2210, ALTERA's Nios II three processors transplant.Key Words:μC/OS-II port 51 microprocessor LPC2210 Nios II μC/OS-II操作系统是一种抢占式多任务、单内存空间、微小内核的嵌入式操作系统,具有高效、紧凑的特点。
它具有执行效率高、占用空间小、可移植性强、实时性能良好和可扩展性强等特点。
采用μc/os-ii实时操作系统可以有效地对任务进行调度;对各任务赋予不同的优先级可以保证任务及时响应,而且采用实时操作系统,降低了程序的复杂度,方便程序的开发和维护。
非常适合应用在一些小型的嵌入式产品应用场合,在家用电器,机器人,工业控制,航空航天,军事科技等领域有着广泛的应用。
单片机ARM, FPGA与μC/OS-II操作系统的结合,实现一些具体功能是目前嵌入式应用中比较常见。
在这些应用中基础性的工作就是操作系统的移植,故而本文选取使用较多的51单片机,LPC2210, NiosII三种处理器做介绍必定有一定的意义。
51单片机上移植ucos-II
嵌入式实时操作系统实验报告 51单片机上移植μC/ OS-II系别计算机与电子系专业班级电子0901班学生姓名高傲指导教师黄向宇提交日期 2012 年 4 月 17 日一、实验目的理解移植μC/OS-II的一般原理及基本方法。
掌握在51单片机上移植μC/ OS-II的方法及步骤,掌握在51单片机上基于μC/ OS-II系统构建应用程序的基本原理及方法。
二、实验内容1.建立并熟悉编译及仿真调试环境(keil + proteus)。
2.下载已移植好的软件包,在开发环境下建立工程编译并运行观察运行结果,使用Keil自带的仿真调试工具观察程序运行情况(内存的分配、变量及CPU 寄存器的动态变化、任务的切换运行状态等);比较移植前和移植后的相关文件,分析移植过程中做了哪些改动工作。
3.结合前两次实验内容,在移植软件包的基础上尝试增加用户任务,并利用信号量、消息邮箱等建立任务之间的通信联系;同时尝试采用动态内存分配的方法为任务分配内存,使用Keil仿真工具观察程序运行情况并记录运行结果。
4.输入课本P220的例子程序,编译运行并观察运行结果。
5. 将以上调试好的软件移植到proteus开发环境中去,利用proteus的硬件仿真环境创建几个实际任务(如键盘、显示器、LED点阵、数码管、时钟或温度传感器等)给每个赋以适当的优先级,配置合适的堆栈容量,编译运行并观察运行情况,显示信息可以用液晶显示器或虚拟终端来显示。
三.实验原理1. 移植的概念所谓移植,就是使一个实时内核能在某个微处理器或微控制器上运行。
为了方便移植,大部分的µC/OS-Ⅱ代码是用C语言写的;但仍需要用C和汇编语言写一些与处理器相关的代码,这是因为µC/OS-Ⅱ在读写处理器寄存器时只能通过汇编语言来实现。
由于µC/OS-Ⅱ在设计时就已经充分考虑了可移植性,所以µC/OS-Ⅱ的移植相对来说是比较容易的。
要使µC/OS-Ⅱ正常运行,处理器必须满足以下要求:1. 处理器的C编译器能产生可重入代码。
uCOS-II移植51的汇编部分原理
原理:
由于51单片机RAM比较小,所以各个任务堆栈的内容放在片外RAM,而只在片内设了一个公有堆栈,一旦一个任务被选中,则在任务切换时把该任务在片外的RAM存储的堆栈内容复制到片内公用堆栈,而公用堆栈中的被终止运行任务的堆栈内容复制到该任务片外堆栈中。
程序实现:
在51单片机的外部RAM中设置任务堆栈,任务堆栈的最低地址空间用来存放用户堆栈的长度,并使该任务的TCB中的OSTCBStkPtr指针变量指向该地址。
任务切换时,应该先把当前任务在公用堆栈(即片内RAM中的)的内容复制保存在本身任务堆栈(片外)中。
即用SP-OSStkStart得出保存字节数,将其写入用户堆栈最低地址内,以用户堆栈最低地址为起址,以OSStkStart为系统堆栈起址,由系统栈向用户栈拷贝数据,循环SP-OSStkStart次,每次拷贝前先将各自栈指针增1。
将就绪优先级最高任务的任务堆栈复制到系统堆栈。
方法是:获得最高优先级任务用户堆栈最低地址,从中取出“长度”,以最高优先级任务用户堆栈最低地址为起址,以OSStkStart为系统堆栈起址,由用户栈向系统栈拷贝数据,循环“长度”数值指示的次数,每次拷贝前先将各自栈指针增1。
程序注释见OS_CPU_A.asm内的中文注释,可用记事本打开该文件。
ucos51移植
在51系列单片机上移植uCOS-II引言:随着各种应用电子系统的复杂化和系统实时性需求的提高,并伴随应用软件朝着系统化方向发展的加速,在16位/32位单片机中广泛使用了嵌入式实时操作系统。
然而实际使用中却存在着大量8位单片机,从经济性考虑,对某些应用场合,在8位MCU上使用操作系统是可行的。
从学习操作系统角度,uC/OS-II for 51即简单又全面,学习成本低廉,值得推广。
结语:μC/OS-II具有免费、简单、可靠性高、实时性好等优点,但也有缺乏便利开发环境等缺点,尤其不像商用嵌入式系统那样得到广泛使用和持续的研究更新。
但开放性又使得开发人员可以自行裁减和添加所需的功能,在许多应用领域发挥着独特的作用。
当然,是否在单片机系统中嵌入μC/OS-II应视所开发的项目而定,对于一些简单的、低成本的项目来说,就没必要使用嵌入式操作系统了。
uC/OS-II原理:uCOSII包括任务调度、时间管理、内存管理、资源管理(信号量、邮箱、消息队列)四大部分,没有文件系统、网络接口、输入输出界面。
它的移植只与4个文件相关:汇编文件(OS_CPU_A.ASM)、处理器相关C文件(OS_CPU.H、OS_CPU_C.C)和配置文件(OS_CFG.H)。
有64个优先级,系统占用8个,用户可创建56个任务,不支持时间片轮转。
它的基本思路就是“近似地每时每刻总是让优先级最高的就绪任务处于运行状态” 。
为了保证这一点,它在调用系统API函数、中断结束、定时中断结束时总是执行调度算法。
原作者通过事先计算好数据,简化了运算量,通过精心设计就绪表结构,使得延时可预知。
任务的切换是通过模拟一次中断实现的。
uCOSII工作核心原理是:近似地让最高优先级的就绪任务处于运行状态。
操作系统将在下面情况中进行任务调度:调用API函数(用户主动调用),中断(系统占用的时间片中断OsTimeTick(),用户使用的中断)。
调度算法书上讲得很清楚,我主要讲一下整体思路。
μCOS-II在基于51微控制器上的移植研究
μC/OS-II在基于51微控制器上的移植研究第一章绪论 (1)1.1 背景和选题依据 (1)1.2 国内外的研究现状及发展趋势 (1)1.3 本文的研究内容 (2)第二章μC/OS-II简介 (3)2.1 μC/OS-II的产生背景 (3)2.2 μC/OS-II的特点 (3)2.3 μC/OS-II内核结构 (4)2.3.1 宏OS_ENTER_CRITICAL( )和OS_EXIT_CRITICAL( ) (5)2.3.2 任务 (6)2.3.3 调度器上锁、开锁 (10)2.3.4 μC/OS-II中的中断与时钟节拍 (11)2.3.5 μC/OS-II初始化与启动 (12)第三章Keil Cx51基础知识 (14)3.1 Cx51程序设计基础 (14)3.1.1 标识符与关键字 (14)3.1.2 基本语法及语句 (14)3.2 函数 (16)3.2.1 函数定义与调用 (16)3.2.2 函数的递归调用与再入函数 (18)第四章μC/OS-II移植基础知识 (20)4.1 μC/OS-II源文件移植 (20)4.2 硬件平台构成与编译器的选择 (22)4.3 μC/OS-II移植的一般性问题 (23)第五章μC/OS-II在51单片机上的移植 (25)5.1 头文件处理 (25)5.2 修改OS_CPU.H文件 (25)5.3 修改OS_CPU_C.C文件 (25)5.3OS_CPU_A.ASM文件 (28)5.3.1 汇编文件头部定义 (28)5.3.2修改OSStartHighRdy( )函数 (29)5.3.3修改OSCtxSW( )函数 (30)5.3.4 OSIntCtxSW( )函数 (31)5.3.5OSTickISR( )函数 (31)5.4 定时器初始值设置 (32)第六章实验及其结果分析................................................................................... 错误!未定义书签。
ucos2操作系统在51单片机上的移植
μC/OS-Ⅱ在51单片机上的移植姓名:学号:目录1 绪论 (2)1.1 嵌入式实时操作系统 (2)1.2 μC/OS-Ⅱ嵌入式操作系统 (2)1.3 μC/OS-Ⅱ原理 (2)2 μC/OS-Ⅱ内核结构 (3)2.1 临界区 (3)2.2 任务及任务控制块 (3)2.3 任务状态 (4)2.4 任务调度 (5)2.5 中断处理 (5)2.6 时钟节拍 (5)2.7 μC/OS-Ⅱ初始化与启动 (6)3 μC/OS-Ⅱ在51单片机上的移植 (6)3.1 OS_CPU.H文件的移植 (6)3.2 OS_CPU_A.ASM文件的移植 (8)3.3 OS_CPU_C.C文件的移植 (20)4 移植结果测试 (23)4.1 设计原理 (23)4.2 应用程序设计 (23)4.3 结果分析 (25)1 绪论1.1嵌入式实时操作系统大多数的操作系统只注重平均性能,如对于整个系统来说,所有任务的平均响应时间是关键,而不关心单个任务的响应时间。
而嵌入式实时操作系统最主要的特征是性能上的实时性,从这个角度上看,可以把嵌入式实时操作系统定义为“当外界事件或数据产生时,能够接受并以足够快的速度予以处理,其处理的结果又能在规定的时间之内来控制生产过程或对处理系统作出快速响应,并控制所有实时任务协调一致运行的嵌入式操作系统”。
目前大多数嵌入式操作系统提供以下管理功能:1.任务管理所有嵌入式操作系统都是多任务的,目前所说的多任务大都是指多线程方式或多进程方式,两者的运行机制不完全一样。
以多进程为例,调度程序的好坏直接影响到系统的性能。
和一般的操作系统一样,嵌入式操作系统的作用也是决定在特定的某一时刻系统应该运行哪一个进程,对嵌入式系统中的运行软件进行描述和管理,并完成处理机资源的分配与调度。
2.存储管理在嵌入式系统中,一般不采用虚拟内存管理,而采用动态内存管理方式,即当程序的某一部分需要使用内存时,利用操作系统提供的分配函数来处理,一旦使用完,可通过释放函数来释放所占用的内存,这样内存就可以重复使用,这样提高了内存的利用率,方便了用户的使用,并提供了足够的存储空间。
uCOSⅡ内核在80C51系列单片机上的移植
;以下代码完成第①步操作
万方数据
·——2097·——
PUSHALL:用户定义的宏,将全部CPU寄存器保存到 3.2实验的过程和结果
系统堆栈
实验过程主要镪括以下3个步骤:@创建两个任务Taskl
MOV A,SP;淤下3匍蜜现获褥堆筏戆长度
秘Task2,验涯OSTaskStldnit袭OSStartHighRdyoi蕊数;◇刳建
save_stack: ;以下实现从系统堆棱到用户堆栈豹拷贝 INC DFFR:撵自惩产臻筏
巍输出的不同结聚,验证OSIntCtxSw鞠OSTicklSR函数。 主要测试健弱黧下:
0引言
近年来,嵌入式系统已成为后PC时代一个广阔的研发领 域,其应用范围越来越广。实际应用中,由于移植所花费代价 最小,原有操作系统无法支持新增应用功能时,常会采用系统 移植来解决问题。uC/OS.II作为一个高可靠,开源的嵌入式实 时操作系统,具有广泛的应用;而利用廉价的80C51实现众多 传感器、控制器等电子设备的网络互联,更是具有先天优势。 因此在80C51上移植uC/OS.II具有重要的意义。本文以uC/ OS.II为移植对象,以80C51为移植目标来详细讨论移植的过 程,其中自己设计了一个堆栈结构;最后给出移植测试实验, 分析了移植中要注意的一些问题,总结了移植的一般方法。
1移植前的准备工作
移植前首先要对移植对象,移植目标及其结构,以及移植 的编译环境进行了解。这样才会起到事半功倍的效果。以下 便是从这几个方面进行简单分析。 1.1 移植对象——uc,os.Ⅱ
.
uC/OS.II具有很强的可移植性,可以广泛应用于各类8 位,16位,32位微控制器或DSP中。它具有完全可剥夺型的 实时内核,其核心工作原理是让最高优先级的就绪任务处于 运行状态;它具有多任务的特点,可以管理64个任务,其中56
μC/OS-Ⅱ在51单片机上的移植
分 重 要 的意 义 。
函数 调 用 时 , 栈 的 一 个 重 要 功 能 就 是 保 存 被 调 函 数 的 断 点 堆 地 址 。若 有 4 函 数 ,u 1 用 F n 。u2调 用 Fn , u3 个 Fn 调 u2Fn u 3 F n
1 I /  ̄ OS实 时操 作 系统 概 述 C
P ri g RTOS IC OS H 0M CS 5 ot n / - t  ̄ .1
LV a - a,XU — i g Xi o n Lip n
(colfI o ainadE gneig Z egh uU i r , hnz u40 0 , hn ) Sho n r t n n i r , hn zo n es Z egh 5 0 1 C i o fm o e n v o a
间 少 的情 况 , 用 改 变 堆栈 指 针 到 不 同任 务 寄 存 器组 的 方 法 , 过 改 变堆 栈 指 针 的 实验 。 出在 堆 栈 空 间较 少 的 情 况 采 通 得 下 , 能 够 实现 t /S I在 5 单 片 机 上 的 运 行 的 结论 也 r O —I C l 关键 词 : CO ; 片机 ;实 时操 作 系统 ; 栈  ̄ /S 单 堆 中 图分 类 号 : P 1 T 3 文献标识码 : A 文章 编 号 :17 — 2 6 2 1 )6 O 5 — 3 64 6 3 (0 2 0 一 0 2 0
吕 小 纳 .徐 力 平
( 州 大 学 信 息 工 程 学 院 , 南 郑 州 4 00 ) 郑 河 5 0 1
摘 要 :针 对在 5 单 片 机 上 移植 实时操 作 系统 t / S I 的 目的 ,  ̄ / S I 工 作 原 理 为 基础 。 合 5 1 r O —I C 以 CO —I 结 l单 片机 堆 栈 空
设计任务二 uCOS-Ⅱ的移植与应用
设计任务二uC/OS-Ⅱ的移植与应用一、设计目的:1.了解嵌入式实时操作系统u C/OS-Ⅱ可移植、可裁剪等性能特点,正确理解实时操作系统中任务、信号、消息、中断等基本概念以及u C/OS-Ⅱ多任务管理的调度算法;2.掌握u C/OS-Ⅱ在ARM7上移植的方法;3.能将u C/OS-Ⅱ移植在LPC2106中,并根据具体要求创建用户任务,解决实际问题;二、具体任务:1.u C/OS-Ⅱ移植在LPC2106中。
2.编写用户任务程序,完成实时温度的采集控制。
硬件电路见参考硬件电路图,图中用滑动变阻器代替温度传感器转换后的电压,用ADC0809完成A/D转换,并用数码管显示出来。
三、参考硬件电路。
(用文字对所设计的电路功能、原理做详细说明)附图:四、源程序。
(只将C语言应用程序附在后面,其它项目文档不要提供,C语言应用程序要有一定的注释说明)源程序:/******************************************************************** ************************************/#include "config.h"#define TASK_STK_SIZE 64INT32U NUM=0;INT32U LED[10]={0x3F,0x06,0x5b,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//共阴级数码管显示段码表INT32U P8=0x00000100; //管脚P0.8INT32U P9=0x00000200; //管脚P0.9INT32U P10=0x00000400; //管脚P0.10INT32U P11=0x00000800; //管脚P0.11INT32U P12=0x00001000; //管脚P0.12INT32U P13=0x00002000; //管脚P0.13INT32U P14=0x00004000; //管脚P0.14OS_STK Task1Stk[TASK_STK_SIZE];OS_STK Task2Stk[TASK_STK_SIZE];OS_STK Task3Stk[TASK_STK_SIZE];void Task1(void *data);void Task2(void *data);void Task3(void *data);void IO_init(void);void delay(INT32U n);/******************************************************************** *************************************** 函数名称: main** 功能描述: c语言的主函数,由它启动多任务环境********************************************************************* ***********************************/int main (void){OSInit();OSTaskCreate(Task1, (void *)0, &Task1Stk[TASK_STK_SIZE - 1], 4);OSTaskCreate(Task2, (void *)0, &Task2Stk[TASK_STK_SIZE - 1], 5);OSTaskCreate(Task3, (void *)0, &Task3Stk[TASK_STK_SIZE - 1], 6);OSStart();return 0;}/******************************************************************** *************************************** 函数名称: Task1** 功能描述: μCOS-II的第一个任务,通常由它初始化目标板和建立其它任务********************************************************************* ***********************************/void Task1(void *p_arg){p_arg = p_arg; /* 避免编译警告*/TargetInit(); /* 初始化*/IO_init();while(1){while((IOPIN&P12)!=0);IO_init();while((IOPIN&P12)==0);IOCLR=0x0000FFFF; //输出引脚清零OSTaskSuspend(4); //任务切换}}/******************************************************************** *************************************** 函数名称: Task2** 功能描述: μCOS-II的第二个任务********************************************************************* ***********************************/void Task2(void *p_arg){p_arg = p_arg; /* 避免编译警告*/ IO_init();while(1){IOCLR=P13;delay(10); //送单次脉冲启动A/D转换IOSET=P13;delay(10);IOCLR=P13;delay(10);IO_init();while((IOPIN&P14)==0);IOSET=P11; //打开传送数据开关NUM=IOPIN; //读取数据NUM=NUM>>15;OSTaskSuspend(5); //切换任务}}/******************************************************************** *************************************** 函数名称: Task3** 功能描述: μCOS-II的第三个任务********************************************************************* ***********************************/void Task3(void *p_arg){INT32U n;INT32U A,B,C;p_arg = p_arg; /* 避免编译警告*/while(1){A=NUM/100;B=NUM%100/10;C=NUM%10;IOCLR=0x000000FF;IOSET=0x00000700;for(n=0;n<500;n++){IOCLR=P10;IOSET=LED[C];delay(20);IOCLR=0x000000FF;IOSET=P10;IOCLR=P9;IOSET=LED[B]+0x0000080;delay(20);IOCLR=0x000000FF;IOSET=P9;IOCLR=P8;IOSET=LED[A];delay(20);IOCLR=0x000000FF;IOSET=P8;}OSTaskResume(5);}}/******************************************************************** *************************************** 函数名称: 其他子函数** 功能描述: 供给多任务调用********************************************************************* ***********************************/void IO_init(){PINSEL0=0x0;PINSEL1=0x0; // PO口为普通io口IODIR=0x00002FFF; // 设置PO口的方向}void delay(INT32U n){INT32U i;for(i=0;i<=n;i++);}/******************************************************************** *************************************** End Of File********************************************************************* ***********************************/五、仿真效果。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
过程与 中断和外部中断时在中断服务子程序中调用 A , 只是因为执行中断服务子函数后, 有 $%"=>%?@A类似, 可能使更高优先级的任务处于就绪态,以前被中断的 任务不一定是要再继续执行的任务了,就要利用调整 堆 栈 指 针 来 去 掉 在 调 用 $%’:=V>9=@A 和 $%’:="=>%?@A 两个函数过程中压入堆栈的多余的内容,调整的值由
置一个常量( 堆栈的生长方向) 、 声明三个宏( 开中断、 关中断和任务切换) , 声明 ); 个与编译器相关的数据 类型 4用 " 语言编写六个简单的函数( 任务堆栈初始化 和五个钩子函数) , 用 汇 编 语 言 写 的 四 个 函 数 $%"<
"
移植中的问题 移 植 !" # $% &’’ 用 的 硬 件 平 台 是 一 块 基 于
!
移植要点
!" # $%&! 的大部分代码是用 +2%’ " 写成的,
只有与处理器硬件相关的一部分代码用汇编语言编 写, 所以 !" # $%&! 的移植性很强, 可以 在 绝 大 多 数
3 位、 ). 位、 ,- 位微处理器、数字信号处理器上运行。 !" # $%&! 的移植并不复杂 4 一般包括用 56789:7 设
( 下转第 ., 页)
# # 优先级最高的就绪
$%/C9P"MC S $%/C9P09DEF6G ; /P9:=7C P8 MN7C N=BIJ S $%H"Q09DEF6G&R$%H"Q%=J/=C ; F7N=PC7 BOO ITM C7D9N=7C 8CPU MN7C N=BIJ ; FVH’; W
:; < =>?@@ 是面向中小型嵌入式系统的,包含全 部功能模块的内核大约为 #"NO,如果经过裁减只保 留核心代码, 则可压缩到 %NO 左右。 KGP 的占用量与 系统中的任务数有关, 任务的堆栈要占用大量的 KGP
空间, 堆栈的大小取决于任务的局部变量、 缓冲区大小 及可能的中断嵌套层数。应用程序的时间精度由系统 时钟节拍决定, :; < =>?@@ 需要用户 提 供 周 期 性 的 时 钟信号源, 用于实现时间延时和确认超时, 一般时钟节 拍 应 在 #" 到 #""LC 之 间 ( 最 大 精 度 为 #"7* ) , 因为
任务
目前调试此卡主 /E9O9TN *+() 的现场仪表用通信卡, 要是为将来扩展此卡的 嵌 入 式 KVQ 功 能 打 下 基 础 。 此卡不仅要完成各种现场控制任务( 如 + # Y、 工 Y # +、 作情况指示等) , 而且要完成基于 H"/ ( !Y/) # ’/ 的通 信, 以此来达到嵌入式 KVQ 的功能, 将工业现场的各 种被测对象的工作状态和实时数据结合,完成远程监 视设备的运行情况和在线组态。由于 "/! 处理的各 种任务之间关系复杂,所以采用嵌入式操作系统来协 调各个任务间的关系。使用的编译器是 0’&HV"0 ", 使用大模式编译。由于 0’&HV"0 " 支持汇编和 " 混 合编译,所以在用需要用汇编语言写的源函数中采用 了汇编语言和 " 语言嵌套的方法。用汇编语言写的函 数在调试跟踪时比较麻烦,嵌套处理后使调试变得方 便, 而且不容易出错, 同时免去了写汇编语言的麻烦。 下面谈谈在移植过程中出现的一些问题。编译文 件程序的过程中,发现编译结果占用了 "/! 很多的 内部 F+Z, 而 ()*+ 片内仅有 ()- 字节, 使片内 F+Z 溢出, 导致程序无法运行, 所以必须把系统源文件中的 大部分指针和变量放到外部 F+Z, 尤其是内核程序使 用的堆栈占用了大量的空间, 必须放到外部 F+Z 区, 这就要求对操作系统的源文件进行修改,在头文件中 的变量、 指针前采用 [+F 指针, 用 [+F 指针把它们放 到外部 F+Z 区。另外因为优先级表中的数值是不变 的, 所以放到程序代码区, 若不放在代码区, 程序将不 能执行, 方法是使用 "$YV 定义( 与编译器相关) , 如
EL@M@E> $#FG 上的移植应用为例,希望能为更多更
广泛的应用起到抛砖引玉的作用。
. /0 1 23455 简介
实 时 嵌 入 式 操 作 系 统 :; < =>?@@ 是 基 于 优 先 级 的抢占式实时多任务操作系统, 包含了实时内核、 任务 管理、 时间管理、 任务间通信同步( 信号量, 邮箱, 消息 队列) 和内存管理等功能。绝大部分代码用 ; 语言写 成, 与硬件相关部分用汇编语言编写, 而且它的源代码 是公开免费的。
再进行操作系统初始化, 主要完成任务 ;E: 初始化, 控制块 ( 初始化, ’;O) ’;O 优 先 级 表 初 始 化 , ’;O 链 表初始化, 事件控制块( ) 链表初始化, 空任务的创 Q;O 建等等; 然后就可以开始创建新任务, 并可在新创建的 任务中再创建其他的新任务; 最后调用 =>>’GK’RS 函 数启动多任务调度。 在多任务调度开始后, 启动时钟节 拍源开始计时,此节拍源给系统提供周期性的时钟中 断信号, 实现延时和超时确认。当时钟中断来临时, 系 统把当前正在执行的任务挂起, 保护现场, 进行中断处 理, 判断有无任务延时到期, 若有则使该任务进入就绪 态, 并把所有进入就绪态的任务的优先级进行比较, 通 过任务切换去执行最高优先级的任务,若没有别的任 务进入就绪态, 则恢复现场继续执行原任务。 另一种调 度方式是任务级的调度,是通过发软中断命令或依靠 处理器在任务执行中调度,如任务要等待信号量或一 个正在执行的任务被悬挂起来时,就需要在此任务中 调度,找出目前处于就绪态的优先级最高的任务去执 行。当没有任何任务进入就绪态时, 就去执行空任务。
6 /0 1 23455 内核的工作原理 :; < =>?@@ 多 任 务 操 作 系 统 工 作 原 理 : 首 先 把
;E: 寄 存 器 读 出 和 存 储 到 堆 栈 或 内 存 中 的 指 令 。 $#FG 是菲利浦公司推出的一款为嵌入式应用而设计 的 高 性 能 的 具 扩 展 结 构 并 与 T";$# 兼 容 的 #U 位 ;P=> 微控制器。 $#FG?V% 微控制器有 !" 条 地 址 线, 各 #P 字 节 的 程 序 和 数 据 空 间 , 有 $#! 字 节 的 片 内 KGP 区和三个定时器 < 计数器, 它提供了多种支持
7 8.9! 芯片适合实时操作系统的特点
一般来说,嵌入式实时操作系统要求处理器能支 持中断,并能产生定时中断 ( 通 常 在 #"?#""LC 之 间) ,能容纳一定数量的硬件堆栈以及将堆栈指针和
:; < =>?@@ 在每一个节拍都要检查有没有更高优先级
的任务在等待执行, 若有, 就要进行任务切换, 所以时 钟节拍率越高, 系统的额外负荷就越重。
$%"=>%?@AL /MNE BOO C7D9N=7C =P MN7C N=BIJ ; /MNE /%K B:6 /" =P MN7C N=BIJ ; $%H"Q"MC&R$%H"Q%=J/=C S =PT TP9:=7C P8 MN7C N=BIJ ; "BOO $%HBNJ%?0PPJ@A; $%H"Q"MC S $%H"Q09DEF6G ;
$%’:="=>%?@A 完成中断级的任务 切 换 @ 当 有 时 钟
《 工业控制计算机》 !""! 年 #$ 卷片机对两片 8U-F!"\ 的读写控制同 !D#。图中未画出各单片机对 8U-F!"\ 的状态信号的测试线, 请参照 !D#。 以 主 单 片 机 L"\#J 和 从 单 片 机 L"\#+ 通 信 为 例,说明通信的过程: L"\#J 的 <#" 为 发 送 应 答 信 号 线, <## 为接受应答信号线。 L"\#+ 的 <#" 和 <## 正好相 反 。 L"\#J 向 L"\#+ 发 送 数 据 时 , 需 事 先 判 断
摘 要 本文介绍了嵌入式实时操作系统 :;=>?@@ 的工作原理,分析了移植到 E()5)+* 的 $#FG 芯片上所要完成的工作, 并 给出了移植过程中出现的问题及解决的方法。 移植 关键词: 嵌入式实时操作系统, :; < =>?@@, $#FG,
随着工业应用系统复杂程度的不断提高, 对 ;E: 的处理能力的要求越来越高,在 ;E: 上开发程序的 复杂度迫使用户选用一些嵌入式实时操作系统 ( ,同时使用 K’=> 可大大缩短产品的开发周 K’=>) 期 。 本 文 以 较 简 单 的 嵌 入 式 实 时 内 核 :; < =>?@@ 在
通信的实时性。
"
结束语 采用 I8I/ 器件作用数据暂存器,用于单片机之
间的并行通信, 电路结构十分简单, 软件设计方便。由 于 I8I/ 器件只占用单片机的一个地址空间,控制线 少, 且在一对一的通信中双方不需进行联系, 为系统的 硬件和软件设计带来较大的灵活性,设计的并行通信 接口, 性能可靠, 不失为一种较好的单片机通信方法。 参考文献
"/! 和编译器决定。 $%%=BC=09DEF6G@A用于在调度中
使最高优先级的任务处于就绪态并开始执行:首先置
()*+&1, 和 !" # $%&’’ 能够很好地结合起来,完成