1、1.什么是操作系统?它应具备什么功能?管理电脑硬件与软件资源的程序,同时也是计算机系统的内核与基石.1.)操作系统是计算机硬件的封装和扩充 2).操作系统是计算机资源的管理者,包括处理器管理、存储器存储空间管理、外部输入输出(I/O)设备管理、文件管理、网络和通信管理、提供用户接口。2 嵌入式操作系统与普通操作系统区别嵌入式操作系统具有通用操作系统的基本特点,但嵌入式操作系统在系统实时高效性、硬件的相关依赖性、软件固态化以及应用的专用性等方面具有较为突出的特点3 什么是实时系统?对实时系统有什么要求?如果一个系统能及时响应外部事件的请求,并能在规定的时间内完成对事件的处理,这种系统称为实时系统
2、. 1.实时系统的计算必须产生正确的结果,称为逻辑或功能正确.2.实时系统的计算必须在预定的时间内完成.称为时间正确.4 可剥夺内核:当一个进程正在被处理器所运行时,其他就绪进程可以按照事先规定的规定的规则,强行剥夺正在运行进程的处理器使用权,而使自己获得处理器使用权并得以运行6 一个应用程序为什么一定要使用空闲任务在多任务系统运行时,系统经常会在某个时间内无用户任务运行而处于空闲状态,为了使 CPU 在此时有事可作,提供空闲任务。空闲任务是不能被软件删除的7 统计任务是必须使用的吗?简述它的功能用户应用程序可根据实际需要来选择是否使用统计任务。每秒计算一次 CPU 在单位时间内被使用的时间,
3、并把计算结果以百分比的形式存放在变量 OSCPUsage 中,以便应用程序通过访问它来了解 CPU 的利用率.8 什么是任务的优先权?UC/OS-II 是用什么来描述任务的优先权的。处于就绪态的任务优先获取其他任务 cpu 使用权的能力。 uC/OS-II 是按可剥夺型内核来设计的,为此,每一个任务都必须具有唯一的优先级别,用来表示该任务在抢夺处理器时所具有的优先权力,共有64 个优先级别,用数字“0”“63”表示,数字“0”所表示的优先级最高9 在 UC/OS-II 中任务有哪 5 种状态?分别简述 5 个状态的特征:睡眠状态:任务只是以代码的形式驻留在内存,还没有交给操作系统管理.就绪状态
4、:任务配备了任务控制块且在任务就绪表中登记,具备了任务运行的充分条件.运行状态:处于就绪状态的任务获得了 CPU 的使用权,任何时候只有一个任务处于运行.等待状态:正在运行的任务,把 CPU 的使用权让给其他任务.中断服务状态:正在运行的任务一旦响应中断申请,就会中止运行而去执行中断服务程序.10 任务控制块记录了任务的那些信息包括任务堆栈的各种指针及数目,任务优先级,任务的状态标志参数等。11 什么是空任务控制块链表?什么是任务控制块链表?空任务块链表,其中所有任务控制块还没有分配给任务;任务控制块链表,其中所有任务块已经分配给任务16UC/OS-II 的中断响应过程: 系统接收到中断请求后
5、,如果这是 CPU 处于中断允许状态,系统会中止正在运行的当前任务,而按照中断向量的指向转而去运行中断服务子程序;当中断服务子程序的运行结束后,系统会根据情况返回到被中止的任务,或转向更高优先级的任17 全局变量 OSIntNesting 的作用: 记录中断嵌套的层数。18 操作系统的时钟:操作系统中特定的周期性中断为系统提供时间依据。19 在 UC/OS-II 中,时钟节拍服务做了什么工作?时钟节拍服务做了:可以使人物延时若干个整数的时钟节拍以及当任务等待事件发生时提供等待超时依据。20 说明延时函数 OSTimeDly()与 OSTimeDlyHMSM()的区别: OSTimeDly():
6、时钟节拍数;OSTimeDlyHMSM():按照时 分 秒的设置延时21 使用信号量可在应用程序中完成哪些工作?任务间通信 完成共享资源的访问 任务的同步执行22 什么叫优先级反转?这种现象什么情况下发生?有什么危害?在可剥夺型内核中,当任务以独占方式使用共享资源时,会出现低优先级任务先于高优先级任务而被运行的情况。称优先级反转。一个低优先级任务在获得信号量使用共享资源期间,被高优先级任务所打断而不能释放信号量,从而使正在等待该信号量的高优先级任务因得不到信号量而被迫处于等待状态。在等待期间,就让占据该信号量的低优先级任务先运行 如果这种情况发生较多,则会极大地恶化优先级任务地运行环境。23
7、互斥型信号量是如何防止优先级反转的?在低优先级的任务要使用共享资源前 将其优先级提升到高于可能使用该共享资源的任务优先级,使用完共享资源后在讲其优先级恢复到原值。25 1.UC/OS-II 为什么要定义信号量集?在实际运用中,任务常常需要与多个事件同步,即要根据多个信号量组合作用得结果来决定任务得运行方式。信号量集就是实现这种功能的数据结构。26 信号量集所管理的是什么信号?信号量集所管理的信号量都是二值信号。它实质上是一种可以对多个输入的逻辑信号进行基本逻辑运算(“与”运算(AND),“或”运算(OR))的组合逻辑。27 使用信号量集可以在程序中完成哪些工作?信号量集 用一个双向链表来组织等
8、待任务,每一个等待任务都是该链表中的一个节点28 什么叫内存分区?什么叫内存块?内存分区与内存块之间有什么关系?内存分区与内存块:操作系统将大片连续的内存分区管理,每个分区内含有整数个大小相同的内存块29 在同一个内存分区中内存块是按什么方式组织起来的?每个分区又分成若干大小相等的内存块来进行管理30 什么叫内存控制块?它记录了一些什么信息?内存控制块是由 uC/OSII 为每个内存分区定义的一个数据结构。系统用它来记录和跟踪每一个内存分区的状态。嵌入式系统 是以应用为中心,以计算机技术为基础,且软硬件可裁减,适应应用系统对功能、可靠性、成本、体积、功耗有严格要求的专用计算机系统。它一般由以下
9、几部分组成: 嵌入式微处理器 外围硬件设备 嵌入式操作系统 特定的应用程序特点: 应用的特定性和广泛性 技术、知识、资金的密集性 高效性 较长的生命周期 高可靠性 软硬一体,软件为主 无自举开发能力C/OS-简介特点之一是:结构小巧。包含全部功能的核心部分代码只占用 8.3K 字节,同时由于 C/OS-是可裁剪的,所以用户系统中实际的代码最少可达 2.7K 字节。特点之二:是一个真正的实时操作系统。实时操作系统一般定义为“一个能够在指定的或者确定的时间内,完成系统功能和对外部或内部、同步或异步事件做出响应的系统” 。特点之三是:C/OS-实际上是一个实时操作系统内核,只包含了任务调度、任务管理
10、、时间管理、内存管理和任务间的通信与同步等基本功能。12、简述 C/OS-II 的主要特点。可移植性:C/OS-II 的源代码绝大部分是使用移植性很强的 ANSI C 写的,将与微处理器硬件相关的汇编语言使用量压缩到最低的限度,以使 C/OS-II 便于移植到其它微处理器上。可剪裁:C/OS-II 使用条件编译实现可剪裁。占先式:C/OS-II 是占先式实时内核,总是运行就绪条件下优先级最高的任务。多任务:C/OS-II 可以管理 64 个任务,其中 8 个作为系统保留,所以实际用户可使用的为 56 个任务。可确定性:C/OS-II 的函数调用与系统服务的执行时间是可知的。任务栈:C/OS-I
11、I 的每个任务都有自己单独的栈。中断管理:C/OS-II 允许中断嵌套层数可达 255 层。 13、简述 C/OS-II 实时内核中任务调度器的原理。C/OS-II 根据组变量、表变量得到优先级最高的任务,通用公式是:OSUnMapTblOSRdyGrp3+ OSUnMapTblOSRdyTblOSRdyGrp。这里 OSRdyGrp 为组变量,OSRdyTbl 为表变量。14、说明函数 OSTimeTick()、OSTimeDly()的主要任务。OSTimeTick()的主要任务就是定期将时间延时项 OSTCBDly 减 1,直至为 0。任务延时函数 OSTimeDly(),可置任务控制块
12、OSTCBDly 的值为所需要的,一旦对某个任务调用了OSTimeDly()函数,则该任务将被挂起,直到 OSTCBDly 被减为 0。15、简述解决互斥的 3 种办法,它们各有何优缺点。常用的解决互斥的 3 种办法包括:关闭中断法,进程在进入临界区后立即关中断,在离开时开中断,这样就可以简单的实现任务互斥。优点:这是实现互斥最简单的办法。缺点:把禁止中断的权利交给用户进程很危险,若一个进程禁止中断后不再打开中断,整个系统会因此而中止。锁变量法,对临界资源设置一个锁变量,初值为 0。缺点:是忙等待的解决方案,会浪费大量的 CPU 时间。信号量法,设置一个初值为 1 的信号量便能很好的解决互斥问
13、题。这种方法是迄今最完全的解决方案。16、信号量是如何实现同步的?信号量能很好的解决同步问题,为此,必须进行如下设置(这样的安排是保证进程同步的关键):设置一个初值为 0 的信号量;在进程 A 的同步点 X 处安排关于信号量的 P 操作;在进程 B 的 Y 处安排关于信号量的 V 操作。中断:任务在运行过程中,应内部或外部异步事件的请求中止当前任务,而去处理异步事件所要求的任务的过程叫做中断。中断服务程序:应中断请求而运行的程序叫中断服务子程序(ISR)。中断向量:中断服务子程序的入口地址叫中断向量。CPU 响应中断的条件: 至少有一个中断源向 CPU 发出中断信号 系统允许中断,且对此中断信
14、号未予屏蔽任务间的同步依赖于任务间的通信。在 uC/OS-II 中,使用信号量、邮箱和消息队列这些被称作事件的中间环节来实现任务间的通信。使用信号量的目的:为共享资源设立一个表示该共享资源被占用情况的标志。在实际应用中,任务常常需要于多个事件同步,即根据多个信号量组合作用的结果来决定任务的运行方式。信号量集所能管理的信号量一般都是二值信号。请求信号量集的任务得以继续运行的条件与所请求的信号量之间有两种逻辑关系:AND 和 OR。uc/os-ii 的任务有 5 种状态睡眠态(DORMANT): 任务以代码形式驻留在程序空间,还没有交给 uc/os 管理,即还没有配备任务控制块,还没有被创建。就绪
15、态(READY): 系统为任务配备了任务控制块,且在任务就绪表中就行了就绪登记。运行态(RUNNING): 正在使用 CPU 的状态称运行态。 等待态(WAITING):等待一段时间或某事件发生再运行的状态。中断服务态(ISR):正在运行的任务被中断时就进入了中断服务态(ISR)。 任务控制块 (Task Control Blocks, OS_TCBs)是 ucos-ii 用来存储任务堆栈指针、当前状态、优先级及任务链表指针等属性的一个数据结构。 创建任务时,必须创建任务控制块,通过控制块初始化函数 OSTCBInit()完成,其做三件事:从空任务控制块链表获取一个任务控制块;用任务的属性对任
16、务控制块各个成员进行赋值;把这个任务控制块链入到任务控制块链表。1、任务的存储结构主要由哪三部分组成?答:任务程序代码,任务堆栈,任务控制块。 uc/os-ii 预定义了两个为应用程序服务的系统任务:空闲任务和统计任务,其中空闲任务是每个程序必须使用的,而统计任务是应用程序可根据实际情况需要选择使用。任务删除函数:OSTaskDel()#if OS_task_del_enINT8U OSTaskDel(INT8U prio);时钟:任务操作系统都要提供一个周期性的信号源,以供系统提供处理诸如任务的等待,延时等与时间有关的事件,这个周期性的信号源叫时钟。最小的的时钟单位就是两次中断之间间隔的时间
17、,这个最小时钟单位叫着时钟节拍(time tick)事件控制块:为了把描述的事件的数据结构统一起来,uc/os-ii 把事件等待任务表和与事件相关的其他信息组合起来定义了一个叫着事件控制块的 ECB 的数据结构。什么是任务切换?任务切换时主要完成哪些工作? 答:中止正在运行的任务,转而去运行另外的一个任务的工作。也就是暂停现行任务,去完成另一个任务。6 与共享资源打交道时,使之满足互斥条件最一般的方法包括哪些?答:包括:关中断、使用测试并置位指令、禁止做任务切换、利用信号量等。7. 描述利用 C/OS_ 宏调用关中断和开中断处理共享数据的示意性代码程序。答: OS_ENTER_CRITICAL
18、(); /*在这里处理共享数据 */OS_EXIT_CRITICAL();8. 信号量的典型应用包括哪些?答:信号量(Semaphores) 是一种约定机制,在多任务内核中的典型应用包括:(1) 控制共享资源的使用权(满足互斥条件);(2) 标志某事件的发生(3) 使两个任务的行为同步9对信号量只能实施哪三种操作?答:一般地说,对信号量只能实施三种操作:(1) 初始化(INITIALIZE),也可称作建立(CREATE);(2) 等信号(WAIT)也可称作挂起(PEND);(3) 给信号(SIGNAL)或发信号(POST)。(4) OS_ENTER_CRITICAL() 和 OS_EXIT_C
19、RITICAL()的含义及作用?答:OS_ENTER_CRITICAL() :关中断;OS_EXIT_CRITICAL():开中断。关中断和开中断是为了保护临界段代码。用户的应用代码可以使用这两个宏来开中断和关中断。很明显,关中断会影响中断延迟,所以要特别小心。用户还可以用信号量来保护临界段代码。4基于 PC 的服务中如何测量 PC_DisplayChar()的执行时间?答:测量 PC_DisplayChar()的执行时间的代码如下:INT16U time; /定义时间变量PC_ElapsedInit(); /时钟初始化PC_ElapsedStart(); /开始计时PC_DispChar(4
20、0, 24, A, DISP_FGND_WHITE); /执行代码time = PC_ElapsedStop(); /结束计时5uC/OS-II 的任务框架答:void task_xxx(void *pData) /* 该任务的初始化工作 */* 进入该任务的死循环 */while(1)事件驱动模型也涵盖了中断驱动模型,uC/OS-II 事件归根结底来自三个方面:(1)中断服务函数发送的事件(2)系统延时时间到所引起的(3)其它任务发送的事件。填空题1.uC/OS-II 是一个简洁、易用的 基于优先级的嵌入式【 抢占式 】多任务实时内核。2.任务是一个无返回的无穷循环。uc/os-ii 总是运
21、行进入就绪状态的【 最高优先级 】的任务 。3.因为 uc/os-ii 总是运行进入就绪状态的最高优先级的任务。所以,确定哪个任务优先级最高,下面该哪个任务运行,这个工作就是由【调度器(scheduler) 】来完成的。4.【 任务级 】的调度是由函数 OSSched()完成的,而【 中断级 】的调度是由函数 OSIntExt() 完成。对于 OSSched(),它内部调用的是【 OS_TASK_SW()】 完成实际的调度;OSIntExt()内部调用的是【 OSCtxSw() 】实现调度。5.任务切换其实很简单,由如下 2 步完成:(1)将被挂起任务的处理器寄存器推入自己的【 任务堆栈 】
22、。(2)然后将进入就绪状态的最高优先级的任务的寄存器值从堆栈中恢复到【寄存器 】中。6 任务的 5 种状态。【睡眠态(task dormat) 】:任务驻留于程序空间(rom 或 ram)中,暂时没交给 ucos-ii 处理。【就绪态(task ready)】:任务一旦建立,这个任务就进入了就绪态。【运行态(task running)】:调用 OSStart()可以启动多任务。OSStart()函数只能调用一次,一旦调用,系统将运行进入就绪态并且优先级最高的任务。【等待状态(task waiting)】:正在运行的任务,通过延迟函数或 pend(挂起)相关函数后,将进入等待状态。【中断状态(I
23、SR running)】:正在运行的任务是可以被中断的,除非该任务将中断关闭或者 ucos-ii将中断关闭。7【 不可剥夺型 】内核要求每个任务自我放弃 CPU 的所有权。不可剥夺型调度法也称作合作型多任务,各个任务彼此合作共享一个 CPU。8当系统响应时间很重要时,要使用【 可剥夺型 】内核。最高优先级的任务一旦就绪,总能得到 CPU的控制权。9使用可剥夺型内核时,应用程序不应直接使用不可重入型函数。调用不可重入型函数时,要满足互斥条件,这一点可以用【 互斥型信号量 】来实现。10【 可重入型 】函数可以被一个以上的任务调用,而不必担心数据的破坏。11可重入型函数任何时候都可以被中断,一段时
24、间以后又可以运行,而相应数据不会丢失。可重入型函数或者只使用【 局部变量 】,即变量保存在 CPU 寄存器中或堆栈中。如果使用全局变量,则要对全局变量予以【 保护 】。12每个任务都有其优先级。任务越重要,赋予的优先级应【 越高 】。13C/OS-初始化是通过调用系统函数【OSIint()】实现的,完成 C/OS-所有的变量和数据结构的初始化。14多任务的启动是用户通过调用【OSStart()】实现的。然而,启动 C/OS-之前,用户至少要建立一个应用【任务】 。15. C/OS-的参数配置文件名为【OS_CFG.H】。16 删除任务,是说任务将返回并处于【休眠状态】,并不是说任务的代码被删除
25、了,只是任务的代码不再被 C/OS-调用。17C/OS-要求用户提供【定时中断】来实现延时与超时控制等功能。18定时中断也叫做【时钟节拍】,它应该每秒发生 10 至 100 次。19. 时钟节拍的实际频率是由用户的应用程序决定的。时钟节拍的频率越高,系统的负荷就【越重】。20C/OS-II 中的信号量由两部分组成:一个是信号量的【计数值】 ,它是一个 16 位的无符号整数(0 到 65,535 之间) ;另一个是由等待该信号量的任务组成的【等待任务表】 。用户要在 OS_CFG.H 中将OS_SEM_EN 开关量常数置成【 1 】 ,这样 C/OS-II 才能支持信号量。21. C/OS-II
26、 中表示当前已经创建的任务数全局变量名为:【 OSTaskCtr 】。21. C/OS-II 中表示当前内核运行的标记全局变量名为:【 OSRunning 】。二 名词解释1代码的临界段 代码的临界段也称为临界区,指处理时不可分割的代码。2资源 任何为任务所占用的实体都可称为资源。资源可以是输入输出设备;资源也可以是一个变量,一个结构或一个数组等。3共享资源 可以被一个以上任务使用的资源叫做共享资源。4任务 一个任务,也称作一个线程,是一个简单的程序,该程序可以认为 CPU 完全只属该程序自己。典型地、每个任务都是一个无限的循环。5任务切换 指 Context Switch,其含义是 CPU
27、寄存器内容切换。当多任务内核决定运行另外的任务时,它保存正在运行任务的当前状态(Context) ,即 CPU 寄存器中的全部内容。6内核 多任务系统中,内核负责管理各个任务,或者说为每个任务分配 CPU 时间,并且负责任务之间的通讯。内核提供的基本服务是任务切换。7调度( Scheduler) 内核的主要职责之一,就是要决定该轮到哪个任务运行了。多数实时内核是基于优先级调度法的。8可剥夺型内核 最高优先级的任务一旦就绪,总能得到 CPU 的控制权。当一个运行着的任务使一个比它优先级高的任务进入了就绪态,当前任务的 CPU 使用权就被剥夺了,或者说被挂起了,那个高优先级的任务立刻得到了 CPU
28、 的控制权。如果是中断服务子程序使一个高优先级的任务进入就绪态,中断完成时,中断了的任务被挂起,优先级高的那个任务开始运行。OS_TASK_SW()函数需要用户移植实现,主要内容如下:1. 把全部 CPU 寄存器(包括堆栈指针寄存器和 PC 寄存器)推入当前任务堆栈; 2. 调用 OSTaskSwHook()函数; 3. OSPrioCur = OSPrioHighRdy; 4. OSTCBCur = OSTCBHighRdy; 5. 设置处理器的堆栈指针寄存器为 OSTCBHighRdy-OSTCBStkPtr; 6. 恢复所有处理器的寄存器内容(不包括堆栈指针寄存器和 PC 寄存器); 7
29、. 恢复 PC 寄存器并开始执行 PC 指向的指令。三简答题1. 举例说明 COS-II 可移植型数据类型的定义方式答:因为不同的微处理器有不同的字长,C/OS-II 的移植文件包括很多类型定义以确保可移植性。COS-II 不使用 C 语言中的 short,int,long 等数据类型的定义,因为它们与处理器类型有关,隐含着不可移植性。C/OS-II 代之以移植性强的整数数据类型,这样,既直观又可移植(该 数据类型不依赖于编译 ),举例如下:typedef unsigned char BOOLEAN;typedef unsigned char INT8U;typedef signed char
30、 INT8S;typedef unsigned int INT16U;typedef signed int INT16S;typedef unsigned long INT32U;typedef signed long INT32S;2. COS-II 如何定义全局变量?答:众所周知,全局变量应该是得到内存分配且可以被其他模块通过 C 语言中 extern 关键字调用的变量。因此,必须在 .C 和 .H 文件中定义。这种重复的定义很容易导致错误。COS-II 采用的方法只需用在头文件中定义一次。uC/OS_II.H 头文件中包括以下定义全局宏定义:#ifdef OS_GLOBALS#defin
31、e OS_EXT#else#define OS_EXT extern#endifOS_EXT INT32U OSIdleCtr;同时,uCOS_II.H 有中以下定义:#define OS_GLOBALS#include “includes.h”当编译器处理 uCOS_II.C 时,它使得头文件变成如下所示,因为 OS_EXT 被设置为空。INT32U OSIdleCtr;这样编译器就会将这些全局变量分配在内存中。当编译器处理其他.C 文件时,头文件变成了如下的样子,因为 OS_GLOBAL 没有定义,所以 OS_EXT 被定义为 extern。extern INT32U OSIdleCtr;
32、在这种情况下,不产生内存分配,而任何 .C 文件都可以使用这些变量。这样的就只需在 .H 文件中定义一次就可以了。10.给出 C/OS-中如何用信号量处理共享数据的示意代码?答:通过获得信号量处理共享数据的示意代码如下:OS_EVENT *SharedDataSem;void Function (void)INT8U err;OSSemPend(SharedDataSem, 0, /*共享数据的处理在此进行,(中断是开着的)*/OSSemPost(SharedDataSem);11.给出初始化和启动 C/OS-的示意代码。答:void main (void)OSInit(); /* 初始化 u
33、C/OS-II */通过调用 OSTaskCreate()或 OSTaskCreateExt()创建至少一个任务;OSStart(); /* 开始多任务调度!OSStart()永远不会返回 */12 描述建立任务 OSTaskCreate()的函数原型。答:建立任务 OSTaskCreate()的函数原型为:INT8U OSTaskCreate (void (*task)(void *pd), void *pdata, OS_STK *ptos, INT8U prio)其中,task: 任务代码的指针;pdata: 当任务开始执行时传递给任务的参数的指针;ptos: 分配给任务的堆栈的栈顶指针
34、;prio: 分配给任务的优先级。13任务可以是一个无限的循环,也可以是在一次执行完毕后被删除掉。请给出示意代码结构。答:C/OS-描述的任务示意代码必须是以下两种结构之一:void YourTask (void *pdata) for (;) /* 用户代码 */ 调用C/OS-的服务例程之一:OSMboxPend();OSQPend();OSSemPend();OSTaskDel(OS_PRIO_SELF);OSTaskSuspend(OS_PRIO_SELF); OSTimeDly();OSTimeDlyHMSM();/* 用户代码 */ 或void YourTask (void *pd
35、ata) /* 用户代码 */ OSTaskDel(OS_PRIO_SELF);14C/OS-任务管理提供哪些服务?答:C/OS-任务管理提供的服务包括:(1)建立任务:OSTaskCreate()或 OSTaskCreateExt();(2)删除任务:OSTaskDel();(3)请求删除任务:OSTaskDelReq();(4)改变任务的优先级:OSTaskChangePrio();(5)挂起任务:OSTaskSuspend();(6)恢复任务:OSTaskResume();(7)获得有关任务的信息:OSTaskQuery()。15C/OS-时间任务管理提供哪些服务?答:C/OS-时间任务
36、管理提供的服务包括:(1) 任务延时函数:OSTimeDly()(2) 按时分秒延时函数:OSTimeDlyHMSM()(3) 让处在延时期的任务结束延时:OSTimeDlyResume()(4) 设置系统时间:OSTimeGet()(5) 获得系统时间:OSTimeSet()16. C/OS-提供的数据共享和任务通讯的方法包括哪些?答:C/OS-提供的数据共享和任务通讯的方法包括五种方法:(1) 利用宏 OS_ENTER_CRITICAL()和 OS_EXIT_CRITICAL()来关闭中断和打开中断。(2) 利用函数 OSSchedLock()和 OSSchekUnlock()对 C/OS
37、-II 中的任务调度函数上锁和开锁。(3) 信号量。(4) 邮箱。(5) 消息队列。17对于事件控制块进行的一些通用包括哪些操作?答:对于事件控制块进行的一些通用操作包括:(1) 初始化一个事件控制块: OSEventWaitListInit();(2) 使一个任务进入就绪态:OSEventTaskRdy();(3) 使一个任务进入等待该事件的状态:OSEventTaskWait();(4) 因为等待超时而使一个任务进入就绪态:OSEventTO()。18C/OS-信号量提供哪些服务?答:C/OS-信号量提供的服务包括:(1) 建立一个信号量:OSSemCreate();(2) 等待一个信号量
38、:OSSemPend();(3)发送一个信号量:OSSemPost();(4)无等待地请求一个信号量:OSSemAccept();(5)查询一个信号量的当前状态:OSSemQuery()。19C/OS-邮箱提供哪些服务?答:C/OS-邮箱提供的服务包括:(1)建立一个邮箱:OSMboxCreate();(2)等待一个邮箱中的消息:OSMboxPend();(3)发送一个消息到邮箱中:OSMboxPost();(4)无等待地从邮箱中得到一个消息:OSMboxAccept();(5)查询一个邮箱的状态:OSMboxQuery()20C/OS-消息队列提供哪些服务?答:C/OS-消息队列提供的服务包
39、括:(1)建立一个消息队列:OSQCreate();(2)等待一个消息队列中的消息:OSQPend();(3)向消息队列发送一个消息(FIFO):OSQPost();(4)向消息队列发送一个消息(LIFO):OSQPostFront();(5)无等待地从一个消息队列中取得消息:OSQAccept();(6)清空一个消息队列:OSQFlush();(7)查询一个消息队列的状态:OSQQuery()。21C/OS-内存管理提供哪些服务?答:C/OS-内存管理提供的服务包括:(1) 建立一个内存分区:OSMemCreate();(2) 分配一个内存块:OSMemGet();(3) 释放一个内存块:O
40、SMemPut();(4) 查询一个内存分区的状态:OSMemQuery()。22移植 C/OS-时,要使 C/OS-正常运行,处理器必须满足哪些基本要求?答:要使 C/OS-正常运行,处理器必须满足以下要求:处理器的 C 编译器能产生可重入代码。(1) 用 C 语言就可以打开和关闭中断。(2) 处理器支持中断,并且能产生定时中断(通常在 10 至 100Hz 之间)。(3) 处理器支持能够容纳一定量数据(可能是几千字节)的硬件堆栈。(4) 处理器有将堆栈指针和其它 CPU 寄存器读出和存储到堆栈或内存中的指令。22在使用 OSTaskCreate 创建任务时,若需要 TaskData 作伪参
41、数传递给任务 Task,并从任务 Task 中获得传入的字符参数值,请在下面【 】填上合适的代码。char TaskData=A; OSTaskCreate(Task, 【(void *)void Task (void *pdata)char value = 【 *(char *)pdata 】;for (;) OSSemPend(RandomSem, 0, y = (int) (*(char *)pdata - A); OSSemPost(RandomSem); PC_DispChar(10, 25, value, DISP_FGND_WHITE + DISP_BGND_BLUE);OSTi
42、meDly(1); 23. 在 C/OS-II 在任务 Task1 中使用邮箱函数 OSMboxPost()发送字符;而在 Task2 中接收OSMboxPost()字符, 请在下面【 】填上合适的代码。void Task1 (void *data)char txmsg;INT8U err;txmsg = A;for (;) OSMboxPost(TxMbox, 【 (void *) /* Send message to Task2*/ OSMboxPend(AckMbox, 0, txmsg+; if (txmsg = Z) txmsg = A; void Task5 (void *data
43、)char *rxmsg; INT8U err;data = data;for (;) rxmsg = 【(char *)】OSMboxPend(TxMbox, 0, PC_DispChar(70, 18, *rxmsg, DISP_FGND_YELLOW + DISP_BGND_BLUE);OSMboxPost(AckMbox, (void *)1); 24. 在 Task1 中使用消息队列 OSQPend()函数接收消息“Hello World!”,而在 Task2 中使用消息队列 OSQPost()函数发送消息“Hello World!”, 请在下面【 】填上合适的代码.void Tas
44、k1 (void *pdata)char *msg;INT8U err;pdata = pdata;for (;) msg = 【(char *)】OSQPend(MsgQueue, 0, PC_DispStr(70, 13, msg, DISP_FGND_YELLOW + DISP_BGND_BLUE);OSTimeDlyHMSM(0, 0, 0, 100);void Task2 (void *pdata)char msg20;pdata = pdata;strcpy(for (;) OSQPost(MsgQueue, 【(void *)】OSTimeDlyHMSM(0, 0, 0, 500
45、);创建信号量集OS_FLAG_GRP *FlagPtr;INT8Uerr;void main(void).OSInit();.FlagPtr = OSFlagCreate(OS_FLAGS) 0, / 所有信号的初值为 0.请求信号量集OS_FLAGS OSFlagPend(OS_FLAG_GRP *pgrp, / 所请求的信号量集指针OS_FLAGS flags, / 滤波器INT8U wait_type, / 逻辑运算类型INT16U timeout, / 等待时限 INT8U *err / 错误信息);向信号量集发信号OS_FLAGS OSFlagAccept(OS_FLAG_GRP
46、*pgrp, / 信号量集指针OS_FLAGS flags, / 选择所要发送的信号INT8U wait_type, / 信号有效的选项INT8U *err / 错误信息);查询信号量集的状态OS_FLAGS OSFlagQuery(OS_FLAG_GRP *pgrp, / 待查询的信号量集的指针INT8U *err / 错误信息);删除信号量集OS_FLAGS *OSFlagDel(OS_FLAG_GRP *pgrp, / 待删除的信号量集的指针INT8U *err / 错误信息);两个创建任务的函数:OSTaskCreate()和 OSTaskCreateExt()。INT8U OSTas
47、kCreate (void (*task)(void *pd), /指向任务的指针void *pdata, /传递给任务的参数 OS_STK *ptos, /指向任务堆栈栈顶的指针 INT8U prio ) 任务切换 三、OS_Sched(): : OS_Sched()函数被各种任务间通信函数如 xxxPost()和 xxxPend()调用,OS_Sched()函数调用更底层的函 数 OS_TASK_SW()来实现任务切换,OS_Sched()函数的源代码如下:void OS_Sched (void) #if OS_CRITICAL_METHOD = 3OS_CPU_SR cpu_sr;#endif INT8U y;OS_ENTER_CRITICAL(); if (OSIntNesting = 0) &;&; (OSLockNesting = 0) y = OSUnMapTblOSRdyGrp;OSPrioHighRdy= (INT8U)(y 3) + OSUnMapTblOSRdyTbly); if (OSPrioHighRdy != OSPrioCur)