|
|
A Linux-oriented Intro to Embeddable Single Board Computers
1997-03-09
What's an SBC?Early microcomputers typically consisted of half a dozen (or more) circuit boards -- plugged into a backplane -- which implemented the central processor unit (CPU), memory, disk controllers, and serial/parallel port functions. These backplane-based microcomputers were used for data acquisition, process control, and R&D projects, but were generally...
too bulky to be used as the intelligence embedded within devices. By the early 80's, integrated circuit (IC) technology had advanced to where functions that previously occupied entire circuit boards could be crammed into single "large scale integration" (LSI) logic chips. LSI chips for CPU, memory, storage, and serial/parallel ports now made it practical to implement complete microcomputer systems on a single board -- without backplanes. The Z80-based "Big Board" (1980) was probably the first such single board computer (SBC) that was capable of running a commercial disk operating system (CP/M). The embedded SBC market Like the Big Board, the "Little Board" (Ampro, 1983) used a Z80 CPU and was targeted specifically at the CP/M operating system. But it was much smaller in size, matching the footprint of a floppy disk drive (5.75 x 8.0 in.). Thanks to its unique combination of compactness, simplicity, reliability, and low cost, the Little Board made it practical for a commercial disk operating system to be easily embedded directly within devices that were not themselves computers. Thus was born the embedded SBC market, which by now has become crowded with hundreds of SBC manufacturers producing thousands of different SBC products that target a vast array of embedded and dedicated computing applications. Initially, every SBC product was completely unique -- both architecturally and physically. This was largely due to the inherent diversity of embedded system requirements, combined with the wide assortment of processors and peripheral controllers that were available. Moreover, there were no standards to influence SBC developers' choices of functional and mechanical specs. The dawn of the PC-compatible SBC By the mid '80s, there was growing interest in IBM PC compatibility in embedded and other non-desktop applications, for two key reasons . . .
In the case of embeddable non-backplane SBCs, the trend towards PC compatibility quickly became a stampede. Consensus also emerged around several popular form-factors . . .
Strongly blowing winds of change Today, several significant factors seriously challenge the SBC market status quo . . .
A little chaos theory Prior to the embedded SBC market coalescing around the PC architecture and a handful of form-factor standards, it was nearly impossible to locate two SBCs that bore much similarity with to other. The PC architecture brought a degree of order (in several shapes and sizes) to that chaos, by serving as a unifying force -- a situation which persisted for nearly two decades. Today, with the established norms disrupted by new interfaces (USB, FireWire, Bluetooth), architectures (MIPS, PowerPC, ARM), and operating systems (Linux), the embedded SBC market had better prepare itself for a new phase of its lifecycle -- one that will initially be characterized by a heightened diversity of operating systems, processor architectures, peripheral interfaces, and physical form-factors. A few words about Linux on Embedded-PC SBCs These days, most manufacturers of PC-compatible single board computers claim to support embedded Linux on their products -- either directly, or via third-party relationships with embedded Linux software providers. However, be careful not to get too complacent when the sales rep says "Sure, we support Linux." In general, Linux support for PC-compatible embedded SBCs tends to be straightforward -- provided: (1) the chipsets used are mainstream and fairly current; and (2) the chipsets have been used in the normal manner. Always ask the SBC vendor what specific versions of Linux they have tested, how they conducted the tests, which interfaces on the SBC were exercised, and what functions are either untested or unsupported. Specifically, areas to watch out for include . . .
Fortunately, if you are using Linux in your embedded SBC based system, you can at least take heart in the knowledge that driver source code is readily available and that there are plenty of Linux-aware programmers around who can help you untangle any problems that may arise. Story navigation . . .
Talk back! Do you have questions or comments on this article? talkback here
|