This paper presents an implementation of scheduling abstractions originally developed for the Rialto real-time operating system within a research version of Windows NT called Rialto/NT. These abstractions, CPU Reservations and Time Constraints, as described in the 1997 SOSP paper [Jones et al. 97], are intended to allow: (1) activities to obtain minimum guaranteed execution rates with application-specified reservation granularities via CPU Reservations, and (2) applications to schedule tasks by deadlines via Time Constraints, with on-time completion guaranteed for tasks with accepted constraints.
The Rialto/NT scheduler differs from the original Rialto scheduler in several key respects. First, it has been extended to schedule multiprocessors--this is the primary new intellectual contribution of this work. It has been adapted to operate with operating system clock services that only provide timing interrupts at regular periodic intervals measured in milliseconds, rather than being able to schedule clock interrupts at arbitrary sub-millisecond points of time. It coexists with the existing Windows NT scheduler, allowing it to schedule time not scheduled by itself. Finally, it has been implemented in a particularly non-intrusive manner, using rather than replacing the existing Windows NT priority-based scheduler.
Results presented will demonstrate that CPU Reservations and Time Constraints can be effectively implemented on multiprocessors. We will also describe the implementation techniques chosen and tradeoffs made as a result of implementing within Windows NT. Finally, we will present performance results and execution traces.
[1]
Michael B. Jones,et al.
CPU reservations and time constraints: efficient, predictable scheduling of independent activities
,
1997,
SOSP.
[2]
Bill Carpenter,et al.
The RTX real-time subsystem for windows NT
,
1997
.
[3]
David A. Solomon,et al.
Inside windows nt second edition
,
1998
.
[4]
Michael B. Jones,et al.
An overview of the Rialto real-time architecture
,
2001
.
[5]
Michael B. Jones,et al.
Vassal: loadable scheduler support for multi-policy scheduling
,
1998
.
[6]
Michael B. Jones,et al.
The problems you're having may not be the problems you think you're having: results from a latency study of Windows NT
,
1999,
Proceedings of the Fifth IEEE Real-Time Technology and Applications Symposium.
[7]
Klara Nahrstedt,et al.
A soft real-time scheduling server on the Windows NT
,
1998
.
[8]
Helen Custer,et al.
Inside Windows NT
,
1992
.