个人理解,内核级线程和进程是一样的,后者与POSIX线程(pthread)有很大的区别。为此,内核的进程调度策略和系统调用也适用于内核级线程。
调度策略有三种:
1.SCHED_NORMAL非实时调度策略,默认情况下是100~139,由nice值决定;
2.SCHED_FIFO实时调度策略,先到先服务。一旦占用cpu则仍然运行。仍然运行直至有更高优先级任务抵达或自己舍弃
3.SCHED_RR实时调度策略linux社区,时间片轮转。当进程的时间片用完,系统将重新分配时间片linux nfs 进程优先级linux nfs 进程优先级,并放在就绪队列尾。同样可以被高优先级占据。
两种实时优先级范围在0至MAX_RT_PRIO-1之间,默认为0到99。
相关的系统调用(来自于LKDlinux服务器配置与管理,不同内核可能有所不同):
nice()设置进程的nice值sched_setscheduler()设置进程的调度策略sched_getscheduler()获取进程的调度策略sched_setparam()设置进程的实时优先级sched_getparam()获取进程的实时优先级sched_get_priority_max()获取实时优先级的最大值sched_get_priority_min()获取实时优先级的最小值sched_rr_get_interval()获取进程的时间片值sched_setaffinity()设置进程的处理器的亲和力sched_getaffinity()获取进程的处理器的亲和力sched_yield()暂时让出处理器
设置时须要用到structsched_param这个结构。
以下为我写的内核线程中的部份代码:
代码如下:
structsched_paramparam;
param.sched_priority=99;
sched_setscheduler(current,SCHED_FIFO,?m)//出错时返回-1