rtlinux 原理
摘抄自: https://rt.wiki.kernel.org/index.php/Frequently_Asked_Questions
How does the CONFIG_PREEMPT_RT patch work?
The RT-Preempt patch converts Linux into a fully preemptible kernel. The magic is done with:
Making in-kernel locking-primitives (using spinlocks) preemptible though reimplementation with rtmutexes.
Critical sections protected by i.e. spinlock_t and rwlock_t are now preemptible. The creation of non-preemptible sections (in kernel) is still possible with raw_spinlock_t (same APIs like spinlock_t).
Implementing priority inheritance for in-kernel spinlocks and semaphores. For more information on priority inversion and priority inheritance please consult Introduction to Priority Inversion.
Converting interrupt handlers into preemptible kernel threads: The RT-Preempt patch treats soft interrupt handlers in kernel thread context, which is represented by a task_struct like a common user space process. However it is also possible to register an IRQ in kernel context.
Converting the old Linux timer API into separate infrastructures for high resolution kernel timers plus one for timeouts, leading to user space POSIX timers with high resolution.
总结:
减少linux的关抢占时间,让高优先级任务能够更快的被调度到运行
- 将会关抢占的spinlock改成rtmutext, spinlock变成可抢占
- 将中断内核线程化。软中断改成内核线程
- 增加优先级继承,解决优先级反锁问题
原生linux 内核抢占选项
- CONFIG_PREEMPT_VOLUNTARY
在内核函数流程中布置了cond_schedule 函数, 即内核里布满了检查是否有高优先级任务可以抢占当前任务的情况 - CONFIG_PREEMPT
— 增加中断在内核态返回以及 抢占打开时的任务抢占切换检查
参考资料
https://blog.csdn.net/rikeyone/article/details/94555165