OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7858|回复: 9

求助 任务阻塞态的通俗含义

[复制链接]

1

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2018-4-2
在线时间
7 小时
发表于 2018-4-2 13:16:11 | 显示全部楼层 |阅读模式
1金钱
void PackUpdateRegular_task(void *pvParameters)     任务优先级最高
{
   while(1)
  {
       err=xSemaphoreTake(RegHeartSemaphore,portMAX_DELAY);        //获取信号量
     if( err==pdTRUE)
      {
      ..........
      }
  }
}

void 任务1   //  任务优先级低
{
  while(1)
  {
   ......
  }
}
void 任务2   //  任务优先级低
{
  while(1)
  {
   ......
  }
}


void 某个中断
{
      xSemaphoreGiveFromISR(RegHeartSemaphore,&xHigherPriorityTaskWoken);        //释放二值信号量
}

大神 请教下这样处理        ,PackUpdateRegular_task里面一直在获取二值信号量,是不是获取第一次  信号量无效的时候 就进入堵塞态的,然后就去执行低优先级的任务,PackUpdateRegular_task阻塞态没有结束,不会去频繁查询二值信号量,只有当中断里面释放了 二值信号量 才会再下次任务调度后 去执行PackUpdateRegular_task 里面的内容,。。。。。。。。。。。。。。。。还是每次任务调度后 都去判断下任务优先级高的PackUpdateRegular_task的二值信号量的状态

最佳答案

查看完整内容[请看2#楼]

任务阻塞以后会把任务放到对应等待的信号量的等待列表里面,这样信号量更新的时候会查询等待该信号量的任务,并将对应的任务移到就绪列表中,下一次时钟节拍来的时候会将最高优先级的任务运行
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

1

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-4-16
在线时间
20 小时
发表于 2018-4-2 13:16:12 | 显示全部楼层
任务阻塞以后会把任务放到对应等待的信号量的等待列表里面,这样信号量更新的时候会查询等待该信号量的任务,并将对应的任务移到就绪列表中,下一次时钟节拍来的时候会将最高优先级的任务运行
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165353
金钱
165353
注册时间
2010-12-1
在线时间
2108 小时
发表于 2018-4-3 01:31:32 | 显示全部楼层
帮顶
回复

使用道具 举报

1

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2018-4-2
在线时间
7 小时
 楼主| 发表于 2018-4-7 15:17:35 | 显示全部楼层
自己再顶下,我自己理解和实验的结果是, PackUpdateRegular_task获取一次 信号量无效的时候 就进入堵塞态,直到中断释放了信号量 这个任务才到就绪态,等待下次任务切换。
回复

使用道具 举报

22

主题

203

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
378
金钱
378
注册时间
2017-11-29
在线时间
135 小时
发表于 2018-4-9 22:37:45 来自手机 | 显示全部楼层
讲清这个问题最好结合代码。把源码拉出来
回复

使用道具 举报

22

主题

203

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
378
金钱
378
注册时间
2017-11-29
在线时间
135 小时
发表于 2018-4-9 22:39:52 来自手机 | 显示全部楼层
暗尘香 发表于 2018-4-9 21:48
任务阻塞以后会把任务放到对应等待的信号量的等待列表里面,这样信号量更新的时候会查询等待该信号量的任务 ...

也可能是恢复调度器的时候做任务切换?
回复

使用道具 举报

12

主题

144

帖子

0

精华

高级会员

Rank: 4

积分
545
金钱
545
注册时间
2017-8-1
在线时间
92 小时
发表于 2018-4-25 21:56:21 | 显示全部楼层
4楼正解!
青涩不及当初,聚散不由你我!
回复

使用道具 举报

0

主题

7

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2020-2-6
在线时间
5 小时
发表于 2020-2-26 00:02:04 | 显示全部楼层
自己在这里总是没能理解清楚,不是太清。是不是堵塞时,这个任务就一直等待,还是只是这一段代码处于等待中。直到信号列表里有信号后才会执行相应的信号代码。不在上锁的代码段里的程序还是会执行的。是这样现解对么?有大虾指点下为盼。
回复

使用道具 举报

19

主题

334

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1108
金钱
1108
注册时间
2018-11-6
在线时间
240 小时
发表于 2020-2-26 10:10:35 | 显示全部楼层
本帖最后由 霸王猫 于 2020-2-26 10:28 编辑
包戴远 发表于 2020-2-26 00:02
自己在这里总是没能理解清楚,不是太清。是不是堵塞时,这个任务就一直等待,还是只是这一段代码处于等待中 ...

1、是不是堵塞时,这个任务就一直等待
       你的理解是片面的,不准确。
       当程序中调用操作系统的堵塞API函数时,操作系统将当前任务的ID放入到【等待的信号量的等待列表里面】。然后做一次任务切换,跳转到处于就绪状态的最高优先级的任务中继续运行。
       刚刚被堵塞的任务再也不会被执行,不存在【这一段代码处于等待中】这种说法,因为CPU连被堵塞的任务都不予理睬,哪还有这一段代码处于等待中】这种说法呀!
      被堵塞的任务再也无法获得CPU的控制权啦!除非解除堵塞,也就不存在【这一段代码处于等待中】这种说法

       注:如果堵塞任务是等待消息队列,则收到消息队列则解锁;
              如果堵塞任务是等待信号量,则收到信号量则解锁;
              如果堵塞任务是等待互斥信号量,则收到互斥信号量则解锁;
被堵塞的任务解锁后,操作系统将其从【等待的信号量的等待列表里面】删除,让其添加到就绪等待列表中,让其处于就绪状态,可以被操作系统调度。

     可以被操作系统调度就是说,这个任务可以获得CPU的控制权了。注:可以获得CPU的控制权并不代表你能够立即获得CPU,原因参见下面:
   
     (1)、如果【堵塞的任务又处于就绪状态】时,它的优先级最高,则该被堵塞的任务【立即】获得CPU的控制权,则CPU继续从阻塞前的断点处继续执行代码。
     (2)、如果【堵塞的任务又处于就绪状态】时,它的优先级不是最高,则该被堵塞的任务【还不能立即】获得CPU的控制权,它要等到比它优先级高的任务依次获得CPU的控制权,然后处于阻塞状态时,【堵塞的任务又处于就绪状态】的任务获得CPU的控制权,则CPU继续从阻塞前的断点处继续执行代码。
回复

使用道具 举报

0

主题

7

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2020-2-6
在线时间
5 小时
发表于 2020-2-26 22:46:23 | 显示全部楼层
谢,秒清楚了。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-25 21:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表