Re: sched_{set,get}attr() manpage
From: Peter Zijlstra
Date: Wed Apr 09 2014 - 11:42:41 EST
On Wed, Apr 09, 2014 at 05:19:11PM +0200, Henrik Austad wrote:
> > The following "real-time" policies are also supported, for
>
> why the "'s?
I borrowed those from SCHED_SETSCHEDULER(2).
> > sched_attr::sched_flags additional flags that can influence
> > scheduling behaviour. Currently as per Linux kernel 3.14:
> >
> > SCHED_FLAG_RESET_ON_FORK - resets the scheduling policy
> > to: (struct sched_attr){ .sched_policy = SCHED_OTHER, }
> > on fork().
> >
> > is the only supported flag.
...
> > The flags argument should be 0.
>
> What about SCHED_FLAG_RESET_ON_FOR?
Different flags. The one is sched_attr::flags the other is
sched_setattr(.flags).
> > The other sched_attr fields are filled out as described in
> > sched_setattr().
> >
> > Scheduling Policies
> > The scheduler is the kernel component that decides which runnable
> > process will be executed by the CPU next. Each process has an associâ
> > ated scheduling policy and a static scheduling priority, sched_priorâ
> > ity; these are the settings that are modified by sched_setscheduler().
> > The scheduler makes it decisions based on knowledge of the scheduling
> > policy and static priority of all processes on the system.
>
> Isn't this last sentence redundant/sliglhtly repetitive?
I borrowed that from SCHED_SETSCHEDULER(2) again.
> > SCHED_DEADLINE: Sporadic task model deadline scheduling
> > SCHED_DEADLINE is an implementation of GEDF (Global Earliest
> > Deadline First) with additional CBS (Constant Bandwidth Server).
> > The CBS guarantees that tasks that over-run their specified
> > budget are throttled and do not affect the correct performance
> > of other SCHED_DEADLINE tasks.
> >
> > SCHED_DEADLINE tasks will fail FORK(2) with -EAGAIN
> >
> > Setting SCHED_DEADLINE can fail with -EINVAL when admission
> > control tests fail.
>
> Perhaps add a note about the deadline-class having higher priority than the
> other classes; i.e. if a deadline-task is runnable, it will preempt any
> other SCHED_(RR|FIFO) regardless of priority?
Yes, good point, will do.
> > SCHED_FIFO: First In-First Out scheduling
> > SCHED_FIFO can only be used with static priorities higher than 0, which
> > means that when a SCHED_FIFO processes becomes runnable, it will always
> > immediately preempt any currently running SCHED_OTHER, SCHED_BATCH, or
> > SCHED_IDLE process. SCHED_FIFO is a simple scheduling algorithm withâ
> > out time slicing. For processes scheduled under the SCHED_FIFO policy,
> > the following rules apply:
> >
> > * A SCHED_FIFO process that has been preempted by another process of
> > higher priority will stay at the head of the list for its priority
> > and will resume execution as soon as all processes of higher priorâ
> > ity are blocked again.
> >
> > * When a SCHED_FIFO process becomes runnable, it will be inserted at
> > the end of the list for its priority.
> >
> > * A call to sched_setscheduler() or sched_setparam(2) will put the
> > SCHED_FIFO (or SCHED_RR) process identified by pid at the start of
> > the list if it was runnable. As a consequence, it may preempt the
> > currently running process if it has the same priority.
> > (POSIX.1-2001 specifies that the process should go to the end of the
> > list.)
> >
> > * A process calling sched_yield(2) will be put at the end of the list.
>
> How about the recent discussion regarding sched_yield(). Is this correct?
>
> lkml.kernel.org/r/alpine.DEB.2.02.1403312333100.14882@xxxxxxxxxxxxxxxxxxxxxxx
>
> Is this the correct place to add a note explaining te potentional pitfalls
> using sched_yield?
I'm not sure; there's a SCHED_YIELD(2) manpage to fill with that
nonsense.
Also; I realized I have not described the DEADLINE sched_yield()
behaviour.
> > No other events will move a process scheduled under the SCHED_FIFO polâ
> > icy in the wait list of runnable processes with equal static priority.
> >
> > A SCHED_FIFO process runs until either it is blocked by an I/O request,
> > it is preempted by a higher priority process, or it calls
> > sched_yield(2).
> >
> > SCHED_RR: Round Robin scheduling
> > SCHED_RR is a simple enhancement of SCHED_FIFO. Everything described
> > above for SCHED_FIFO also applies to SCHED_RR, except that each process
> > is only allowed to run for a maximum time quantum. If a SCHED_RR
> > process has been running for a time period equal to or longer than the
> > time quantum, it will be put at the end of the list for its priority.
> > A SCHED_RR process that has been preempted by a higher priority process
> > and subsequently resumes execution as a running process will complete
> > the unexpired portion of its round robin time quantum. The length of
> > the time quantum can be retrieved using sched_rr_get_interval(2).
>
> -> Default is 0.1HZ ms
>
> This is a question I get form time to time, having this in the manpage
> would be helpful.
Again, brazenly stolen from SCHED_SETSCHEDULER(2); but yes. Also I'm not
sure I'd call RR an enhancement of anything much at all ;-)
> > ERRORS
> > EINVAL The scheduling policy is not one of the recognized policies,
> > param is NULL, or param does not make sense for the policy.
> >
> > EPERM The calling process does not have appropriate privileges.
> >
> > ESRCH The process whose ID is pid could not be found.
> >
> > E2BIG The provided storage for struct sched_attr is either too
> > big, see sched_setattr(), or too small, see sched_getattr().
>
> Where's the EBUSY? It can throw this from __sched_setscheduler() when it
> checks if there's enough bandwidth to run the task.
Uhhm.. it got lost :-) /me quickly adds.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/