xref: /xnu-10002.61.3/osfmk/man/P_set_policy_disable.html (revision 0f4c859e951fba394238ab619495c4e1d54d0f34)
1*0f4c859eSApple OSS Distributions<h2>processor_set_policy_disable</h2>
2*0f4c859eSApple OSS Distributions<hr>
3*0f4c859eSApple OSS Distributions<p>
4*0f4c859eSApple OSS Distributions<strong>Function</strong> - Disables a scheduling policy for a processor set.
5*0f4c859eSApple OSS Distributions<h3>SYNOPSIS</h3>
6*0f4c859eSApple OSS Distributions<pre>
7*0f4c859eSApple OSS Distributions<strong>#include&lt mach/mach_host.h&gt</strong>
8*0f4c859eSApple OSS Distributions
9*0f4c859eSApple OSS Distributions<strong>kern_return_t	processor_set_policy_disable</strong>
10*0f4c859eSApple OSS Distributions		<strong>(processor_set_t</strong>	<var>processor_set</var>,
11*0f4c859eSApple OSS Distributions		<strong>int</strong>	<var>policy</var>,
12*0f4c859eSApple OSS Distributions		<strong>boolean_t</strong>	<var>change_threads</var><strong>);</strong>
13*0f4c859eSApple OSS Distributions</pre>
14*0f4c859eSApple OSS Distributions<h3>PARAMETERS</h3>
15*0f4c859eSApple OSS Distributions<dl>
16*0f4c859eSApple OSS Distributions<dt> <var>processor_set</var>
17*0f4c859eSApple OSS Distributions<dd>
18*0f4c859eSApple OSS Distributions[in processor-set-control port] The control port for the processor set for which a scheduling policy is to be disabled.
19*0f4c859eSApple OSS Distributions<dt> <var>policy</var>
20*0f4c859eSApple OSS Distributions<dd>
21*0f4c859eSApple OSS Distributions[in scalar] Policy to be disabled. The values currently defined are POLICY_TIMESHARE and POLICY_FIXEDPRI.
22*0f4c859eSApple OSS Distributions<dt> <var>change_threads</var>
23*0f4c859eSApple OSS Distributions<dd>
24*0f4c859eSApple OSS Distributions[in scalar] If true, causes the scheduling policy for all threads currently running with policy to POLICY_TIMESHARE.
25*0f4c859eSApple OSS Distributions</dl>
26*0f4c859eSApple OSS Distributions<h3>DESCRIPTION</h3>
27*0f4c859eSApple OSS Distributions<p>
28*0f4c859eSApple OSS DistributionsThe <strong>processor_set_policy_disable</strong>
29*0f4c859eSApple OSS Distributionsfunction restricts the set of scheduling policies allowed for
30*0f4c859eSApple OSS Distributions<var>processor_set</var>. The set of scheduling policies allowed for a
31*0f4c859eSApple OSS Distributionsprocessor set is the set of policies allowed to be set for threads
32*0f4c859eSApple OSS Distributionsassigned to that processor set. The current set of permitted policies
33*0f4c859eSApple OSS Distributionscan be obtained from <strong>processor_set_info</strong>. Timesharing may
34*0f4c859eSApple OSS Distributionsnot be forbidden for any processor set. This is a compromise to reduce
35*0f4c859eSApple OSS Distributionsthe complexity of the assign operation; any thread whose
36*0f4c859eSApple OSS Distributions<var>policy</var> is forbidden by its target processor set has its
37*0f4c859eSApple OSS Distributions<var>policy</var> reset to timesharing. Disabling a scheduling
38*0f4c859eSApple OSS Distributions<var>policy</var> for a processor set has no effect on threads
39*0f4c859eSApple OSS Distributionscurrently assigned to that processor set unless
40*0f4c859eSApple OSS Distributions<var>change_threads</var> is TRUE, in which case their policies will
41*0f4c859eSApple OSS Distributionsbe reset to timesharing.
42*0f4c859eSApple OSS Distributions<h3>RETURN VALUES</h3>
43*0f4c859eSApple OSS Distributions<p>
44*0f4c859eSApple OSS DistributionsOnly generic errors apply.
45*0f4c859eSApple OSS Distributions<h3>RELATED INFORMATION</h3>
46*0f4c859eSApple OSS Distributions<p>
47*0f4c859eSApple OSS DistributionsFunctions:
48*0f4c859eSApple OSS Distributions<a href="P_set_policy_enable.html">processor_set_policy_enable</a>,
49*0f4c859eSApple OSS Distributions<a href="processor_set_info.html">processor_set_info</a>,
50*0f4c859eSApple OSS Distributions<a href="thread_policy.html">thread_policy</a>.
51