3 #include <minix/callnr.h>
5 #include <minix/config.h>
6 #include <minix/sched.h>
7 #include <minix/sysinfo.h>
8 #include <minix/type.h>
9 #include <machine/archtypes.h>
13 #include <machine/archtypes.h>
15 #include "kernel/proc.h"
17 /*===========================================================================*
19 *===========================================================================*/
26 for (proc_nr
=0, trmp
=mproc
; proc_nr
< NR_PROCS
; proc_nr
++, trmp
++) {
27 /* Don't take over system processes. When the system starts,
28 * init is blocked on RTS_NO_QUANTUM until PM assigns a
29 * scheduler, from which other. Given that all other user
30 * processes are forked from init and system processes are
31 * managed by RS, there should be no other process that needs
32 * to be assigned a scheduler here */
33 if (trmp
->mp_flags
& IN_USE
&& !(trmp
->mp_flags
& PRIV_PROC
)) {
34 assert(_ENDPOINT_P(trmp
->mp_endpoint
) == INIT_PROC_NR
);
35 parent_e
= mproc
[trmp
->mp_parent
].mp_endpoint
;
36 assert(parent_e
== trmp
->mp_endpoint
);
37 s
= sched_start(SCHED_PROC_NR
, /* scheduler_e */
38 trmp
->mp_endpoint
, /* schedulee_e */
39 parent_e
, /* parent_e */
41 USER_QUANTUM
, /* quantum */
42 -1, /* don't change cpu */
43 &trmp
->mp_scheduler
); /* *newsched_e */
45 printf("PM: SCHED denied taking over scheduling of %s: %d\n",
52 /*===========================================================================*
54 *===========================================================================*/
55 int sched_start_user(endpoint_t ep
, struct mproc
*rmp
)
58 endpoint_t inherit_from
;
61 /* convert nice to priority */
62 if ((rv
= nice_to_priority(rmp
->mp_nice
, &maxprio
)) != OK
) {
66 /* scheduler must know the parent, which is not the case for a child
67 * of a system process created by a regular fork; in this case the
68 * scheduler should inherit settings from init rather than the real
71 if (mproc
[rmp
->mp_parent
].mp_flags
& PRIV_PROC
) {
72 assert(mproc
[rmp
->mp_parent
].mp_scheduler
== NONE
);
73 inherit_from
= INIT_PROC_NR
;
75 inherit_from
= mproc
[rmp
->mp_parent
].mp_endpoint
;
79 return sched_inherit(ep
, /* scheduler_e */
80 rmp
->mp_endpoint
, /* schedulee_e */
81 inherit_from
, /* parent_e */
82 maxprio
, /* maxprio */
83 &rmp
->mp_scheduler
); /* *newsched_e */
86 /*===========================================================================*
88 *===========================================================================*/
89 int sched_nice(struct mproc
*rmp
, int nice
)
95 /* If the kernel is the scheduler, we don't allow messing with the
96 * priority. If you want to control process priority, assign the process
97 * to a user-space scheduler */
98 if (rmp
->mp_scheduler
== KERNEL
|| rmp
->mp_scheduler
== NONE
)
101 if ((rv
= nice_to_priority(nice
, &maxprio
)) != OK
) {
105 m
.SCHEDULING_ENDPOINT
= rmp
->mp_endpoint
;
106 m
.SCHEDULING_MAXPRIO
= (int) maxprio
;
107 if ((rv
= _taskcall(rmp
->mp_scheduler
, SCHEDULING_SET_NICE
, &m
))) {