Lines Matching +full:inactive +full:- +full:delay +full:- +full:ms
12 3. Scheduling Real-Time Tasks
18 4.1 System-wide settings
33 system behavior. As for -rt (group) scheduling, it is assumed that root users
50 ------------------
70 with the "traditional" real-time task model (see Section 3) can effectively
76 - Each SCHED_DEADLINE task is characterized by the "runtime",
79 - The state of the task is described by a "scheduling deadline", and
82 - When a SCHED_DEADLINE task wakes up (becomes ready for execution),
86 ---------------------------------- > ---------
87 scheduling deadline - current time period
91 remaining runtime are re-initialized as
99 - When a SCHED_DEADLINE task executes for an amount of time t, its
102 remaining runtime = remaining runtime - t
107 - When the remaining runtime becomes less or equal than 0, the task is
108 said to be "throttled" (also known as "depleted" in real-time literature)
113 - When the current time is equal to the replenishment time of a
126 ------------------------
134 ------------
136 ------------->| |
138 | ------------
140 ---------- | |
142 | Inactive | |(b) | (a)
144 ---------- | |
146 | ------------
148 --------------| Non |
150 ------------
154 - ActiveContending: if it is ready for execution (or executing);
156 - ActiveNonContending: if it just blocked and has not yet surpassed the 0-lag
159 - Inactive: if it is blocked and has surpassed the 0-lag time.
163 (a) When a task blocks, it does not become immediately inactive since its
165 real-time guarantees. It therefore enters a transitional state called
166 ActiveNonContending. The scheduler arms the "inactive timer" to fire at
167 the 0-lag time, when the task's bandwidth can be reclaimed without
168 breaking the real-time guarantees.
170 The 0-lag time for a task entering the ActiveNonContending state is
174 deadline - ---------------------
180 (b) If the task wakes up before the inactive timer fires, the task re-enters
181 the ActiveContending state and the "inactive timer" is canceled.
186 "inactive timer" is running on a different CPU, the "dl_non_contending"
189 "inactive timer" fires or when the task wakes up).
191 (c) When the "inactive timer" fires, the task enters the Inactive state and
194 (d) When an inactive task wakes up, it enters the ActiveContending state and
200 - Active bandwidth (running_bw): this is the sum of the bandwidths of all
203 - Total bandwidth (this_bw): this is the sum of all tasks "belonging" to the
204 runqueue, including the tasks in Inactive state.
207 The algorithm reclaims the bandwidth of the tasks in Inactive state.
211 dq = -max{ Ui / Umax, (1 - Uinact - Uextra) } dt
215 - Ui is the bandwidth of task Ti;
216 - Umax is the maximum reclaimable utilization (subjected to RT throttling
218 - Uinact is the (per runqueue) inactive utilization, computed as
219 (this_bq - running_bw);
220 - Uextra is the (per runqueue) extra reclaimable utilization
231 |-------- |----
233 |---|---|---|---|---|---|---|---|--------->t
241 | ------------------------|
243 |---|---|---|---|---|---|---|---|--------->t
249 1 ----------------- ------
251 0.5- -----------------
253 |---|---|---|---|---|---|---|---|--------->t
257 - Time t = 0:
261 Since there are no inactive tasks, its runtime is decreased as dq = -1 dt.
263 - Time t = 2:
267 runtime is equal to 2, its 0-lag time is equal to t = 4.
268 Task T2 start execution, with runtime still decreased as dq = -1 dt since
269 there are no inactive tasks.
271 - Time t = 4:
273 This is the 0-lag time for Task T1. Since it didn't woken up in the
274 meantime, it enters the Inactive state. Its bandwidth is removed from
277 dq = - 0.5 dt because Uinact = 0.5.
280 - Time t = 8:
286 2.3 Energy-aware scheduling
287 ---------------------------
290 GRUB-PA [19] algorithm, reducing the CPU operating frequency to the minimum
299 3. Scheduling Real-Time Tasks
308 This section contains a (not-thorough) summary on classical deadline
319 suited for periodic or sporadic real-time tasks that need guarantees on their
323 ------------------------
325 A typical real-time task is composed of a repetition of computation phases
333 A real-time task can be periodic with period P if r_{j+1} = r_j + P, or
334 sporadic with minimum inter-arrival time P is r_{j+1} >= r_j + P. Finally,
336 Summing up, a real-time task can be described as
340 The utilization of a real-time task is defined as the ratio between its
341 WCET and its period (or minimum inter-arrival time), and represents
348 WCET_i/P_i over all the real-time tasks in the system. When considering
349 multiple real-time tasks, the parameters of the i-th task are indicated
352 non- real-time tasks by real-time tasks.
353 If, instead, the total utilization is smaller than M, then non real-time
369 ----------------------------------------------------
372 real-time task is statically assigned to one and only one CPU), it is
387 Task_1=(50ms,50ms,100ms) and Task_2=(10ms,100ms,100ms).
391 its response time cannot be larger than 50ms + 10ms = 60ms) even if
410 time-consuming to be performed on-line. Hence, as explained in Section
414 ------------------------------------------------------
424 and WCET equal to P. The remaining M tasks Task_i=(e,P-1,P-1) have an
428 (because their absolute deadlines are equal to t + P - 1, hence they are
432 task set is U = M · e / (P - 1) + P / P = M · e / (P - 1) + 1, and for small
436 lim_{e->0}U).
439 real-time literature[8,9], but they are not based on a simple comparison
444 sum(WCET_i / P_i) <= M - (M - 1) · U_max
447 M - (M - 1) · U_max becomes M - M + 1 = 1 and this schedulability condition
449 about schedulability tests for multi-processor real-time scheduling can be
455 a total utilization smaller than M is enough to guarantee that non real-time
456 tasks are not starved and that the tardiness of real-time tasks has an upper
458 experienced by real-time tasks have been developed in various papers[13,14],
464 -----------------------------------------------
468 deadline and period) and the real-time task parameters (WCET, D, P)
474 are respected, then SCHED_DEADLINE can be used to schedule real-time tasks
478 - runtime >= WCET
479 - deadline = D
480 - period <= P
491 1 - C. L. Liu and J. W. Layland. Scheduling algorithms for multiprogram-
492 ming in a hard-real-time environment. Journal of the Association for
494 2 - L. Abeni , G. Buttazzo. Integrating Multimedia Applications in Hard
495 Real-Time Systems. Proceedings of the 19th IEEE Real-time Systems
496 Symposium, 1998. http://retis.sssup.it/~giorgio/paps/1998/rtss98-cbs.pdf
497 3 - L. Abeni. Server Mechanisms for Multimedia Applications. ReTiS Lab
498 Technical Report. http://disi.unitn.it/~abeni/tr-98-01.pdf
499 4 - J. Y. Leung and M.L. Merril. A Note on Preemptive Scheduling of
500 Periodic, Real-Time Tasks. Information Processing Letters, vol. 11,
501 no. 3, pp. 115-118, 1980.
502 5 - S. K. Baruah, A. K. Mok and L. E. Rosier. Preemptively Scheduling
503 Hard-Real-Time Sporadic Tasks on One Processor. Proceedings of the
504 11th IEEE Real-time Systems Symposium, 1990.
505 6 - S. K. Baruah, L. E. Rosier and R. R. Howell. Algorithms and Complexity
506 Concerning the Preemptive Scheduling of Periodic Real-Time tasks on
507 One Processor. Real-Time Systems Journal, vol. 4, no. 2, pp 301-324,
509 7 - S. J. Dhall and C. L. Liu. On a real-time scheduling problem. Operations
510 research, vol. 26, no. 1, pp 127-140, 1978.
511 8 - T. Baker. Multiprocessor EDF and Deadline Monotonic Schedulability
512 Analysis. Proceedings of the 24th IEEE Real-Time Systems Symposium, 2003.
513 9 - T. Baker. An Analysis of EDF Schedulability on a Multiprocessor.
515 pp 760-768, 2005.
516 10 - J. Goossens, S. Funk and S. Baruah, Priority-Driven Scheduling of
517 Periodic Task Systems on Multiprocessors. Real-Time Systems Journal,
519 11 - R. Davis and A. Burns. A Survey of Hard Real-Time Scheduling for
521 http://www-users.cs.york.ac.uk/~robdavis/papers/MPSurveyv5.0.pdf
522 12 - U. C. Devi and J. H. Anderson. Tardiness Bounds under Global EDF
523 Scheduling on a Multiprocessor. Real-Time Systems Journal, vol. 32,
524 no. 2, pp 133-189, 2008.
525 13 - P. Valente and G. Lipari. An Upper Bound to the Lateness of Soft
526 Real-Time Tasks Scheduled by EDF on Multiprocessors. Proceedings of
527 the 26th IEEE Real-Time Systems Symposium, 2005.
528 14 - J. Erickson, U. Devi and S. Baruah. Improved tardiness bounds for
530 Real-Time Systems, 2010.
531 15 - G. Lipari, S. Baruah, Greedy reclamation of unused bandwidth in
532 constant-bandwidth servers, 12th IEEE Euromicro Conference on Real-Time
534 16 - L. Abeni, J. Lelli, C. Scordino, L. Palopoli, Greedy CPU reclaiming for
535 SCHED DEADLINE. In Proceedings of the Real-Time Linux Workshop (RTLWS),
537 17 - L. Abeni, G. Lipari, A. Parri, Y. Sun, Multicore CPU reclaiming: parallel
540 18 - J. Lelli, C. Scordino, L. Abeni, D. Faggioli, Deadline scheduling in the
541 Linux kernel, Software: Practice and Experience, 46(6): 821-839, June
543 19 - C. Scordino, L. Abeni, J. Lelli, Energy-Aware Real-Time Scheduling in
551 As previously mentioned, in order for -deadline scheduling to be
556 no guarantee can be given on the actual scheduling of the -deadline tasks.
559 correctly schedule a set of real-time tasks is that the total utilization
560 is smaller than M. When talking about -deadline tasks, this requires that
563 of a "traditional" real-time task, and is also often referred to as
566 to -deadline tasks is similar to the one already used for -rt
567 tasks with real-time group scheduling (a.k.a. RT-throttling - see
568 Documentation/scheduler/sched-rt-group.rst), and is based on readable/
570 Notice that per-group settings (controlled through cgroupfs) are still not
571 defined for -deadline tasks, because more discussion is needed in order to
575 A main difference between deadline bandwidth management and RT-throttling
576 is that -deadline tasks have bandwidth on their own (while -rt ones don't!),
583 interface we can put a cap on total utilization of -deadline tasks (i.e.,
587 ------------------------
591 For now the -rt knobs are used for -deadline admission control and the
592 -deadline runtime is accounted against the -rt runtime. We realize that this
595 run -rt tasks from a -deadline server; in which case the -rt bandwidth is a
598 This means that, for a root_domain comprising M CPUs, -deadline tasks
605 This is done by writing -1 in /proc/sys/kernel/sched_rt_runtime_us.
609 ------------------
615 - a (maximum/typical) instance execution time,
616 - a minimum interval between consecutive instances,
617 - a time constraint by which each instance must be completed.
633 ---------------------
636 950000. With rt_period equal to 1000000, by default, it means that -deadline
639 This means that non -deadline tasks will receive at least 5% of the CPU time,
640 and that -deadline tasks will receive their runtime with a guaranteed
641 worst-case delay respect to the "deadline" parameter. If "deadline" = "period"
644 deterministically guarantee that -deadline tasks will receive their runtime
648 -deadline task cannot fork.
652 -----------------------------
660 This behavior of sched_yield() allows the task to wake-up exactly at
670 -deadline tasks cannot have an affinity mask smaller that the entire
672 through the cpuset facility (Documentation/admin-guide/cgroup-v1/cpusets.rst).
675 ------------------------------------
677 An example of a simple configuration (pin a -deadline task to CPU0)
678 follows (rt-app is used to create a -deadline task)::
681 mount -t cgroup -o cpuset cpuset /dev/cpuset
691 rt-app -t 100000:10000:d:0 -D5 # it is now actually superfluous to specify
699 - programmatic way to retrieve current runtime and absolute deadline
700 - refinements to deadline inheritance, especially regarding the possibility
701 of retaining bandwidth isolation among non-interacting tasks. This is
704 - (c)group based bandwidth management, and maybe scheduling;
705 - access control for non-root users (and related security concerns to
707 and how to prevent non-root users "cheat" the system?
719 available as a GitHub repository: https://github.com/scheduler-tools.
721 The first testing application is called rt-app and can be used to
722 start multiple threads with specific parameters. rt-app supports
724 parameters (e.g., niceness, priority, runtime/deadline/period). rt-app
726 workloads (maybe mimicking real use-cases) and evaluate how the scheduler
728 rt-app is available at: https://github.com/scheduler-tools/rt-app.
733 # rt-app -t 100000:10000:d -t 150000:20000:f:10 -D5
736 executes for 10ms every 100ms. The second one, scheduled at SCHED_FIFO
737 priority 10, executes for 20ms every 150ms. The test will run for a total
741 can be passed as input to rt-app with something like this::
743 # rt-app my_config.json
746 of the command line options. Please refer to rt-app documentation for more
747 details (`<rt-app-sources>/doc/*.json`).
750 schedtool-dl, which can be used to setup SCHED_DEADLINE parameters for a
751 certain pid/application. schedtool-dl is available at:
752 https://github.com/scheduler-tools/schedtool-dl.git.
756 # schedtool -E -t 10000000:100000000 -e ./my_cpuhog_app
759 of 10ms every 100ms (note that parameters are expressed in microseconds).
763 # schedtool -E -t 10000000:100000000 my_app_pid
768 We provide in what follows a simple (ugly) self-contained code snippet
769 showing how SCHED_DEADLINE reservations can be created by a real-time
853 /* This creates a 10ms/30ms reservation */
862 exit(-1);