Previous page Next page Bottom Top One level up Home
Home > Directory > Computers > Consultants [2] > Embedded Systems

Embedded Systems

Webpages concerning "Embedded Systems"

J-Tech specializes in high-performance embedded control and signal processing hardware design. Experts in Digital, Analog and RF product development.
http://www.jtecheng.com
Keywords:
electronics consultant, microchip consultant, embedded design consultant, engineering consultant, electronics consultant vancouver, schematic consultant, electrical consultant, electrical engineer vancouver, cirrus logic designer, cirrus ARM consultant, pic consultant, pic designer, microcontroller designer, microcontroller programming, embedded c programmer, telephony consultant, ...

http://www.jtecheng.com

www.vdCruijsen.nl: Martijn and Irna van der Cruijsen, personal homepage. Lots of info about climbing, hiking, walking, cycling.
http://www.EmbedTime.com/
Keywords:
van, der, Cruijsen, Wanroij, Noord Brabant, NKBV, NTFU, TWC Oost Brabant, Climbing, Cycling, Walking, www.vdcruijsen.tk

http://www.EmbedTime.com/

»¶Ó­¹âÁÙÀϹſª·¢Íø--µ¥Æ¬»ú¡¢Ç¶Èëʽϵͳ¡¢µç×ÓÉè¼Æ×¨ÒµÍøÕ¾
http://www.laogu.com
Keywords:
ÀϹſª·¢Íø, ÀϹÅ, laogu, ÀϹÅÓ²¼þÎÝ

http://www.laogu.com

BrightSoft : aviation, real-time, data-acquisition, embedded software consultancy
http://www.brightsoft.be/index.html
Keywords:
aviation, avionics, aerospace, air, force, airforce, eurocontrol, flight, plan, management, flight plan management, automobile, automotive, MIL-STD-1553, 1553, DO-178, DO-178B, 178, ARINC, ARINC429, ARINC-429, ARINC739, ARINC-739, 429, 739, it, consultant, consultancy, consulting, design, Ada, C, C++, Fortran, Visual Basic, assembler, oop, object oriented programming, object, oriented, ...

http://www.brightsoft.be/index.html

Camelback Computer Architecture, LLC offers computer architecture consulting services to assess technology, develop products, and protect intellectual property. Donald Alpert is the president and principal consultant.
http://camelback-comparch.com/

http://camelback-comparch.com/

Looking for a Software Specialist? We provide expert services in IT Consulting, WDM Drivers, VLSI Testing &Embedded Software, Payment Systems and Custom Software development..
http://www.centrillium-it.com/
Keywords:
Centrillium, Centrillium IT Consulting, Device Driver Consultant, Software Consultant, Payment Systems, Java SmartCard, EMV Consultant, VLSI Consultant, ASIC Testing, FPGA, USB Developer, USB Consultant, Quality Assurance, Configuration Management, Project Leading, Softwar Design, Software Development, Software Project Planning, Process Improvment, Analysis, Software Debugging, ...

http://www.centrillium-it.com/

CTC is an award-winning product development and technical consultancy. Whether you're looking for one-off problem-solving, bespoke software or volume production of a new product, we can design, develop and support all, or any part, of the hardware, software, processes or systems you need to drive your business forward.
http://www.camtechconsultants.com/
Keywords:
computing, technology, consultancy, consultants, cambridge, arm, linux, embedded, software, development, research, and, development, software, design, OptionExist, Cambridge, Technology, Consultants, it, support, hardware, development, electronic, hardware, design, digital, electronics, prototyping, prototypes, communications, application, design, feasibility, study, technological, innovation, ...

http://www.camtechconsultants.com/

asic and SOC design consultancy, asic and SOC design contracting, Intellectual Property cores, IP,RC5,NEC,Remote controller, 10Gbps CRC32,embedded design,MIPS, ARM, AMBA,fpga design,software, turnkey asic design.
http://www.asicdesk.com
Keywords:
"ASIC, SOC, EMBEDDED, MIPS, ARM, AMBA, FPGA, SOFTWARE, CONSULTANCY, DESIGN"

http://www.asicdesk.com

eInfochips electronic design solution & services company
http://www.einfochips.com/
Keywords:
eInfochips, ASIC, design IP, Verification IP, ASIC Verification, Verification services, HVL, Physical Design, front end design, Physical Design, Product design, DSP, ARM services, Firmware, OEM solutions, Reference Borad design, Software services, QA, Offshore Services, Functional verifcation, storage area network, Linux, Porting and Migration

http://www.einfochips.com/

Engineering design services for the embedded control, DSP and office automation markets.
http://www.fsisys.com/
Keywords:
www.fsisystems.com, FSI Systems, Farmington New York, Victor New York, Rochester, New York, ZigBee, electronic product design, hardware design, software design, embedded control, dsp, dsp applications, high, speed, protocol, interfaces, document on demand, electronic engineering, office automation, feeding equipment, finishing equipment, research and development, electronic design, ...

http://www.fsisys.com/

HarteTec provides hardware and software engineering services, including device driver development, hardware design, and system architecture.
http://www.hartetec.com/
Keywords:
consulting, consultant, software, drivers, firmware, driver, development, hardware, embedded, design, systems, programming, engineering, services, IMSAI, Series, Two, 8080, system, architecture, definition, Harte, Technologies, Hartetec, desing

http://www.hartetec.com/

Legacy migration and translation tools, Assembly, Cobol, Pl/I, Pascal, PL/M, MASM to C, C++, C#, Java, XML. Free samples.
http://mpsinc.com
Keywords:
AcuCobol, CA Realia COBOL, CA Realia Cobol, CA realia cobol, CA-Realia COBOL, CA-Realia Cobol, CA-realia cobol, COB2C Converter, COB2C Translator, COBOL 68, COBOL 74, COBOL 85, COBOL C Sharp, COBOL C sharp, COBOL C#, COBOL C++, COBOL JAVA, COBOL conversion, COBOL convert JAVA, COBOL converter, COBOL migration, COBOL migration tools, COBOL, migration, tools, &, services, COBOL re-engineering, ...

http://mpsinc.com

Nuvation is a leading Electronics Design Services firm based in the Silicon Valley, providing ASIC, FPGA, printed circuit board (PCB), firmware, and embedded software design services for technology companies.
http://www.nuvation.com/
Keywords:
Electronic Design Services, EDS, design, engineering, consultancy, consulting, outsource, outsourcing, contract engineering, electrical engineering, electronic design, Venture Engineering, Embedded Systems, invent, create, innovation, product design firm, hardware, firmware, embedded software, hardware engineering, firmware coding, software engineering, system software development, ...

http://www.nuvation.com/

PC104 single board computer boards from Arcom - PXA255, PXA270, IXP425 based SBCs and low power fanless industrial PC with support for Windows CE, XP Embedded, embedded Linux and VxWorks
http://www.arcomcontrols.com
Keywords:
pc104, pxa255, pxa270, xscale, ixp425, industrial pc, linux, windows ce, xp embedded, embedded pc, pc/104, rfid, vxworks, single board computer

http://www.arcomcontrols.com

Experts in the development of electronic controllers, control algorithms, systems simulation, rapid control prototyping and automatic code generation (ACG) for the automotive and aerospace industries.
http://www.potenza.co.uk/technology/home.htm
Keywords:
innovators, technology, consultancy, potenza, training, simulation, co-simulation, autocoding, automatic code generation, acg, Matlab, Simulink, dspace, targetlink, rapid controller prototyping, rcp, automotive, aerospace, algorithms, ascet, ev, fuel cell, fuel-cell, electric, electronic, controller, research, research and development, uk, england, Midlands, automotive consultancy, vehicle, ...

http://www.potenza.co.uk/technology/home.htm

RTOS, Software Component Maintenance Monitor SCM16X, from Fieldnet to Internet, Real Time Operating System for Infineon 16X Microcontrollers, Real Time Kernel, Test Management System - TestLab, 166 RTOS, 164 RTOS, 167 RTOS, Infineon, Embedded System, CAN, CANLab, PLC programming, Object Navigator, Trending, Metawindow emulator, CoDeSys, Web applications, Java, Messaging (SMS, E-mail, WAP)...
http://www.compass.com.pl
Keywords:
RTOS, Software, Component, Maintenance, Monitor, SCM16X, fieldnet, internet, test management, kernel, real time kernel, can, infineon, 164, 167, 166, profibus, modbus, rtos, embedded, embedded system, windows ce, supro, object navigator, trending, metawindow, metawindow emulator, codesys, trend, trending, java, mmi, messaging, project management, device drivers, tcp/ip, tcp/ip, over, can, bus, ...

http://www.compass.com.pl

Experienced Software Developers with references available. We have an automated solution to convert Centura (Gupta, Team Developer, Gupta Team Developer, Centura Team Developer, CTD) to Java (J2EE) and DOTNET (VB.NET and C#). We have experience with many different software languages and databases and claim to be able to build any solution in any language and platform at affordable prices.
http://www.sibants.com/
Keywords:
Gupta, Centura, Team Developer, SQLWindows, Java, DOTNET, Gupta to Java, Centura to Java, Gupta to DOTNET, Centura to DOTNET, Software Development, software tools, development, CTD to VB.NET, database, SQL, client/server, database migration, CTD to Java, Software Migration, Migration, migrate, convert, converions, J2EE

http://www.sibants.com/

Logic 1 Design and Services offers Embedded Controller Product Design, Domain Hosting, and Web Page Design. Complete Embedded Controller Product Developement using ORCAD design tools including PCB layout and schematic capture. Domain Hosting includes 100MB of disk space, 10 email accounts and a whole lot more.
http://logic1design.com
Keywords:
Embedded, Controller, Product, Design, Domain Hosting, Web Page Design, E-Commerce, Web, Site, Development, Web Hosting, Product Design, Embedded Products, Phoenix, Arizona, Electronic Product Design, Hardware, Software, PCB Layout, ORCAD Design, Schematic Capture, Circuit Design

http://logic1design.com

Software to Spec, develops solutions for real-time embedded software systems, products, services. We offer an investment in quality software through Quality Software Process and reuse
http://www.softwaretospec.com
Keywords:
Software to Spec, solutions, embedded, development, applications, systems, simulation, simulator, consultants, board support packages, real-time, satellite, reuse, device drivers, digital signal processing, DSP, MIPS, ARM, PPC, P603, TMS320, design, test, WAP, wireless, network, VxWorks, Corba, Nucleus, ENEA, MFC, proprietary, Ada, C++, Object Oriented, smart sensors, home automation

http://www.softwaretospec.com

http://www.t-systems.com/
Keywords:
Business flexibility

http://www.t-systems.com/

A leader in professional internet and intranet design, custom programming, e-commerce and e-business solutions.
http://www.chitech1.com
Keywords:
americaneagle.com, americaneagle, idev, internet, intranet, internet hosting, hosting, e-commerce, e-business, web applications, website, web programming, web site programming, internet maintenance, web site design, web developers, web site developers, website developers, web developers, maintenance, database, database design, law firms, accounting, accounting firms, marketing, peachtree, dcd, ...

http://www.chitech1.com

Located in Northwest Indiana, ACT specializes in Computer and Process Control Consulting with Experience, Knowledge,and Abilities in the Steel and Manufacturing Industries. Providing support services for the Past 12 Years.
http://www.act2001.com/
Keywords:
computer consulting, experienced professionals, IS consultants, HR, human resources, jobs, Indiana, IS, PeopleSoft, Steel, Northwest Indiana, consulting, software, Applied Computer Techniques, ACT, hardware, computer, software development, process control, implementation, system maintenance, systems, information, support, problem solving, mainframe, client server, Windows, functional, technical, ...

http://www.act2001.com/

Applied Research Contsultants is the leading developer of embedded controls and systems. ARC specializes in engineering design, development, assembly, manufacturing and servicing of electronic hardware and software.
http://www.arcorp.net/
Keywords:
embedded controls, data acquisition devices, deterministic software, distributed control systems, power supplies, high voltage, power supply, real-time software, control software, supervisory

http://www.arcorp.net/

Electronic product design tailored for small companies on a budget and on a schedule.
http://www.aqdi.com
Keywords:
embedded systems design, electronic design, real time software, hardware design, software design, c/c++, visual c++, communications systems design, electromechanical, control systems, microchip pic, printed circuit layout, rf, wireless, z80, z180, 64180, 68hc11, ARM, eZ80, MSP430, 68hc05, 8051, 8052, low power, remote control, infrared, protocols, rs-232, rs-485, product design

http://www.aqdi.com

Coactive Networks enables high-level communications among control devices such as temperature sensors, air conditioners, card readers, and utility meters.
http://www.coactive.com/
Keywords:
telemetry, e-services, utiltity, utilities, telecommunications, networks, networking, gateway, residential, residential gateway, home, home gateway, home networking, LonWorks, LonMark, coactive

http://www.coactive.com/

CRESCO Technologies provides hardware and software design services to the telecommunications industry.
http://www.cresco-tech.com

http://www.cresco-tech.com

graphical DSP design software and hardware products for high performance DSP and real-time parallel processing applications; TI C4x, C6x, PSOS, Virtuoso, Diamond, Analog Devices 2106x Sharc compatible.
http://www.jovian.com/
Keywords:
DSP Development Tools, DSP Development Software, DSP Software, DSP, Graphical, Development, Software, DSP, Block, Diagram, Development, Software, DSP Multi-processing Development, DSP Parallel Processing, DSP Consulting, Sharc Development Tools, Sharc Development Software, Sharc Software, DSP Software Development, DSP, Digital Signal Processing, graphical, software, tools, block diagram, ...

http://www.jovian.com/

Embedded Linux systems and realtime linux systems, using 1u chassis to small pc104 embedded linux platforms, is Locus Logic's specialty.
http://www.locuslogic.com/
Keywords:
embedded Linux, 1u controller, locuslogic, PLM, RMX, PL/M, PL/M linux, PL/M controller, PL/M conversion, PL/M to C, Multibus, IBM multibus, linux, locuslogic cm300, linux controller, 1u chassis, industrial computer, embedded industrial controller, embedded systems, embedded computer, embedded OS, rtos, realtime, embedded appliance

http://www.locuslogic.com/

EmbVUE: an integrated software engineering company specializing in embedded systems.
http://www.embvue.com/
Keywords:
embedded systems consulting, embedded system development, embedded system software, bsp, board support package, device driver, RTOS, linux, palm, macromedia flash, dwb, altia, rapid, matlab, simulink, statemate, Ada, C, C++, Java, user interfaces, graphics, aerospace, defence, DO-178B, managed software, vxworks, integrity, QNX, Neutrino, 1553, OpenGL, HMI, MMI, software, development, 3D, 2D, ...

http://www.embvue.com/

Design consultancy for products using embedded microcontrollers or PCs. Located in South Wales, UK.
http://www.computekconsultancy.co.uk
Keywords:
datalogging, datalogger, software, embedded, microcontrollers, microcomputers, micros, firmware, development, Windows, C++, C, computek, consultancy, real-time, ControlCAD, PCB, layout

http://www.computekconsultancy.co.uk

Unimal tool for multiple project configurations. C-SLang for testing and diagnosing embedded systems. Related consulting. Customizing.
http://www.macroexpressions.com/
Keywords:
romable development tools, Unimal, unified macro language, embedded project configuration, ROMable const data, static, compile-time initialization, macro processor, macro extensions, embedded, software, configuration, tool, project maintainability, embedded project testability, device testability, C-SLang, field return testing, diagnostics, analysis, embedded systems diagnostics, testing, ...

http://www.macroexpressions.com/

Contract design manufacturing, Original design manufacturing, Component Obsolescence, FPGA development, compact PCI & PMC products
http://www.parsec.co.za/
Keywords:
parsec, manufacturing, component obsolescence, FPGA development, compact PCI PMC

http://www.parsec.co.za/

http://www.qsolv-inc.com/
Keywords:
QSolv, Outsourcing, managed, projects, IT, information, technology, staffing, systems, integration, B2B, B2C, Business, business, business-to-consumer, California, cell, commerce, computer, consultant, consultants, Consultants, Consulting, consulting, eBusiness, ebusiness, e-business, eCommerce, ecommerce, e-commerce, electronic, engineering, eservices, e-services, Implementation, information, ...

http://www.qsolv-inc.com/

Spirit Solutions, Inc., located in Indianapolis, IN, is a firm dedicated to the design of embedded systems.
http://www.spiritsolutionsinc.com/
Keywords:
embedded systems, design, embedded systems design, software engineering, hardware engineering, engineer, contract, contracting, Raymond Strickland, embedded, Spirit Solutions

http://www.spiritsolutionsinc.com/

Offering electronic engineering, software engineering, and custom OEM electronic product development services. Applications experience includes factory automation, industrial, commercial, building automation, medical, scientific, and space research applications.
http://www.jged.com
Keywords:
J., Gordon, Electronic, Design, electronic engineering, software engineering, system engineering, OEM product development, project management, test services, prototyping, production support, embedded control systems, real time applications, networks, distributed controls, Internet enabled products, windows front ends, industrial process control, machine automation, energy management, HVAC, ...

http://www.jged.com

Custom software for controlling and simulating hardware, custom computer graphics rendering engines, and multimedia applications.
http://www.electric-algorithms.com/
Keywords:
software, consulting, embedded system, programmable, simulator, HMI, graphics, rendering, multimedia, California

http://www.electric-algorithms.com/

Abtec is een ingenieursbureau en levert advies, diensten en oplossingen in Linux software. Abtec heeft veel ervaring en expertise op het gebeid van regeltechniek en embedded, realtime besturingen
http://www.abtec.nl/
Keywords:
linux, software, embedded, realtime, mechatronica, robot, regeltechniek, simulatie, control, aansturen, besturen, besturing, aansturing, systeem, integratie, automatisering, industrial, automation, elektronica

http://www.abtec.nl/

Outsourcing real time software design for electronic products - development in c and assembler for PIC, 8051, H8 microprocessors
http://www.andybrownsoftware.com/
Keywords:
embedded software, embedded software development, embedded software engineer, software, development, for, embedded, system, embedded software design, embedded system software, program software embedded, software outsourcing, outsourcing software development, software development outsourcing, outsourcing software, embedded c, 8051 software, pic programmer software, pic software, ...

http://www.andybrownsoftware.com/

http://www.phystream.com
Keywords:
electronic, consultancy, FPGA, ASIC, PCB, board, design, service, hardware, verilog, vhdl, orcad

http://www.phystream.com

http://www.trycom.com.tw/

http://www.trycom.com.tw/

http://www.hardwaredesigner.com/

http://www.hardwaredesigner.com/

http://www.indscape.com/

http://www.indscape.com/

http://www.xogenus.com
Keywords:
xogenus, contractor, telecom, datacom, design, MPC860, MPC850, engineer, hardware, layout, geophysics, electronics, ottawa, design services, FCRAM, ethernet switch, backplane, semtech, MPC8260, ADSL, gigabit ethernet, SONET, OC-3, OC-12, OC-48, OC-192, high speed, digital, termination, transimission line, controlled impedance, LVPECL, xilinx, altera, FPGA, PLD, vxworks, software, RTOS, ottawa, ...

http://www.xogenus.com

http://www.specialcomp.com/

http://www.specialcomp.com/

Help building the largest human-edited directory of the web
Suggest URL - Open Directory Project - Become an editor
directopedia.org uses links and structure from dmoz Open Directory Project.
The contents has been generating using technology developed by scientec.

Wikipedia-Article "Embedded Systems"

An embedded system is a special-purpose computer system, which is completely encapsulated by the device it controls. An embedded system has specific requirements and performs pre-defined tasks, unlike a general-purpose personal computer. An embedded system is a programmed hardware device. A programmable hardware chip is the 'raw material' and it is programmed with particular applications. This is to be understood in comparison to older systems with full functional hardware or systems with general purpose hardware and externally loaded software. Embedded systems are a combination of hardware and software which facilitates mass production and variety of application.

Contents

History

Apollo Guidance Computer.source: The Computer History Museum (fair use)
Enlarge
Apollo Guidance Computer.
source: The Computer History Museum (fair use)

The first recognizably modern embedded system was the Apollo Guidance Computer, developed by Charles Stark Draper at the MIT Instrumentation Laboratory. Each flight to the moon had two. They ran the inertial guidance systems of both the command module and LEM.

At the project's inception, the Apollo guidance computer was considered the riskiest item in the Apollo project. The use of the then new monolithic integrated circuits, to reduce the size and weight, increased this risk.

Autonetics D-17 guidance computer from a Minuteman I missile.
Enlarge
Autonetics D-17 guidance computer from a Minuteman I missile.

The first mass-produced embedded system was the guidance computer for the Minuteman missile in 1961. It was the Autonetics D-17 guidance computer, built using discrete transistor logic and a hard disk for main memory. When the Minuteman II went into production in 1966, the D-17 was replaced with a new computer that used integrated circuits, and was the first volume user of them. Without this program, integrated circuits might never have reached a usable price-point.

The crucial design features of the Minuteman computer were that its guidance algorithm could be reprogrammed later in the program, to make the missile more accurate, and the computer could also test the missile, saving cable and connector weight.

Examples of embedded systems

Characteristics

Embedded computer systems constitute the widest possible use of computer systems; it includes all computers other than those specifically intended as general-purpose computers. Examples of embedded systems range from a portable music player, to real-time control of systems like the space shuttle. They are characterized by providing a function, or functions, that is not itself a computer.

The majority of commercial embedded systems are designed to perform selected functions at a low cost. Many, but not all embedded systems have real-time system constraints that must be met. These systems may need to be very fast for some functions, but most of its other functions will probably not need speed. These systems meet their real-time constraints with a combination of special purpose hardware and software tailored to the system requirements.

It is difficult to characterize embedded systems as to speed, or cost requirements, but for high volume systems, cost will often dominate much of the system design. Fortunately, most systems have limited real-time requirements that can usually be met with a combination of custom hardware and a limited amount of high performance software. Take for instance a digital set-top box for satellite television. Even though such a system has to process tens of megabits of continuous-data per second, most of the heavy lifting is done by custom hardware that parses, directs, and decodes the multi-channel digital stream down into a single video output. The embedded CPU is left to determine data paths, handle interrupts at frame boundaries, generate and display graphics, etc. to enable the set-top look and feel. Therefore, often many parts of an embedded system will require low performance compared to primary mission of the system. This allows architecture of an embedded system to be intentionally simplified to lower costs compared to a general-purpose computer accomplishing the same task, by using a CPU that is “good enough” for these secondary functions.

For embedded systems that are not high volume, personal computers can often be conscripted into service either by limiting the programs or by replacing the operating system with a real-time operating system. In this case special purpose hardware may be replaced by one or more high performance CPUs. Still, some embedded system may require both high performance CPUs, special hardware, and large memories to accomplish a required task.

In the domain of high volume embedded system, e.g. a portable music player, reducing cost becomes a major concern. These systems will often have just a few chips, a highly integrated CPU, a custom chip that controls all other functions and a single memory chip. In these designs each component is selected and designed to minimize system cost..

The software written for many embedded systems, especially those without a disk drive is sometimes called firmware, the name for software that is embedded in hardware devices, e.g. in one or more ROM/Flash memory IC chips.

Programs on an embedded system often run with real-time constraints with limited hardware resources: often there is no disk drive, operating system, keyboard or screen. The software may not have anything remotely like a file system, or if one is present, a flash drive may replace rotating media. If a user interface is present, it may be a small keypad and liquid crystal display.

Embedded systems reside in machines that are expected to run continuously for years without errors. Therefore the software and Firmware is usually developed and tested more carefully than Software for Personal computers. Many embedded systems avoid mechanical moving parts such as Disk drives, switches or buttons because these are unreliable compared to solid-state parts such as Flash memory

In addition, the embedded system may be outside the reach of humans (down an oil well borehole, launched into outer space, etc.), so the embedded system must be able to restart itself even if catastrophic data corruption has taken place. This is usually accomplished with a standard electronic part called a watchdog timer that resets the computer unless the software periodically resets the timer.

Design of embedded systems

The electronics usually uses either a microprocessor or a microcontroller. Some large or old systems use general-purpose mainframe computers or minicomputers.

User interfaces

User interfaces for embedded systems vary wildly, and thus deserve some special comment.

Interface designers at PARC, Apple Computer, Boeing and HP minimize the number of types of user actions. For example, their systems use two buttons (the absolute minimum) to control a menu system (just to be clear, one button should be "next menu entry" the other button should be "select this menu entry").

A touch-screen or screen-edge buttons also minimize the types of user actions.


Another basic trick is to minimize and simplify the type of output. Designs sometimes use a status light for each interface plug, or failure condition, to tell what failed. A cheap variation is to have two light bars with a printed matrix of errors that they select- the user can glue on the labels for the language that he speaks.

For example, Boeing's standard test interface is a button and some lights. When you press the button, all the lights turn on. When you release the button, the lights with failures stay on. The labels are in Basic English.

Another example is probably right next to you. Look at a computer printer. Very often the lights are labelled with stick-on labels that can be printed in any language. In some markets, devices are delivered with several sets of labels, so customers can pick the most comfortable language.

Designers use colors. Red means the users can get hurt (think of blood). Yellow means something might be wrong. Green means the status is OK/good. This is intentionally like a stop-light, because most people understand those.

Most designs arrange for a display to change immediately after a user action. If the machine is going to do anything, it usually starts within 7 seconds, or gives progress reports.

If a design needs a screen, many designers use plain text. It's preferred because users have been reading signs for years. A GUI is pretty and can do anything, but typically adds a year from artist, approval and translator delays and one or two programmers to a project's cost, without adding any value. Often, an overly-clever GUI actually confuses users, because it can use unfamiliar symbols.

If a design needs to point to parts of the machine (as in copiers), these are often labelled with numbers on the actual machine, that are visible with the doors closed.

A network interface is just a remote screen. It behaves much like any other user interface.

One of the most successful general-purpose screen-based interfaces is the two menu buttons and a line of text in the user's native language. It's used in pagers, medium-priced printers, network switches, and other medium-priced situations that require complex behavior from users.

When there's text, the designer chooses one or more languages. The default language is usually the one most widely understood by the targetted group of users.

Most designers try to use the native character sets, no matter how painful. People with peculiar character sets feel coddled and loved when their language shows up on machinery they use.

Text is usually translated by professional translators, even if native speakers are on staff. Marketing staff have to be able to tell foreign distributors that the translations are professional.

A foreign organization often tries to give the highest-volume distributor the duty to review and correct any translations in their native language. This stops critiques by other native speakers, who tend to believe that no foreign organization will ever know their language as well as they.

Another common trick is that modes are made absolutely clear on the user's display. If an interface has modes, they are almost always reversible in an obvious way.

Most authorities consider a usability test more important than any number of opinions. Designers recommend testing the user interface for usability at the earliest possible instant. A commonly-used quick, dirty test is to ask an executive secretary to use cardboard models drawn with magic markers, and manipulated by an engineer. The videotaped result is likely to be both humorous and very educational. In the tapes, every time the engineer talks, the interface has failed because it would cause a service call.

In well-run organizations, one person approves the user interface. Often this is a customer, the major distributor or someone directly responsible for selling the system. Committees do not quickly make decisions, and some people never do. This causes avoidable, expensive delays.

Platform

There are many different CPU architectures used in embedded designs such as ARM, MIPS, Coldfire/68k, PowerPC, X86, PIC, 8051, Atmel AVR, H8, SH, V850, FR-V, M32R etc.

This in contrast to the desktop computer market, which as of this writing (2003) is limited to just a few competing architectures, mainly the Intel/AMD x86, and the Apple/Motorola/IBM PowerPC, used in the Apple Macintosh. Side note: with the growing acceptance of Java in this field, there is a tendency to even further eliminate the dependency on specific CPU/hardware (and OS) requirements.

Standard PC/104 is a typical base for small, low-volume embedded and ruggedized system design. These often use DOS, Linux or an embedded real-time operating system such as QNX or Inferno.

A common configuration for very-high-volume embedded systems is the system on a chip, an application-specific integrated circuit, for which the CPU was purchased as intellectual property to add to the IC's design. A related common scheme is to use a field-programmable gate array, and program it with all the logic, including the CPU. Most modern FPGAs are designed for this purpose.

Tools

Like typical computer programmers, embedded system designers use compilers, assemblers, and debuggers to develop embedded system software.

Those software tools can come from several sources:

  • Software companies that specialize in the embedded market
  • Ported from the GNU software development tools. ( see cross-compiler)
  • Sometimes, development tools for a personal computer can be used if the embedded processor is a close relative to a common PC processor.

Embedded system designers also use a few software tools rarely used by typical computer programmers.

  • More common are utility programs to add a checksum or CRC to a program, so it can check its program data before executing it.
  • Less common are utility program to turn data files into code, so one can include any kind of data in a program.
  • Uncommon are Synchronous programming languages, used for extra reliability.

Operating system

An Internet payphone loading Windows XP
Enlarge
An Internet payphone loading Windows XP

These systems often have no operating system, or a specialized embedded operating system (often a real-time operating system), or the programmer is assigned to port one of these to the new system.

Built-In Self-Test

Most embedded systems have some degree or amount of built-in self test. There are several basic types:

  1. Testing the computer: CPU, RAM, and program memory. These often run once at power-up. In safety-critical systems, they are also run periodically, or over time.
  2. Tests of peripherals: These simulate inputs and read-back or measure outputs. A surprising number of communication, analog and control systems can have these tests, often very cheaply.
  3. Tests of power: These usually measure each rail of the power supply, and may check the input (battery or mains) as well. Power supplies are often highly stressed, with low margins.
  4. Communication tests: These verify the receipt of a simple message from connected units. The internet, for example, has the ICMP message "ping."
  5. Cabling tests: These usually run a wire in a serpentine arrangement through representative pins of the cables that have to be attached. Synchronous communications systems, like telephone media, often use "sync" tests for this purpose. Cable tests are cheap, and extremely useful when the unit has plugs.
  6. Rigging tests: Often a system has to be adjusted when it is installed. Rigging tests provide indicators to the person that installs the system.
  7. Consumables tests: These measure what a system uses up, and warn when the quantities are low. The most common example is the gas gauge of a car. The most complex examples may be the automated medical analysis systems that maintain inventories of chemical reagents.
  8. Operational tests: These measure things that a user would care about to operate the system. Notably, these have to run when the system is operating. This includes navigational instruments on aircraft, a car's speedometer, and disk-drive lights.
  9. Safety tests: These run within a 'safety interval', and assure that the system is still reliable. The safety interval is usually a time less than the minimum time that can cause harm.

Reliability regimes

Reliability has different definitions depending on why people want it. Interestingly, there are relatively few types of reliability, and system with similar types employ similar types of embedded system designs and built-in-self tests:

  1. The system is too unsafe, or inaccessible to repair. (Space systems, undersea cables, navigational beacons, bore-hole systems, and oddly, automobiles and mass-produced products) Generally, the embedded system tests subsystems, and switches redundant spares on line, or incorporates "limp modes" that provide partial function. Often mass-produced equipment for consumers (such as cars, PCs or printers) falls in this category because repairs are expensive and repairmen far away, when compared to the initial cost of the unit.
  2. The system cannot be safely shut down. (Aircraft navigation, reactor control systems, some chemical factory controls, engines on single-engine aircraft) Like the above, but "limp modes" are less tolerable. Often the backups are selected by an operator.
  3. The system will lose large amounts of money when shut down. (Telephone switches, factory controls, bridge and elevator controls, automated sales and service) These usually have a few go/no-go tests, with on-line spares or limp-modes using alternative equipment and manual procedures.
  4. The system cannot be operated when unsafe. (Medical equipment, aircraft equipment with hot spares, such as engines) The testing can be quite exotic, but the only action is to shut down the whole unit and indicate a failure.
  5. The system cannot be operated when it will lose large amounts of money. (chemical factory controls, financial systems) Very similar to medical equipment, above.

Debugging

Debugging is usually performed with an in-circuit emulator, or some type of debugger that can interrupt the microcontroller's internal microcode.

The microcode interrupt lets the debugger operate in hardware in which only the CPU works. The CPU-based debugger can be used to test and debug the electronics of the computer from the viewpoint of the CPU. This feature was pioneered on the PDP-11.

Developers should insist on debugging which shows the high-level language, with breakpoints and single-stepping, because these features are widely available. Also, developers should write and use simple logging facilities to debug sequences of real-time events.

PC or mainframe programmers first encountering this sort of programming often become confused about design priorities and acceptable methods. Mentoring, code-reviews and egoless programming are recommended.

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 assistants 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, OSGi or Embedded Java is required so that the third-party software provider can sell to a large market.

Most such open environments have a reference design that runs on a personal computer. Much of the software for such systems can be developed on a conventional PC. However, the porting of the open environment to the specialized electronics and the development of the device drivers for the electronics are usually still the responsibility of a classic embedded software engineer. In some cases, the engineer works for the integrated circuit manufacturer, but there is still such a person somewhere.


Start-up

All embedded systems have start-up code. Usually it disables interrupts, sets up the electronics, tests the computer (RAM, CPU and software), and then starts the application code. Many embedded systems recover from short-term power failures by restarting (without recent self-tests). Restart times under a tenth of a second are common.

Many designers have found one or more hardware plus software-controlled LEDs useful to indicate errors during development (and in some instances, after product release, to produce troubleshooting diagnostics). A common scheme is to have the electronics turn on all of the LED(s) at reset (thereby proving that power is applied and the LEDs themselves work), whereupon the software changes the LED pattern as the Power-On Self Test executes. After that, the software may blink the LED(s) or set up light patterns during normal operation to indicate program execution progress and/or errors. This serves to reassure most technicians/engineers and some users. An interesting exception is that on electric power meters and other items on the street, blinking lights are known to attract attention and vandalism.

What is an embedded System?

Software as an extension to Hardware both Integreated in One Product.

Types of embedded software architectures

There are several basically different types of software architectures in common use.

The control loop

In this design, the software simply has a loop. The loop calls subroutines. Each subroutine manages a part of the hardware or software. Interrupts generally set flags, or update counters that are read by the rest of the software.

A simple API disables and enables interrupts. Done right, it handles nested calls in nested subroutines, and restores the preceding interrupt state in the outermost enable. This is one of the simplest methods of creating an exokernel.

Typically, there's some sort of subroutine in the loop to manage a list of software timers, using a periodic real time interrupt. When a timer expires, an associated subroutine is run, or flag is set.

Any expected hardware event should be backed-up with a software timer. Hardware events fail about once in a trillion times. That's about once a year with modern hardware. With a million mass-produced devices, leaving out a software timer is a business disaster.

State machines may be implemented with a function-pointer per state-machine (in C++, C or assembly, anyway). A change of state stores a different function into the pointer. The function pointer is executed every time the loop runs.

Many designers recommend reading each IO device once per loop, and storing the result so the logic acts on consistent values.

Many designers prefer to design their state machines to check only one or two things per state. Usually this is a hardware event, and a software timer.

Designers recommend that hierarchical state machines should run the lower-level state machines before the higher, so the higher run with accurate information.

Complex functions like internal combustion controls are often handled with multi-dimensional tables. Instead of complex calculations, the code looks up the values. The software can interpolate between entries, to keep the tables small and cheap.

One major weakness of this system is that it does not guarantee a time to respond to any particular hardware event.

Careful coding can easily assure that nothing disables interrupts for long. Thus interrupt code can run at very precise timings.

Another major weakness of this system is that it can become complex to add new features. Algorithms that take a long time to run must be carefully broken down so only a little piece gets done each time through the main loop.

This system's strength is its simplicity, and on small pieces of software the loop is usually so fast that nobody cares that it is not predictable.

Another advantage is that this system guarantees that the software will run. There is no mysterious operating system to blame for bad behavior.

Nonpreemptive multitasking

This system is very similar to the above, except that the loop is hidden in an API. One defines a series of tasks, and each task gets its own subroutine stack. Then, when a task is idle, it calls an idle routine (usually called "pause", "wait", "yield", or etc.).

An architecture with similar properties is to have an event queue, and have a loop that removes events and calls subroutines based on a field in the queue-entry.

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

Preemptive timers

Take any of the above systems, but add a timer system that runs subroutines from a timer interrupt. This adds completely new capabilities to the system. For the first time, the timer routines can occur at a guaranteed time.

Also, for the first time, the code can step on its own data structures at unexpected times. The timer routines must be treated with the same care as interrupt routine(s).

Preemptive tasks

Take the above nonpreemptive task system, and run it from a preemptive timer or other interrupts.

Suddenly the system is quite different. Any piece of task code can damage the data of another task—they must be precisely separated. Access to shared data must be rigidly controlled by some synchronization strategy, for example message queues or semaphores. (Recently non-blocking synchronization strategies have been developed).

Often, at this stage, the developing organization buys a real-time operating system. This can be a wise decision if the organization lacks people with the skills to write one, or if the port of the operating system to the hardware will be used in several products. Otherwise, be aware that it usually adds six to eight weeks to the schedule, and forever after programmers can blame delays on it.

Office-style operating systems

These are popular for embedded projects that have no systems budget. In the opinion of at least one author of this article, they are usually a mistake. Here's the logic:

  • Operating systems are specially-packaged libraries of reusable code. If the code does something useful, the designer saves time and money. If not, it's worthless.
  • Operating systems for business systems lack interfaces to embedded hardware. Example: if one uses Linux to write a motor controller or telephone switch, most of the real control operations end up as numbered functions in an IOCTL call. Meanwhile, the normal read, write, fseek, interface is purposeless. So the operating system actually interferes with development.
  • Most embedded systems perform no office work, so most code of office operating systems is wasted. Example: most embedded systems never use a file system or screen, so file system and GUI logic is wasted. Unused code is just a reliability liability.
  • Office style operating systems protect the hardware from user programs. That is, they interfere with embedded systems development profoundly.
  • Operating systems must invariably be ported to an embedded system. That is, the hardware driver code must always be written anyway. This is the most difficult part of the operating system, so little is saved by using one.
  • The genuinely useful, portable features of operating systems are small pieces of code. Examples: a basic TCP/IP interface is about 3,000 lines of C code; as is a simple file system. If a design needs these, they can be had for less than 10% of the typical embedded system's development budget, without royalty, just by writing them. And, if the needed code is sufficiently generic, the back of embedded systems magazines typically have vendors selling royalty-free C implementation.

Nevertheless Embedded Linux is increasing in popularity, especially on the more powerful embedded devices such as Wireless Routers and GPS Navigation Systems. Here are some of the reasons:

  • Ports to common embedded platforms are available.
  • The ability to configure the distribution to exclude unneeded functionality.
  • The abilty to develop embedded applications user mode, makes the development process easier and more portable.

Exotic custom operating systems

Some systems require safe, timely, reliable or efficient behavior unobtainable with the above architectures. There are well-known tricks to construct these systems:

  • Hire a real system programmer. They cost a little more, but can save years of debugging, and the associated loss of revenue.
  • RMA (rate monotonic analysis), can be used to find whether a set of tasks can run under a defined hardware system. In its simplest form, the designer assures that the quickest-finishing tasks have the highest priorities, and that on average, the CPU has at least 30% of its time free.
  • Harmonic tasks optimize CPU efficiency. Basically, designers assure that everything runs from a heartbeat timer. It's hard to do this with a real-time operating system, because these usually switch tasks when they wait for an I/O device.
  • Systems with exactly two levels of priority (usually running, and interrupts-disabled) cannot have Priority inversion problems in which a higher priority task waits for a lower priority task to release a semaphore or other resource.
  • Systems with monitors can't have deadlocks. A monitor locks a region of code from interrupts or other preemption. If the monitor is only applied to small, fast pieces of code, this can work acceptably well. If the monitor API can be proven to run to completion in all cases, (say, if it merely disabels interrupts) then no hangs are possible.

This means that systems that use dual priority and monitors are safe and reliable because they lack both deadlocks and priority inversion. If the monitors run to completion, they will never hang. If they use harmonic tasks, they can even be fairly efficient. However, RMA can't characterize these systems, and levels of priority had