Symbiotic jobscheduling for a simultaneous multithreaded processor
- 12 November 2000
- journal article
- Published by Association for Computing Machinery (ACM) in ACM SIGOPS Operating Systems Review
- Vol. 34 (5) , 234-244
- https://doi.org/10.1145/384264.379244
Abstract
Simultaneous Multithreading machines fetch and execute instructions from multiple instruction streams to increase system utilization and speedup the execution of jobs. When there are more jobs in the system than there is hardware to support simultaneous execution, the operating system scheduler must choose the set of jobs to coscheduleThis paper demonstrates that performance on a hardware multithreaded processor is sensitive to the set of jobs that are coscheduled by the operating system jobscheduler. Thus, the full benefits of SMT hardware can only be achieved if the scheduler is aware of thread interactions. Here, a mechanism is presented that allows the scheduler to significantly raise the performance of SMT architectures. This is done without any advance knowledge of a workload's characteristics, using sampling to identify jobs which run well together.We demonstrate an SMT jobscheduler called SOS. SOS combines an overhead-free sample phase which collects information about various possible schedules, and a symbiosis phase which uses that information to predict which schedule will provide the best performance. We show that a small sample of the possible schedules is sufficient to identify a good schedule quickly. On a system with random job arrivals and departures, response time is improved as much as 17% over a schedule which does not incorporate symbiosis.Keywords
This publication has 17 references indexed in Scilit:
- Scheduling with implicit information in distributed systemsPublished by Association for Computing Machinery (ACM) ,1998
- Converting thread-level parallelism to instruction-level parallelism via simultaneous multithreadingACM Transactions on Computer Systems, 1997
- Distributed and multiprocessor schedulingACM Computing Surveys, 1996
- An elementary processor architecture with simultaneous instruction issuing from multiple threadsACM SIGARCH Computer Architecture News, 1992
- The implications of cache affinity on processor scheduling for multiprogrammed, shared memory multiprocessorsPublished by Association for Computing Machinery (ACM) ,1991
- The Tera computer systemPublished by Association for Computing Machinery (ACM) ,1990
- APRILACM SIGARCH Computer Architecture News, 1990
- UNIX Time-Sharing System: UNIX ImplementationBell System Technical Journal, 1978
- The UNIX time-sharing systemCommunications of the ACM, 1974
- A Proof for the Queuing Formula: L = λWOperations Research, 1961