Vestavěný systém - Embedded system
An vestavěný systém je počítačový systém - kombinace a procesor počítače, paměť počítače, a vstup výstup periferní zařízení - která má vyhrazenou funkci ve větším mechanickém nebo elektrickém systému.[1][2] to je vložený jako součást kompletního zařízení často zahrnujícího elektrický nebo elektronický hardware a mechanické součásti. Protože vestavěný systém obvykle řídí fyzické operace stroje, do kterého je vložen, často má výpočet v reálném čase omezení. Integrované systémy dnes ovládají mnoho běžně používaných zařízení.[3] Devadesát osm procent všech vyrobených mikroprocesorů se používá ve vestavěných systémech.[4]
Moderní vestavěné systémy jsou často založeny na mikrokontroléry (tj. mikroprocesory s integrovanou pamětí a periferními rozhraními), ale běžné jsou také běžné mikroprocesory (využívající externí čipy pro paměti a periferní rozhraní), zejména ve složitějších systémech. V obou případech mohou být použitými procesory typy od obecného účelu po ty, které se specializují na určitou třídu výpočtů, nebo dokonce vlastní navržené pro danou aplikaci. Běžnou standardní třídou vyhrazených procesorů je procesor digitálního signálu (DSP).
Jelikož je vestavěný systém určen pro konkrétní úkoly, konstruktéři jej může optimalizovat, aby snížil velikost a náklady na produkt a zvýšil spolehlivost a výkon. Některé vestavěné systémy se vyrábějí hromadně a těží z toho úspory z rozsahu.
Vestavěné systémy sahají od přenosných zařízení, jako jsou digitální hodinky a MP3 přehrávače, na velká stacionární zařízení jako řadiče semaforu, programovatelné logické automaty a velké složité systémy jako hybridní vozidla, lékařské zobrazování systémy a avionika. Složitost se pohybuje od nízké, s jedním čipem mikrokontroléru, po velmi vysokou s více jednotkami, periferní zařízení a sítě připojené uvnitř velkého stojan na vybavení.
Dějiny
Pozadí
Počátky mikroprocesor a mikrokontrolér lze vysledovat zpět do Integrovaný obvod MOS, což je integrovaný obvod čip vymyslel z MOSFETy (kov-oxid-polovodič tranzistory s efektem pole ) a byl vyvinut na počátku 60. let. Do roku 1964 dosáhly čipy MOS výše hustota tranzistoru a nižší výrobní náklady než bipolární bramborové hranolky. MOS čipy se dále zvyšovaly ve složitosti rychlostí předpovídanou Moorův zákon, vedoucí k rozsáhlá integrace (LSI) se stovkami tranzistory na jediném čipu MOS koncem šedesátých let. Aplikace čipů MOS LSI na výpočetní byl základem pro první mikroprocesory, protože inženýři začali uznávat, že je to kompletní procesor počítače systém by mohl být obsažen na několika čipech MOS LSI.[5]
První vícečipové mikroprocesory, Čtyřfázové systémy AL1 v roce 1969 a Garrett AiResearch MP944 v roce 1970 byly vyvinuty s více čipy MOS LSI. První jednočipový mikroprocesor byl Intel 4004, vydané v roce 1971. Byl vyvinut společností Federico Faggin pomocí jeho křemíková brána Technologie MOS, spolu s Intel inženýři Marcian Hoff a Stan Mazor, a Busicom inženýr Masatoshi Shima.[6]
Rozvoj
Jedním z prvních rozpoznatelně moderních vestavěných systémů byl Naváděcí počítač Apollo,[Citace je zapotřebí ] vyvinutý ca. 1965 od Charles Stark Draper na MIT Instrumentation Laboratory. Na počátku projektu byl naváděcí počítač Apollo považován za nejrizikovější položku v projektu Apollo, protože využíval tehdy nově vyvinutý monolitické integrované obvody snížit velikost a hmotnost počítače.
Časný sériově vyráběný vestavěný systém byl Naváděcí počítač Autonetics D-17 pro Minuteman raketa, vydané v roce 1961. Když se Minuteman II dostal do výroby v roce 1966, byl D-17 nahrazen novým počítačem, který představoval první velkoobjemové použití integrovaných obvodů.
Od těchto raných aplikací v šedesátých letech klesly ceny vestavěných systémů a dramaticky vzrostl výkon a funkčnost zpracování. Brzy mikroprocesor, Intel 4004 (vydáno v roce 1971), byl navržen pro kalkulačky a další malé systémy, ale stále vyžadovaly externí paměť a podpůrné čipy. Na začátku 80. let byly komponenty paměti, vstupního a výstupního systému integrovány do stejného čipu jako procesor tvořící a mikrokontrolér. Mikrokontroléry nacházejí aplikace, kde by univerzální počítač byl příliš nákladný. S poklesem nákladů na mikroprocesory a mikrokontroléry se zvýšila prevalence vestavěných systémů.
Dnes může být naprogramován poměrně levný mikrokontrolér, který plní stejnou roli jako velké množství samostatných komponent. U mikrokontrolérů bylo možné nahradit drahé spotřebiče, a to iu spotřebního zboží analogový komponenty jako potenciometry a variabilní kondenzátory pomocí tlačítek nahoru / dolů nebo knoflíků načtených mikroprocesorem. Ačkoli v tomto kontextu je vestavěný systém obvykle složitější než tradiční řešení, většina složitosti je obsažena v samotném mikrokontroléru. Může být zapotřebí jen velmi málo dalších komponent a většina návrhového úsilí spočívá v softwaru. Prototyp a test softwaru mohou být rychlejší ve srovnání s návrhem a konstrukcí nového obvodu bez použití zabudovaného procesoru.
Aplikace
Vestavěné systémy se běžně vyskytují ve spotřebitelských, průmyslových, automobilový průmysl, domácí spotřebiče, lékařské, telekomunikační, komerční a vojenské aplikace.
Telekomunikace systémy využívají řadu vestavěných systémů od telefonní spínače pro síť mobily na koncový uživatel Síť počítačů používá vyhrazené směrovače a síťové mosty směrovat data.
Spotřební elektronika zahrnout MP3 přehrávače, televizní přijímače, mobilní telefony, herní konzole, digitální fotoaparáty, GPS přijímače a tiskaři. Domácí spotřebiče, jako např mikrovlnné trouby, pračky a myčky nádobí, zahrnují vestavěné systémy, které poskytují flexibilitu, efektivitu a funkce. Pokročilý HVAC systémy používají v síti termostaty přesněji a efektivněji regulovat teplotu, která se může měnit podle denní doby a sezóna. Automatizace domácnosti používá kabelové a bezdrátové sítě, které lze použít k ovládání světel, klimatu, zabezpečení, audiovizuálních, sledovacích zařízení atd., které všechny používají pro snímání a ovládání zabudovaná zařízení.
Dopravní systémy od letu k automobilům stále více využívají vestavěné systémy. Nová letadla obsahují pokročilé avionika jako inerciální naváděcí systémy a GPS přijímače, které mají také značné bezpečnostní požadavky. Různé elektrické motory - střídavé stejnosměrné motory, indukční motory a Stejnosměrné motory - používat elektroniku řadiče motorů. Auta, elektrická vozidla, a hybridní vozidla stále více využívají vestavěné systémy k maximalizaci účinnosti a snížení znečištění. Mezi další automobilové bezpečnostní systémy využívající vestavěné systémy patří protiblokovací systém (BŘIŠNÍ SVALY), Elektronická kontrola stability (ESC / ESP), kontrola trakce (TCS) a automatické pohon čtyř kol.
Lékařské vybavení používá vestavěné systémy pro monitorování a různé lékařské zobrazování (PET, SPECT, CT, a MRI ) pro neinvazivní vnitřní kontroly. Integrované systémy v lékařských zařízeních jsou často napájeny průmyslovými počítači.[8]
Používají se vestavěné systémy bezpečnostní kritické systémy. Pokud nejsou připojeny ke kabelovým nebo bezdrátovým sítím prostřednictvím mobilní sítě 3G na čipu nebo jinými metodami pro účely monitorování a kontroly IoT, lze tyto systémy izolovat od hackerství a být tak bezpečnější.[9] Z hlediska požární bezpečnosti mohou být systémy navrženy tak, aby měly větší schopnost zvládat vyšší teploty a pokračovat v provozu. Při řešení bezpečnosti mohou být vestavěné systémy soběstačné a být schopné vypořádat se s přerušenými elektrickými a komunikačními systémy.
Volají se miniaturní bezdrátová zařízení motes jsou síťové bezdrátové senzory. Síť bezdrátových senzorů využívá miniaturizaci umožněnou pokročilým designem IC k propojení plných bezdrátových subsystémů se sofistikovanými senzory, což umožňuje lidem a společnostem měřit nesčetné množství věcí ve fyzickém světě a reagovat na tyto informace prostřednictvím monitorovacích a řídicích systémů. Tyto moty jsou zcela samostatné a obvykle z nich vybije bateriový zdroj po celá léta, než bude nutné baterie vyměnit nebo nabít.
Vlastnosti
Integrované systémy jsou navrženy tak, aby prováděly určité konkrétní úkoly, nikoli aby byly univerzálním počítačem pro více úkolů. Někteří také mají reálný čas výkonnostní omezení, která musí být splněna z důvodů, jako je bezpečnost a použitelnost; jiné mohou mít nízké nebo žádné požadavky na výkon, což umožňuje zjednodušení systémového hardwaru za účelem snížení nákladů.
Integrované systémy nejsou vždy samostatná zařízení. Mnoho vestavěných systémů se skládá z malých částí ve větším zařízení, které slouží obecnějším účelům. Například Robotická kytara Gibson obsahuje zabudovaný systém pro ladění strun, ale celkovým účelem Robot Guitar je samozřejmě přehrávání hudby.[10] Podobně vestavěný systém v automobil poskytuje specifickou funkci jako subsystém samotného automobilu.
Programové instrukce napsané pro vestavěné systémy jsou označovány jako firmware, a jsou uloženy v paměti jen pro čtení nebo flash paměť bramborové hranolky. Běží s omezenými prostředky hardwaru počítače: málo paměti, malá nebo neexistující klávesnice nebo obrazovka.
Uživatelské rozhraní
Rozsah vestavěných systémů od žádné uživatelské rozhraní vůbec, v systémech věnovaných pouze jednomu úkolu, složitému grafická uživatelská rozhraní které se podobají moderním počítačovým operačním systémům pro stolní počítače tlačítka, LED diody, grafika nebo znak LCD (HD44780 LCD například) s jednoduchým systém menu.
Sofistikovanější zařízení, která používají grafickou obrazovku s dotek snímací tlačítka nebo tlačítka na okraji obrazovky poskytují flexibilitu při minimalizaci použitého prostoru: význam tlačítek se může měnit s obrazovkou a výběr zahrnuje přirozené chování ukazování na to, co je požadováno. Ruční systémy často mají obrazovku s „tlačítkem joysticku“ pro polohovací zařízení.
Některé systémy poskytují uživatelské rozhraní na dálku pomocí sériového rozhraní (např. RS-232, USB, I²C atd.) nebo síť (např. Ethernet ) připojení. Tento přístup přináší několik výhod: rozšiřuje možnosti vestavěného systému, vyhýbá se nákladům na displej, zjednodušuje BSP a umožňuje člověku vybudovat na PC bohaté uživatelské rozhraní. Dobrým příkladem je kombinace vestavěný webový server běžící na vloženém zařízení (například IP kamera ) nebo a síťový router. Uživatelské rozhraní je zobrazeno v a webový prohlížeč na počítači připojeném k zařízení, a proto není nutné instalovat žádný software.
Procesory ve vestavěných systémech
Příklady vlastností typických vestavěných počítačů ve srovnání s univerzálními protějšky jsou nízká spotřeba energie, malá velikost, robustní operační rozsah a nízké náklady na jednotku. To přichází za cenu omezených zdrojů zpracování, díky nimž je programování a interakce s nimi výrazně obtížnější. Budováním inteligentních mechanismů na horní straně hardwaru, využíváním výhod existujících senzorů a existencí sítě vestavěných jednotek, je však možné jak optimálně spravovat dostupné zdroje na úrovni jednotek, tak i na úrovni sítě, a také poskytovat rozšířené funkce, mnohem dále ty, které jsou k dispozici.[11] Mohou být například navrženy inteligentní techniky pro správu spotřeby energie vestavěných systémů.[12]
Vestavěné procesory lze rozdělit do dvou širokých kategorií. Obyčejné mikroprocesory (μP) používají samostatné integrované obvody pro paměť a periferní zařízení. Mikrokontroléry (μC) mají periferní zařízení na čipu, čímž snižují spotřebu energie, velikost a náklady. Na rozdíl od trhu osobních počítačů, mnoho různých základních Architektury CPU jsou používány, protože software je vyvinut na zakázku pro aplikaci a nejedná se o komoditní produkt nainstalovaný koncovým uživatelem. Oba Von Neumann, stejně jako různé stupně Harvardské architektury, Jsou používány. RISC jsou nalezeny i jiné procesory než RISC. Délky slov se liší od 4 bitů do 64 bitů a dále, i když nejtypičtější zůstávají 8/16 bitů. Většina architektur má velké množství různých variant a tvarů, z nichž mnohé vyrábí také několik různých společností.
Četné mikrokontroléry byly vyvinuty pro použití vestavěných systémů. Mikroprocesory pro všeobecné účely se také používají ve vestavěných systémech, ale obecně vyžadují více podpůrných obvodů než mikrokontroléry.
Hotové počítačové desky
PC / 104 a PC / 104 + jsou příklady standardů pro hotový počítačové desky určené pro malé, maloobjemové vestavěné a robustní systémy, většinou na bázi x86. Ty jsou často fyzicky malé ve srovnání se standardním počítačem, i když stále poměrně velké ve srovnání s většinou jednoduchých (8 / 16bitových) vestavěných systémů. Často používají DOS, Linux, NetBSD, nebo vložený operační systém v reálném čase jako MicroC / OS-II, QNX nebo VxWorks. Někdy tyto desky používají procesory jiné než x86.
V určitých aplikacích, kde není primárním problémem malá velikost nebo energetická účinnost, mohou být použité komponenty kompatibilní s těmi, které se používají v běžných osobních počítačích x86. Desky jako VIA EPIA range pomáhají překlenout mezeru tím, že jsou kompatibilní s PC, ale vysoce integrované, fyzicky menší nebo mají jiné atributy, díky nimž jsou atraktivní pro vestavěné inženýry. Výhodou tohoto přístupu je, že lze použít levné komoditní komponenty spolu se stejnými nástroji pro vývoj softwaru, které se používají pro obecný vývoj softwaru. Systémy postavené tímto způsobem jsou stále považovány za vestavěné, protože jsou integrovány do větších zařízení a plní jednu roli. Příklady zařízení, která mohou tento přístup přijmout, jsou Bankomaty a arkádové automaty, které obsahují kód specifický pro aplikaci.
Většina hotových desek vestavěných systémů však není zaměřena na PC a nepoužívá sběrnice ISA nebo PCI. Když systém na čipu Pokud se jedná o procesor, může mít malá výhoda standardizovaná sběrnice spojující diskrétní komponenty a prostředí pro hardwarové i softwarové nástroje se může velmi lišit.
Jeden běžný styl designu používá malý systémový modul, možná velikost vizitky, který má vysokou hustotu BGA čipy, jako je PAŽE -na základě systém na čipu procesor a periferní zařízení, externí flash paměť pro skladování a DOUŠEK pro runtime paměť. Dodavatel modulu obvykle poskytne spouštěcí software a zajistí, aby byl k dispozici výběr operačních systémů, obvykle včetně Linux a několik možností v reálném čase. Tyto moduly mohou být vyráběny ve velkém objemu organizacemi obeznámenými s jejich specializovanými problémy s testováním a kombinovány s vlastními základními deskami s mnohem nižším objemem s externími periferními zařízeními specifickými pro aplikaci.
Implementace vestavěných systémů pokročila, takže je lze snadno implementovat pomocí již vyrobených desek založených na celosvětově přijímaných platformách. Mezi tyto platformy patří mimo jiné: Arduino a Raspberry Pi.
ASIC a FPGA řešení
Společným polem pro vestavěné systémy s velkým objemem je systém na čipu (SoC), který obsahuje kompletní systém skládající se z více procesorů, multiplikátorů, mezipamětí a rozhraní na jednom čipu. SoC lze implementovat jako aplikačně specifický integrovaný obvod (ASIC) nebo pomocí a pole programovatelné brány (FPGA).
Periferní zařízení
Vestavěné systémy komunikují s vnějším světem prostřednictvím periferní zařízení, jako:
- Sériová komunikační rozhraní (SCI): RS-232, RS-422, RS-485, atd.
- Synchronní sériové komunikační rozhraní: I2C, SPI, SSC a ESSI (Enhanced Synchronous Serial Interface)
- Universal Serial Bus (USB)
- Multimediální karty (karty SD, Compact Flash atd.)
- Sítě: Ethernet, LonWorks, atd.
- Fieldbusy: CAN-Bus, LIN-Bus, PROFIBUS, atd.
- Časovače: PLL s, Zachytit / Porovnat a Jednotky zpracování času
- Diskrétní IO: aka Univerzální vstup / výstup (GPIO)
- Analogový na digitální / digitální na analogový (ADC /DAC )
- Ladění: JTAG, ISP, BDM Porty, porty BITP a DB9.
Nástroje
Stejně jako u jiného softwaru používají návrháři vestavěných systémů překladače, montéři, a debuggery vyvíjet software vestavěného systému. Mohou však také použít některé konkrétnější nástroje:
- V ladicích obvodech nebo emulátorech (viz další část).
- Nástroje pro přidání kontrolního součtu nebo CRC k programu, takže integrovaný systém může zkontrolovat, zda je program platný.
- Pro systémy využívající zpracování digitálních signálů, mohou vývojáři k simulaci matematiky použít matematický pracovní stůl.
- Nástroje pro modelování a simulaci na úrovni systému pomáhají návrhářům konstruovat simulační modely systému s hardwarovými komponentami, jako je procesory, vzpomínky, DMA, rozhraní, sběrnice a chování softwaru proudí jako stavový diagram nebo vývojový diagram pomocí konfigurovatelných bloků knihovny. Simulace se provádí za účelem výběru správných komponent provedením kompromisu mezi výkonem a výkonem, analýzou spolehlivosti a analýzou úzkých míst. Typické zprávy, které designérovi pomáhají při rozhodování o architektuře, zahrnují latenci aplikace, propustnost zařízení, využití zařízení, spotřebu energie celého systému a spotřebu energie na úrovni zařízení.
- Modelový vývojový nástroj vytváří a simuluje grafický tok dat a diagramy stavových diagramů UML komponent, jako jsou digitální filtry, řadiče motorů, dekódování komunikačního protokolu a úlohy s více rychlostmi.
- K optimalizaci specializovaného hardwaru lze použít vlastní kompilátory a linkery.
- Integrovaný systém může mít svůj vlastní speciální jazyk nebo nástroj pro návrh, nebo přidat vylepšení existujícího jazyka, jako je Forth nebo Základní.
- Další alternativou je přidání a operační systém v reálném čase nebo vestavěný operační systém
- Modelování a generování kódu nástroje často na základě státní stroje
Softwarové nástroje mohou pocházet z několika zdrojů:
- Softwarové společnosti, které se specializují na integrovaný trh
- Přeneseno z GNU nástroje pro vývoj softwaru
- Někdy lze vývojové nástroje pro osobní počítač použít, pokud je integrovaný procesor blízký příbuzný běžnému procesoru PC
Jak roste složitost vestavěných systémů, nástroje a operační systémy vyšší úrovně migrují do strojů, kde to dává smysl. Například, mobily, osobní digitální asistenti a další spotřební počítače často potřebují značný software, který kupuje nebo poskytuje jiná osoba než výrobce elektroniky. V těchto systémech je otevřené programovací prostředí, jako je Linux, NetBSD, OSGi nebo Vestavěná Java je vyžadováno, aby poskytovatel softwaru třetí strany mohl prodávat na velkém trhu.
Vestavěné systémy se běžně vyskytují ve spotřebitelských, kuchyňských, průmyslových, automobilových a lékařských aplikacích. Některé příklady vestavěných systémů jsou přehrávače MP3, mobilní telefony, herní konzole, digitální fotoaparáty, DVD přehrávače a GPS. Domácí spotřebiče, jako jsou mikrovlnné trouby, pračky a myčky nádobí, obsahují vestavěné systémy, které poskytují flexibilitu a účinnost.
Ladění
Vestavěné ladění lze provádět na různých úrovních v závislosti na dostupných zařízeních. Různé metriky, které charakterizují různé formy vloženého ladění, jsou: zpomaluje hlavní aplikaci, jak blízko je laděný systém nebo aplikace ke skutečnému systému nebo aplikaci, jak výrazné jsou spouštěče, které lze nastavit pro ladění (např. prohlížení paměti, když konkrétní počítadlo programů hodnota je dosažena) a co lze v procesu ladění zkontrolovat (například pouze paměť nebo paměť a registry atd.).
Od nejjednodušších po nejsofistikovanější je lze zhruba rozdělit do následujících oblastí:
- Interaktivní ladění rezidentů pomocí jednoduchého prostředí poskytovaného integrovaným operačním systémem (např.Forth a Basic)
- Externí ladění pomocí protokolování nebo výstupu sériového portu pro trasování operace pomocí monitoru ve flashi nebo pomocí ladicího serveru, jako je Nápravný debugger který dokonce funguje pro heterogenní vícejádrový systémy.
- Obvodový debugger (ICD), hardwarové zařízení, které se připojuje k mikroprocesoru pomocí a JTAG nebo Nexus rozhraní.[13] To umožňuje, aby byl provoz mikroprocesoru řízen externě, ale je obvykle omezen na konkrétní možnosti ladění v procesoru.
- An emulátor v obvodu (ICE) nahrazuje mikroprocesor simulovaným ekvivalentem a poskytuje plnou kontrolu nad všemi aspekty mikroprocesoru.
- Kompletní emulátor poskytuje simulaci všech aspektů hardwaru, umožňuje jeho ovládání a úpravy a umožňuje ladění na běžném počítači. Nevýhody jsou náklady a pomalý provoz, v některých případech až stokrát pomalejší než konečný systém.
- U návrhů SoC je typickým přístupem ověření a ladění návrhu na desce prototypu FPGA. Nástroje jako Certus[14] se používají k vložení sond do FPGA RTL, které zpřístupňují signály pro pozorování. Používá se k ladění interakcí hardwaru, firmwaru a softwaru napříč několika FPGA s funkcemi podobnými logickému analyzátoru.
- Softwarové ladicí programy mají tu výhodu, že nepotřebují žádné úpravy hardwaru, ale musí pečlivě kontrolovat, co zaznamenávají, aby šetřily čas a úložný prostor.[15]
Pokud není omezeno na externí ladění, programátor může obvykle načíst a spustit software prostřednictvím nástrojů, zobrazit kód spuštěný v procesoru a spustit nebo zastavit jeho provoz. Pohled na kód může být jako HLL zdrojový kód, montážní kód nebo směs obou.
Protože vložený systém se často skládá z nejrůznějších prvků, může se strategie ladění lišit. Například ladění softwarového (a mikroprocesorového) vestavěného systému se liší od ladění vestavěného systému, kde většinu zpracování provádějí periferní zařízení (DSP, FPGA a koprocesor). Stále větší počet vestavěných systémů dnes používá více než jedno jádro procesoru. Společným problémem vývoje více jader je správná synchronizace provádění softwaru. V tomto případě může design vestavěného systému chtít zkontrolovat datový provoz na sběrnicích mezi jádry procesoru, což vyžaduje velmi nízké ladění, na úrovni signálu / sběrnice, pomocí logický analyzátor, například.
Trasování
Operační systémy v reálném čase (RTOS ) často podporuje sledování událostí operačního systému. Grafický pohled je prezentován nástrojem hostitelského počítače na základě záznamu chování systému. Záznam trasování lze provádět v softwaru, pomocí RTOS nebo pomocí speciálního sledovacího hardwaru. Trasování RTOS umožňuje vývojářům porozumět problémům s načasováním a výkonem softwarového systému a umožňuje dobré pochopení chování systému na vysoké úrovni.
Spolehlivost
Integrované systémy se často nacházejí ve strojích, u nichž se očekává nepřetržitý provoz po celá léta bez chyb, a v některých případech se samy obnoví, pokud dojde k chybě. Proto je software obvykle vyvíjen a testován pečlivěji než software pro osobní počítače a nedochází k nespolehlivým mechanickým pohyblivým částem, jako jsou diskové jednotky, přepínače nebo tlačítka.
Mezi konkrétní problémy se spolehlivostí patří:
- Systém nelze bezpečně vypnout kvůli opravě nebo je příliš nepřístupný k opravě. Mezi příklady patří vesmírné systémy, podmořské kabely, navigační majáky, systémy vrtů a automobily.
- Z bezpečnostních důvodů musí být systém udržován v chodu. „Limpové režimy“ jsou méně snesitelné. Zálohy často vybírá operátor. Jako příklady lze uvést letadlovou navigaci, řídicí systémy reaktorů, bezpečnostní chemické továrny, vlakové signály.
- Systém při vypnutí ztratí velké množství peněz: telefonní spínače, ovládání z výroby, ovládání mostů a výtahů, převod finančních prostředků a tvorba trhu, automatizovaný prodej a servis.
K zotavení z chyb se používá řada technik, někdy i v kombinaci - obě softwarové chyby jako např úniky paměti, a také měkké chyby v hardwaru:
- hlídací časovač který resetuje počítač, pokud software pravidelně neoznámí subsystémy hlídacího psa redundantními náhradními díly, které lze přepnout na softwarové „limpové režimy“, které poskytují částečnou funkci
- Navrhování s Trusted Computing Base (TCB) architektura[16] zajišťuje vysoce bezpečné a spolehlivé systémové prostředí
- A hypervisor navržený pro vestavěné systémy je schopen zajistit bezpečné zapouzdření pro jakoukoli komponentu subsystému, takže kompromitovaná softwarová komponenta nemůže interferovat s jinými subsystémy nebo systémovým softwarem na privilegované úrovni.[17] Toto zapouzdření zabraňuje šíření chyb z jednoho subsystému do druhého, čímž zvyšuje spolehlivost. To může také umožnit automatické vypnutí a restartování subsystému při detekci poruchy.
- Programování s vědomím imunity
Vysoká vs. nízká hlasitost
Pro velkoobjemové systémy, jako je přenosné hudební přehrávače nebo mobilní telefony, minimalizace nákladů je obvykle primární úvahou designu. Inženýři obvykle vybírají hardware, který je „dostatečně dobrý“ pro implementaci nezbytných funkcí.
U nízkoobjemových nebo prototypových vestavěných systémů lze univerzální počítače přizpůsobit omezením programů nebo nahrazením operačního systému operační systém v reálném čase.
Integrované softwarové architektury
V roce 1978 Národní asociace výrobců elektřiny vydala standard pro programovatelné mikrokontroléry, včetně téměř všech počítačových řadičů, jako jsou jednodeskové počítače, číselné řadiče a řadiče založené na událostech.
Dnes se běžně používá několik různých typů softwarové architektury.
Jednoduchá kontrolní smyčka
V tomto designu má software jednoduše a smyčka. Smyčka volá podprogramy, z nichž každý spravuje část hardwaru nebo softwaru. Proto se nazývá jednoduchá kontrolní smyčka nebo kontrolní smyčka.
Systém řízený přerušením
Některé vestavěné systémy jsou ovládány převážně přerušení. To znamená, že úkoly prováděné systémem jsou spouštěny různými druhy událostí; přerušení by mohlo být generováno například časovačem na předem definované frekvenci nebo řadičem sériového portu přijímajícím bajt.
Tyto druhy systémů se používají, pokud obslužné rutiny událostí vyžadují nízkou latenci a obslužné rutiny událostí jsou krátké a jednoduché. Obvykle tyto druhy systémů provozují také jednoduchý úkol v hlavní smyčce, ale tento úkol není příliš citlivý na neočekávaná zpoždění.
Občas obslužný program přerušení přidá do struktury fronty delší úkoly. Později, po dokončení obsluhy přerušení, jsou tyto úkoly provedeny hlavní smyčkou. Tato metoda přibližuje systém multitaskingovému jádru s diskrétními procesy.
Kooperativní multitasking
Nepreventivní multitaskingový systém je velmi podobný jednoduchému schématu řídicí smyčky, kromě toho, že smyčka je skrytá v API.[3][1] Programátor definuje řadu úkolů a každý úkol má své vlastní prostředí, ve kterém se „spustí“. Když je úkol nečinný, zavolá nečinnou rutinu, která se obvykle nazývá „pauza“, „čekání“, „výnos“, „nop“ (znamená žádná operace), atd.
Výhody a nevýhody jsou podobné jako u řídicí smyčky, kromě toho, že přidání nového softwaru je jednodušší, jednoduše napsáním nového úkolu nebo přidáním do fronty.
Preventivní multitasking nebo multi-threading
V tomto typu systému se část kódu na nízké úrovni přepíná mezi úkoly nebo vlákny na základě časovače (připojeného k přerušení). Toto je úroveň, na které je systém obecně považován za jádro „operačního systému“. V závislosti na tom, kolik funkcí je vyžadováno, zavádí více či méně složitosti správy více úloh běžících koncepčně paralelně.
Jakýkoli kód může potenciálně poškodit data jiného úkolu (s výjimkou větších systémů využívajících MMU ) programy musí být pečlivě navrženy a otestovány a přístup ke sdíleným datům musí být řízen nějakou strategií synchronizace, jako je fronty zpráv, semafory nebo a neblokující synchronizace systém.
Z důvodu těchto složitostí je běžné, že organizace používají a operační systém v reálném čase (RTOS), což umožňuje aplikačním programátorům soustředit se spíše na funkčnost zařízení než na služby operačního systému, alespoň pro velké systémy; menší systémy si často nemohou dovolit režii spojenou s a obecný systém v reálném čase kvůli omezením týkajícím se velikosti paměti, výkonu nebo výdrže baterie. Volba, kterou vyžaduje RTOS, přináší své vlastní problémy, protože výběr musí být proveden před zahájením procesu vývoje aplikace. Toto načasování nutí vývojáře, aby si vybrali vestavěný operační systém pro své zařízení na základě aktuálních požadavků, a tak do značné míry omezuje budoucí možnosti.[18] Omezení budoucích možností se stává více problémem, protože se snižuje životnost produktu. Úroveň složitosti navíc neustále roste, protože zařízení jsou povinna spravovat proměnné jako sériové, USB, TCP / IP, Bluetooth, Bezdrátové připojení k internetu, dálkové rádio, více kanálů, dat a hlasu, vylepšená grafika, více stavů, více vláken, četné stavy čekání atd. Tyto trendy vedou k zavádění vložený middleware kromě operačního systému v reálném čase.
Microkernels a exokernels
A mikrokernel je logickým krokem od OS v reálném čase. Obvyklé uspořádání je takové, že jádro operačního systému přiděluje paměť a přepíná CPU na různá podprocesy provádění. Procesy v uživatelském režimu implementují hlavní funkce, jako jsou souborové systémy, síťová rozhraní atd.
Obecně platí, že mikrokernely uspějí, když je přepínání úkolů a komunikace mezi úkoly rychlé a selžou, když jsou pomalé.
Exokernels efektivně komunikovat běžnými voláními podprogramů. Hardware a veškerý software v systému jsou dostupné a rozšiřitelné aplikačními programátory.
Monolitická jádra
V tomto případě je relativně velké jádro se sofistikovanými schopnostmi upraveno tak, aby vyhovovalo vloženému prostředí. To programátorům poskytuje prostředí podobné operačnímu systému pro stolní počítače Linux nebo Microsoft Windows, a proto je velmi produktivní pro vývoj; Nevýhodou je, že vyžaduje podstatně více hardwarových prostředků, je často dražší a vzhledem ke složitosti těchto jader může být méně předvídatelný a spolehlivý.
Běžné příklady vložených monolitických jader jsou vestavěný Linux, VXWorks a Windows CE.
Navzdory zvýšeným nákladům na hardware tento typ vestavěného systému roste v popularitě, zejména na výkonnějších vestavěných zařízeních, jako je bezdrátové směrovače a GPS navigační systémy. Zde jsou některé z důvodů:
- K dispozici jsou porty k běžným integrovaným čipovým sadám.
- Umožňují opětovné použití veřejně dostupného kódu pro ovladače zařízení, webové servery, firewally a další kód.
- Vývojové systémy mohou začínat širokými sadami funkcí a poté lze distribuci nakonfigurovat tak, aby vylučovala nepotřebné funkce a šetřila výdaje paměti, které by spotřebovala.
- Mnoho inženýrů věří, že spuštění kódu aplikace v uživatelském režimu je spolehlivější a snáze laditelné, což usnadňuje vývojový proces a kód je přenosnější.[Citace je zapotřebí ]
- Často je možné umístit funkce vyžadující rychlejší odezvu, než je možné zaručit Hardware.
Další softwarové komponenty
Kromě hlavního operačního systému má mnoho vestavěných systémů další softwarové komponenty vyšší vrstvy. Tyto komponenty se skládají ze zásobníků síťového protokolu UMĚT, TCP / IP, FTP, HTTP, a HTTPS, a také zahrnoval možnosti úložiště jako TLUSTÝ a systémy správy paměti flash. Pokud má integrované zařízení zvukové a obrazové funkce, budou v systému přítomny příslušné ovladače a kodeky. V případě monolitických jader je zahrnuto mnoho z těchto softwarových vrstev. V kategorii RTOS závisí dostupnost dalších softwarových komponent na komerční nabídce.
Architektury specifické pro doménu
V automobilovém sektoru AUTOSAR je standardní architektura pro vestavěný software.
Viz také
- Komunikační server
- Kyberfyzický systém
- DSP
- Elektronická řídicí jednotka
- Hypervisor
- Integrované operační systémy
- Integrovaný software
- Firmware
- FPGA
- Informační zařízení
- Mikroprocesor
- Mikrokontrolér
- Překladač křemíku
- Operační systém v reálném čase
- Softwarové inženýrství
- Systém na čipu
- Systém na modulu
- Všudypřítomné výpočty
- Fotonicky optimalizované vestavěné mikroprocesory
Poznámky
Reference
- ^ A b Michael Barr. "Slovník vestavěných systémů". Technická knihovna Neutrino. Citováno 2007-04-21.
- ^ Heath, Steve (2003). Návrh vestavěných systémů. Řada EDN pro konstruktéry (2. vyd.). Noví. p.2. ISBN 978-0-7506-5546-0.
Integrovaný systém je a mikroprocesor systém založený na ovládání funkce nebo řady funkcí.
- ^ A b Michael Barr; Anthony J. Massa (2006). "Úvod". Programování vestavěných systémů: s vývojovými nástroji C a GNU. O'Reilly. s. 1–2. ISBN 978-0-596-00983-0.
- ^ Barr, Michael (1. srpna 2009). "Program pro skutečné muže v C". Návrh vestavěných systémů. TechInsights (United Business Media). p. 2. Citováno 2009-12-23.
- ^ Shirriff, Ken (30. srpna 2016). „Překvapivý příběh prvních mikroprocesorů“. IEEE Spectrum. Institute of Electrical and Electronics Engineers. 53 (9): 48–54. doi:10.1109 / MSPEC.2016.7551353. S2CID 32003640. Citováno 13. října 2019.
- ^ „1971: Mikroprocesor integruje funkci CPU do jednoho čipu“. Křemíkový motor. Muzeum počítačové historie. Citováno 22. července 2019.
- ^ „Electronic Frontier Foundation“. Nadace Electronic Frontier Foundation.
- ^ Zabudované systémy Dell OEM řešení | Dell. Content.dell.com (04.01.2011). Citováno 2013-02-06.
- ^ Mulla, Ifath Azeem (srpen 2019). „Komplexní studie o vestavěném systému a internetu věcí“ (PDF). International Advanced Research Journal in Science, Engineering and Technology. 6 (8).
- ^ David Carey (2008-04-22). „Under the Hood: Robot Guitar embeds autotuning“. Návrh vestavěných systémů. Archivovány od originál dne 2008-07-08.
- ^ C.Alippi: Inteligence pro vestavěné systémy. Springer, 2014, 283pp, ISBN 978-3-319-05278-6.
- ^ S. Mittal, “Přehled technik pro zlepšení energetické účinnosti ve vestavěných počítačových systémech ", IJCAET, 6 (4), 440–459, 2014.
- ^ Tancreti, Matthew; Hossain, Mohammad Sajjad; Bagchi, Saurabh; Raghunathan, Vijay (2011). „Aveksha: Hardwarový a softwarový přístup pro nerušivé sledování a profilování bezdrátových vestavěných systémů“. Sborník příspěvků z 9. konference ACM o vestavěných síťových senzorových systémech. SenSys '11. New York, NY, USA: ACM: 288–301. doi:10.1145/2070942.2070972. ISBN 9781450307185. S2CID 14769602.
- ^ „Tektronix otřásá prototypováním, integrovaná instrumentace zvyšuje desky na stav emulátoru“. Electronic Engineering Journal. 2012-10-30. Citováno 2012-10-30.
- ^ Tancreti, Matthew; Sundaram, Vinaitheerthan; Bagchi, Saurabh; Eugster, Patrick (2015). „TARDIS: Softwarové nahrávání a přehrávání na úrovni systému pouze v bezdrátových senzorových sítích“. Sborník příspěvků ze 14. mezinárodní konference o zpracování informací v senzorových sítích. IPSN '15. New York, NY, USA: ACM: 286–297. doi:10.1145/2737095.2737096. ISBN 9781450334754. S2CID 10120929.
- ^ Heiser, Gernot (prosinec 2007). „Váš systém je zabezpečený? Dokažte to!“ (PDF). ;přihlásit se:. 2 (6): 35–8.
- ^ Moratelli, C; Johann, S; Neves, M; Hessel, F (2016). „Integrovaná virtualizace pro návrh bezpečných aplikací IoT“. Mezinárodní sympozium 2016 o rychlém vytváření prototypů systému (RSP): 2–6. doi:10.1145/2990299.2990301. ISBN 9781450345354. S2CID 17466572. Citováno 2. února 2018.
- ^ „Práce napříč více vestavěnými platformami“ (PDF). klarinox. Citováno 2010-08-17.
Další čtení
- John Catsoulis (květen 2005). Designing Embedded Hardware, 2nd Edition. O'Reilly. ISBN 0-596-00755-8.
- James M. Conrad; Alexander G. Dean (září 2011). Vestavěné systémy, úvod do používání mikrokontroléru Renesas RX62N. Mikrium. ISBN 978-1935-7729-96.
- Klaus Elk (srpen 2016). Vývoj vestavěného softwaru pro internet věcí, základy, technologie a osvědčené postupy. ISBN 978-1534602533.
externí odkazy
- Kurz Embedded Systems s mbed YouTube, probíhá od roku 2015
- Trendy v kybernetické bezpečnosti a vestavěných systémech Dan Geer, listopad 2013
- Kurz programování moderních vestavěných systémů YouTube, probíhá od roku 2013
- Týden vestavěných systémů (ESWEEK) každoroční akce s konferencemi, workshopy a návody pokrývající všechny aspekty vestavěných systémů a softwaru
- Workshop o vzdělávání vestavěných a kyberfyzikálních systémů, workshop pokrývající vzdělávací aspekty vestavěných systémů