The case for active device drivers
Authors
Leonid Ryzhyk, Yanjin Zhu and Gernot Heiser
School of Computer Science and Engineering
University of New South Wales
Sydney 2052 Australia
NICTA, Sydney,
Australia
Open Kernel Labs, Sydney, Australia
Abstract
We revisit the device-driver architecture supported by the majority of operating systems, where a driver is a passive object that does not have its own thread of control and is only activated when an external thread invokes one of its entry points. This architecture complicates driver development and induces errors in two ways. First, since multiple threads can invoke the driver concurrently, it must take care to synchronise the invocations to avoid race conditions. Second, since every invocation occurs in the context of its own thread, the driver cannot rely on programming-language constructs to maintain its control flow. Both issues make the control logic of the driver difficult to implement and even harder to understand and verify.
To address these issues, we propose a device-driver architecture where each driver has its own thread of control and communicates with other threads in the system via message passing. We show how this architecture addresses both of the above problems. Unlike previous message-based driver frameworks, it does not require any special language support and can be implemented inside an existing operating system as a kernel extension. We present our Linux-based implementation in progress and report on preliminary performance results.
BibTeX Entry
@inproceedings{Ryzhyk_ZH_10,
title = {The Case for Active Device Drivers},
booktitle = {Proceedings of the 1st Asia-Pacific Workshop on Systems},
author = {Leonid Ryzhyk and Yanjin Zhu and Gernot Heiser},
year = {2010},
month = {Aug},
address = {New Delhi, India},
pages = {25--30}
}

