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日上传