当前位置:  技术问答>linux和unix

linux进程调度问题

    来源: 互联网  发布时间:2016-08-08

    本文导语:  linux进程调度相关的结构有:runqueue,prio_arry,list_head struct prio_arry {    int               nr_active;    unsigned long     bigmap[BITMAP_SIZE];    struct list_head  queue[MAX_PRIO];//每种优先级的都包含一个相应的队列...

linux进程调度相关的结构有:runqueue,prio_arry,list_head
struct prio_arry
{
   int               nr_active;
   unsigned long     bigmap[BITMAP_SIZE];
   struct list_head  queue[MAX_PRIO];//每种优先级的都包含一个相应的队列
};
其中queue成员是一个数组,每个元素表示某种优先级上的可执行任务队列
但是list_head结构的定义如下:
struct list_head
{
   struct list_head *next, *prev;
};

看不懂,怎么得到任务的。。。
比如我现在已经得到了一个list_head,表示某种优先级的可执行任务队列,那我怎么从这个list_head中得到任务???

望高手不吝赐教阿,谢谢

|
你说的是O(1)调度器,2.6.23以上被废了
你要实现的功能可以参考2.6.22的/kernel/sched.c
中的schedule()



asmlinkage void __sched schedule(void)
{
struct task_struct *prev, *next;
struct prio_array *array;
struct list_head *queue;
struct rq *rq;
int cpu, idx, new_prio;

...
rq = this_rq();
array = rq->active;
idx = sched_find_first_bit(array->bitmap); //查找位图中第一个为1的位,即最高优先级对应的位
queue = array->queue + idx; //取出相应优先级的list_head

//得到该优先级第一个task_struct
next = list_entry(queue->next, struct task_struct, run_list);
...

}

    
 
 

您可能感兴趣的文章:

  • 请问操作系统中任务调度主要有哪些策略,LINUX用哪种啊??实时操作系统又有哪些任务调度哪些策略啊??
  • 求意见如何在linux的应用软件中实现一个cpu调度框架,使得多个cpu调度算法可以在同一个系统中实现无缝整合?(分数不够还能再加)
  • linux进程调度
  • Linux 内核调度器 BFS
  • 请教下linux达人 相关版本2.6的进程调度
  • Linux 调度器 SCHED_DEADLINE
  • linux cpu调度策略中的老化公式
  • 求Linux 2.6 进程调度分析报告一篇,比较急,有的话发送到我的邮箱crazyswan@163.com
  • 求:linux2.4进程调度内核原代码的完全注解!!!
  • linux下多线程开发遇到的调度问题!!!急~~~~~在线等!
  • 关于LINUX内核调度个人一些思索
  • linux 进程调度
  • 兄弟们,请帮帮忙吧,关于LINUX 的调度和时钟中断处理代码的分析!在线等待啊。。。:(
  • 求 x86 架构下 Linux 的进程调度的实现分析文档
  • 回声抵消算法在LINUX ARM上跑的调度问题求助
  • LINUX的任务调度
  • linux如何主动将线程放入到线程调度队列中重新排队?
  • linux调度模拟器 LinSched
  • 新手,请教一个linux线程调度问题
  • linux下调用sleep或者usleep函数的CPU线程调度情况?
  • linux僵尸(zombie)进程介绍及清除
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • linux下进程占用内存空间详解
  • linux命令如何实现重启父进程而不会使其子进程退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • Linux中最多同时可以开多少个进程,一个进程可以开多少个线程?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • Linux守护进程 的子进程 终端处理
  • Linux内核进程与应用进程的通信方式有哪些?
  • 在linux,如何用共享内存来实现进程间的通讯?(这些进程没有父子关系)
  • linux下system函数调用shell命令后,怎样让主进程不等子进程返回,接着执行(在线)?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux下时钟同步问题:Clock skew detected原因分析及解决方法
  • linux 繁体 汉字输入法 问题 linux 繁体 汉字输入法 问题
  • Linux 下c++开发error while loading shared libraries问题解决
  • 先安装linux,后安装winxp,能否解决正常启动linux的问题不?(初学者问题,很容易回答)
  • 弱弱的一问,linux下的中文问题及网络问题,分不是问题
  • Linux新手问,Linux安装问题。
  • linux下游戏问题。(菜鸟问题)
  • 初学Linux,发现Linux下的版本问题很头痛。【系列问题】
  • 高深问题:有了linux内核源代码如何做成一个linux操作系统
  • 一个很菜的问题,关ARM与linux内核裁剪的问题!
  • vmware装的linux,通过win2000访问linux的web服务器有问题
  • 初次接触linux,关于linux 用户权限问题请教!
  • Linux下是否存在磁盘碎片问题和内存碎片问题?
  • linux开发的应用程序部署到其他linux的问题
  • vmware上装LINUX的问题,WIN7可以拼的通linux的IP,linux拼不通win7的IP
  • Linux互ping在局域网内大量丢包,但是linux和windows互ping就没问题。
  • 最菜的问题—关于linux“动态库”的问题
  • linux下挂载linux分区的问题
  • 一个小问题。Linux下编程语言的问题。
  • linux问题 secureCRT连接的问题 在线等急!~~
  • Linux下环境变量问题以及FLEX安装问题
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3