xen的cpu调度流程分析

xen的cpu调度流程分析

__start_xen→init_idle_domain→init_idle_domain→scheduler_init

void __init scheduler_init(void)

{

    …

open_softirq(SCHEDULE_SOFTIRQ, schedule);

for_each_possible_cpu ( i )

{

    spin_lock_init(&per_cpu(schedule_data, i).schedule_lock);

    init_timer(&per_cpu(schedule_data, i).s_timer, s_timer_fn, NULL, i);

}

扫描二维码关注公众号,回复: 11417804 查看本文章

}

SCHEDULE_SOFTIRQ

这个软中断用于触发调度器的执行。在调度器初始化的时候初始化,中断服务例程是调度函数schedule。

在调度器初始化时,初始化调度定时器,到那个时刻触发函数s_timer_fn。

/* The scheduler timer: force a run through the scheduler */

static void s_timer_fn(void *unused)

{

    raise_softirq(SCHEDULE_SOFTIRQ);

    perfc_incr(sched_irq);

}

raise_softirq在s_timer_fn中触发调度的软中断,从而执行调度函数schedule。

static void schedule(void)

{

    …

if ( next_slice.time >= 0 ) /* -ve means no limit */

        set_timer(&sd->s_timer, now + next_slice.time);

}

在schedule中执行set_timer,触发调度定时器s_timer,时间到后触发函数s_timer_fn,如此循环反复调度。

 

2013年5月20日上传

猜你喜欢

转载自blog.csdn.net/tdaajames/article/details/107516005
XEN