BUG: scheduling while atomic

▌▌上篇文章的内容还没有结束

中断处理函数中如果执行了调度,会发生什么

▌这次,我修改了程序,在中断处理函数中调用了msleep

程序执行后,会有这样的日志

▌关键就是这句

BUG: scheduling while atomic

我们追代码,可以看到这个打印调用是这样的

msleep() -> schedule() ->__schedule() ->schedule_debug()

继续

▌这个日志已经明确说明这是一个bug

宏 in_atomic_preempt_off()用于判断当前的上下文是否在原子上下文(atomic context)中,并且禁用了抢占(preemptdisable)。原子上下文是指不允许发生调度的上下文,例如中断处理程序、软中断或其他关键部分。

在Linux内核中,preempt_count() 函数返回当前的抢占计数,这个计数用来跟踪当前上下文是否可以发生抢占。`PREEMPT_DISABLE_OFFSET` 是一个常量,它的值通常设置为0,表示没有禁用抢占时的抢占计数。

▌因此,in_atomic_preempt_off() 宏的作用是:

1)调用 `preempt_count()` 获取当前的抢占计数。

2)比较这个计数是否不等于 `PREEMPT_DISABLE_OFFSET`(即是否不等于0)。

3)如果返回值不为0,说明当前上下文禁用了抢占,可能是在原子上下文中。

这个宏通常用于调试或在内核调度器代码中检查当前上下文的状态,以确保在不允许抢占的上下文中不会执行可能导致调度的操作。如果在这个宏返回非零值的情况下发生了调度,就会触发 "scheduling while atomic" 的错误。

▌在看这个宏上面还有一个宏

这两个宏内容是一样的,只是名字略微不同,并且说明了这个宏不能在驱动代码上使用。

关于不能在中断执行msleep这个事情咨询了两个大佬

▌谢宝友老师

谢老师的观点有点和窝窝的观点一致,以理解为主

https://www.cnblogs.com/zzb-Dream-90Time/p/9394248.html

▌韦老师的观点

msleep是给线程用的,中断没有线程的概念,调用msleep简直牛头不对马嘴。

好啦,这个问题就到此为止咯,后续有新的发现再研究

相关推荐
十五年专注C++开发16 分钟前
cargs: 一个轻量级跨平台命令行参数解析库
linux·c++·windows·跨平台·命令行参数解析
mahuifa41 分钟前
C++(Qt)软件调试---bug排查记录(36)
c++·bug·软件调试
极地星光42 分钟前
版本发布流程手册:Release分支规范与Bug分级标准全解析
运维
Kyln.Wu43 分钟前
【python实用小脚本-205】[HR揭秘]手工党逐行查Bug的终结者|Python版代码质量“CT机”加速器(建议收藏)
开发语言·python·bug
三坛海会大神5551 小时前
Linux服务器资源自动监控与报警脚本详解
linux·运维·服务器
CookieCrusher4 小时前
数据泄露危机逼近:五款电脑加密软件为企业筑起安全防线
运维·数据库·windows·安全·文件加密·数据防泄漏·dlp
小薛博客6 小时前
17、DevOps持续集成、持续部署
运维·ci/cd·devops
霍格沃兹软件测试开发7 小时前
Browser Use:打造你的浏览器自动化助手
运维·自动化
向qian看_-_7 小时前
Linux 使用pip报错(error: externally-managed-environment )解决方案
linux·python·pip
yaoxtao7 小时前
java.nio.file.InvalidPathException异常
java·linux·ubuntu