1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
/* sched_plugin.c -- core infrastructure for the scheduler plugin system
*
* This file includes the initialization of the plugin system, the no-op Linux
* scheduler plugin and some dummy functions.
*/
#include <linux/litmus.h>
#include <linux/sched_plugin.h>
/*************************************************************
* Dummy plugin functions *
*************************************************************/
void litmus_dummy_finish_switch(struct task_struct * prev)
{
}
int litmus_dummy_schedule(struct task_struct * prev,
struct task_struct** next,
runqueue_t* q)
{
return 0;
}
reschedule_check_t litmus_dummy_scheduler_tick(void)
{
return NO_RESCHED;
}
long litmus_dummy_prepare_task(struct task_struct *t)
{
return 0;
}
void litmus_dummy_wake_up_task(struct task_struct *task)
{
printk(KERN_WARNING "task %d: unhandled real-time wake up!\n",
task->pid);
}
void litmus_dummy_task_blocks(struct task_struct *task)
{
}
long litmus_dummy_tear_down(struct task_struct *task)
{
return 0;
}
int litmus_dummy_scheduler_setup(int cmd, void __user *parameter)
{
return -EPERM;
}
long litmus_dummy_sleep_next_period(void)
{
return -EPERM;
}
long litmus_dummy_inherit_priority(struct pi_semaphore *sem,
struct task_struct *new_owner)
{
return -EPERM;
}
long litmus_dummy_return_priority(struct pi_semaphore *sem)
{
return -EPERM;
}
long litmus_dummy_pi_block(struct pi_semaphore *sem,
struct task_struct *new_waiter)
{
return -EPERM;
}
/* The default scheduler plugin. It doesn't do anything and lets Linux do its
* job.
*/
sched_plugin_t linux_sched_plugin = {
.plugin_name = "Linux",
.ready_to_use = 1,
.scheduler_tick = litmus_dummy_scheduler_tick,
.prepare_task = litmus_dummy_prepare_task,
.tear_down = litmus_dummy_tear_down,
.wake_up_task = litmus_dummy_wake_up_task,
.task_blocks = litmus_dummy_task_blocks,
.sleep_next_period = litmus_dummy_sleep_next_period,
.schedule = litmus_dummy_schedule,
.finish_switch = litmus_dummy_finish_switch,
.scheduler_setup = litmus_dummy_scheduler_setup,
.inherit_priority = litmus_dummy_inherit_priority,
.return_priority = litmus_dummy_return_priority,
.pi_block = litmus_dummy_pi_block
};
/*
* The reference to current plugin that is used to schedule tasks within
* the system. It stores references to actual function implementations
* Should be initialized by calling "init_***_plugin()"
*/
sched_plugin_t *curr_sched_plugin = &linux_sched_plugin;
|