xref: /minix3/minix/kernel/system/do_schedctl.c (revision dc2c582f364d955cff3a86092716702b099d2db2)
1433d6423SLionel Sambuc #include "kernel/system.h"
2433d6423SLionel Sambuc #include <minix/endpoint.h>
3433d6423SLionel Sambuc 
4433d6423SLionel Sambuc /*===========================================================================*
5433d6423SLionel Sambuc  *			          do_schedctl			     *
6433d6423SLionel Sambuc  *===========================================================================*/
do_schedctl(struct proc * caller,message * m_ptr)7433d6423SLionel Sambuc int do_schedctl(struct proc * caller, message * m_ptr)
8433d6423SLionel Sambuc {
9433d6423SLionel Sambuc 	struct proc *p;
10433d6423SLionel Sambuc 	uint32_t flags;
11433d6423SLionel Sambuc 	int priority, quantum, cpu;
12433d6423SLionel Sambuc 	int proc_nr;
13433d6423SLionel Sambuc 	int r;
14433d6423SLionel Sambuc 
15433d6423SLionel Sambuc 	/* check parameter validity */
16433d6423SLionel Sambuc 	flags = m_ptr->m_lsys_krn_schedctl.flags;
17433d6423SLionel Sambuc 	if (flags & ~SCHEDCTL_FLAG_KERNEL) {
18433d6423SLionel Sambuc 		printf("do_schedctl: flags 0x%x invalid, caller=%d\n",
19433d6423SLionel Sambuc 			flags, caller - proc);
20433d6423SLionel Sambuc 		return EINVAL;
21433d6423SLionel Sambuc 	}
22433d6423SLionel Sambuc 
23433d6423SLionel Sambuc 	if (!isokendpt(m_ptr->m_lsys_krn_schedctl.endpoint, &proc_nr))
24433d6423SLionel Sambuc 		return EINVAL;
25433d6423SLionel Sambuc 
26433d6423SLionel Sambuc 	p = proc_addr(proc_nr);
27433d6423SLionel Sambuc 
28433d6423SLionel Sambuc 	if ((flags & SCHEDCTL_FLAG_KERNEL) == SCHEDCTL_FLAG_KERNEL) {
29433d6423SLionel Sambuc 		/* the kernel becomes the scheduler and starts
30433d6423SLionel Sambuc 		 * scheduling the process.
31433d6423SLionel Sambuc 		 */
32433d6423SLionel Sambuc 		priority = m_ptr->m_lsys_krn_schedctl.priority;
33433d6423SLionel Sambuc 		quantum = m_ptr->m_lsys_krn_schedctl.quantum;
34433d6423SLionel Sambuc 		cpu = m_ptr->m_lsys_krn_schedctl.cpu;
35433d6423SLionel Sambuc 
36433d6423SLionel Sambuc 		/* Try to schedule the process. */
37*dc2c582fSDavid van Moolenbroek 		if((r = sched_proc(p, priority, quantum, cpu, FALSE)) != OK)
38433d6423SLionel Sambuc 			return r;
39433d6423SLionel Sambuc 		p->p_scheduler = NULL;
40433d6423SLionel Sambuc 	} else {
41433d6423SLionel Sambuc 		/* the caller becomes the scheduler */
42433d6423SLionel Sambuc 		p->p_scheduler = caller;
43433d6423SLionel Sambuc 	}
44433d6423SLionel Sambuc 
45433d6423SLionel Sambuc 	return(OK);
46433d6423SLionel Sambuc }
47