[宏]preempt_disable

[宏]preempt_disable,第1张

[宏]preempt_disable
 //include/linux/preempt.h
#ifdef CONFIG_PREEMPT_COUNT //如果内核支持抢占
#define preempt_disable() \
do { \
inc_preempt_count(); \
barrier(); \
} while ()
#else //如果不支持抢占,退化成了一个内存屏障
#define preempt_disable() barrier()
#endif
#define inc_preempt_count() add_preempt_count(1) //一般发行版本不会开启debug配置这里选择else
#if defined(CONFIG_DEBUG_PREEMPT) || defined(CONFIG_PREEMPT_TRACER)
extern void add_preempt_count(int val);
extern void sub_preempt_count(int val);
#else
# define add_preempt_count(val) do { preempt_count() += (val); } while ()
# define sub_preempt_count(val) do { preempt_count() -= (val); } while ()
#endif //这里就是或取了对应线程的thread_info的prempt_count字段
#define preempt_count() (current_thread_info()->preempt_count) //arch/x86/include/asm/thread_info.h
struct thread_info {
int preempt_count; /* 0 => preemptable,<0 => BUG */
}; /*内存屏障有不同的实现方法,例如gcc可以插入如下汇编实现,在某些特殊的编译器下,
提供了其他方法,内存屏障本身不具有运算功能。


因此在阅读代码时可以忽略,内存屏障的语意:
“指令实际执行时确保存屏障后代码产生的指令开始执行前,内存屏障之前代码产生的指令一定
已经执行结束。


并且屏障前对内存中变量的访问都已经写入到内存。


”gcc的一种实现如下:*/
#define barrier() __asm__ __volatile__("": : :"memory") /*总结:
1.如果配置没有开启内核抢占配置preempt_disable退化成一个内存屏障
2.如果开启了内核抢占功能,preempt_disable一次调用会让当前线程的thread_info.preempt_count字段加1
*/

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/588160.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-12
下一篇 2022-04-12

发表评论

登录后才能评论

评论列表(0条)

保存