linux进程调度的实现——进程记账

本文探讨了Linux进程调度中的进程记账机制,包括如何记录进程的运行时间和虚拟运行时间(vruntime)。通过sched_entity结构保存进程状态,并使用update_curr()函数更新虚拟运行时间。该过程涉及delta_exec的计算,表示已执行时间的增量,进而通过__update_curr函数和calc_delta_fair计算权重值,完成进程记账。
摘要由CSDN通过智能技术生成

linux进程调度的实现一共由四部分组成

                 (1)、时间记账(就是记录进程已经运行了多长时间了,还要运行多长时间)

                 (2)、进程选择(加入红黑树)

                 (3)、调度器入口

                 (4)、睡眠和唤醒


进程记账:

          这个说的挺形象的,就是记录一个进程占用处理器资源的时间长短。既然要记录,那么就需要存放在一个位置,内核说:放在sched_entity结构中吧!


sched_entity结构(2.6内核源码kernel/sched/fair.c 1134 行):

struct sched_entity {
        struct load_weight      load;           /* for load-balancing */
        struct rb_node          run_node;
        struct list_head        group_node;
        unsigned int            on_rq;

        u64                     exec_start;
        u64                     sum_exec_runtime;
        u64                     vruntime;
        u64    
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值