The Chorus distributed operating system research project began at the French
Institut national de recherche en informatique et en automatique (INRIA) in 1979.[1]
The project was begun by Hubert Zimmerman,[1]
a pioneer of networked computing[2] who devised the OSI reference model which became a popular way to describe network protocols.[3]
In large part the French CYCLADES computer networking project was a precursor for the Chorus work,[4][5] as essential to the idea of Chorus was to take advantage of what was learned in research into networking in order to add communication and distribution within heretofore monolithic operating system kernels.[6]
Several iterations of the Chorus technology were produced at INRIA between 1980 and 1986,[7] which were referred to by the Chorus creators as Chorus-v0 through Chorus-v2.[1]
Concurrently, there was another INRIA project, called Sol.[1] It had been begun by Michel Gien,[6] who also had a background from CYCLADES;[4] it sought to build a Unix operating system implementation for French minicomputers and microcomputers.[1] Sol used the Pascal programming language rather than C for this, as part of adopting more modern software engineering techniques.[6]
In 1984, the Sol project was merged into the Chorus project, and as one result, the Chorus-v2 iteration adopted the interfaces of Unix System V rather than having its own custom set of interfaces.[1]
History
Beginning years
Microkernel technology was seen as having great promise for advancing the state of operating system and distributed computing.[8]
Accordingly, Chorus Systèmes SA was founded in 1986, in order to commercialise the results of the INRIA research.[8]
The co-founders were Zimmerman and Gien.[4]
Having spent a decade or more enmeshed in the politics of publicly-funded research work, both felt that it was time to try a startup company, especially since they had seen others they knew doing so (such as the American networking pioneer Robert Metcalfe founding 3Com).[6]
Some Chorus engineers from INRIA joined them in the new venture.[6] Zimmermann became head of the new company, in a position described at different times as president, chairman, or CEO.[9][10] Gien was variously described as chief of technology,[6]
or general manager and director of research,[11] for Chorus Systèmes.
At the time, technology startups in France were rare, a point emphasized by the French trade publication 01 Informatique in a profile of the company and by co-founder Gien in retrospect.[5][6] Thus Chorus Systèmes and system software company ILOG, founded soon after, were in the vanguard.[6] Venture capitalists did not exist in France, but the new firm was able to get funding from European projects and from government contracts.[6] In particular this included funding from INRIA and France Telecom.[5]
The offices of Chorus Systèmes were located at 6 avenue Gustave Eiffel in the town of Saint-Quentin-en-Yvelines in the Île-de-France region outside of Paris.[7]
Chorus Systèmes was able to attract engineering talent from around the world, in part because of the connections the founders had in the research world, in part because of the interesting nature of the work, and in part because people were attracted to the idea of working in the Paris area.[6]
By mid-1989, Chorus Systèmes had some 30 employees.[5]
By arrangement with its financial backers, during its first two years Chorus Systèmes focused solely on improvements to the Chorus technology, with no attempts to garner revenue via consulting or similar activities.[5]
The Chorus-v3 iteration consequently came out around 1988 from Chorus Systèmes, which improved on its real-time and distributed capabilities.[12] Some of the improvements were inspired by work done in other microkernel projects; as an academic paper put out by two of Chorus's staff members stated, their goal was to "[build] on the experience of state-of-the-art research systems ... while taking into account constraints of the industrial environment."[7] Chorus-v3 also featured a variant of Unix, called MiX, in such a way that, as one Chorus paper put it, "we will refer to the combination of the Chorus Nucleus and the set of Unix System V subsystem servers as the Chorus/MiX™ operating system."[13]
Emphasis on Unix
Chorus Systèmes believed it held the key to the technological direction Unix should take and had large ambitions in this realm.[5][14] Indeed, almost from the start of the company's history, Zimmerman was proclaiming that the existing Unix technology had reached the end of its useful life and that it needed a new kernel approach going forward.[5] As part of this, Zimmerman wanted to expand usage of Unix into new areas and then, within a few years, capture ten percent of that expanded market.[5]
As such, the company's executives met with people from both the Open Software Foundation and Unix International (the two sides of the Unix Wars then taking place) to seek their endorsements of the Chorus microkernel and to navigate their requirements.[14]
Similarly, Chorus Systèmes engaged with a number of hardware vendors in an effort to convince them to adopt the Chorus technology.[14]
In early 1990,[12]GEC Plessey Telecommunications agreed to adopt Chorus for a new generation of its System X product, a digital switching system.[14] At the time it was the biggest deal Chorus Systèmes had made,[12] and was subsequently mentioned in the general press.[8]
Chorus Systèmes also made a deal with Gipsi SA, a maker of X terminals.[14]
During 1990, Unisys agreed to use Chorus as the basis for a Unix operating system.[15] The same year, Intel's Scientific Computers group agreed to use Chorus for its Intel iPSC supercomputer.[16]
These successes were followed in 1991 by ports of the Chorus microkernel to the transputer architecture from Inmos and to Acorn Computers' ARM3 RISC processor "for use in a multimedia workstation".[16] The year after that, Tolerance Computer agreed to work with the Chorus microkernel towards making the first fault-tolerant Unix for a microcomputer-level system.[17]ICL employed the Chorus microkernel in the software architecture of its GOLDRUSH MegaSERVER product: a parallel database server featuring up to 64 SPARC-based processing elements, each running its own database server in a Chorus microkernel-based Unix System V Release 4 environment, and accessing a common, coherent file store.[18] This product employed Chorus/MiX V.4 specifically.[19]
Business aspects
The primary alternative to Chorus in the microkernel space was the Mach software at Carnegie Mellon University.[8][6] Two other microkernel projects going on at the time were Amoeba from Vrije Universiteit Amsterdam[8] and V at Stanford University.[6]
Chorus and Mach shared many similar features of their outward design, but had differences in areas such as naming and addressing and protection schemes.[20] In some cases this gave Chorus an advantage, because it provided greater flexibility at the kernel mode–user mode boundary.[21]
In any case, Chorus was the only one of these projects that was ready with a commercial product.[22][6]
In 1990, the company created a United States subsidiary, Chorus Systems Inc., located in Beaverton, Oregon, that initially had seven employees but plans to double that.[23][24] Will Neuhauser was president of the subsidiary.[22] Chorus employees did a lot of evangelizing of the technology, including in the United States.[6] But initially, the large majority of the company's sales came from Europe.[22]
By 1990, Chorus Systèmes had some $6.5 million in annual revenues.[14]
Over time, Chorus Systèmes received various outside investments of funds.[25] By mid-1991, 63 percent of the company was owned by its founders and employees; 16 percent by Innovacom; and amounts of less than 10 percent by, in descending order, Soffinova, Credit Lyonnais, Banexi Ventures, and Banque Hervet.[25]
In 1991, Unix System Laboratories (USL), an off-shoot of Unix founder AT&T, forged an arrangement with Chorus Systèmes to engage in cooperative work on the Chorus microkernel technology, with the idea of supporting USL's Unix System V Release 4 on Chorus/MiX and thereby making it more scalable and better suited for parallel and distributed applications.[22][24] As part of this, USL took a $1 million stake in Chorus Systèmes.[22][26] Much of the USL Chorus work was done at the USL Europe facility in London.[27] This was part of the larger Ouverture project, a $14 million effort that was itself part of the European Strategic Program on Research in Information Technology (ESPRIT), overseen by the European Commission.[17]
Microkernels also offer the possibility of multiple operating systems running side-by-side on the same machine.[8] The ability of Chorus to support this soon became of interest to Novell, which had acquired USL and was looking for a way to combined its flagship NetWare product with USL's SVR4-based UnixWare. In 1994 Novell began publicly describing its plans to develop "SuperNOS", a microkernel-based network operating system that would run NetWare's network services alongside UnixWare's application services and accordingly be a product that could successfully compete with Microsoft's Windows NT.[28][29] SuperNOS, which attracted considerable industry attention, was based on the work that had already started between USL and Chorus Systèmes, and a significant number of engineers got assigned to it.[30][28] The project endured prolonged internal architectural debates, including Gien and Novell's chief scientist Drew Major disagreeing in the trade press about whether the existent Chorus technology was up to the task.[21] In any case, later in 1995, Novell sold the Unix technology to The Santa Cruz Operation (SCO) and SuperNOS was abandoned.[31]
SCO itself had had its own dealings with Chorus Systèmes, going back to 1992 with an agreement between the two companies for cooperative work in the context of combining SCO's OpenServer variant of Unix with the Chorus microkernel for use in real-time processing environments in telecommunications and other areas.[32] The first result of this, a dual-functionality product called Chorus/Fusion for SCO Open Systems Software, was released in 1994.[33] Further work between the two companies took place during the next few years; by 1995, SCO had set up a business unit for the venture and was spending considerable amounts of engineering resources on what was now a re-implementation of OpenServer to run on top of the Chorus microkernel, in what was going to be called the SCO Telecommunications OS Platform.[34][35] In 1996, SCO and Chorus unveiled a technology roadmap for its OpenServer/Chorus product, giving a codename of MK2 for a product aimed at telephone switches, telephony and multimedia servers, and announcing adoption by Siemens Private Communications Systems.[36] But the project ended up being scrapped before it achieved fruition.[37][38]
Other projects
Object-oriented operating systems were another area of active research at the time and there were several efforts to provide ones on top of microkernels. One was GUIDE, a project of the Universities of Grenoble, which implemented their object-oriented OS on Chorus, Mach, and regular Unix, and drew comparisons between the three.[20]
Another was COOL and was undertaken by Chorus Systèmes itself.[20] Standing for the Chorus Object-Oriented Layer, the first version of COOL was done in conjunction with INRIA and the SEPT, a research laboratory of France Telecom, and came into being in late 1988.[39] A primary aim of the COOL work was to support distributed groupware applications;[39] with that goal partly in mind, COOL was substantially revised into a two-layer architecture with clusters on the lower layer and objects represented through the higher layer.[40] This revision was developed in partnership with the ISA and Commandos projects under the aegis of ESPRIT and materialised in late 1991.[39] The findings from the COOL project were described in an article in Communications of the ACM in 1993.[39]
Independent investigations were also made into integrating Chorus with Mac OS, pursuing an approach superficially similar to those already taken with other microkernel technologies such as Mach 3.0 where DOS or Mac OS were run as user-level applications. Following on from earlier work that ported the Chorus simulator software to Apple's A/UX operating system, allowing experience to be gained with Chorus itself, such efforts proceeded to the point of porting Chorus to the Macintosh IIcx hardware, permitting Chorus to be started within the Mac OS environment, and for Chorus to appear as an application within that environment, achieving a form of "cohabitation".[41]
Change of focus
Over time, development effort on Chorus shifted towards real-time operating systems for embedded systems.[37] As part of the ESPRIT's STREAM project, Chorus was structured into a scaled series of capabilities, with the smallest of these being a 10K-byte "nanokernel" with a simple executive and memory management logic up to a full-featured distributed operating system that could run Unix.[42]
Subsequently the company looked to change directions away from Unix, as it said its customers were more interested in the Java software platform and its capabilities on real-time devices.[37] In February 1997, the company announced the Chorus/Jazz product, which was intended to allow Java applications to run in a distributed, real-time embedded system environment.[43] The basis of Chorus/Jazz was Chorus Systèmes having licensed JavaOS from Sun Microsystems and replaced that technology's hardware abstraction layer with the Chorus microkernel.[37] At this point, Chorus Systèmes offered three products for the embedded systems space: Chorus/Micro, for small, hard real-time applications; Chorus/ClassiX for larger, RT-POSIX-compliant applications, and Chorus/Jazz in the Java realm.[44]
By this point, Chorus Systèmes was looking to get acquired by another company.[6] A couple of years previously, SCO had inquired about such a possibility, but felt that Chorus Systèmes was valuing itself too highly.[3] But with the Java work going on, and a personal connection that Gien had with Sun co-founder Bill Joy, there was an obvious possibility in this respect.[6]
Acquisition by Sun and aftermath
In September 1997, it was announced that Sun Microsystems was acquiring Chorus Systèmes SA.[10] The total amount paid for the company was the equivalent of $26.5 million.[45] The deal was part of an overall desire by Sun to enter the embedded systems market, which was a growing industry that was attracting the attention of analysts and investors.[46] Given the declining interest in microkernels, the industry publication Computergram International considered Chorus Systèmes fortunate to have found a buyer for itself.[3]
The Sun acquisition closed on 21 October 1997.[45] The Chorus technology became part a new Embedded Systems Software business group at Sun.[10] The name of Chorus itself was changed to ChorusOS.[47] Some of the work done at Sun included providing a combination of ChorusOS and Sun Solaris for high-availability systems in the telecommunications market.[6]
Subsequently, Sun went through a restructuring during the early 2000s recession and decided to jettison the ChorusOS technology.[6] Some three dozen Sun employees working on Chorus formed their own company, Jaluna, which used microkernel-analogous approaches to the increasingly important domain of virtualization.[6] This company was then renamed to VirtualLogix, which was then acquired by Red Bend Software in 2010.[48]
References
^ abcdefRozier, M.; V. Abrossimov; F. Armand; I. Boule; M. Gien; M. Guillemont; F. Herrmann; C. Kaiser; S. Langlois; P. Leonard; W. Neuhauser (Fall 1988). "CHORUS Distributed Operating Systems"(PDF). USENIX Computing Systems: 305–370. At pp. 306, 308, 309, 366.
^ abcZimmerman, Hubert (25 May 1988). "Interview of Hubert Zimmerman"(PDF) (Interview). Interviewed by James L. Pelkey. Paris, France: COmputer History Museum. p. 10n11.
^ abcdefghijklmnopqrsGien, Michel (3 April 2012). "An Interview with Michel Gien"(PDF) (Interview). Interviewed by Andrew L. Russell. Paris, France: Charles Babbage Institute, University of Minnesota. pp. 16–18, 20–22.
^Rozier, M.; V. Abrossimov; F. Armand; I. Boule; M. Gien; M. Guillemont; F. Herrmann; C. Kaiser; S. Langlois; P. Leonard; W. Neuhauser (1991). "Overview of the CHORUS Distributed Operating Systems"(PDF). Chorus Systèmes. p. 23. Archived(PDF) from the original on 7 February 2015. Retrieved 30 July 2013. Revised and expanded version of the Usenix paper.
^ abcBoyer, F.; Cayuela, J.; Chevalier, P.Y.; Freyssinet, A.; Hagimont, D. (1991). "Supporting an object-oriented distrubted system: experience with Unix, Mach and Chorus". Proc. Symposium on Experience with Distributed and Multiprocessor Systems (SEDMS), Atlanta, Mar. 91. USENIX. pp. 283–299. CiteSeerX10.1.1.25.2738. At pp. 1, 2, 7–9 of the pdf.
^ abUdell, Jon (February 1995). "Novell's Campaign". Byte. pp. 42–44, 46–47, 50, 52, 54, 58, 60, 62, 64. Retrieved 27 May 2022. "The New World of Novell", cover story of issue.
^ abcdeKhermouch, Gerry (25 November 1991). "USL backs French firm's Microkernel". Electronic News. p. 13. Archived from the original on 28 March 2021. Retrieved 28 March 2021 – via Gale General OneFile.
^Bac, Christian; Garnier, Edmond (1993). "Cohabitation and Cooperation of Chorus and MacOS". Proceedings of the USENIX Symposium on Microkernels and Other Kernel Architectures. USENIX Association: 61–71. Retrieved 25 May 2022.