If you use adaptive partitions, you need to be aware of the following limitations:
-
The API allows a window size as short as 8 milliseconds,
but practical window sizes may need to be larger.
For example, in an eight-partition system, with all partitions busy,
to reasonably expect all eight to run during every window, the
window size needs to be at least 8 timeslices long,
which for most systems is 32 milliseconds.
- Overloads aren't reported to users.
The Adaptive Partition scheduler does detect
overload and acts to limit some partitions to guarantee the percentage shares of others,
but it doesn't inform anything outside of the kernel that an overload was detected.
The problem is that an overload might occur (or might not occur) on every scheduling
operation, which can occur at the rate of 50000 per second on a 200mhz machine (an older,
slower machine).
- SCHED_RR threads might not round robin in partitions whose portion of the
averaging window is smaller than one timeslice. For example, when the timeslice is 4 ms (the
default) and the adaptive partitioning scheduler's window size is 100 ms (the default), then
SCHED_RR threads in a 4% partition may not round-robin correctly.
- If you use adaptive partitioning and bound multiprocessing (BMP), some combinations of
budgets might not be met. Threads in a zero-budget partition should run
only when all other nonzero-budget partitions are idle.
On SMP machines, zero-budget partitions may incorrectly run when some other partitions are
demanding time.
At all times, all partitions' minimum budgets are still guaranteed,
and zero-budget partitions won't run if all nonzero-budget partitions are ready to run.
For detailed information, see Using the thread scheduler and multicore together.
- To
calculate the total microcycle used in a window size, the product of P ×
W × N must be less than 2,147,483,648, where:
- P is the processor clock rate (in Hz)
- W is the APS window size (in seconds)
- N is the number of processors on the SMP device
The default value of
W is 0.1 (100 milliseconds) and, given this
value, the following constraints apply:
- 1 processor: maximum clock rate 21.5 GHz
- 2 processors: maximum clock rate 10.7 GHz
- 4 processors: maximum clock rate 5.4 GHz
- 8 processors: maximum clock rate 2.7 GHz
- As reported by the aps show -v command on ARM targets, the 10 and 100
window averages occasionally give incorrect information, but this has no effect on
scheduling.