| Tim Bird on "What is Linux?" |
Tim Bird, CTO of Lineo Inc. (July 17, 2000)
The following is Tim Bird's answer to the question, "What is Linux?"
In answer to the question, "What is Linux?" it is important to identify the key attributes of Linux that distinguish it from other similar operating systems. In particular, it is important to identify those attributes that make Linux a compelling and popular choice for developers of all kinds, embedded or not, which are missing from some of the alternatives.
First, however, you need to distinguish between "Linux" the kernel, and a "Linux distribution." A Linux distribution can contain all kinds of software, from a number of sources and available under a number of licenses. Richard Stallman likes to call this collection of software a "GNU/Linux" system. This is fair for systems which consist mostly of GNU and Linux software. In the embedded space, particularly, a distribution may include very much or very little of the same types of programs found in a desktop distribution. I prefer to refer only to the kernel as Linux, although many attributes of the kernel that make it successful are also found in the surrounding software of a Linux distribution.
So what makes Linux, Linux? I believe the key attributes are: (1) the license for the source; (2) the community effect this generates for the code; and (3) the code itself generated by open source contributors.
Linux has an API and ABI, but these are largely borrowed from other places in definition, style and even sometimes in implementation. The Linux API is a superset of POSIX, which almost every UNIX has, and the ABI is just the syscalls, which are unexciting at best. What is exciting about Linux is its rapid pace of development, the amount of security and robustness it has (due largely to extensive peer review), its breadth of device support, and its performance and quality. These things derive from the community that supports Linux, and the way that they do it. This is partly attributable to the license of Linux, GPL, but is also due to the way software contributions are managed by Linus and others in the community. So maybe Linux really is "what Linus says it is."
Note that although other operating systems like QNX, LynxOS or SCO might have available source code, or API or ABI compatibility, they are not Linux because they don't have the same community support or code management model. Thus, things like extensive peer review or pace of development, will elude them. This is even true of BSD, which has a license with less restrictions than GPL, because its code base is managed differently, even it is closer than the others.
The difficult question is whether uClinux or RtLinux or RTAI (the latter being hard real-time versions of Linux) are Linux. All of these projects (and several others) consist of source trees where a significant patch has been applied to the Linux kernel, that Linus has yet to incorporate into the main tree. I would contend that all of these branches are still Linux.
Each of them follows the same general pattern of Linux open source, with a single central leader approving new development, continued licensing of the code under GPL, and (most significantly) a thriving community of developers adding value to the code base (even if the respective communities are somewhat smaller than the "main tree" community."
Actually, it can be argued that this type of branching is a good thing, because it allows the type of evolution (via natural selection of the best code and adaptation to specific environments [markets]), that allows Linux to thrive, grow and dominate.
However, this argument lies on a slippery slope. How many patches make Linux not Linux? Maybe the best analogy is drawn from the classification of species: XYZ is not Linux when it can no longer mate with Linux. Note that, in the case of uClinux, it still can "mate with Linux" because many advances in 2.2 Linux can (and have been) easily be back-ported to uCLinux, thus allowing uClinux continued value from its proximity with Linux. Maybe Linux needs to be thought of as more than just one species of operating system, but rather as a family all belonging to one genus (phylum, etc.). With similar important attributes.
In the end, I don't think it matters where you draw some arbitrary cutoff line to distinguish Linux from non-Linux. As I heard Rick Lehrbaum say one time, "when the sun sets when does it get dark?" It really is subjective. What is most important is identifying the pros and cons of using variants of the "pure main source tree" Linux, to make informed judgements about the long term value and cost of using Linux in its different forms.
(Click here for further information)
|
|
|
FUEL Database on MontaVista Linux
Whether building a mobile handset, a car navigation system, a package tracking device, or a home entertainment console, developers need capable software systems, including an operating system, development tools, and supporting libraries, to gain maximum benefit from their hardware platform and to meet aggressive time-to-market goals.
Breaking New Ground: The Evolution of Linux Clustering
With a platform comprising a complete Linux distribution, enhanced for clustering, and tailored for HPC, Penguin Computing¿s Scyld Software provides the building blocks for organizations from enterprises to workgroups to deploy, manage, and maintain Linux clusters, regardless of their size.
Data Monitoring with NightStar LX
Unlike ordinary debuggers, NightStar LX doesn¿t leave you stranded in the dark. It¿s more than just a debugger, it¿s a whole suite of integrated diagnostic tools designed for time-critical Linux applications to reduce test time, increase productivity and lower costs. You can debug, monitor, analyze and tune with minimal intrusion, so you see real execution behavior. And that¿s positively illuminating.
Virtualizing Service Provider Networks with Vyatta
This paper highlights Vyatta's unique ability to virtualize networking functions using Vyatta's secure routing software in service provider environments.
High Availability Messaging Solution Using AXIGEN, Heartbeat and DRBD
This white paper discusses a high-availability messaging solution relying on the AXIGEN Mail Server, Heartbeat and DRBD. Solution architecture and implementation, as well as benefits of using AXIGEN for this setup are all presented in detail.
Understanding the Financial Benefits of Open Source
Will open source pay off? Open source is becoming standard within enterprises, often because of cost savings. Find out how much of a financial impact it can have on your organization. Get this methodology and calculator now, compliments of JBoss.
Embedded Hardware and OS Technology Empower PC-Based Platforms
The modern embedded computer is the jack of all trades appearing in many forms.
Data Management for Real-Time Distributed Systems
This paper provides an overview of the network-centric computing model, data distribution services, and distributed data management. It then describes how the SkyBoard integration and synchronization service, coupled with an implementation of the OMG¿s Data Distribution Service (DDS) standard, can be used to create an efficient data distribution, storage, and retrieval system.
7 Advantages of D2D Backup
For decades, tape has been the backup medium of choice. But, now, disk-to-disk (D2D) backup is gaining in favor. Learn why you should make the move in this whitepaper.
|
|
|
|
|