All Topics  
Embedded system

 
Embedded System

   Email Print
   Bookmark   Link






 

Embedded system



 
 
An embedded system is a special-purpose computer
Computer

A computer is a machine that manipulates Data according to a list of Code .The first devices that resemble modern computers date to the mid-20th century , although the computer concept and various machines similar to computers existed earlier....
 system designed to perform one or a few dedicated functions, often with real-time computing
Real-time computing

In computer science, real-time computing is the study of Computer hardware and computer software systems that are subject to a "real-time constraint"?i.e., operational deadlines from event to system response....
 constraints. It is usually embedded as part of a complete device including hardware and mechanical parts.






Discussion
Ask a question about 'Embedded system'
Start a new discussion about 'Embedded system'
Answer questions from other users
Full Discussion Forum



Encyclopedia


Adsl Modem Router Internals Labeled
An embedded system is a special-purpose computer
Computer

A computer is a machine that manipulates Data according to a list of Code .The first devices that resemble modern computers date to the mid-20th century , although the computer concept and various machines similar to computers existed earlier....
 system designed to perform one or a few dedicated functions, often with real-time computing
Real-time computing

In computer science, real-time computing is the study of Computer hardware and computer software systems that are subject to a "real-time constraint"?i.e., operational deadlines from event to system response....
 constraints. It is usually embedded as part of a complete device including hardware and mechanical parts. In contrast, a general-purpose computer, such as a personal computer
Personal computer

A personal computer is any general-purpose computer whose original sales price, size, and capabilities make it useful for individuals, and which is intended to be operated directly by an end user, with no intervening computer operator....
, can do many different tasks depending on programming. Embedded systems control many of the common devices in use today.

Since the embedded system is dedicated to specific tasks, design engineers can optimize it, reducing the size and cost of the product, or increasing the reliability and performance. Some embedded systems are mass-produced, benefiting from economies of scale
Economies of scale

Economies of scale, in microeconomics, are the cost advantages that a business obtains due to expansion. They are factors that cause a producer?s average cost per unit to fall as output rises....
.

Physically, embedded systems range from portable devices such as digital watches and MP3 players, to large stationary installations like traffic light
Traffic light

Traffic lights, also known as traffic signals, stop lights, traffic lamps, stop-and-go lights, robots or semaphore, are signaling devices positioned at road intersections, pedestrian crossing, or other location to control the flow of traffic....
s, factory controllers, or the systems controlling nuclear power plants. Complexity varies from low, with a single microcontroller
Microcontroller

A microcontroller is a small computer on a single integrated circuit consisting of a relatively simple CPU combined with support functions such as a crystal oscillator, timers, watchdog, serial and analog I/O etc....
 chip, to very high with multiple units, peripherals and networks mounted inside a large chassis or enclosure.

In general, "embedded system" is not an exactly defined term, as many systems have some element of programmability. For example, Handheld computers share some elements with embedded systems — such as the operating systems and microprocessors which power them — but are not truly embedded systems, because they allow different applications to be loaded and peripherals to be connected.

Examples of embedded systems


Embedded systems span all aspects of modern life and there are many examples of their use.

Telecommunications systems employ numerous embedded systems from telephone switches for the network to mobile phone
Mobile phone

A mobile phone is a long-range, electronic device used for mobile voice or data communication over a network of specialized base stations known as cell sites....
s at the end-user. Computer networking uses dedicated router
Router

A router is a Computer network device whose software and hardware are usually tailored to the tasks of routing and forwarding information. For example, on the Internet, information is directed to various paths by routers....
s and network bridge
Network bridge

A network bridge connects multiple network segments at the data link layer of the OSI model, and the term layer 2 switch is very often used interchangeably with bridge....
s to route data.

Consumer electronics
Consumer electronics

Consumer electronics include electronic equipment intended for everyday use. Consumer electronics are most often used in entertainment, communications and office productivity....
 include personal digital assistant
Personal digital assistant

A personal digital assistant is a handheld computer, also known as a palmtop computer. Newer PDAs also have both color screens and audio capabilities, enabling them to be used as mobile phones, , web browsers, or portable media players....
s (PDAs), mp3 players, mobile phones, videogame consoles, digital camera
Digital camera

A digital camera is a camera that takes video or still photographs, or both, digitally by recording digital image via an electronics .Many compact digital still cameras can record sound and moving video as well as still photographs....
s, DVD player
DVD player

A DVD player is a device that plays discs produced under both the DVD Video and DVD Audio technical standards, two different and incompatible standards....
s, GPS
Global Positioning System

The Global Positioning System is a global navigation satellite system developed by the United States Department of Defense and managed by the United States Air Force 50th Space Wing....
 receivers, and printer
Computer printer

File:Lexmark X5100 Series.jpgIn computing, a printer is a peripheral which produces a hard copy of documents stored in computer file form, usually on physical print media such as paper or Transparency ....
s. Many household appliances, such as microwave oven
Microwave oven

A microwave oven, or a microwave, is a kitchen appliance that cookings or heats food by dielectric heating. This is accomplished by using microwave radiation to heat water and other dipole within the food....
s, washing machine
Washing machine

A washing machine, or washer, is a machine designed to clean laundry, such as clothing, towels and Bed sheets. The term is mostly applied only to machines that use water as the primary cleaning solution, as opposed to dry cleaning or even ultrasonic cleaners....
s and dishwashers, are including embedded systems to provide flexibility, efficiency and features. Advanced HVAC
HVAC

HVAC is an initialism or acronym that stands for "heating, Ventilation , and air conditioning". HVAC is sometimes referred to as climate control and is particularly important in the design of medium to large industrial and office buildings such as skyscrapers and in marine environments such as aquariums, where humidity and tem...
 systems use networked thermostat
Thermostat

A thermostat is a Measuring instrument for regulating the temperature of a system so that the system's temperature is maintained near a desired setpoint temperature....
s to more accurately and efficiently control temperature that can change by time of day and season
Season

A season is one of the major divisions of the year, generally based on yearly periodic changes in weather.Seasons result from the yearly revolution of the Earth around the Sun and the Axial tilt....
. Home automation
Home automation

Home automation is a field within building automation, specializing in the specific automation requirements of private homes and in the application of automation techniques for the comfort and security of its residents....
 uses wired- and wireless-networking that can be used to control lights, climate, security, audio/visual, surveillance, etc., all of which use embedded devices for sensing and controlling.

Transportation systems from flight to automobiles increasingly use embedded systems. New airplanes contain advanced avionics
Avionics

Avionics means "aviation electronics". It comprises Electronics systems for use on aircraft, artificial satellites and spacecraft, comprising communications, navigation and the display and management of multiple systems....
 such as inertial guidance systems and GPS
Global Positioning System

The Global Positioning System is a global navigation satellite system developed by the United States Department of Defense and managed by the United States Air Force 50th Space Wing....
 receivers that also have considerable safety requirements. Various electric motors — brushless DC motors, induction motor
Induction motor

An induction motor is a type of asynchronous AC motor where power is supplied to the rotating device by means of Electromagnetic induction. Other commonly used name is squirrel cage motor due to the fact that the rotor bars with short circuit rings resemble a squirrel cage ....
s and DC motor
DC motor

A DC motor is an electric motor that runs on direct current electricity....
s — are using electric/electronic motor controller
Motor controller

A motor controller is a device or group of devices that serves to govern in some predetermined manner the performance of an electric motor. A motor controller might include a manual or automatic means for starting and stopping the motor, selecting forward or reverse rotation, selecting and regulating the speed, regulating or limiting the torq...
s. Automobile
Automobile

An automobile or motor car is a wheeled motor vehicle for transportation passengers, which also carries its own car engine or motor. Most definitions of the term specify that automobiles are designed to run primarily on roads, to have seating for one to eight people, to typically have four wheels, and to be constructed principally f...
s, electric vehicle
Electric vehicle

An electric vehicle is a vehicle with one or more electric motors for propulsion. This is also referred to as an electric drive vehicle....
s, and hybrid vehicle
Hybrid vehicle

File:HondaInsight.jpgA hybrid vehicle is a vehicle that uses two or more distinct power sources to move the vehicle . The term most commonly refers to hybrid electric vehicles , which combine an internal combustion engine and one or more electric motors....
s are increasingly using embedded systems to maximize efficiency and reduce pollution. Other automotive safety systems such as anti-lock braking system
Anti-lock braking system

An anti-lock braking system, or ABS is a safety system which prevents the wheels on a motor vehicle from locking while brake.A rotating road wheel allows the driver to maintain steering control under heavy braking by preventing a skid and allowing the wheel to continue interacting Traction with the road surface as directed by driver...
 (ABS), Electronic Stability Control
Electronic Stability Control

Electronic stability control is a computerized technology that improves the safety of a car handling by detecting and preventing skids. When ESC detects loss of steering control, ESC automatically applies individual brakes to help "steer" the vehicle where the driver wants to go....
 (ESC/ESP), traction control (TCS) and automatic four-wheel drive
Four-wheel drive

Four-wheel drive, 4WD, 4x4 , or AWD is a four-wheeled vehicle with a Powertrain that allows all four wheels to receive torque from the engine simultaneously....
.

Medical equipment
Medical equipment

Medical equipment is designed to aid in the diagnosis, monitoring or treatment of medical conditions. These devices are usually designed with rigorous safety engineering....
 is continuing to advance with more embedded systems for vital signs
Vital signs

Vital signs are measures of various physiological statistics often taken by health professionals in order to assess the most basic body functions....
 monitoring, electronic stethoscopes for amplifying sounds, and various medical imaging
Medical imaging

Medical imaging refers to the techniques and processes used to create s of the human body for clinical purposes or medical science .As a discipline and in its widest sense, it is part of biological imaging and incorporates radiology , radiological sciences, endoscopy, thermography, medical photography and microscopy ....
 (PET
Positron emission tomography

Positron emission tomography is a nuclear medicine medical imaging technique which produces a three-dimensional image or picture of functional processes in the body....
, SPECT
Single photon emission computed tomography

Single photon emission computed tomography is a nuclear medicine tomography imaging technique using gamma rays. It is very similar to conventional nuclear medicine planar imaging using a gamma camera....
, CT
Computed tomography

Computed tomography is a medical imaging method employing tomography. Geometry Processing is used to generate a stereoscopy of the inside of an object from a large series of two-dimensional X-ray images taken around a single axis of rotation....
, MRI
Magnetic resonance imaging

GaneshMagnetic resonance imaging , or nuclear magnetic resonance imaging , is primarily a medical imaging technique most commonly used in radiology to visualize the structure and function of the body....
) for non-invasive internal inspections.

In addition to commonly described embedded systems based on small computers, a new class of miniature wireless devices called motes are quickly gaining popularity as the field of wireless sensor networking rises. Wireless sensor networking, WSN, makes use of miniaturization made possible by advanced IC design to couple full wireless subsystems to sophisticated sensor, enabling people and companies to measure a myriad of things in the physical world and act on this information through IT monitoring and control systems. These motes are completely self contained, and will typically run off a battery source for many years before the batteries need to be changed or charged. Embedded System is a combination of Hardware and Software and its have some mechanical components to perform specific task in a fixed time of frame.

History

In the earliest years of computers in the 1930-40s, computers were sometimes dedicated to a single task, but were far too large and expensive for most kinds of tasks performed by embedded computers of today. Over time however, the concept of programmable controllers evolved from traditional electromechanical sequencers, via solid state devices, to the use of computer technology.

One of the first recognizably modern embedded systems was the Apollo Guidance Computer
Apollo Guidance Computer

The Apollo Guidance Computer was the first recognizably modern embedded system, used in Real-time computing by astronaut pilot to collect and provide flight information, and to automatically control all of the navigational functions of the Apollo spacecraft....
, developed by Charles Stark Draper
Charles Stark Draper

Charles Stark Draper was an American scientist and engineer, often referred to as "the father of inertial navigation system."...
 at the MIT Instrumentation Laboratory. At the project's inception, the Apollo guidance computer was considered the riskiest item in the Apollo project as it employed the then newly developed monolithic integrated circuits to reduce the size and weight. An early mass-produced embedded system was the Autonetics D-17 guidance computer for the Minuteman missile, released in 1961. It was built from transistor
Transistor

In electronics, a transistor is a semiconductor device commonly used to Electronic amplifier or switch Electronics signals. A transistor is made of a solid piece of a semiconductor material, with at least three terminals for connection to an external circuit....
 logic
Digital circuit

Digital electronics are electronics systems that use digital signals. Digital electronics are representations of Boolean algebra and are used in computers, mobile phones, and other consumer products....
 and had a hard disk
Hard disk

A hard disk drive , commonly referred to as a hard drive, hard disk, or fixed disk drive, is a non-volatile storage device which stores digitally encoded data on rapidly rotating hard disk platters with magnetic surfaces....
 for main memory. When the Minuteman II went into production in 1966, the D-17 was replaced with a new computer that was the first high-volume use of integrated circuits. This program alone reduced prices on quad nand gate ICs
Sheffer stroke

The Sheffer stroke, written "|" or "?", in the subject matter of boolean functions or propositional calculus, denotes a logical operation that is equivalent to the logical negation of the logical conjunction operation, expressed in ordinary language as "not both"....
 from $1000/each to $3/each, permitting their use in commercial products.

Since these early applications in the 1960s, embedded systems have come down in price and there has been a dramatic rise in processing power and functionality. The first microprocessor
Microprocessor

A microprocessor incorporates most or all of the functions of a central processing unit on a single integrated circuit . The first microprocessors emerged in the early 1970s and were used for electronic calculators, using Binary-coded decimal arithmetic on 4-bit Word ....
 for example, the Intel 4004
Intel 4004

The Intel 4004 is a 4-bit central processing unit released by Intel Corporation in 1971. The 4004 is the first complete CPU on one chip, the first commercially available microprocessor, a feat made possible by the use of the new silicon gate technology allowing the integration of a higher number of transistors and a faster speed than was pos...
, was designed for calculator
Calculator

A calculator is a device for performing mathematical calculations, distinguished from a computer by having a limited problem solving ability and an interface optimized for interactive calculation rather than programming....
s and other small systems but still required many external memory and support chips. In 1978 National Engineering Manufacturers Association released a "standard" for programmable microcontrollers, including almost any computer-based controllers, such as single board computers, numerical, and event-based controllers.

As the cost of microprocessors and microcontrollers fell it became feasible to replace expensive knob-based analog components such as potentiometer
Potentiometer

A potentiometer is a three-terminal resistor with a sliding contact that forms an adjustable voltage divider. If only two terminals are used , it acts as a variable resistor or Rheostat....
s and variable capacitor
Variable capacitor

A variable capacitor is a capacitor whose capacitance may be intentionally and repeatedly changed mechanically or electronically. Variable capacitors are often used in RLC circuit to set the resonance frequency, e.g....
s with up/down buttons or knobs read out by a microprocessor even in some consumer products. By the mid-1980s, most of the common previously external system components had been integrated into the same chip as the processor and this modern form of the microcontroller
Microcontroller

A microcontroller is a small computer on a single integrated circuit consisting of a relatively simple CPU combined with support functions such as a crystal oscillator, timers, watchdog, serial and analog I/O etc....
 allowed an even more widespread use, which by the end of the decade were the norm rather than the exception for almost all electronics devices.

The integration of microcontrollers has further increased the applications for which embedded systems are used into areas where traditionally a computer would not have been considered. A general purpose and comparatively low-cost microcontroller may often be programmed to fulfill the same role as a large number of separate components. Although in this context an embedded system is usually more complex than a traditional solution, most of the complexity is contained within the microcontroller itself. Very few additional components may be needed and most of the design effort is in the software. The intangible nature of software makes it much easier to prototype and test new revisions compared with the design and construction of a new circuit not using an embedded processor.

Characteristics


  1. Embedded systems are designed to do some specific task, rather than be a general-purpose computer for multiple tasks. Some also have real-time
    Real-time computing

    In computer science, real-time computing is the study of Computer hardware and computer software systems that are subject to a "real-time constraint"?i.e., operational deadlines from event to system response....
     performance constraints that must be met, for reasons such as safety and usability; others may have low or no performance requirements, allowing the system hardware to be simplified to reduce costs.
  2. Embedded systems are not always standalone devices. Many embedded systems consist of small, computerized parts within a larger device that serves a more general purpose. For example, the Gibson Robot Guitar
    Gibson Robot Guitar

    The Gibson Robot Guitar typically refers to a sub-class of Gibson Les Paul style guitars from Gibson Guitar Corporation. This is because the first run of limited edition Robot Guitars was exclusively made up of Les Paul bodies....
     features an embedded system for tuning the strings, but the overall purpose of the Robot Guitar is, of course, to play music. Similarly, an embedded system in an automobile
    Automobile

    An automobile or motor car is a wheeled motor vehicle for transportation passengers, which also carries its own car engine or motor. Most definitions of the term specify that automobiles are designed to run primarily on roads, to have seating for one to eight people, to typically have four wheels, and to be constructed principally f...
     provides a specific function as a subsystem of the car itself.
  3. The program instructions written for embedded systems are referred to as firmware
    Firmware

    Firmware is a term sometimes used to denote the fixed, usually rather small, programs that internally control various electronic devices. Typical examples range from end user products such as remote controls or calculators, via computer parts and devices like harddisks, keyboard s, TFT screens or memory cards, all the way to scientific instr...
    , and are stored in read-only memory or Flash memory
    Flash memory

    Flash memory is a non-volatile memory computer storage that can be electrically erased and reprogrammed. It is a technology that is primarily used in memory cards and USB flash drives for general storage and transfer of data between computers and other digital products....
     chips. They run with limited computer hardware resources: little memory, small or non-existent keyboard and/or screen.


User interfaces

Embedded systems range from no user interface at all — dedicated only to one task — to complex graphical user interfaces that resemble modern computer desktop operating systems.

Simple systems


Simple embedded devices use buttons, LEDs, and small character- or digit-only displays, often with a simple menu system
Menu (computing)

In computing and telecommunications, a menu is a list of commands presented to an operator by a computer or communications system. They may be thought of as shortcuts to frequently used commands that avoid the operator having to have a detailed knowledge or recall of syntax....
.

In more complex systems

A full graphical screen, with touch sensing or screen-edge buttons provides flexibility while minimising space used: the meaning of the buttons can change with the screen, and selection involves the natural behavior of pointing at what's desired.

Handheld systems often have a screen with a "joystick button" for a pointing device.

Many systems have "maintenance" or "test" interfaces that provide a menu or command system via an RS-232 interface. This avoids the cost of a display, but gives a lot of control. Most consumers cannot assemble the required cables, however.

The rise of the World Wide Web
World Wide Web

The World Wide Web is a very large set of interlinked hypertext documents accessed via the Internet. With a Web browser, one can view Web pages that may contain writing, s, videos, and other multimedia and navigate between them using hyperlinks....
 has given embedded designers another quite different option: providing a web page interface over a network connection. This avoids the cost of a sophisticated display, yet provides complex input and display capabilities when needed, on another computer. This is successful for remote, permanently installed equipment such as Pan-Tilt-Zoom cameras and network routers.

CPU platforms


Embedded processors can be broken into two broad categories: ordinary microprocessors (µP) and microcontrollers (µC), which have many more peripherals on chip, reducing cost and size. Contrasting to the personal computer and server markets, a fairly large number of basic CPU architectures are used; there are Von Neumann
Von Neumann architecture

The von Neumann architecture is a design model for a stored-program digital computer that uses a central processing unit and a single separate computer storage structure to hold both instructions and data ....
 as well as various degrees of Harvard architecture
Harvard architecture

The Harvard architecture is a computer architecture with physically separate computer storage and signal pathways for instructions and data. The term originated from the Harvard Mark I relay-based computer, which stored instructions on punched tape and data in electro-mechanical counters ....
s, RISC as well as non-RISC and VLIW; word lengths vary from 4-bit to 64-bits and beyond (mainly in DSP
Digital signal processor

A digital signal processor is a specialized microprocessor designed specifically for digital signal processing, generally in real-time computing....
 processors) although the most typical remain 8/16-bit. Most architectures come in a large number of different variants and shapes, many of which are also manufactured by several different companies.

A long but still not exhaustive list of common architectures are: 65816, 65C02, 68HC08, 68HC11, 68k
68k

The Motorola 680x0/m68k/68k/68K is a family of 32-bit Complex instruction set computer microprocessor central processing unit chips and was the primary competition for the Intel x86 family of chips in personal computers of the 1980s and early 1990s....
, 8051
Intel 8051

The Intel 8051 is a Harvard architecture, single chip microcontroller which was developed by Intel in 1980 for use in embedded systems. Intel's original versions were popular in the 1980s and early 1990s, but has largely been superseded by a vast range of faster and/or functionally enhanced 8051-compatible devices manufactured by more th...
, ARM
ARM architecture

The ARM architecture is a 32-bit RISC central processing unit architecture developed by ARM Limited that is widely used in embedded system designs....
, AVR
Atmel AVR

The AVR is a Modified Harvard architecture 8-bit Reduced instruction set computer single chip microcontroller which was developed by Atmel in 1996....
, AVR32
AVR32

The AVR32 is a 32-bit RISC microprocessor architecture designed by Atmel. The microprocessor architecture was designed by a handful of people educated at the Norwegian University of Science and Technology, including lead designer ?yvind Str?m, PhD and CPU architect Erik Renno, M.Sc in Atmel's Norwegian design center....
, Blackfin
Blackfin

Blackfin refers to a family of 16/32-bit microprocessors with built-in Digital Signal Processor functionality, which is traditionally only accompanied by a small and power-efficient microcontroller....
, C167
C167 family

The C167 family is a 16 bit microcontroller architecture from Infineon Technologies. It is a further development of the C166 family, which has been brought by Siemens 1993 on the market as controller for measurement and control tasks....
, Coldfire, COP8
COP8

The COP8 microcontroller from National Semiconductor is an 8 bit Complex instruction set computer core microcontroller, whose main features are:...
, eZ8
Zilog Z8

The Zilog Z8 is a microcontroller architecture, originally introduced in 1979, which today also includes the eZ8 Encore!, eZ8 Encore! XP, and eZ8 Encore! MC families....
, eZ80, FR-V
FR-V

The Fujitsu FR-V is a VLIW-based RISC microprocessor, including FR-400 and FR-450 which runs Linux, and are also supported by the GNU Compiler Collection....
, H8, HT48
HT48FXX Flash I/O type series

The Holtek HT48FXX I/O Series is a series of Holtek devices optimised for multiple I/O control digital applications. The device range is supplied with Program Memory capacities from 1K to 8K and is a Flash Memory type meaning it can be reprogrammed by the user using Holtek's programming tools....
, M16C, M32C, MIPS
MIPS architecture

MIPS is a RISC instruction set architecture developed by MIPS Technologies . In the mid to late 1990s, it was estimated that one in three RISC microprocessors produced were MIPS implementations....
, MSP430, PIC
PIC microcontroller

PIC is a family of Harvard architecture microcontrollers made by Microchip Technology, derived from the PIC1640 originally developed by General Instrument's Microelectronics Division....
, PowerPC
PowerPC

PowerPC is a RISC instruction set architecture created by the 1991 Apple Inc.?IBM?Motorola alliance, known as AIM alliance. Originally intended for personal computers, PowerPC CPUs have since become popular embedded system and high-performance processors....
, R8C, SHARC
Super Harvard Architecture Single-Chip Computer

The Super Harvard Architecture Single-Chip Computer is a high performance floating-point and fixed-point digital signal processor from Analog Devices,...
, ST6
ST6

ST6 may refer to:*...
, SuperH
SuperH

The SuperH is brandname of a certain microcontroller and microprocessor architecture. The SuperH is fundamentally a 32-bit load/store reduced instruction set computer architecture found in a large number of embedded systems....
, TLCS-47, TLCS-870, TLCS-900, Tricore
Tricore

TriCore is the name of a multicore-processor design by Infineon Technologies.According to its designers, TriCore is advantageous based on its 3-in-1 architecture consisting of a microcontroller, Digital signal processing , and RISC-based load-store computing system ....
, V850
V850

The NEC Electronics Corporation V850 is a 32-bit embedded RISC microcontroller originally developed and manufactured by NEC Corporation, succeeded by V850 variants named V850ES, V850E, and V850E2 which run uClinux....
, x86
X86 architecture

The generic term x86 refers to the most commercially successful instruction set architecture in the history of personal computing. It derived from the model numbers, ending in "86", of the first few processor generations Backward compatibility with the original Intel 8086....
, XE8000
XE8000

The XE8000 series is a low-power microcontroller family from XEMICS . Advanced analog features are combined with a proprietary RISC Central processing unit named CoolRISC on all XE8000 devices....
, Z80, etc.

Ready made computer boards
PC/104
PC/104

PC/104 is an embedded computer standardization controlled by the which defines both a form factor and computer bus. PC/104 is intended for specialized embedded computing environments where applications depend on reliable data acquisition despite an often extreme environment....
 and PC/104+ are examples of available ready made computer boards intended for small, low-volume embedded and ruggedized systems. These often use DOS
DOS

DOS, short for "Disk Operating System", is a shorthand term for several closely related operating systems that dominated the IBM PC compatible market between 1981 and 1995, or until about 2000 if one includes the partially DOS-based Microsoft Windows versions Windows 95, Windows 98, and Windows Me....
, Linux
Linux

Linux is a generic term referring to Unix-like computer operating systems based on the Linux kernel. Their development is one of the most prominent examples of free and open source software collaboration; typically all the underlying source code can be used, freely modified, and redistributed by anyone under the terms of the GNU GPL license...
, NetBSD
NetBSD

NetBSD is a freely redistributable, open source version of the Unix-derivative Berkeley Software Distribution computer operating system. It was the second open source BSD descendant to be formally released, after 386BSD, and continues to be actively developed....
, or an embedded real-time operating system
Real-time operating system

A Real-Time Operating System is a Computer multitasking operating system intended for real-time computing applications. Such applications include embedded systems , industrial robots, spacecraft, industrial control , and scientific research equipment....
 such as MicroC/OS-II
MicroC/OS-II

MicroC/OS-II , is a low-cost priority-based preemption real-time operating system computer multitasking kernel for microprocessors, written mainly in the C programming language....
, QNX
QNX

QNX is a commercial Unix-like real-time operating system, aimed primarily at the embedded systems market. On September 12, 2007, the source of the QNX kernel was released for non-commercial use....
 or VxWorks
VxWorks

VxWorks is a real-time operating system operating system made and sold by Wind River Systems of Alameda, California, California, USA.VxWorks is designed for use in embedded systems....
.

In certain applications, where small size is not a primary concern, the components used may be compatible with those used in general purpose computers. Boards such as the VIA EPIA
EPIA

VIA EPIA is a series of mini-ITX, nano-ITX and pico-ITX motherboards with integrated VIA processors. They feature a small size and low power consumption, so are particularly popular in the embedded market....
 range help to bridge the gap by being PC-compatible but highly integrated, physically smaller or have other attributes making them attractive to embedded engineers. The advantage of this approach is that low-cost commodity components may be used along with the same software development tools used for general software development. Systems built in this way are still regarded as embedded since they are integrated into larger devices and fulfill a single role. Examples of devices that may adopt this approach are ATMs and arcade machines.and which can maintains separate coding according for the device .

ASIC and FPGA solutions
A common configuration for very-high-volume embedded systems is the system on a chip (SoC) which contains a complete system consisting of (multiple processors, multipliers, caches and interfaces on a single chip. SoCs can be implemented as an application-specific integrated circuit
Application-specific integrated circuit

An application-specific integrated circuit is an integrated circuit customized for a particular use, rather than intended for general-purpose use....
 (ASIC) or using a field-programmable gate array
Field-programmable gate array

A field-programmable gate array is a semiconductor device that can be configured by the customer or designer after manufacturing—hence the name "field-programmable"....
 (FPGA).

Peripherals

Embedded Systems talk with the outside world via peripheral
Peripheral

A peripheral is a device attached to a host computer behind the chipset whose primary functionality is dependent upon the host, and can therefore be considered as expanding the hosts capabilities, while not forming part of the system's core computer architecture....
s, such as:
  • Serial Communication Interfaces (SCI): RS-232
    RS-232

    In telecommunications, RS-232 is a standard for serial communications binary data signals connecting between a DTE and a DCE . It is commonly used in computer serial ports....
    , RS-422, RS-485 etc
  • Synchronous Serial Communication Interface: I2C, SPI
    Serial Peripheral Interface Bus

    The Serial Peripheral Interface Bus or SPI bus is a synchronous Serial communications standard named by Motorola that operates in full duplex mode....
    , SSC and ESSI
  • Universal Serial Bus
    Universal Serial Bus

    In information technology, Universal Serial Bus is a Serial communications computer bus standard to electrical connector devices to a host computer....
     (USB)
  • Networks: Ethernet
    Ethernet

    Ethernet is a family of Data frame-based computer networking technologies for local area networks . The name comes from the physical concept of the Luminiferous aether....
    , Controller Area Network
    Controller Area Network

    Controller?area network is a vehicle bus standard designed to allow microcontrollers and devices to communicate with each other within a vehicle without a host computer....
    , LonWorks
    LonWorks

    LonWorks is a networking platform specifically created to address the unique performance, reliability, installation, and maintenance needs of control applications....
    , etc
  • Timers: PLL(s), Capture/Compare and Time Processing Units
  • Discrete IO: aka General Purpose Input/Output (GPIO)
  • Analog to Digital/Digital to Analog (ADC/DAC)
  • Debugging: JTAG
    JTAG

    Joint Test Action Group is the common name used for the Institute of Electrical and Electronics Engineers 1149.1 standard entitled Standard Test Access Port and Boundary-Scan Architecture for test access ports used for testing printed circuit boards using boundary scan....
    , ISP, ICSP, BDM Port, ...


Tools


As for other software, embedded system designers use compiler
Compiler

A compiler is a computer program that transforms source code written in a programming language into another computer language . The most common reason for wanting to transform source code is to create an executable program....
s, assembler
Assembly language

An assembly language is a low-level language for programming computers. It implements a symbolic representation of the numeric machine codes and other constants needed to program a particular CPU architecture....
s, and debugger
Debugger

A debugger is a computer program that is used to test and debug other programs. The code to be examined might alternatively be running on an Instruction Set Simulator, a technique that allows great power in its ability to halt when specific conditions are encountered but which will typically be much slower than executing the code directly on...
s to develop embedded system software. However, they may also use some more specific tools:

  • In circuit debuggers or emulators (see next section).
  • Utilities to add a checksum or CRC
    Cyclic redundancy check

    A cyclic redundancy check is a type of function that takes as input a data stream of any length, and produces as output a value of a certain space, commonly a 32-bit integer....
     to a program, so the embedded system can check if the program is valid.
  • For systems using digital signal processing
    Digital signal processing

    Digital signal processing is concerned with the representation of the signal s by a sequence of numbers or symbols and the processing of these signals....
    , developers may use a math workbench such as Scilab
    Scilab

    Scilab is a Numerical analysis package developed since 1990 by researchers from the Institut National de Recherche en Informatique et en Automatique and the ?cole nationale des ponts et chauss?es ....
     / Scicos
    Scicos

    Scicos is a graphical dynamical system modeler and simulator. With Scicos you can create block diagrams to model and simulate the dynamics of hybrid dynamical systems and compile your models into executable code....
    , MATLAB
    MATLAB

    MATLAB is a Numerical analysis environment and programming language. Maintained by The MathWorks, MATLAB allows easy matrix manipulation, plotting of function and data, implementation of algorithms, creation of user interfaces, and interfacing with programs in other languages....
     / Simulink
    Simulink

    Simulink, developed by The MathWorks, is a commercial tool for modeling, simulating and analyzing multidomain dynamic systems. Its primary interface is a visual modeling and a customizable set of block library ....
    , EICASLAB
    EICASLAB

    EICASLAB is a laboratory for automatic control design and time-series forecasting developed as final output of the European ACODUASIS Project IPS-2001-42068 funded by the European Community, which - during its lifetime - aimed at delivering in the robotic field the scientific breakthrough consisting in a new methodology for the automatic...
    , MathCad
    MathCad

    Mathcad is desktop software for performing and documenting engineering and scientific calculations. First introduced in 1986 on MS-DOS, it was the first to introduce live editing of typeset mathematical notation, combined with its automatic computation....
    , or Mathematica
    Mathematica

    Mathematica is a computational software program used widely in scientific, engineering, and mathematical fields and other areas of technical computing....
     to simulate the mathematics. They might also use libraries for both the host and target which eliminates developing DSP routines as done in DSPnano RTOS
    DSPnano RTOS

    DSPnano is an embedded real-time operating system which is 100% compatible with POSIX and offers a tiny tiny embedded Linux compatible solution. It was first created in 1996 and was one of the first pthread based real-time kernels....
     and Unison Operating System
    Unison Operating System

    The Unison Operating System is a SoC, multi-core and digital signal processor optimized open source real-time operating system which offers a tiny tiny Linux compatible solution....
    .
  • Custom compilers and linkers may be used to improve optimisation for the particular hardware.
  • An embedded system may have its own special language or design tool, or add enhancements to an existing language such as Forth or Basic
    BASIC Stamp

    The BASIC Stamp is a microcontroller with a small, specialized BASIC programming language interpreter built into read-only memory. It is made by Parallax, Inc....
    .
  • Another alternative is to add a Real-time operating system
    Real-time operating system

    A Real-Time Operating System is a Computer multitasking operating system intended for real-time computing applications. Such applications include embedded systems , industrial robots, spacecraft, industrial control , and scientific research equipment....
     or Embedded operating system
    Embedded operating system

    An embedded operating system is an operating system for embedded system. These operating systems are designed to be very compact and efficient, forsaking many functions that non-embedded computer operating systems provide, and which may not be used by the specialized applications they run....
    , which may have DSP capabilities like DSPnano RTOS
    DSPnano RTOS

    DSPnano is an embedded real-time operating system which is 100% compatible with POSIX and offers a tiny tiny embedded Linux compatible solution. It was first created in 1996 and was one of the first pthread based real-time kernels....
    .


Software tools can come from several sources:
  • Software companies that specialize in the embedded market
  • Ported from the GNU
    GNU

    GNU is a computer operating system composed entirely of free software. Its name is a recursive acronym for GNU's Not Unix; it was chosen because its design is Unix-like, but differs from Unix by being free software and containing no Unix code....
     software development tools
  • Sometimes, development tools for a personal computer can be used if the embedded processor is a close relative to a common PC processor


As the complexity of embedded systems grows, higher level tools and operating systems are migrating into machinery where it makes sense. For example, cellphones, personal digital assistant
Personal digital assistant

A personal digital assistant is a handheld computer, also known as a palmtop computer. Newer PDAs also have both color screens and audio capabilities, enabling them to be used as mobile phones, , web browsers, or portable media players....
s and other consumer computers often need significant software that is purchased or provided by a person other than the manufacturer of the electronics. In these systems, an open programming environment such as Linux
Linux

Linux is a generic term referring to Unix-like computer operating systems based on the Linux kernel. Their development is one of the most prominent examples of free and open source software collaboration; typically all the underlying source code can be used, freely modified, and redistributed by anyone under the terms of the GNU GPL license...
, NetBSD
NetBSD

NetBSD is a freely redistributable, open source version of the Unix-derivative Berkeley Software Distribution computer operating system. It was the second open source BSD descendant to be formally released, after 386BSD, and continues to be actively developed....
, OSGi
OSGi

The OSGi Alliance is an open standards organization founded in March 1999. The Alliance and its members have specified a Java -based Service platform that can be remotely managed....
 or Embedded Java
Embedded Java

In discussions of Java Platform, Micro Edition specifications, such as the Connected Device Configuration/Connected Limited Device Configuration device capability sets and the MIDP profile definition, attention needs to be given to Embedded Java, which additionally requires very specialized, optimized Java virtual machines, and the means to update...
 is required so that the third-party software provider can sell to a large market.

Debugging


Embedded Debugging
Debugging

Debugging is a methodical process of finding and reducing the number of computer bugs, or defects, in a computer program or a piece of electronic hardware thus making it behave as expected....
 may be performed at different levels, depending on the facilities available. From simplest to most sophisticated they can be roughly grouped into the following areas:
  • Interactive resident debugging, using the simple shell provided by the embedded operating system (e.g. Forth and Basic)
  • External debugging using logging or serial port output to trace operation using either a monitor in flash or using a debug server like the Remedy Debugger
    Remedy Debugger

    The Remedy debugger was the first embedded system level debugger in the world. It offered many features that users take for granted today in the days when having a source level debugger was a luxury....
     which even works for heterogeneous multicore
    Multicore

    Multicore may refer to:* Multi-core * multicore cable* audio multicore cable...
     systems.
  • An in-circuit debugger (ICD), a hardware device that connects to the microprocessor via a JTAG
    JTAG

    Joint Test Action Group is the common name used for the Institute of Electrical and Electronics Engineers 1149.1 standard entitled Standard Test Access Port and Boundary-Scan Architecture for test access ports used for testing printed circuit boards using boundary scan....
     or NEXUS interface. This allows the operation of the microprocessor to be controlled externally, but is typically restricted to specific debugging capabilities in the processor.
  • An in-circuit emulator
    In-circuit emulator

    An in-circuit emulator is a hardware device used to debugger the software of an embedded system. It is usually in the form of bond-out processor which has many internal signals brought out for the purpose of debugging....
     replaces the microprocessor with a simulated equivalent, providing full control over all aspects of the microprocessor.
  • A complete emulator
    Emulator

    An emulator duplicates the functions of one system using a different system, so that the second system behaves like the first system. This focus on exact reproduction of external behavior is in contrast to some other forms of computer simulation, which can concern an abstract model of the system being simulated....
     provides a simulation of all aspects of the hardware, allowing all of it to be controlled and modified, and allowing debugging on a normal PC.


Unless restricted to external debugging, the programmer can typically load and run software through the tools, view the code running in the processor, and start or stop its operation. The view of the code may be as assembly code or source-code.

Because an embedded system is often composed of a wide variety of elements, the debugging strategy may vary. For instance, debugging a software- (and microprocessor-) centric embedded system is different from debugging an embedded system where most of the processing is performed by peripherals (DSP, FPGA, co-processor). An increasing number of embedded systems today use more than one single processor core. A common problem with multi-core development is the proper synchronization of software execution. In such a case, the embedded system design may wish to check the data traffic on the busses between the processor cores, which requires very low-level debugging, at signal/bus level, with a logic analyzer
Logic analyzer

A logic analyzer is an electronic instrument that displays signals in a digital circuit that are too fast to be observed and presents it to a user so that the user can more easily check correct operation of the digital system....
, for instance.

Reliability


Embedded systems often reside in machines that are expected to run continuously for years without errors, and in some cases recover by themselves if an error occurs. Therefore the software is usually developed and tested more carefully than that for personal computers, and unreliable mechanical moving parts such as disk drives, switches or buttons are avoided.

Specific reliability issues may include:
  1. The system cannot safely be shut down for repair, or it is too inaccessible to repair. Examples include space systems, undersea cables, navigational beacons, bore-hole systems, and automobiles.
  2. The system must be kept running for safety reasons. "Limp modes" are less tolerable. Often backups are selected by an operator. Examples include aircraft navigation, reactor control systems, safety-critical chemical factory controls, train signals, engines on single-engine aircraft.
  3. The system will lose large amounts of money when shut down: Telephone switches, factory controls, bridge and elevator controls, funds transfer and market making, automated sales and service.


A variety of techniques are used, sometimes in combination, to recover from errors -- both software bugs such as memory leaks, and also soft error
Soft error

In electronics and computing, an error is a signal or datum which is wrong. Errors may be caused by a defect, usually understood either to be a mistake in design or construction, or a broken component....
s in the hardware:

  • watchdog timer
    Watchdog timer

    A watchdog timer is a computer hardware timing device that triggers a system Reset if the main computer program, due to some fault condition, such as a hang , neglects to regularly service the watchdog ....
     that resets the computer unless the software periodically notifies the watchdog
  • subsystems with redundant spares that can be switched over to
  • software "limp modes" that provide partial function
  • Designing with a Trusted Computing Base
    Trusted computing base

    The trusted computing base of a computer system is the set of all Computer hardware, firmware, and/or Computer software components that are critical to its computer security, in the sense that Software bug occurring inside the TCB might jeopardize the security properties of the entire system....
     (TCB) architecture ensures a highly secure & reliable system environment
  • An Embedded Hypervisor
    Embedded Hypervisor

    Software virtualization has been a major topic in the enterprise space for quite some time, but has become an important technology for embedded systems only in the last few years....
     is able to provide secure encapsulation for any subsystem component, so that a compromised software component cannot interfere with other subsystems, or privileged-level system software. This encapsulation keeps faults from propagating from one subsystem to another, improving reliability. This may also allow a subsystem to be automatically shut down and restarted on fault detection.
  • Immunity Aware Programming
    Immunity Aware Programming

    When writing firmware for an embedded system, immunity aware programming is a set of programming techniques used in an attempt to tolerate transient errors in the program counter or other that would otherwise lead to failure....


High vs Low Volume

For high volume systems such as portable music players
Digital audio player

A digital audio player, more commonly referred to as an MP3 player, is a consumer electronics device that stores, organizes and plays audio file formats....
 or mobile phone
Mobile phone

A mobile phone is a long-range, electronic device used for mobile voice or data communication over a network of specialized base stations known as cell sites....
s, minimizing cost is usually the primary design consideration. Engineers typically select hardware that is just “good enough” to implement the necessary functions.

For low-volume or prototype embedded systems, general purpose computers may be adapted by limiting the programs or by replacing the operating system with a real-time operating system
Real-time operating system

A Real-Time Operating System is a Computer multitasking operating system intended for real-time computing applications. Such applications include embedded systems , industrial robots, spacecraft, industrial control , and scientific research equipment....
.

Embedded software architectures


There are several different types of software architecture in common use.

Simple control loop


In this design, the software simply has a loop. The loop calls subroutines, each of which manages a part of the hardware or software.

Interrupt controlled system


Some embedded systems are predominantly interrupt controlled. This means that tasks performed by the system are triggered by different kinds of events. An interrupt could be generated for example by a timer in a predefined frequency, or by a serial port controller receiving a byte.

These kinds of systems are used if event handlers need low latency and the event handlers are short and simple.

Usually these kinds of systems run a simple task in a main loop also, but this task is not very sensitive to unexpected delays.

Sometimes the interrupt handler will add longer tasks to a queue structure. Later, after the interrupt handler has finished, these tasks are executed by the main loop. This method brings the system close to a multitasking kernel with discrete processes.

Cooperative multitasking

A nonpreemptive multitasking
Nonpreemptive multitasking

Nonpreemptive multitasking is a style of Computer multitasking in which the operating system never initiates a Context switch from a running Process to another process....
 system is very similar to the simple control loop scheme, except that the loop is hidden in an API
Application programming interface

An application programming interface is a set of subroutine, data structures, class and/or Protocol provided by library and/or operating system Service s in order to support the building of applications....
. The programmer defines a series of tasks, and each task gets its own environment to "run" in. Then, when a task is idle, it calls an idle routine (usually called "pause", "wait", "yield", "nop" (Stands for no operation), etc.).

The advantages and disadvantages are very similar to the control loop, except that adding new software is easier, by simply writing a new task, or adding to the queue-interpreter.

Preemptive multitasking or multi-threading

In this type of system, a low-level piece of code switches between tasks or threads based on a timer (connected to an interrupt). This is the level at which the system is generally considered to have an "operating system" kernel. Depending on how much functionality is required, it introduces more or less of the complexities of managing multiple tasks running conceptually in parallel.

As any code can potentially damage the data of another task (except in larger systems using an MMU) programs must be carefully designed and tested, and access to shared data must be controlled by some synchronization strategy, such as message queue
Message queue

In computer science, a message queue is a software engineering software componentry used for interprocess communication or inter-thread communication within the same process....
s, semaphores
Semaphore (programming)

In computer science, a semaphore is a protected variable or abstract data type which constitutes the classic method for restricting access to shared resources such as shared memory in a multiprogramming environment....
 or a non-blocking synchronization
Non-blocking synchronization

In computer science, non-blocking synchronization ensures that thread s competing for a shared resource do not have their execution indefinitely postponed by mutual exclusion....
 scheme.

Because of these complexities, it is common for organizations to buy a real-time operating system
Real-time operating system

A Real-Time Operating System is a Computer multitasking operating system intended for real-time computing applications. Such applications include embedded systems , industrial robots, spacecraft, industrial control , and scientific research equipment....
, allowing the application programmers to concentrate on device functionality rather than operating system services, at least for large systems; smaller systems often cannot afford the overhead associated with a generic real time system, due to limitations regarding memory size, performance, and/or battery life.

Microkernels and exokernels

A microkernel
Microkernel

In computer science, a microkernel is a computer kernel which provides the mechanisms needed to implement an operating system, such as low-level address space management, thread management, and inter-process communication....
 is a logical step up from a real-time OS. The usual arrangement is that the operating system kernel allocates memory and switches the CPU to different threads of execution. User mode processes implement major functions such as file systems, network interfaces, etc.

In general, microkernels succeed when the task switching and intertask communication is fast, and fail when they are slow.

Exokernel
Exokernel

Exokernel is an operating system kernel developed by the MIT Parallel and Distributed Operating Systems group, and also a class of similar operating systems....
s communicate efficiently by normal subroutine calls. The hardware, and all the software in the system are available to, and extensible by application programmers.

Monolithic kernels

In this case, a relatively large kernel with sophisticated capabilities is adapted to suit an embedded environment. This gives programmers an environment similar to a desktop operating system like Linux
Linux

Linux is a generic term referring to Unix-like computer operating systems based on the Linux kernel. Their development is one of the most prominent examples of free and open source software collaboration; typically all the underlying source code can be used, freely modified, and redistributed by anyone under the terms of the GNU GPL license...
 or Microsoft Windows
Microsoft Windows

Microsoft Windows is a series of software operating systems and graphical user interfaces produced by Microsoft. Microsoft first introduced an operating environment named Windows in November 1985 as an add-on to MS-DOS in response to the growing interest in graphical user interfaces ....
, and is therefore very productive for development; on the downside, it requires considerably more hardware resources, is often more expensive, and because of the complexity of these kernels can be less predictable and reliable.

Common examples of embedded monolithic kernels are Embedded Linux
Embedded Linux

Embedded Linux is the use of a Linux kernel operating system in embedded computer systems such as mobile phones, personal digital assistants, media centers, set-top boxes, and other consumer electronics devices, computer network equipment, machine control, industrial automation, navigation equipment and medical instruments....
 and Windows CE
Windows CE

Windows CE is Microsoft's operating system for minimalistic computers and embedded systems. Windows CE is a distinctly different operating system and Kernel , rather than a trimmed-down version of desktop Windows....
.

Despite the increased cost in hardware, this type of embedded system is increasing in popularity, especially on the more powerful embedded devices such as Wireless Routers and GPS Navigation Systems
Automotive navigation system

An automotive navigation system is a Global Navigation Satellite System designed for use in automobiles. It typically uses a GPS navigation device to acquire position data to locate the user on a road in the unit's map database....
. Here are some of the reasons:

  • Ports to common embedded chip sets are available.
  • They permit re-use of publicly available code for Device Drivers
    Device driver

    In computing, a device driver or software driver is a computer program allowing higher-level computer programs to interact with a hardware device....
    , Web Servers, Firewalls
    Firewall (networking)

    A firewall is an integrated collection of security measures designed to prevent unauthorized electronic access to a networked computer system....
    , and other code.
  • Development systems can start out with broad feature-sets, and then the distribution can be configured to exclude unneeded functionality, and save the expense of the memory that it would consume.
  • Many engineers believe that running application code in user mode is more reliable, easier to debug and that therefore the development process is easier and the code more portable.
  • Many embedded systems lack the tight real time requirements of a control system. A system such as Embedded Linux has fast enough response for many applications.
  • Features requiring faster response than can be guaranteed can often be placed in hardware
    Programmable logic device

    A programmable logic device or PLD is an electronics component used to build Reconfigurable Computing digital circuits. Unlike a logic gate, which has a fixed function, a PLD has an undefined function at the time of manufacture....
    .
  • Many RTOS systems have a per-unit cost. When used on a product that is or will become a commodity, that cost is significant.


Exotic custom operating systems

A small fraction of embedded systems require safe, timely, reliable or efficient behavior unobtainable with the one of the above architectures. In this case an organization builds a system to suit. In some cases, the system may be partitioned into a "mechanism controller" using special techniques, and a "display controller" with a conventional operating system. A communication system passes data between the two.

Additional software components

In addition to the core operating system, many embedded systems have additional upper-layer software components. These components consists of networking protocol stacks like CAN
CAN

CAN may refer to:...
, TCP/IP, FTP, HTTP, and HTTPS
Https

Hypertext Transfer Protocol Secure is a combination of the Hypertext Transfer Protocol and a secure communication protocol.HTTP operates at the highest layer of the TCP/IP model, the Application layer; but the security protocol operates at lower sublayer, encrypting an HTTP message prior to transmission and decrypting a message upon arriva...
, and also included storage capabilities like FAT
Fat

Fats consist of a wide group of compounds that are generally soluble in organic solvents and largely insoluble in water. Chemistry, fats are generally ester of glycerol and fatty acids....
 and Flash memory management systems. If the embedded devices has audio and video capabilities, then the appropriate drivers and codecs will be present in the system. In the case of the monolithic kernels, many of these software layers are included. In the RTOS category, the availability of the additional software components depends upon the commercial offering.

See also


Further reading

  • John Catsoulis, , O'Reilly, May 2005, ISBN 0-596-00755-8.
  • Anoop MS, , Tata Elxsi, India, May 2008.


External links