b620126

    1. 系统最大关中断时间为0us的原理 8/5539 嵌入式系统 2013-02-23
      版主啊 对你的操作系统很感兴趣,问一下 关于 第二种是关抢占形式: #define  RAW_CRITICAL_ENTER()                                       \          do {                                                     \              RAW_CPU_DISABLE();                                 \              raw_sched_lock++;                           \              RAW_CPU_ENABLE();                                  \          } while (0) 后一种方式即为系统统最大关中断时间为0us的实现关键,可以看到 raw_sched_lock++; 即为关了系统抢占。 但是系统只关了抢占,只能防止任务和任务之间临界区的冲突,不能防止任务和中断之间的冲突。raw os 的api 很多都能在中断里面,这样的话势必会和外面api 产生临界区的冲突,必须采用特殊的方法把中断里面使用的api 弄到任务空间里去做。Task 0 的存在正是解决这个问题的方法,假设中断里面调用到了 raw os 的api ,假设是raw_semaphore_put, 此函数会接着调用int_msg_post 把这个api 的事件存储起来,然后快速唤醒task 0, 一出中断后立马运行raw_semaphore_put. 实际上就是说 你的API函数改为到任务空间去执行 减少绝对关中断时的操作时间 但是这样我调用API实际上 这个信号量就没有被立即执行 而是被延时到了 一个Task里面去调度之后才执行完成 那这时函数返回值 怎么处理呢 是不是应该在信号量执行完成之后 才能给出呢?

最近访客

< 1/1 >

统计信息

已有49人来访过

  • 芯积分:--
  • 好友:--
  • 主题:--
  • 回复:1

留言

你需要登录后才可以留言 登录 | 注册


现在还没有留言