aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/sched_plugin.c
blob: 1f759b7c9f4b215c7cb92a60f5fa2a1e5d88b3c5 (plain) (blame)
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;