嵌入式操作系统

  1. 嵌入式操作系统的特点:

必要性:嵌入式系统软件愈加庞大复杂。

微型化、可裁剪:软、硬件小而精,够用即可。

实时性:抢占式管理策略,满足时件正确性。

可靠性:无人值守、自动化设备的使用要求。

易移植:便于应用到多种的硬件平台。

微内核:完成OS主要功能的代码很小。

  1. 嵌入式操作系统的基本功能:

多任务管理:丰富的多任务管理函数供目标系 统设计者容易完成多任务应用设计。

内存管理:动态内存管理充分利用硬件资源。

外设管理:例如I2C、UART、Timer、SPI等设 备的驱动。

  1. 实时操作系统VS分时操作系统

实时性:计时性,能够在要求的时间内响应并处理完系统事件。

实时系统的正确性:既要逻辑正确,还要时间正确。

  1. uC/OS-II的两种任务:系统任务、用户任务。
  • μC/OS_II进行任务调度的思想是“近似地每时每 刻总是让优先级最高的就绪任务处于运行状 态” 。为了保证这一点,它在系统或用户任务 调用系统函数及执行中断服务程序结束时总是 调用调度器,来确定应该运行的任务并运行它 。
  1. 任务的5种状态:
  • Sleep(睡眠状态):任务没有被配备任务控制块或被剥夺了任务控制块的状态

  • Ready(就绪状态):系统为任务配备了任务控制块且在任务就绪表中进行了就绪登记。

  • Running(运行状态):处于就绪状态的任务如果经调度器判断获得了CPU的使用权。

  • Wait(等待状态):正在运行的任务,需要等待一段事件或需要等待一个事件发生在运行的使用权。。。

  • ISR_Sta(中断服务状态):一个正在运行任务一旦响应中断申请就会中止运行而去执行中断服务程序。

  1. 任务的有限权和有限级别:
  • uC/OS-II的每一个任务都必须有唯一的优先级。

  • uC/OS-II最多可以管理64个优先级别分配给64个任务。

  • uC/OS-II 中用一个8b的整型数(低6b有效)来表示优先级 别,数字越小,优先级越高,prio = 0 的任务优先级最高。

  • uC/OS-II 中使用任务的优先级(prio)作为任务句柄。

系统任务

  1. 空闲任务(OS_Taskdle())使用说明:
  • uC/OS-II规定用户程序中必须使用空闲任务。

  • 该任务不能通过程序来删除。

  • 该任务是uC/OS-II初始化时自动创建,其任务优先级固定为 最低级,用户也可修改该任务的业务。

  • 目的 ---- 使 CPU 在没有用户任务可执行时也有事可做。

  1. 统计任务(OS_TaskStat())使用说明:
  • 该任务固定拥有次末任务优先级。
  1. 任务的组成:
  • 任务控制块 —— uC/OS-II进行任务管理用的一个数据结构。

  • 任务代码 —— 描述任务算法的程序编码。

  • 任务堆栈 —— 任务的工作现场环境。

  1. 任务堆栈的使用注意事项 :存在两种堆栈形式
  • 递减堆栈 ---- 进栈操作向小 地址方向发展。(向上增长)

  • 递增堆栈 ---- 进栈操作向大地 址9方向发展。(向下增长)

  1. 空任务控制块链表
  • 当进行系统初始化时,初始化函数 OSInit()会按用户提供的任务数为系 统创建具有相应数量的任务控制块并 把它们链接为一个链表。

  • 由于这些任务控制块还没有对应的 任务,故这个链表叫做空任务块链表。 即相当于是一些空白的身份证。

  1. 当应用程序调用函数OSTaskCreate( )创建一个任务时,这个函数内部会调用系统函数 OSTCBInit( )来为任务控制块进行初始化。这个函数首先为被创建任务从空任务控制块链表 获取一个任务控制块,然后用任务的属性对任 务控制块各个成员进行赋值,最后再把这个任 务控制块链入到任务控制块链表的头部。

  2. 任何OS都要提供一个周期性的信号源,如用于系统定 时、延时、超时判断等,这个周期性的信号叫时钟,定时 通常由硬件定时器实现。

  3. uC/OS-II与大多数计算机系统一样,用硬件定时器产生 一个周期为毫秒级别的周期性中断来实现系统时钟。

  4. 最小的时钟单位就是两次中断之间相间隔的时间,这个最小的时钟单位叫做时钟节拍(Time Tick)。

  5. 硬件定时器以时钟节拍为周期定时地产生中断,该中断的中断服务程序叫做OSTickISR(),通过调用 OSTimeTick( ) 函数,完成每个OS节拍的系统工作。

  6. 任务件的同步和时间控制块

  • 任务之间的这种相互制约、相互合作的运行机制称为 “任务间的同步”

  • uC/OS-II系统中任务之间通过相互传递事件,来实现任 务的同步、依次协作。

  1. 任务间的同步和事件控制块
  • 互斥信号量是一个二值信号量,主要用于 “独占式共享 资源” 的管理(例如:打印机)。

  • 计数型信号量用于 “多个同类型资源” 的管理,通常用 一个计数器实现。(“>0”就说明有资源可用)

  1. 事件——消息邮箱(Mbox)
  • 在多任务OS中采用消息传送的方式实现任务间的 “单批次数据” 通信,这个数据称为 “消息” 。
  1. 事件——消息队列
  • 用于解决任务间的 “多个数据” 传送问题。(定义 一个指针数组,让指针数组的每个元素都存放一个消 息缓冲区指针)
  1. 三类事件:信号量/互斥信号量、消息邮箱、消息队列。

  2. 互斥型信号和任务优先级反转:

  • 解决问题的办法之一,是使获得信号量任务的优先级别在使用共享资源期间暂时提 升到所有任务最高优先级的高一个级别上, 以使该任务不被其他的任务所打断,从而 能尽快地使用完共享资源并释放信号量, 然后在释放了信号量之后再恢复该任务原 来的优先级别。
  1. 互斥型信号量是一个二值信号量,是 一种解决“任务优先级反转”现象的特 殊信号量,主要用于处理任务对共享资 源独占问题。为此,“事件” 数据结构 上有一些特殊:

  2. 消息邮箱功能:用于在任务件传递一个数据;

  • 消息邮箱使用传递变量指针的手段在任务之间进行通信。
  1. 消息队列:用于任务或ISR向其他任务传送多条数据;
  • 消息队列组成部分:ESB、OS_Q(队列控制块)、void *Msg Tbl、Message。
  1. 在实际应用中,任务常需要与多个事件同步。即需要根据多个逻辑信号量组合作用(逻辑运算)的结果来决定任务的运行方式。uC/OS-II中定义了一种特殊的数据结构——信号量集,来专用于此类 事务的管理。

  2. 位图默认16位,每一位都对应一个信号量,用来接收并保存其他任务发送来的信号量,值,可以看做输入信号暂存器。

  3. uC/OS-II为什么要进行动态内存管理?

答:合理有效地对内存存储器进行分配和管理,是衡量一个操作系统品质的指标之一,比较完善的操作系统必须具有动态分配内存的能力。

uC/OS-II改进了标准C用来动态和释放内存的函数malloc()和free(),实现了动态内存分配管理的实时性要求,保证系统在动态内存分配时,执行时间时可确定的。

  1. uC/OS-II对内存进行两级管理:
  • uC/OS-II中将连续的大块内存按分区来管理,称之为 “内存
  1. 嵌入式操作系统的特点:

必要性:嵌入式系统软件愈加庞大复杂。

微型化、可裁剪:软、硬件小而精,够用即可。

实时性:抢占式管理策略,满足时件正确性。

可靠性:无人值守、自动化设备的使用要求。

易移植:便于应用到多种的硬件平台。

微内核:完成OS主要功能的代码很小。

  1. 嵌入式操作系统的基本功能:

多任务管理:丰富的多任务管理函数供目标系 统设计者容易完成多任务应用设计。

内存管理:动态内存管理充分利用硬件资源。

外设管理:例如I2C、UART、Timer、SPI等设 备的驱动。

  1. 实时操作系统VS分时操作系统

实时性:计时性,能够在要求的时间内响应并处理完系统事件。

实时系统的正确性:既要逻辑正确,还要时间正确。

  1. uC/OS-II的两种任务:系统任务、用户任务。
  • μC/OS_II进行任务调度的思想是“近似地每时每 刻总是让优先级最高的就绪任务处于运行状 态” 。为了保证这一点,它在系统或用户任务 调用系统函数及执行中断服务程序结束时总是 调用调度器,来确定应该运行的任务并运行它 。
  1. 任务的5种状态:
  • Sleep(睡眠状态):任务没有被配备任务控制块或被剥夺了任务控制块的状态

  • Ready(就绪状态):系统为任务配备了任务控制块且在任务就绪表中进行了就绪登记。

  • Running(运行状态):处于就绪状态的任务如果经调度器判断获得了CPU的使用权。

  • Wait(等待状态):正在运行的任务,需要等待一段事件或需要等待一个事件发生在运行的使用权。。。

  • ISR_Sta(中断服务状态):一个正在运行任务一旦响应中断申请就会中止运行而去执行中断服务程序。

  1. 任务的有限权和有限级别:
  • uC/OS-II的每一个任务都必须有唯一的优先级。

  • uC/OS-II最多可以管理64个优先级别分配给64个任务。

  • uC/OS-II 中用一个8b的整型数(低6b有效)来表示优先级 别,数字越小,优先级越高,prio = 0 的任务优先级最高。

  • uC/OS-II 中使用任务的优先级(prio)作为任务句柄。

系统任务

  1. 空闲任务(OS_Taskdle())使用说明:
  • uC/OS-II规定用户程序中必须使用空闲任务。

  • 该任务不能通过程序来删除。

  • 该任务是uC/OS-II初始化时自动创建,其任务优先级固定为 最低级,用户也可修改该任务的业务。

  • 目的 ---- 使 CPU 在没有用户任务可执行时也有事可做。

  1. 统计任务(OS_TaskStat())使用说明:
  • 该任务固定拥有次末任务优先级。
  1. 任务的组成:
  • 任务控制块 —— uC/OS-II进行任务管理用的一个数据结构。

  • 任务代码 —— 描述任务算法的程序编码。

  • 任务堆栈 —— 任务的工作现场环境。

  1. 任务堆栈的使用注意事项 :存在两种堆栈形式
  • 递减堆栈 ---- 进栈操作向小 地址方向发展。(向上增长)

  • 递增堆栈 ---- 进栈操作向大地 址9方向发展。(向下增长)

  1. 空任务控制块链表
  • 当进行系统初始化时,初始化函数 OSInit()会按用户提供的任务数为系 统创建具有相应数量的任务控制块并 把它们链接为一个链表。

  • 由于这些任务控制块还没有对应的 任务,故这个链表叫做空任务块链表。 即相当于是一些空白的身份证。

  1. 当应用程序调用函数OSTaskCreate( )创建一个任务时,这个函数内部会调用系统函数 OSTCBInit( )来为任务控制块进行初始化。这个函数首先为被创建任务从空任务控制块链表 获取一个任务控制块,然后用任务的属性对任 务控制块各个成员进行赋值,最后再把这个任 务控制块链入到任务控制块链表的头部。

  2. 任何OS都要提供一个周期性的信号源,如用于系统定 时、延时、超时判断等,这个周期性的信号叫时钟,定时 通常由硬件定时器实现。

  3. uC/OS-II与大多数计算机系统一样,用硬件定时器产生 一个周期为毫秒级别的周期性中断来实现系统时钟。

  4. 最小的时钟单位就是两次中断之间相间隔的时间,这个最小的时钟单位叫做时钟节拍(Time Tick)。

  5. 硬件定时器以时钟节拍为周期定时地产生中断,该中断的中断服务程序叫做OSTickISR(),通过调用 OSTimeTick( ) 函数,完成每个OS节拍的系统工作。

  6. 任务件的同步和时间控制块

  • 任务之间的这种相互制约、相互合作的运行机制称为 “任务间的同步”

  • uC/OS-II系统中任务之间通过相互传递事件,来实现任 务的同步、依次协作。

  1. 任务间的同步和事件控制块
  • 互斥信号量是一个二值信号量,主要用于 “独占式共享 资源” 的管理(例如:打印机)。

  • 计数型信号量用于 “多个同类型资源” 的管理,通常用 一个计数器实现。(“>0”就说明有资源可用)

  1. 事件——消息邮箱(Mbox)
  • 在多任务OS中采用消息传送的方式实现任务间的 “单批次数据” 通信,这个数据称为 “消息” 。
  1. 事件——消息队列
  • 用于解决任务间的 “多个数据” 传送问题。(定义 一个指针数组,让指针数组的每个元素都存放一个消 息缓冲区指针)
  1. 三类事件:信号量/互斥信号量、消息邮箱、消息队列。

  2. 互斥型信号和任务优先级反转:

  • 解决问题的办法之一,是使获得信号量任务的优先级别在使用共享资源期间暂时提 升到所有任务最高优先级的高一个级别上, 以使该任务不被其他的任务所打断,从而 能尽快地使用完共享资源并释放信号量, 然后在释放了信号量之后再恢复该任务原 来的优先级别。
  1. 互斥型信号量是一个二值信号量,是 一种解决“任务优先级反转”现象的特 殊信号量,主要用于处理任务对共享资 源独占问题。为此,“事件” 数据结构 上有一些特殊:

  2. 消息邮箱功能:用于在任务件传递一个数据;

  • 消息邮箱使用传递变量指针的手段在任务之间进行通信。
  1. 消息队列:用于任务或ISR向其他任务传送多条数据;
  • 消息队列组成部分:ESB、OS_Q(队列控制块)、void *Msg Tbl、Message。
  1. 在实际应用中,任务常需要与多个事件同步。即需要根据多个逻辑信号量组合作用(逻辑运算)的结果来决定任务的运行方式。uC/OS-II中定义了一种特殊的数据结构——信号量集,来专用于此类 事务的管理。

  2. 位图默认16位,每一位都对应一个信号量,用来接收并保存其他任务发送来的信号量,值,可以看做输入信号暂存器。

  3. uC/OS-II为什么要进行动态内存管理?

答:合理有效地对内存存储器进行分配和管理,是衡量一个操作系统品质的指标之一,比较完善的操作系统必须具有动态分配内存的能力。

uC/OS-II改进了标准C用来动态和释放内存的函数malloc()和free(),实现了动态内存分配管理的实时性要求,保证系统在动态内存分配时,执行时间时可确定的。

  1. uC/OS-II对内存进行两级管理:
  • uC/OS-II中将连续的大块内存按分区来管理,称之为 “内存
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容