Jazyk popisu hardwaru - Hardware description language - Wikipedia
Tento článek má několik problémů. Prosím pomozte vylepši to nebo diskutovat o těchto otázkách na internetu diskusní stránka. (Zjistěte, jak a kdy tyto zprávy ze šablony odebrat) (Zjistěte, jak a kdy odstranit tuto zprávu šablony)
|
v počítačové inženýrství, a jazyk popisu hardwaru (HDL) je specializovaný počítačový jazyk používá se k popisu struktury a chování elektronické obvody a nejčastěji digitální logika obvodů.
Jazyk popisu hardwaru umožňuje přesný, formální popis elektronického obvodu, který umožňuje automatickou analýzu a simulace elektronického obvodu. Umožňuje také syntéza popisu HDL do a netlist (specifikace fyzických elektronických součástek a způsob jejich vzájemného propojení), které pak mohou být umístěny a směrovány vyrábět sada masek slouží k vytvoření integrovaný obvod.
Jazyk popisu hardwaru vypadá podobně jako programovací jazyk jako C nebo ALGOL; jedná se o textový popis skládající se z výrazů, příkazů a řídicích struktur. Jedním důležitým rozdílem mezi většinou programovacích jazyků a HDL je to, že HDL výslovně obsahují pojem času.
HDL jsou nedílnou součástí elektronická automatizace designu (EDA) systémy, zejména pro složité obvody, jako jsou aplikačně specifické integrované obvody, mikroprocesory, a programovatelná logická zařízení.
Motivace
Vzhledem k explodující složitosti digitálních elektronických obvodů od 70. let (viz Moorův zákon ), potřebují návrháři obvodů digitální logika popisy, které mají být prováděny na vysoké úrovni, aniž by byly vázány na konkrétní elektronickou technologii, jako např ECL, TTL nebo CMOS. HDL byly vytvořeny k implementaci úroveň přenosu registru abstrakce, model toku dat a načasování obvodu.[1]
Existují dva hlavní jazyky popisu hardwaru: VHDL a Verilog. Jsou v nich různé typy popisu: „datový tok, behaviorální a strukturální“. Příklad toku dat VHDL:
KNIHOVNA IEEE;POUŽITÍ IEEE.STD_LOGIC_1164.VŠECHNO;ENTITY not1 JE PŘÍSTAV( A : V STD_LOGIC; b: VEN STD_LOGIC; );KONEC not1;ARCHITEKTURA behaviorální Z not1 JEZAČÍT b <= NE A;KONEC behaviorální;
Struktura HDL
HDL jsou standardní textové výrazy struktury elektronických systémů a jejich chování v čase. Jako souběžné programování jazyky, syntaxe HDL a sémantika zahrnují explicitní notace pro vyjádření konkurence. Na rozdíl od většiny softwaru programovací jazyky „HDL také obsahují explicitní pojem času, který je primární vlastností hardwaru. Jazyky, jejichž jedinou charakteristikou je vyjádření konektivity obvodů mezi hierarchií bloků, jsou správně klasifikovány jako netlist jazyky používané v elektrickém počítačem podporovaný design. HDL lze použít k vyjádření návrhů v strukturálních, behaviorálních nebo na úrovni registru přenosových architektur pro stejnou funkčnost obvodu; v posledních dvou případech syntetizér rozhoduje o architektuře a rozložení logické brány.
HDL se používají k zápisu spustitelných specifikací pro hardware. Program navržený k implementaci základní sémantiky jazykových příkazů a simulaci postupu času poskytuje návrháři hardwaru možnost modelovat hardware před jeho fyzickým vytvořením. Právě tato spustitelnost dává HDL iluzi bytí programovací jazyky, když jsou přesněji klasifikovány jako specifikační jazyky nebo modelovací jazyky. Existují simulátory schopné podporovat diskrétní (digitální) a kontinuální (analogové) modelování a pro každý je k dispozici cílené HDL.
Srovnání s jazyky řízení toku
Určitě je možné reprezentovat sémantiku hardwaru pomocí tradičních programovacích jazyků, jako je C ++, které operují regulační tok na rozdíl od sémantiky datový tok, i když fungují jako takové, musí být programy doplněny o rozsáhlé a nepraktické třídní knihovny. Obecně však softwarové programovací jazyky neobsahují žádné možnosti výslovného vyjádření času, a proto nemohou fungovat jako jazyky popisu hardwaru. Před zavedením Systém Verilog v roce 2002, C ++ integrace s a logický simulátor byl jedním z mála způsobů použití objektově orientované programování při ověřování hardwaru. System Verilog je první hlavní HDL, který nabízí orientaci na objekt a odvoz odpadu.
Pomocí správné podmnožiny jazyka popisu hardwaru se program nazývá syntetizátor nebo nástroj logické syntézy, může odvodit hardwarové logické operace z příkazů jazyka a vytvořit ekvivalentní netlist obecných hardwarových primitiv[žargon ] implementovat zadané chování.[Citace je zapotřebí ] Syntezátory obecně ignorují výraz všech časovacích konstruktů v textu. Obecně se používají například digitální logické syntetizátory okraje hodin jako způsob načasování obvodu, ignorování jakýchkoli časovacích konstrukcí. Schopnost mít syntetizovatelnou podmnožinu jazyka sama o sobě neznamená jazyk popisu hardwaru.
Dějiny
První jazyky pro popis hardwaru se objevily koncem šedesátých let a vypadaly jako tradiční jazyky.[2] První, který měl trvalý účinek, byl popsán v roce 1971 v roce C. Gordon Bell a text Allena Newella Počítačové struktury.[3] Tento text představil koncept úroveň přenosu registru, poprvé použito v jazyce ISP k popisu chování Digital Equipment Corporation (DEC) PDP-8.[4]
Jazyk se rozšířil zavedením DEC modulů PDP-16 RT na úrovni (RTM) a knihou popisující jejich použití.[5]Následovaly nejméně dvě implementace základního jazyka ISP (ISPL a ISPS).[6][7]ISPS byl vhodný pro popis vztahů mezi vstupy a výstupy návrhu a byl rychle přijat komerčními týmy na DEC, stejně jako řadou výzkumných týmů v USA i mezi jejich spojenci v NATO.
Produkty RTM se nikdy komerčně nerozběhly a společnost DEC je přestala prodávat v polovině 80. let, zejména jako nové techniky velmi rozsáhlá integrace (VLSI) se stala populárnější.
Samostatná práce od roku 1979 na University of Kaiserslautern vytvořil jazyk s názvem KARL („KAiserslautern Register Transfer Language“), který zahrnoval funkce jazyka designového počtu podporující plánování čipů VLSI[žargon ] a strukturovaný design hardwaru. Tato práce byla také základem interaktivního grafického sesterského jazyka KARL ABL, jehož jméno bylo An inicialismus pro „Jazyk blokového diagramu“.[8] ABL byla zavedena počátkem 80. let Centro Studi e Laboratori Telecomunicazioni (CSELT ) v italském Turíně, kde vyrábí grafický designový editor VLSI společnosti ABLED. V polovině 80. let 20. století byl kolem KARL a ABL implementován návrhový rámec VLSI mezinárodním konsorciem financovaným Komisí Evropské unie.[9]
Koncem sedmdesátých let 20. století se design používal programovatelná logická zařízení (PLD) se staly populární, i když tyto návrhy byly primárně omezeny na navrhování konečné stavové automaty. Práce na Obecné údaje v roce 1980 použila ke konstrukci stejná zařízení Data General Eclipse MV / 8000 a začala se rozvíjet komerční potřeba jazyka, který by jim dobře odpovídal. Do roku 1983 Datové I / O představil ABEL k vyplnění této potřeby.
Jak se design posunul k VLSI, první moderní HDL, Verilog, byl představen Automatizace návrhu brány v roce 1985. Cadence Design Systems později získal práva na Verilog-XL, HDL simulátor, který by se stal de facto standardem Verilogové simulátory pro příští desetiletí. V roce 1987 vedla žádost amerického ministerstva obrany k vývoji VHDL (VHSIC Hardware Description Language). VHDL byl založen na Programovací jazyk Ada, jakož i na zkušenostech získaných s dřívějším vývojem ISPS.[10] Zpočátku byly Verilog a VHDL použity k dokumentaci a simulaci návrhů obvodů již zachycených a popsaných v jiné formě (například schematické soubory). Simulace HDL umožnila technikům pracovat na vyšší úrovni abstrakce než simulace na schematické úrovni, a tím zvýšila konstrukční kapacitu ze stovek tranzistorů na tisíce.[Citace je zapotřebí ]
Zavedení logická syntéza pro HDL tlačil HDL z pozadí do popředí digitálního designu. Syntetické nástroje kompilovaly HDL zdrojové soubory (napsáno v omezeném formátu zvaném RTL) do vyrobitelného popisu netlistu, pokud jde o brány a tranzistory. Psaní syntetizovatelných souborů RTL vyžadovalo praxi a disciplínu ze strany návrháře; ve srovnání s tradičním schematickým uspořádáním byly syntetizované netlisty RTL téměř vždy větší v oblasti a pomalejší ve výkonu[Citace je zapotřebí ]. Návrh obvodu od zkušeného inženýra, který by využíval pracné schematické zachycení / ruční rozložení, by téměř vždy překonal svůj logicky syntetizovaný ekvivalent, ale výhoda produktivity, kterou syntéza získala, brzy posunula digitální schematické zachycení přesně do těch oblastí, které byly problematické pro Syntéza RTL: extrémně vysokorychlostní, nízkoenergetické nebo asynchronní obvody.
Během několika let se VHDL a Verilog ukázaly jako dominantní HDL v elektronickém průmyslu, zatímco starší a méně schopné HDL se postupně z používání vytratily. VHDL a Verilog však sdílejí mnoho stejných omezení, například nevhodnost pro analogové nebo obvod smíšeného signálu simulace. Specializované HDL (jako je Confluence) byly zavedeny s výslovným cílem opravit specifická omezení Verilogu a VHDL, ačkoli žádný z nich nikdy neměl nahradit.
V průběhu let bylo do zdokonalování HDL investováno velké úsilí. Nejnovější iterace Verilogu, formálně známá jako IEEE 1800-2005 SystemVerilog, zavádí mnoho nových funkcí (třídy, náhodné proměnné a vlastnosti / tvrzení), které řeší rostoucí potřebu lepšího zkušební stolice randomizace, návrhová hierarchie a opětovné použití. Budoucí revize VHDL je také ve vývoji[když? ], a očekává se, že bude odpovídat vylepšením SystemVerilog.
Design pomocí HDL
V důsledku zvýšení efektivity realizovaných pomocí HDL se točí kolem většiny moderních návrhů digitálních obvodů. Většina návrhů začíná jako soubor požadavků nebo architektonický diagram na vysoké úrovni. Kontrolní a rozhodovací struktury jsou často prototypovány vývojový diagram aplikace nebo zadané do a stavový diagram editor. Proces psaní popisu HDL je vysoce závislý na povaze obvodu a preferenci designéra pro styl kódování. HDL je pouze „zachytávací jazyk“, který často začíná algoritmickým popisem na vysoké úrovni, jako je matematický model C ++. Návrháři často používají skriptovací jazyky, jako je Perl automaticky generovat opakující se obvodové struktury v jazyce HDL. Speciální textové editory nabízejí funkce pro automatické odsazení, syntaxe závislé zbarvení a makro -rozšíření deklarace entity / architektury / signálu.
Kód HDL poté prochází kontrolou kódu nebo auditováním. V rámci přípravy na syntézu je popis HDL předmětem řady automatických dám. Checkers report devitions from standardized code guidelines, identify potential ambiguous code constructs before they can cause misinterpretation, and check for common logical coding errors, such as floating porty nebo zkratovaný výstupy. Tento proces pomáhá při řešení chyb před syntetizací kódu.
V průmyslovém jazyce návrh HDL obecně končí ve fázi syntézy. Jakmile nástroj pro syntézu mapuje popis HDL do netlistu brány, je netlist předán do back-end fáze. V závislosti na fyzikální technologii (FPGA, ASIC hradlové pole, ASIC standardní buňka ), HDL mohou nebo nemusí hrát významnou roli v back-end toku. Obecně platí, že jak návrhový tok postupuje směrem k fyzicky realizovatelné formě, návrhová databáze se postupně více obtěžuje technologickými informacemi, které nelze uložit do obecného popisu HDL. Nakonec je integrovaný obvod vyroben nebo naprogramován pro použití.
Simulace a ladění kódu HDL
Základní konstrukcí HDL je schopnost simulovat HDL programy. Simulace umožňuje projít popisem HDL designu (nazývaného model) ověření návrhu, důležitý milník, který ověřuje zamýšlenou funkci (specifikaci) designu proti implementaci kódu v popisu HDL. Umožňuje také architektonický průzkum. Inženýr může experimentovat s možnostmi návrhu napsáním několika variant základního návrhu a poté porovnat jejich chování v simulaci. Simulace je tedy zásadní pro úspěšný návrh HDL.
Pro simulaci modelu HDL inženýr napíše simulační prostředí nejvyšší úrovně (tzv. A zkušební stolice ). Testovací stůl obsahuje minimálně instanci modelu (nazývaného testované zařízení nebo DUT), deklarace pinů / signálů pro I / O modelu a tvar vlny hodin. Kód testbench je řízen událostmi: inženýr zapisuje příkazy HDL za účelem implementace (generovaného testbench) resetovacího signálu, modelování transakcí rozhraní (například čtení / zápis na hostitelské sběrnici) a sledování výstupu DUT. Simulátor HDL - program, který provádí testbench - udržuje hodiny simulátoru, což je hlavní reference pro všechny události v simulaci testbench. Události se vyskytují pouze v okamžicích diktovaných testovacím stolkem HDL (například reset-toggle kódovaný do testovacího stolku) nebo v reakci (podle modelu) na stimul a spouštěcí události. Moderní HDL simulátory mají všechny funkce grafická uživatelská rozhraní, doplněný sadou ladicích nástrojů. Umožňují uživateli kdykoli zastavit a restartovat simulaci, vložit hraniční body simulátoru (nezávisle na kódu HDL) a sledovat nebo upravovat libovolný prvek v hierarchii modelu HDL. Moderní simulátory mohou také prostřednictvím definovaného propojit prostředí HDL s uživatelsky kompilovanými knihovnami PLI /VHPI rozhraní. Propojení je závislé na systému (x86, SPARC běží atd Okna /Linux /Solaris ), protože simulátor HDL a uživatelské knihovny jsou kompilovány a propojeny mimo prostředí HDL.
Ověření návrhu je často časově nejnáročnější částí procesu návrhu, kvůli odpojení mezi zařízením funkční specifikace, návrhářův výklad specifikace a nepřesnost[Citace je zapotřebí ] jazyka HDL. Většina počátečního cyklu testování / ladění se provádí v HDL simulátor prostředí, protože raná fáze návrhu podléhá častým a zásadním změnám obvodu. Popis HDL lze také prototypovat a otestovat v hardwaru - programovatelná logická zařízení se k tomuto účelu často používají. Hardwarové prototypování je poměrně dražší než simulace HDL, ale nabízí skutečný pohled na design. Prototypování je nejlepší způsob, jak zkontrolovat propojení s jinými hardwarovými zařízeními a prototypy hardwaru. Dokonce i ti, kteří běží na pomalých FPGA, nabízejí mnohem kratší doby simulace než čistá simulace HDL.
Ověření návrhu pomocí HDL
Historicky bylo ověření návrhu pracnou, opakující se smyčkou psaní a simulace běhu testovací případy proti zkoušenému designu. Jak se návrhy čipů rozrostly a staly se složitějšími, úloha ověření návrhu se rozrostla do bodu, kdy nyní dominuje plánu designového týmu. Hledají se způsoby, jak zlepšit produktivitu designu, elektronická automatizace designu průmysl vyvinul Jazyk specifikace vlastnosti.
v formální ověření pojmy, vlastnost je věcné prohlášení o očekávaném nebo předpokládaném chování jiného objektu. V ideálním případě může být pro daný popis HDL vlastnost nebo vlastnosti prokázána jako pravdivá nebo nepravdivá pomocí formálních matematických metod. Z praktického hlediska mnoho vlastností nelze prokázat, protože zaujímají neomezené možnosti prostor řešení. Pokud je však poskytnuta sada provozních předpokladů nebo omezení, může kontrola vlastností prokázat (nebo vyvrátit) určité vlastnosti zúžením prostoru řešení.
Tvrzení nemodelují aktivitu obvodu, ale zachycují a dokumentují záměr návrháře v kódu HDL. V simulačním prostředí simulátor vyhodnocuje všechna zadaná tvrzení, hlásí umístění a závažnost případných porušení. V prostředí syntézy nástroj pro syntézu obvykle pracuje s politikou zastavení syntézy při jakémkoli porušení. Ověření založené na tvrzení je stále v plenkách, ale očekává se, že se stane nedílnou součástí sady návrhových nástrojů HDL.
HDL a programovací jazyky
HDL je hrubě podobný softwaru programovací jazyk, ale existují velké rozdíly. Většina programovacích jazyků je ze své podstaty procesní (single-threaded), s omezenou syntaktickou a sémantickou podporou pro zpracování konkurence. HDL se naproti tomu podobají souběžné programování jazyky v jejich schopnosti modelovat více paralelních procesů (např žabky a sčítače ), které se automaticky provádějí nezávisle na sobě. Jakákoli změna vstupu procesu automaticky spustí aktualizaci v zásobníku procesů simulátoru.
Oba programovací jazyky a HDL jsou zpracovávány kompilátorem (v případě HDL se často nazývá syntezátor), ale s jinými cíli. Pro HDL označuje „kompilace“ logická syntéza; proces transformace výpisu kódu HDL na fyzicky realizovatelnou bránu netlist. Výstup netlistu může mít jakoukoli z mnoha podob: netlist „simulace“ s informacemi o zpoždění brány, netlist „handoff“ pro postsyntézu umístění a směrování na polovodičové matrici nebo obecném průmyslovém standardu Formát elektronické výměny designu (EDIF) (pro následnou konverzi na a JEDEC -formátový soubor).
Na druhou stranu softwarový kompilátor převede výpis zdrojového kódu na a mikroprocesor - specifický objektový kód pro provedení na cílovém mikroprocesoru. Jelikož si HDL a programovací jazyky navzájem půjčují koncepty a funkce, hranice mezi nimi se stává méně zřetelnou. Čisté HDL jsou však nevhodné pro obecné účely aplikační software rozvoj,[proč? ] stejně jako univerzální programovací jazyky jsou pro modelování hardwaru nežádoucí.
Jak se však elektronické systémy stávají stále složitějšími, a rekonfigurovatelné systémy čím dál častější, v průmyslu roste touha po jediném jazyce, který může provádět některé úkoly jak při návrhu hardwaru, tak při programování softwaru. SystemC je příkladem takových -vestavěný systém hardware lze modelovat jako nedetailní architektonické bloky (černé skříňky s modelovanými vstupními a výstupními budiči signálu). Cílová aplikace je napsána v C nebo C ++ a nativně kompilována pro systém vývoje hostitele; na rozdíl od cílení na vestavěný CPU, který vyžaduje simulaci hostitele vestavěného CPU nebo emulovaného CPU.
Vysoká úroveň abstrakce modelů SystemC je vhodná pro začátek průzkum architektury, protože architektonické úpravy lze snadno vyhodnotit s malým zájmem o problémy s implementací na úrovni signálu. Model vláken použitý v SystemC však spoléhá na sdílená paměť, což způsobí, že jazyk nebude dobře zpracovávat paralelní provádění nebo modely nižší úrovně.
Syntéza na vysoké úrovni
Ve své úrovni abstrakce byly HDL srovnávány s montážní jazyky.[Citace je zapotřebí ] Existují pokusy o zvýšení úrovně abstrakce návrhu hardwaru, aby se snížila složitost programování v HDL a vytvořilo se podpole s názvem syntéza na vysoké úrovni.
Společnosti jako Kadence, Synopsys a Agility Design Solutions se propagují SystemC jako způsob, jak kombinovat jazyky na vysoké úrovni s modely souběžnosti, které umožňují rychlejší návrhové cykly FPGA než je možné pomocí tradičních HDL. Přístupy založené na standardu C nebo C ++ (s knihovnami nebo jinými rozšířeními umožňujícími paralelní programování) se nacházejí v Katapult C. nástroje od Mentor Graphics a Impulse C. nástroje od Impulse Accelerated Technologies.
Annapolis Micro Systems CoreFire Design Suite, Inc.[11] a Národní nástroje LabVIEW FPGA poskytuje grafiku datový tok přístup ke vstupu na vysoké úrovni designu a jazyků, jako je SystemVerilog, SystemVHDL a Handel-C usilují o dosažení stejného cíle, ale jejich cílem je zvýšit produktivitu stávajících hardwarových inženýrů, spíše než zpřístupnit stávající FPGA stávajícím softwaroví inženýři.
Je také možné navrhnout hardwarové moduly pomocí MATLAB a Simulink za použití MathWorks Nástroj HDL Coder[12] nebo Xilinx System Generator (XSG) (dříve Accel DSP) z Xilinx.[13]
Příklady HDL
HDL pro design analogových obvodů
název | Popis |
---|---|
Popisný jazyk analogového hardwaru | an otevřeno analogový hardware popisný jazyk |
SpectreHDL | patentovaný jazyk popisu analogového hardwaru |
Verilog-AMS (Verilog pro analogový a smíšený signál) | otevřený standard rozšiřující Verilog pro analogovou a smíšenou analogovou / digitální simulaci |
VHDL-AMS (VHDL s rozšířením o analogový / smíšený signál) | standardizovaný jazyk pro smíšenou analogovou / digitální simulaci |
HDL-A | patentovaný jazyk popisu analogového hardwaru |
HDL pro design digitálních obvodů
Dvě nejpoužívanější a nejlépe podporované odrůdy HDL používané v průmyslu jsou Verilog a VHDL.
název | Popis |
---|---|
Advanced Boolean Expression Language (ABEL) | |
Altera Popis hardwaru Jazyk (AHDL) | proprietární jazyk z Altera |
AHPL | Hardwarový programovací jazyk |
Bluespec | HDL na vysoké úrovni na základě Haskell (není vloženo DSL )[14] |
Bluespec SystemVerilog (BSV) | na základě Bluespec, s Verilog Syntaxe HDL, podle Bluespec, Inc. |
C-to-Verilog | Převaděč z C na Verilog |
Dláto (Konstrukce hardwaru v jazyce Scala Embedded)[15] | na základě Scala (vloženo DSL ) |
Střet Clash Moderní, funkční jazyk popisu hardwaru | Clash je funkční jazyk pro popis hardwaru, který si vypůjčuje syntaxi i sémantiku z funkčního programovacího jazyka Haskell |
COLAMO (Společně orientovaný jazyk pro architekturu více objektů)[16] | proprietární jazyk společnosti „Supercomputers and Neurocomputers Research Center“ Co Ltd. |
Soutok | funkční HDL; byla ukončena |
CoWareC | HDL na bázi C od CoWare. Nyní ukončeno ve prospěch SystemC |
CUPL (kompilátor pro univerzální programovatelnou logiku)[17] | proprietární jazyk z Logical Devices, Inc. |
ELLA | již se běžně nepoužívá |
ESys.net | .NET Framework napsáno v C # |
Handel-C | designový jazyk podobný písmenu C. |
Hardcaml (Konstrukce hardwaru v integrovaném jazyce Ocaml) | na základě OCaml (vložený DSL). Zkus to online. |
HHDL | na základě Haskell (vložený DSL). |
Hardware Připojte se k Javě (HJJ) | na základě Připojte se k Javě |
HML (hardware ML) | na základě Standardní ML[18] |
Hydra | na základě Haskell |
Impulse C. | další HDL typu C |
ISPS | Originální HDL od CMU, již se běžně nepoužívá |
ParC (Paralelní C ++) | kusu rozšířeno o vlákna HDL a komunikaci pro paralelní programování úkolů |
JHDL | na základě Jáva |
KARL | KAiserslautern Register Language (kapitola v),[9] pascalishský popisný jazyk hardwaru, který se již běžně nepoužívá. |
Láva | na základě Haskell (vložený DSL).[19][20][21][22] |
Lola | jednoduchý jazyk používaný pro výuku |
M | HDL z Mentor Graphics |
MyHDL | na základě Krajta (vloženo DSL ) |
nMigen | na základě Krajta |
PALASM | pro Programovatelná logika pole (PAL) zařízení |
PyMTL | založený na Pythonu z Cornell University |
ROCCC (Riverside Optimizing Compiler for Configurable Computing) | Zdarma a open-source nástroj C na HDL |
RHDL | založeno na Programovací jazyk Ruby |
Ruby (jazyk popisu hardwaru) | |
SystemC | standardizovaná třída knihoven C ++ pro modelování chování a transakcí na vysoké úrovni digitální hardware na vysoké úrovni abstrakce, tj. na úrovni systému |
SystemVerilog | nadmnožina Verilogu s vylepšeními zaměřenými na návrh a ověřování na úrovni systému |
SpinalHDL | Na základě Scala (vložený DSL) |
SystemTCL | SDL na základě Tcl. |
THDL ++ (Templated HDL inspirovaný C ++) | Rozšíření VHDL s dědičností, pokročilými šablonami a třídami zásad |
TL-Verilog (Verilog na úrovni transakce) | Rozšíření Verilog / SystemVerilog s konstrukty pro potrubí a transakce. |
Verilog | Jeden z nejčastěji používaných a dobře podporovaných HDL |
VHDL (VHSIC HDL) | Jeden z nejčastěji používaných a dobře podporovaných HDL |
HDL pro design desek plošných spojů
Existuje několik projektů k definování tištěný spoj připojení pomocí jazykových metod zadávání textu.
název | Popis |
---|---|
PHDL (PCB HDL) | Bezplatný a otevřený zdroj HDL pro definování připojení desek plošných spojů |
EDAsolver | HDL pro řešení schematických návrhů na základě omezení |
SKiDL | Open source pythonový modul pro návrh elektronických obvodů |
Viz také
- Specifikační jazyk
- Modelovací jazyk
- Jazyk ověření hardwaru
- SystemC
- SystemVerilog
- Jazyk specifikace vlastnosti
- OpenVera
- Bluespec
- C až HDL
- Tok do HDL
- Rosetta-lang
Reference
- ^ Ciletti, Michael D. (2011). Pokročilý digitální design s Verilog HDL (2. vyd.). Prentice Hall. ISBN 9780136019282.
- ^ Lutellier, T .; Chollak, D .; Garcia, J .; Tan, L .; Rayside, D .; Medvidovic, N .; Kroeger, R. (2015). "Porovnání technik obnovy softwarové architektury pomocí přesných závislostí". 2015 IEEE / ACM 37. mezinárodní konference IEEE o softwarovém inženýrství, Florencie. str. 69–78. doi:10.1109 / ICSE.2015.136. ISBN 978-1-4799-1934-5.
- ^ Bell, C. G .; Newell, A. (1971). Počítačové struktury: čtení a příklady. McGraw-Hill. ISBN 0-07-004357-4.
- ^ Reilly, E.D. (2003). Milníky v informatice a informačních technologiích. Greenwood Press. str.183. ISBN 1-57356-521-0.
- ^ Bell, C.G .; Grason, J .; Newell, A. (1972). Navrhování počítačů a digitálních systémů. Digitální tisk. LCCN 72-89566. OCLC 440245727.
- ^ Barbacci, M.C. (1976). "Symbolická manipulace s popisy počítačů: ISPL překladač a simulátor". Ústav výpočetní techniky, Carnegie-Mellon University. doi:10.1184 / R1 / 6610790.v1. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ Barbacci, M.C .; Barnes, G. E.; Cattell, R.G.G .; Siewiorek, D.P. (1977). "Jazyk popisu počítače ISPS". Ústav výpočetní techniky, Carnegie-Mellon University. doi:10.1184 / R1 / 6610637.v1. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ Girardi, G .; Hartenstein, R. (1983). Specifikace ABL (zpráva). CSELT a University of Kaiserslautern.
- ^ A b Hartenstein, Reiner W. (2012) [1993], „KARL a ABL“, v Mermet, J. (ed.), Základy a standardy v jazycích popisu hardwaru, Věda NATO série E, 249, Springer, str. 447–, ISBN 9789401119146
- ^ Barbacci, M.C .; Grout, S .; Lindstrom, G .; Maloney, M.P. (1984). "Ada jako jazyk popisu hardwaru: počáteční zpráva". Ústav výpočetní techniky, Carnegie-Mellon University. CiteSeerX 10.1.1.938.8003. doi:10.1184 / R1 / 6602984.v1. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ „Programový aplikační softwarový nástroj založený na VHDL FPGA“. Annapolis Micro Systems, Inc.. Citováno 2018-12-01.
- ^ „VHDL code - HDL Coder - MATLAB & Simulink“. Mathworks.com. 2011-04-30. Citováno 2012-08-11.
- ^ "Generátor systému pro DSP". Xilinx.com. Archivovány od originál dne 2012-07-12. Citováno 2012-08-11.
- ^ Historie Haskella: být líný s třídou §12.4.2
- ^ "Rámec hardwarového kompilátoru sekáč / FIRRTL".
- ^ "Jazyk vyšší úrovně COLAMO | НИЦ супер-ЭВМ и нейрокомпьютеров".
- ^ Eurich, J.P .; Roth, G. (1990). "EDIF vyroste". IEEE Spectrum. 27 (11): 68–72. doi:10.1109/6.62219.
- ^ Yanbing Li; Leeser, M. (1995). "HML: Inovativní jazyk popisu hardwaru a jeho překlad do VHDL". Sborník ASP-DAC'95 / CHDL'95 / VLSI'95 s EDA Technofair. 691–696. doi:10.1109 / ASPDAC.1995.486388. ISBN 4-930813-67-0.
- ^ Chalmers Lava
- ^ Xilinx Lava
- ^ Kansas Lava
- ^ York Lava
externí odkazy
- Technický podvýbor Verilog-AMS
- HCT - Nástroj HDL Complexity, který se používá ke stanovení složitosti návrhu.