SCHEDCTL_INIT(3C) Standard C Library Functions SCHEDCTL_INIT(3C)


NAME


schedctl_init, schedctl_lookup, schedctl_exit, schedctl_start,
schedctl_stop - preemption control

SYNOPSIS


cc [ flag... ] file... [ library... ]
#include <schedctl.h>

schedctl_t *schedctl_init(void);


schedctl_t *schedctl_lookup(void);


void schedctl_exit(void);


void schedctl_start(schedctl_t *ptr);


void schedctl_stop(schedctl_t *ptr);


DESCRIPTION


These functions provide limited control over the scheduling of a thread
(see threads(7)). They allow a running thread to give a hint to the
kernel that preemptions of that thread should be avoided. The most likely
use for these functions is to block preemption while holding a spinlock.
Improper use of this facility, including attempts to block preemption for
sustained periods of time, may result in reduced performance.


The schedctl_init() function initializes preemption control for the
calling thread and returns a pointer used to refer to the data. If
schedctl_init() is called more than once by the same thread, the most
recently returned pointer is the only valid one.


The schedctl_lookup() function returns the currently allocated preemption
control data associated with the calling thread that was previously
returned by schedctl_init(). This can be useful in programs where it is
difficult to maintain local state for each thread.


The schedctl_exit() function removes the preemption control data
associated with the calling thread.


The schedctl_start() macro gives a hint to the kernel scheduler that
preemption should be avoided on the current thread. The pointer passed to
the macro must be the same as the pointer returned by the call to
schedctl_init() by the current thread. The behavior of the program when
other values are passed is undefined.


The schedctl_stop() macro removes the hint that was set by
schedctl_start(). As with schedctl_start(), the pointer passed to the
macro must be the same as the pointer returned by the call to
schedctl_init() by the current thread.


The schedctl_start() and schedctl_stop() macros are intended to be used
to bracket short critical sections, such as the time spent holding a
spinlock. Other uses, including the failure to call schedctl_stop() soon
after calling schedctl_start(), might result in poor performance.

RETURN VALUES


The schedctl_init() function returns a pointer to a schedctl_t structure
if the initialization was successful, or NULL otherwise. The
schedctl_lookup() function returns a pointer to a schedctl_t structure if
the data for that thread was found, or NULL otherwise.

ERRORS


No errors are returned.

ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Stable |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+

SEE ALSO


priocntl(1), exec(2), fork(2), priocntl(2), attributes(7), threads(7)

NOTES


Preemption control is intended for use by threads belonging to the time-
sharing (TS), interactive (IA), fair-share (FSS), and fixed-priority (FX)
scheduling classes. If used by threads in other scheduling classes, such
as real-time (RT), no errors will be returned but schedctl_start() and
schedctl_stop() will not have any effect.


The data used for preemption control are not copied in the child of a
fork(2). Thus, if a process containing threads using preemption control
calls fork and the child does not immediately call exec(2), each thread
in the child must call schedctl_init() again prior to any future uses of
schedctl_start() and schedctl_stop(). Failure to do so will result in
undefined behavior.


May 28, 2003 SCHEDCTL_INIT(3C)