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