免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2053 | 回复: 7
打印 上一主题 下一主题

2.6.27, sched.c中pair_start是做什么的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-28 16:01 |只看该作者 |倒序浏览
给出定义和调用。

struct cfs_rq {
        struct load_weight load;
        unsigned long nr_running;

        u64 exec_clock;
        u64 min_vruntime;
        u64 pair_start;
。。。
}

sched_fair.c中
static struct sched_entity *
pick_next(struct cfs_rq *cfs_rq, struct sched_entity *se)
{
        struct rq *rq = rq_of(cfs_rq);
        u64 pair_slice = rq->clock - cfs_rq->pair_start;

        if (!cfs_rq->next || pair_slice > sched_slice(cfs_rq, cfs_rq->next)) {
                cfs_rq->pair_start = rq->clock;
                return se;
        }

        return cfs_rq->next;
}


============
还有,sched_fair.c中

static inline unsigned long
calc_delta_weight(unsigned long delta, struct sched_entity *se)
{
        for_each_sched_entity(se) {
                delta = calc_delta_mine(delta,
                                se->load.weight, &cfs_rq_of(se)->load);
        }

        return delta;
}


calc_delta_weight() 是算一个se的delta吧?为什么把第一个用calc_delta_mine()算出来的delta再一次带到循环中去,一直循环下去直到遍历到空。
这个函数不明白再干嘛?

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
2 [报告]
发表于 2008-11-28 16:17 |只看该作者
LZ研究的内核比较新啊。对照ULKv3中,看看有没有相应的解释。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
3 [报告]
发表于 2008-11-28 16:25 |只看该作者
原帖由 Godbach 于 2008-11-28 16:17 发表
LZ研究的内核比较新啊。对照ULKv3中,看看有没有相应的解释。


ulk不可能有这个东西的解释,2.6.24里面都没出现这个东西,我还是在lxr上,最新的2.6.27中查到这个东西的。关注一下。

[ 本帖最后由 dreamice 于 2008-11-28 16:30 编辑 ]

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
4 [报告]
发表于 2008-11-28 16:36 |只看该作者

回复 #1 bjut_penguin 的帖子

查了一下,这个好像是2.6.27内核中引进的,用于改进伙伴算法以及进程的唤醒粒度的:

The initial idea was that buddies could run ahead as far as a normal task
can - do this by measuring a pair 'slice' just as we do for a normal task.

This means we can drop the wakeup_granularity back to 5ms.

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
5 [报告]
发表于 2008-11-28 16:41 |只看该作者
原帖由 dreamice 于 2008-11-28 16:36 发表
查了一下,这个好像是2.6.27内核中引进的,用于改进伙伴算法以及进程的唤醒粒度的:

The initial idea was that buddies could run ahead as far as a normal task
can - do this by measuring a pair 'sli ...


呵呵,内核快把我们给淘汰了。

论坛徽章:
0
6 [报告]
发表于 2008-11-28 17:16 |只看该作者
谢谢版大(或者版n)。。

还有一个东西,for_each_sched_entity(se)  非常诡异。。。

如果是group_sched,那么这个宏是从se沿着树向上遍历,这还说的过去。
但是如果不是group_sched呢,它定义成
#define for_each_sched_entity(se) \
                for (; se; se = NULL)

这个怎么解释?而且我查了,内核里引用这个东西的地方都没有改变se这个指针。。。(比如下面的函数)

一个se不停地循环,那岂不是跑死了? 可是事实肯定不是这样的呀,为啥 ?

calc_delta_weight(unsigned long delta, struct sched_entity *se)
{
        for_each_sched_entity(se) {
                delta = calc_delta_mine(delta,
                                se->load.weight, &cfs_rq_of(se)->load);
        }

        return delta;
}

原帖由 dreamice 于 2008-11-28 16:36 发表
查了一下,这个好像是2.6.27内核中引进的,用于改进伙伴算法以及进程的唤醒粒度的:

The initial idea was that buddies could run ahead as far as a normal task
can - do this by measuring a pair 'sli ...

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
7 [报告]
发表于 2008-11-28 17:29 |只看该作者
                delta = calc_delta_mine(delta,
                                se->load.weight, &cfs_rq_of(se)->load);

这个里面也没有吗

论坛徽章:
0
8 [报告]
发表于 2008-11-28 18:10 |只看该作者
calc_delta_mine()
这个函数很清楚。
我不是在说它,我是在说:

为啥每次用calc_delta_mine()算出来的delta都作为参数再一次进入calc_delta_mine(),我不明白这里的道理。。

原帖由 Godbach 于 2008-11-28 17:29 发表

这个里面也没有吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP