下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、临界区问题的产生,以及解决方法。临界区问题是嵌入式软件编程一个不得不面对的关键性问题。特别对于底层驱动,代码在内存中只有一份,上层的多任务或者多进程,都会对同一个驱动去访问,这样不可避免的遇到了任务之间打架的问题,处理好这个问题是区分一个菜鸟和老鸟的根本性关键之一。接下来谈谈临界区产生的原因:假设有以下代码:int x;void process_data()x+;假如在一个可以抢占的操作系统上有两个任务task1, task2, 全局变量x 的初始值为0, 现在两个任务task1, task2 同时去访问process_data 这个函数,两个任务各执行一次process_data 这个函数,
2、等到两个人执行完毕后,试问x的值是多少?大部分人可能会回答为2。没有操作系统的时候,的却不错,调用函数2次,就是2.问题是有了操作系统就没这么简单了,一个任务执行期间,随时可能会被另外一个任务给打断,这样就会造成临界区的问题。首先明确一个基本概念,在操作系统中每一个任务都有自己的一套寄存器,各个任务间的寄存器值很可能是不一样的。下面来具体分析这个问题产生的根本原因:x+不是一个原子型的操作,它的汇编函数有3句,分别是:1 ldr r1, mem2 add r1, r1, #13 strr1 mem如果有以下流程,参照下图:假如任务task1 刚执行完(2)即 add r1, r1,#1, 因为
3、是可以抢占的操作系统,所以被高优先级任务task 2 给抢占了,然后task 2 执行完(3) (4) (5)这三个步骤之后还给任务task 1, 最后task1 执行完(6)。如前所述,图中的task1 和task2 的寄存器值是不同的,因为任务各自有自己的一套寄存器。读者可以推导一下,x 的最终值在内存中是1而不是2!所以在多任务的情况下,共同去访问一个全局变量,会产生临界区的问题,如之前所述最终值可能是不确定的,可能是1也可能是2,所以需要采用操作系统的一定机制去保护它。接下来谈谈怎么去解决这个问题。解决方式一:void process_data()RAW_CPU_DISABLE();x
4、+;RAW_CPU_ENABLE();如上代码关了中断的话,任务也就不能被抢了,而且x+的速度很快,推荐使用这样的方式。解决方式二:void _process_data()x+;void process_data()raw_disable_sche();_process_data();raw_enable_sche();如上代码关了系统抢占后,任务之间的调度被禁止。解决方式三:void _process_data()x+;void process_data()lock();_process_data();unlock ();如上代码加软件锁之后,只能有一个任务处理此段临界区,lock可以是se
5、maphore 或者mutex.之前的例子演示的是任务和任务之间的打架冲突,会造成临界区问题,那如果是中断和任务之间的打架冲突呢?答案是一致的,唯一不同点是任务和任务之间的冲突可以有多种保护方式,但是任务和中断之间的冲突只能用关中断去保护,即采用之前的解决方式一来解决冲突。临界区的产生原因有很多,往往是复杂的,考虑如下的fifo循环缓冲区:struct raw_fifo RAW_U32 in; (1)RAW_U32 out; (2)RAW_U32 mask;void *data;RAW_U32 free_bytes;RAW_U32 size;(1) 处是fifo的的写指针,(2)处是fifo读
6、指针下面的代码是往fifo 里面写数据。RAW_U32 fifo_in(struct raw_fifo *fifo,const void *buf, RAW_U32 len)RAW_U32 l;RAW_SR_ALLOC();RAW_CPU_DISABLE(); (1)l = fifo_unused(fifo);if (len > l)len = l;fifo_copy_in(fifo, buf, len, fifo->in);(2)fifo->in += len; (3)fifo->free_bytes -= len;RAW_CPU_ENABLE();(4)return
7、 len;(2)处代码为写入数据到fifo 中。(3)处代码为更新fifo 写指针。可以看到(1) 处为关cpu 中断,(4) 处为开cpu 中断。这样做的目的是保护临界区(2)和(3)处,(2) 和(3) 处是一个连贯的逻辑,这块逻辑是不能被打断的。假设有两个任务task1, task2 同时执行fifo_in,当task1 执行完(2)之后,被高优先级任务task2抢占,当task2 执行(2)处代码时会覆盖task1之前写到fifo里面的数据,因为task1还未更新(3)处的写指针。 这个例子里用到了开关中断来保护临界区,因为中断里也会用到fifo 的api.所以对于软件部分的临界区,往往要保护的是整个全局变量所引发的一系列逻辑。而不仅是保护那个全局变量,读者需要仔细体会。接下来谈谈硬件临界区。所谓的硬件临界区是指一个任务在访问硬件设备的时候,比如写操作,这个时候不允许有其它任务,或者中断去访问这个操作,不然整个写的时序就被破坏了,很可能结果不可预料,往往会挂机。举例如下:_nan
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 19842-2025轨道车辆空调机组
- GB/T 46530-2025营运船舶二氧化碳排放强度等级及评定方法
- GB/T 46441-2025影像材料彩色反射照片臭氧褪色稳定性的试验方法
- 胆囊结石嵌顿的护理
- 雨课堂学堂在线学堂云《财富管理(黑龙江财经学院 )》单元测试考核答案
- 高考化学“3+2”模拟练试卷含答案(七)
- 2026年投资项目管理师之投资建设项目决策考试题库200道含答案【轻巧夺冠】
- 2026航空工业未来机载武器技术协同创新中心校园招聘历年真题汇编附答案解析
- 浙江国企招聘-2025浙江湘旅控股集团有限公司招聘10人历年真题汇编带答案解析
- 2026年度中国石化毕业生招聘历年真题汇编带答案解析
- 河道疏浚沙石运输合同
- 路灯灯头改造施工组织设计(方案)
- GB 8903-2024电梯用钢丝绳
- 羽毛球比赛对阵表模板
- 房屋续租再签合同范本
- 青春健康懂营养智慧树知到期末考试答案章节答案2024年昆明医科大学
- 土壤固化剂对边坡加固
- 非公司企业改制登记(备案)申请书
- 《安装操作系统示范》课件
- 读书与书籍-课件
- 数据中心基础实施培训UPS
评论
0/150
提交评论