Few would argue that protocols are central to the construction of distributed systems. Whether they support remote procedure calls, file transfer, or group communication, protocols are the fundamental building blocks of distributed systems. This paper is not about any particular protocol, but rather about our experiences implementing protocols, in general, in the x-kemel. The x-kernel was originally designedto function as a full-fledged operating system kernel. The original design philosophy was that an operating system kernel is primarily a communication multiplexor, and so the one thing it had better do well is support communication protocols. Towards this end, the x-kernel was explicitly designed to support the rapid implementation of efficient network protocols. Because it was a complete OS kernel, theinitial implementation of the x-kernel on Sun3 workstations included support for lightweight processes and multiple virtual address spaces. However, because communication support was our primary concern, the x-kernel didn't contain any real innovations in other areas such as process and memory management; we mostly borrowed ideas from other experimental operating systems like V, Mach, Sprite, and Amoeba. During the last several months, we have refocused our effort by divorcing those aspects of the x-kemel that are specifically related to the implementation of network protocols from the other aspects of the operating system, and we are attempting to embed this protocol-core of the x-kernel in different existing operating systems, most notably, Mach.
[1]
Larry L. Peterson,et al.
The x-Kernel: An Architecture for Implementing Network Protocols
,
1991,
IEEE Trans. Software Eng..
[2]
Larry L. Peterson,et al.
A language-based approach to protocol implementation
,
1993,
TNET.
[3]
Larry L. Peterson,et al.
TCP Extensions Considered Harmful
,
1991,
RFC.
[4]
Larry L. Peterson,et al.
Beyond micro-kernel design: decoupling modularity and protection in Lipto
,
1992,
[1992] Proceedings of the 12th International Conference on Distributed Computing Systems.
[5]
Larry L. Peterson,et al.
Analysis of I/O Subsystem Design for Multimedia Workstations
,
1992,
NOSSDAV.
[6]
Larry L. Peterson,et al.
A dynamic network architecture
,
1992,
TOCS.