RTOS(实时操作系统)属于抢占式内核类型。
接下来,我们将讨论一下抢占式内核和非抢占式内核的内容。
抢占式内核
抢占式内核允许操作系统中的任务(线程)在任何时刻被更高优先级的任务抢占,以便立即执行。这种内核可以通过时钟中断或其他触发事件来进行任务切换。
相比之下,非抢占式内核要求每个任务都显式地放弃对 CPU 的控制权,才能让其他任务获得执行机会,这种方式被称为协作多任务。只有在当前任务主动放弃 CPU 时,新的更高优先级任务才能获得控制权。
抢占式内核具有更高的灵活性和响应性,可以在实时系统中提供更可靠的任务调度和更低的中断延迟。它允许增加任务的优先级,并且可以立即切换到更高优先级的任务,以满足实时任务的要求。
然而,抢占式内核的上下文切换开销相对较高,且需要额外的硬件支持。此外,编写抢占式任务代码需要考虑并发性和同步性问题,以防止竞态条件和死锁等并发问题的出现。
总结起来,抢占式内核适用于实时系统和对任务响应时间有严格要求的应用程序,可以提供更好的并发性和实时性能。
非抢占式内核的另一个优点是较少需要通过使用信号量来保护共享数据。每个任务都拥有 CPU,你不必担心任务会被抢占。当然,这不是绝对的,在某些情况下,仍应使用信号量。共享 I/O 设备可能仍需要使用互斥信号量;例如,任务可能仍需要对打印机的独占访问。
(1) 任务正在执行但被中断。
(2) 如果中断被使能,CPU 向量(跳转)到 ISR。
(3) ISR 处理事件并使更高优先级的任务准备好运行。
(4) ISR完成后,执行返回指令,CPU返回被中断的任务。
(5) 任务代码在中断指令之后的指令处恢复。
(6) 当任务代码完成时,它调用内核提供的服务,将 CPU 交给另一个任务。
(7) 内核看到更高优先级的任务已经准备好运行,因此,内核执行上下文切换,以便它可以运行(即执行)更高优先级的任务来处理由 ISR 发出信号的事件。
非抢占式内核最重要的缺点是响应性:已准备好运行的较高优先级任务可能需要等待很长时间才能运行,因为当前任务应该及时放弃CPU使用权。
与前台/后台系统中的后台执行一样,非抢占式内核中的任务级响应时间是不确定的;你永远不知道最高优先级的任务何时才能获得 CPU 的控制权。这个操作由你的应用程序来决定怎么时候放弃对 CPU 的控制。
总而言之,非抢占式内核允许每个任务运行,直到它自愿放弃对 CPU 的控制。中断抢占任务,ISR 完成后,ISR 返回到被中断的任务。任务级响应比前台/后台系统要好得多,但仍然是不确定的,因此,很少有商业内核是非抢占式的。
抢占式内核
μC/OS-II、RTT等大多数实时内核都是抢占式的,准备运行的最高优先级任务始终被赋予 CPU 控制权。
当一个任务使更高优先级的任务准备好运行时,当前任务被抢占(挂起)并且更高优先级的任务立即获得 CPU 的控制权。
如果 ISR 使更高优先级的任务准备就绪,当 ISR 完成时,被中断的任务被挂起并恢复新的更高优先级任务。
(1) 任务正在执行但被中断。
(2) 如果中断被使能,CPU 向量(跳转)到 ISR。
(3) ISR 处理事件并使更高优先级的任务准备好运行。ISR 完成后,调用内核提供的服务(即调用内核提供的函数)。
(4) & (5) 该函数知道一个更重要的任务已经准备好运行,因此内核将执行上下文切换并执行更重要的代码而不是返回到被中断的任务任务。当更重要的任务完成时,内核提供的另一个函数被调用,让任务进入休眠状态,等待事件(即 ISR)发生。
(6) & (7) 然后内核“看到”需要执行一个较低优先级的任务,并完成另一个上下文切换以恢复被中断任务的执行。
使用抢占式内核,最高优先级任务的执行是确定性的;你可以确定它何时可以控制 CPU。因此,通过使用抢占式内核可以最大限度地减少任务级响应时间。
使用抢占式内核的应用程序代码不应使用不可重入函数,除非通过使用互斥信号量确保对这些函数的独占访问,因为低优先级和高优先级任务都可以使用公共函数。如果较高优先级的任务抢占正在使用该功能的较低优先级的任务,则可能会发生数据损坏。
总而言之,抢占式内核始终执行准备运行的最高优先级任务。中断抢占任务,完成 ISR 后,内核将继续执行准备运行的最高优先级任务(而不是被中断的任务)。任务级别的响应是最佳的和确定性的,当系统响应性很重要时,建议使用抢占式内核。
以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !