# 2 ZÁKLADNÉ LOGICKÉ HRADLÁ NOR, OR, AND, NAND

Projekt ukazuje postup jednoduchého návrhu "krok za krokom" vo vývojom systéme Quartus II – vytvorenie nového projektu, nových súborov návrhu, kompiláciu, simuláciu a programovanie. Projekt je vytvorený vo vývojom systéme Quartus II ver.4.2.

# 2.1 ZADANIE PRÍKLADU Č.1

Vo vývojovom prostredí Quartus II realizujte projekt na rozsvietenie desatinnej bodky MSD (MSD\_dp) sedem segmentovej LED stlačením jedného z tlačidiel (PB1, PB2) na vývojovej doske UP1 CPLD. Návrh realizujte v grafickom editore. Čísla použitých pinov a ich funkcie sú uvedené v tabuľke č.1.

| Meno pinu | Typ pinu | Pin | Funkcia pinu                                        |  |  |
|-----------|----------|-----|-----------------------------------------------------|--|--|
| PB1       | Vstup    | 28  | Tlačidlo 1 (0 = stlačené tlačidlo)                  |  |  |
| PB2       | Vstup    | 29  | Tlačidlo 2 (0 = stlačené tlačidlo)                  |  |  |
| MSD_dp    | Výstup   | 14  | Desatinná bodka sedem segmentovej LED (0 = LED ON = |  |  |
|           |          |     | svieti, 1 = LED OFF= nesvieti)                      |  |  |

Tab.1: Tabuľka pinov

## 2.2 RIEŠENIE PRÍKLADU Č.1

Úlohu môžeme riešiť návrhom logického obvodu, ktorý zmení logickú hodnotu pinu na ktorý je pripojená desatinná bodka MSD sedem segmentovej LED pri stlačení ľubovoľného tlačidla, PB1 alebo PB2. Takýto logický obvod môžeme realizovať použitím základného logického hradla NOR, ktorý má dva vstupy (PB1 a PB2) a jeden výstup (MSD\_dp). Tlačidlá PB1, PB2 a segment LED MSD\_dp na vývojovej doske UP1 sú zapojené podľa obr.1.



Obr.1: Schéma zapojenia PB1, PB2 a LED na vývojovej doske UP1 CPLD

# 2.3 Postup riešenia vo vývojom prostredí Quartus II

### 2.3.1 VYTVORENIE NOVÉHO PROJEKTU

Nový projekt vytvoríme voľbou **New Project Wizard** z **File menu**, po ktorej sa objaví úvodné okno (obr.2). Kliknutím na tlačidlo **Next** sa objaví sa prvé okno (**New Projekt Wizard**), kde sa definuje miesto uloženia a názov projektu a entity (obr.3).

| ew Project Wizard: In                                                                                                                                                                                                                                             | troduction                                                                                                                                                                                                                  |                                                                                          |                                                                                                                    |                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| The New Project Wizard h<br>the following:<br>Project name and dir<br>Name of the top-leve<br>Design files, other so<br>Device and family to<br>EDA tool settings<br>You can change the settin<br>settings with the Settings dialo<br>Settings, and the Default L | elps you enter settings t<br>ectory<br>I design entity<br>urce files, and libraries t<br>be used for compilation<br>gs for an existing projec<br>ommand (Assignments<br>g box, including the Tim<br>ogic Option Settings pa | hat apply to<br>o be used in<br>t and speci<br>menu). You<br>ming Setting<br>ges, to add | p your entire pro<br>n the project<br>fy additional pro<br>i can use the v<br>s, the Default F<br>functionality to | pject, including<br>pject-wide<br>arious<br>arameter<br>the project. |
| ☐ Don't show me this intr                                                                                                                                                                                                                                         | oduction again                                                                                                                                                                                                              |                                                                                          |                                                                                                                    |                                                                      |

Obr.2: Úvodné okno pri vytváraní nového projektu vo vývojovom prostredí Quartus II

Kliknutím na tlačidlo prvého riadku, sa objaví okno, kde si môžeme vybrať cestu k adresáru, do ktorého uložíme projekt a do ktorého budú ukladané všetky vytvárané súbory, alebo si môžeme vytvoriť nový adresár. Pre tento projekt si vytvoríme adresár *NORHRADLO*. V druhom riadku definujeme názov projektu a v treťom názov najvyššej úrovne entity. Názov projektu a entity môže, ale nemusí, byť taký istý ako názov adresára do ktorého budeme ukladať projekt (väčšinou sa volia rovnaké). Pre tento projekt definujeme rovnaký názov projektu aj názov entity ako je názov adresára – *norhradlo*. Ak sme v prvom okne všetko zadefinovali klikneme na tlačidlo **Next**.

|                   | New Project Wizard: Directory, Name , Top-Level Entity [page 1 of 5] 🛛 🔀                                                                                    |  |  |  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                   | What is the working directory for this project?                                                                                                             |  |  |  |  |  |  |
| Adresár           | D:\dokumenty\rumik\tuke\diplomovka\kapitoly ku diplomovke\tyzden_02\NORHR                                                                                   |  |  |  |  |  |  |
| projektu          | , What is the name of this project?                                                                                                                         |  |  |  |  |  |  |
| Meno              | NORHRADLO                                                                                                                                                   |  |  |  |  |  |  |
| projektu          | What is the name of the top-level design entity for this project? This name is case sensitive<br>and must exactly match the entity name in the design file. |  |  |  |  |  |  |
| meno<br>naivvššei | NORHRADLO                                                                                                                                                   |  |  |  |  |  |  |
| úrovne<br>entity  | Use Existing Project Settings                                                                                                                               |  |  |  |  |  |  |
|                   |                                                                                                                                                             |  |  |  |  |  |  |
|                   |                                                                                                                                                             |  |  |  |  |  |  |
|                   |                                                                                                                                                             |  |  |  |  |  |  |
|                   |                                                                                                                                                             |  |  |  |  |  |  |
|                   | < Back Next > Finish Storno                                                                                                                                 |  |  |  |  |  |  |

*Obr.3: Prvé okno voľby* **New Projekt Wizard** – okno definície miesta, najvyššej úrovne a názvu entity

V nasledujúcom okne priradzujeme súbory do projektu. Napríklad, ak v nejakom inom projekte je vytvorený VHDL kód, ktorý budeme používať aj v novom projekte, tak si ho tu môžeme pridať (obr.4). V tomto projekte nebudeme pridávať žiaden súbor – klikneme na **Next**.

| Project Wizard:<br>elect the design files j<br>the project directory | Add Files [page 2 of 5]<br>you want to include in the project. Note: you can a | ct. Click Add All to a<br>Iways add design file | dd all design file<br>s to the project |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------|
| ile name:                                                            |                                                                                |                                                 | <u>A</u> dd                            |
| File name                                                            |                                                                                | Туре                                            | Add A <u>l</u> l                       |
|                                                                      |                                                                                |                                                 | <u>R</u> emove                         |
|                                                                      |                                                                                |                                                 | Properties                             |
|                                                                      |                                                                                |                                                 | Up                                     |
|                                                                      |                                                                                |                                                 | Down                                   |
|                                                                      |                                                                                |                                                 |                                        |
|                                                                      |                                                                                |                                                 |                                        |
| pecify the path name:                                                | s of any non-default libraries.                                                | U <u>s</u> er Libraries                         |                                        |
|                                                                      | < Back Next                                                                    | > Finish                                        | Storno                                 |

Obr.4: Druhé okno voľby New Project Wizard – okno, priradenia súborov do projektu

Objaví sa okno – tretie okno voľby **New project Wizard**, v ktorom si definujeme rodinu obvodov, v našom prípade rodinu FLEX10K.

V časti **Target device** zaškrtneme možnosť *Specific devices selected in 'Available devices' list.* 

V spodnom okne vyberieme presný typ obvodu, s ktorým chceme pracovať. V našom prípade súčiastku EPF10K20RC240-4. Vo web verzii vývojového prostredia Quartus II ver.4.2 sa súčiastka EPF10K20RC240-4 nemusí nachádzať. Potom zvolíme súčiastku EPF10K20RC240-3. Rozdiel je len v rýchlosti logiky súčiastok.

Vo štvrtom okne **New project Wizard** si môžeme nastaviť nástroje EDA. Tu nebudeme nič nastavovať.

V poslednom okne - piate okno voľby **New Project Wizard**, sú zobrazené všetky voľby a nastavenia, ktoré sme v predchádzajúcich krokoch vykonali. Ak je všetko v súlade s našimi požiadavkami, klikneme na tlačidlo **Finish**. Ak niektoré nastavenie nevyhovuje, vrátime sa k príslušnej voľbe nastavenia tlačidlom **Back**. (obr.5)

| olomovka/kapitoly ku diplomovke/NORHRADLO/ |
|--------------------------------------------|
|                                            |
| NORHRADLO                                  |
| NORHRADLO                                  |
| 0                                          |
| 0                                          |
|                                            |
| FLEX10K                                    |
| EPF10K20RC240-3                            |
|                                            |
| <none></none>                              |
| (None)                                     |
| 110107                                     |
|                                            |

Obr.5: Posledné okno voľby New Projekt Wizard – zobrazuje všetky nastavenia

Po potvrdení všetkých nastavení v **New Project Wizard**, Quartus II vytvorí tieto súbory:

release.fsf – súbor, v ktorom sú definované nastavenia softvéru

debug.fsf - súbor, v ktorom sú tiež nastavenia pre softvér

norhradlo.ssf – súbor, v ktorom sú definované nastavenia simulátora

norhradlo.csf - súbor, obsahujúci nastavenia kompilátora

*norhradlo.psf* – súbor, ktorý obsahuje preddefinované nastavenia pomocníka pri návrhu (**Design Assistant**)

norhradlo.qpf - súbor, ktorý reprezentuje projekt

Okrem týchto súborov sa vygeneruje aj adresár *db*, do ktorého sa ukladajú pomocné súbory.

# **2.3.2** VYTVORENIE NÁVRHU SCHÉMATICKÝM/GRAFICKÝM EDITOROM (*súbor.bdf*)

Tento súbor vytvoríme vykonaním nasledujúcich krokov:

- Vyberieme položku New z File menu
- V záložke Design Files si zvolíme možnosť Block Diagram/Schematic File (obr.6)

| New                                                                                                                                       | X      |
|-------------------------------------------------------------------------------------------------------------------------------------------|--------|
| Device Design Files Software Files Other Files<br>AHDL File<br>Block Diagram/Schematic File<br>EDIF File<br>Verilog HDL File<br>VHDL File |        |
| ОК                                                                                                                                        | Cancel |

Obr.6: Výber možnosti Block Diagram/Schematic File

- Kliknutím na OK sa otvorí okno blokového editora
- Vyberieme položku Save As z File menu
- Vyberieme adresár NORHRADLO a uložíme náš súbor, ktorý nazveme norhradlo.bdf. Pod riadkom, kde sa definuje názov projektu zaškrtneme Add file to curent project (pridať súbor do aktuálneho projektu).
- Potvrdíme tlačidlom Save. Tým sme uložili aj vložili súbor do projektu.

#### 2.3.3 VYTVORENIE (NAKRESLENIE) SCHÉMY

Schému vytvoríme nasledujúcim postupom:

• Na panely nástrojov (obr.7) klikneme na Symbol Tool



Obr.7: Panel nástrojov

- V okne Libraries, ktoré sa objaví vyberieme
   c:\quartus\libraries\→primitives→logic
- Z adresára *logic* vyberieme symbol BNOR2 a potvrdíme stlačením OK (obr.8)



Obr.8: Výber prvku

- Symbol umiestnime na požadované miesto pohybom myšky a vložíme ho kliknutím ľavého tlačidla
- Klikneme na Symbol Tool

• Z adresára **pin** vyberieme a umiestnime na požadované miesto symbol **input** (vstup) dvakrát a potom symbol **output** (výstup)

Jednotlivé vývody prepojíme vodičmi tak, že klikneme na **Orthogonal Node Tool**, priblížime sa s myšou k vývodu (vstupu alebo výstupu) symbolu a ak sa kurzor myši zmení na krížik klikneme a držíme ľavé tlačidlo myši a zároveň sa pohybujeme k vývodu ktorý chceme spojiť.

Názov a hodnotu priradíme k pinom tak, že klikneme na pin pravým tlačidlom myši, zobrazí sa tabuľka, z ktorej vyberieme položku **Properties.** Zobrazí sa nám okno v ktorom môžeme zadefinovať názov príslušného pinu, v riadku **pin name(s)** zadefinujeme názov pinu (PB1, PB2, MSD\_dp) a v riadku **Default value** hodnotu vstupného pinu (VCC). (Výsledná schéma je znázornená na obr.9)



Obr.9: Výsledná schéma návrhu v blokovom editore

Pinom priradíme ich prislúchajúce čísla príkazom **Pins** v **Assigments menu** (obr.10). Do riadku z názvom **Edit**, v editovacom okne, napíšeme názov pinu (**PB1**). Potvrdíme Entrom, alebo stlačením tlačidla so zelenou fajkou. Tento názov pinu sa zobrazí v okne pod editovacím oknom. V príslušnom riadku dvakrát klikneme na kolónku v stĺpci s názvom **Location**, vyberieme číslo pinu a opäť potvrdíme Entrom.

| 🏈 Assi       | gnment Editor             |                       |                           |                  | _ 🗆 🛛               |
|--------------|---------------------------|-----------------------|---------------------------|------------------|---------------------|
| ×<br>jj ± (  | Tategory: Pin             |                       | J                         | 😧 All 🖻 Pin 💍    | Timing Disc Options |
| ×<br>∐ ± №   | Node Filter: Click the N  | lode Filter button to | view more options         |                  |                     |
| <u>×</u> ± 1 | information: This cell sp | ecifies the pin name  | to which you want to make | an assignment.   |                     |
| ≚<br>∬ E     | idit: 🛛 🗙 🗸 M             | SD_Dp                 |                           |                  |                     |
|              | То                        | Location              | General Function          | Special Function | Reserved            |
| 1            | MSD_Dp                    | PIN_14                | Row I/O                   |                  |                     |
| 2            | PB1                       | PIN_28                | Row I/O                   |                  |                     |
| 3            | 🔷 PB2                     | PIN_29                | Row I/O                   |                  |                     |
| 4            | < <new>&gt;</new>         | < <new>&gt;</new>     |                           |                  |                     |
|              |                           |                       |                           |                  |                     |

Obr.10: Priradenie pinov

V prípade pinov PB2 a MSD\_dp postupujeme rovnako ako pri pine PB1. Zadefinovaním všetkých pinov okno zavrieme a zmeny uložíme.

#### 2.3.4 KOMPILÁCIA

Kompilátor v softvéry Quartus II obsahuje niekoľko modulov, ktoré môžeme využiť pri práci s návrhom. Ide o moduly:

- Analysis & Syntesis (Analýza a syntéza)
- Fitter (nástroj na rozmiestnenie a prepojovanie)
- Assembler (Asemblér)
- Timing Analyzer (Časová analýza)

V Quartus II sa môžu moduly spustiť naraz, alebo voľbou **Processing menu**  $\rightarrow$ Start môže spúšťať jednotlivé moduly aj samostatne. (napr.: **Procesing menu**  $\rightarrow$ Start  $\rightarrow$  Start Fitting).

#### Spustenie kompilácie

Kompiláciu môžeme spustiť voľbou **Start Compilation** z **Processing menu**, pomocou ikony na panely nástrojov, alebo prostredníctvom príkazu **Compiler Tool** z **Tools** menu (obr.11).

| 👼 Compiler Tool      |         |           |                 | _ 🗆 🔀              |
|----------------------|---------|-----------|-----------------|--------------------|
| Analysis & Synthesis | Fitter  | Assembler | Timing Analyzer | EDA Netlist Writer |
| 0%                   | 0 %     | 0 %       | 0%              | 0 %                |
|                      |         |           |                 |                    |
|                      | 🕄 🞲 🥋 😻 |           | N               |                    |
|                      |         | 0.0       |                 |                    |
|                      |         | U %       |                 |                    |
|                      |         | 00:00:00  |                 |                    |
| ► Start              |         | T Stop    |                 | \ominus Report     |

Obr.11: Prostriedky kompilácie

Po spustení kompilácie sa automaticky zobrazia tieto okná :

• Status Window (obr.12): v tomto okne môžeme sledovať priebeh kompilácie. Môžeme pozorovať čas, za ktorý jednotlivé moduly spracovali projekt, aj celkový čas kompilácie. Okrem toho je tu znázornená aj miera úspešnosti celkovej kompilácie a jednotlivých modulov v percentách.



Obr.12: Stav kompilácie

 Norhladlo Compililation Report (obr.13): Okno je rozdelené na dve časti: ľavé okno a pravé okno. V ľavom okne sú uvedené výsledky kompilácie, usporiadané do adresárov, v stromovej štruktúre, ktoré obsahujú súbory podľa toho, ktorým modulom boli generované. V pravom okne sú zobrazené najdôležitejšie výsledky kompilácie.

| Ocompilation Report                                                                                                                                 |                                                                                                                                                                                                                        |                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Compilation Report<br>Legal Notice<br>Flow Summary<br>Flow Elapsed Time<br>Flow Log<br>Analysis & Synthesis<br>Fitter<br>Sampler<br>Timing Analyzer | Flow Summary<br>Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Met timing requirements<br>Total logic elements<br>Total pins<br>Total memory bits | Successful - Thu Mar 24 22:36:33 2005<br>4.2 Build 178 01/19/2005 SP 1 SJ Web Edition<br>norhradlo<br>FLEX10K<br>EPF10K20RC240-4<br>Final<br>Yes<br>9 / 1,152 ( < 1 % )<br>10 / 189 ( 5 % )<br>0 / 12,288 ( 0 % ) |

Obr.13: Okno výsledkov kompilácie

Message Window (obr.14): V tomto okne sú zobrazované všetky správy, ktoré sú počas kompilácie generované. Zobrazené správy môžu byť: informačné, varovné a chybové . Ak sa objavia chybové správy, Quartus II umožňuje lokalizovať túto chybu priamo v súbore návrhu (dvojklik ľavým tlačidlom myši na správu). Okrem toho ponúka aj pomoc pri odstránení chyby (kliknutím na správu pravým tlačidlom sa zobrazí tabuľka, v ktorej vyberieme položku Help).



Obr.14: Okno správ

Po úspešnej kompilácii môžeme projekt simulovať a konfigurovať.

Súbory, ktoré vznikajú pri kompilácii sú: norhradlo.map.rpt – súbor správ generovaný modulom analýzy a syntézy norhradlo.fit.rpt – súbor správ generovaný modulom na rozmiestnenie a prepojovanie norhradlo.asm.rpt – súbor správ generovaný asemblérom norhradlo.tan.rpt – súbor správ generovaný časovým analyzátorom norhradlo.map.eqn – súbor operácií (výpočtov), ktoré vykonáva modul analýzy a syntézy norhradlor.fit.eqn – súbor operácií (výpočtov), ktoré vykonáva fitter norhradlo.pin – súbor, kde sú definované priradenia pinov norhradlo.done – čas a dátum vytvorenia projektu norhradlo.pof – súbor POF obsahujúci údaje na programovanie norhradlo.sof – súbor SOF obsahujúci údaje na programovanie SRAM

Po kompilácii môžeme otvoriť **Floorplan editor** (obr.15), ktorý slúži na zobrazenie plánu priestorového usporiadania obvodu (čipu) - usporiadanie buniek, makrobuniek, LAB. V okne môžeme sledovať všetky umiestnenia a prepojenia v obvode, čas jednotlivých prepojení, kritické prepojenia, vstupné a výstupné vetvenia.



Obr.15: Floorplan editor

## 2.3.5 SIMULÁCIA PROJEKTU

Po úspešnej kompilácii môžeme projekt simulovať. Simuláciu vykonáme nasledovným postupom:

Vytvoríme vektorový súbor priebehu signálov – Vector Waveform file (.vwf), voľbou New z File menu (obr.16).

| A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Mas       | ter Time | e Bar: 11.925 ns | Pointer: | 200 ps Interv | val: -11.73 ns | Start: | End: |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|------------------|----------|---------------|----------------|--------|------|
| Æ€                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\square$ |          | Value at         | 0 ps     | 10.1          | 0 ns           | 20.    | 0 ns |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           | Name     | 11.93 ns         |          |               | 11.925 ns      |        |      |
| <b># 1</b> 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |          |                  |          |               |                |        |      |
| $\forall \overline{v} \overset{\mathbf{x}}{\leadsto}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |          |                  |          |               |                |        |      |
| 유 나                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |          |                  |          |               |                |        |      |
| z Xū                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |          |                  |          |               |                |        |      |
| $\sum_{i=1}^{n} \sum_{j=1}^{n} \sum_{i=1}^{n} \sum_{i=1}^{n} \sum_{i=1}^{n} \sum_{j=1}^{n} \sum_{i=1}^{n} \sum_{i=1}^{n} \sum_{i=1}^{n} \sum_{i=1}^{n} \sum_{i$ |           |          |                  |          |               |                |        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |          |                  |          |               |                |        |      |
| $\langle \underline{c} \rangle \langle \underline{\delta} \rangle$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |          |                  |          |               |                |        |      |
| $\langle \underline{2} \rangle \langle \underline{B} \rangle$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |          |                  |          |               |                |        |      |
| <mark>₽</mark> Å↓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |          |                  |          |               |                |        |      |

Obr.16: Okno vektorového súboru

- Pomocou voľby **Save As** z **File** menu uložíme tento vektorový súbor, v tomto prípade s názvom *norhradlo.vwf*
- Pomocou Node Finder (obr.17) vložíme do tohto súboru všetky vstupy a výstupy (stimuly), ktoré chceme simulovať. Node Finder otvoríme nasledujúcim postupom:
   View→ UtilityWindows→ Node Finder. Onačíme požadované piny (Shift + ľavé tlačidlo myši), skopírujeme ich (Ctrl+C) a vložíme do vektorového súboru (Ctrl+V). Druhou možnosťou je chytiť myšou požadovaný pin a jednoducho ho presunúť do vektorového súboru (.*vwf*). V našom prípade presunieme piny: PB1, PB2 a MSD\_dp.

| Node Finder         |             |                   | ×            |
|---------------------|-------------|-------------------|--------------|
| Named: Filter: Pin  | s: all 💌    | Customiz          |              |
| LOOK IN: JUITITALIO | <u> </u>    | . I 🗸 Include sul | pentities    |
| Nodes Found:        |             |                   |              |
| Name                | Assignments | Туре              | Creator      |
|                     | PIN_14      | Output            | User entered |
| PB1                 | PIN_28      | Input             | User entered |
| ₽B2                 | PIN_29      | Input             | User entered |
|                     |             |                   |              |
|                     |             |                   |              |
|                     |             |                   |              |
|                     |             |                   |              |
|                     |             |                   |              |
|                     |             |                   |              |
| 1                   |             |                   |              |

Obr.17: Okno Node finder

- Nastavíme koncový čas simulácie. V položke Edit→End Time, nastavíme hodnotu time na 100µs.
- Klikneme pravým tlačidlom myši na pin PB1 V tabuľke ktorá sa objaví vyberieme Value→Count Value. Zobrazí sa okno (obr.18), kde zadefinujeme v záložke Timing→End Time: 100µs a Cout Event: 20µs. Pre pin PB2 postup opakujeme a zadefinujeme: End Time: 100µs a Count Event: 10µs. (Môžeme zadefinovať aj iné hodnoty).

| Count Value 🛛 🛛 🛛             |
|-------------------------------|
| Counting Timing               |
| Start time: 0 ps 💌            |
| End time: 100.0 us 💌          |
| Transitions occur             |
| C Relative to clock settings: |
| C Positive edge               |
| C Negative edge               |
| Offset:                       |
| At absolute times:            |
| Count every: 20.0 us 💌        |
| Multiplied by: 1              |
|                               |
| OK Storno                     |

Obr.18: Okno definovania hodnôt časov pre pin PB1

 Uložíme nastavenia voľbou Save z File menu, alebo prostredníctvom ikony na panely nástrojov. Potom spustíme simuláciu voľbou Start Simulation z Proccesing menu, alebo prostredníctvom ikony na panely nástrojov.

Po spustení simulácie sa automaticky zobrazia nasledujúce okná:

- Status
- Simulation Report (má pravé a ľavé okno), (obr.19)
- Message Window



Obr.19: Pravé okno Simulator Report

Z výsledkov simulácie môžeme vidieť, kedy bude LED rozsvietená a kedy zhasnutá. Keď sú tlačidlá PB1 a PB2 keď sú stlačené majú na svojom výstupe logickú úroveň 0. Dióda LED svieti vtedy, keď je na ňu privedená logická úroveň 0. Uvedené skutočnosti musíme uvažovať pri vyhodnocovaní priebehov vo waveform editore.

Charakteristika týchto okien je rovnaká ako to bolo pri kompilácii. Simulácia má tiež svoje moduly:

- Netlist Builder

- Simulator

Pri simulácií bol vytvorený nový súbor: *norhradlo.sim.rpt* – súbor správ, ktoré generuje simulátor

## 2.3.6 PROGRAMOVANIE/KONFIGURÁCIA

Po úspešnej kompilácii môžeme programovať obvod voľbou **Tools→Programmer**. Po spustení sa otvorí okno (obr.20) programátora, prostredníctvom ktorého vytvoríme súbor:

.cdf – chain description file – súbor obsahujúci názov a nastavenia obvodov

použitých v návrhu

| 📩 Hardware Setup. | ByteBlaster [LPT1]    |              |          | Mode: JTA | G                     |        | ▼ Pro           | gress:  | 0%              |       |              |
|-------------------|-----------------------|--------------|----------|-----------|-----------------------|--------|-----------------|---------|-----------------|-------|--------------|
| 🏓 Start           | File                  | Device       | Checksum | Usercode  | Program/<br>Configure | Verify | Blank-<br>Check | Examine | Security<br>Bit | Erase | ISP<br>CLAMP |
| 📲 Stop            | ORHRADLO.sof          | EPF10K20R240 | 0000715B | 0000007F  |                       |        |                 |         |                 |       |              |
| 🙀 Auto Detect     | Štart<br>programvania |              |          |           |                       |        |                 |         |                 |       |              |
| 🗙 Delete          |                       |              |          |           |                       |        |                 |         |                 |       |              |
| 🎽 Add File        | Pridať<br>súbor       |              |          |           |                       |        |                 |         |                 |       |              |
| 🞬 Change File     |                       |              |          |           |                       |        |                 |         |                 |       |              |
| 🕞 Save File       |                       |              |          |           |                       |        |                 |         |                 |       |              |
| Add Device        |                       |              |          |           |                       |        |                 |         |                 |       |              |
| 📲 Up              |                       |              |          |           |                       |        |                 |         |                 |       |              |
| 🔑 Down            |                       |              |          |           |                       |        |                 |         |                 |       |              |

Obr.20: Okno programovania/konfigurácie

V tomto okne, pred samotným programovaním, musíme nastaviť položky **Hardware Setup** a **Mode** nasledovným postupom:

• Kliknutím na položku **Hardware Setup** sa objaví okno hardvérovej konfigurácie (obr.21)

| ardware Setup<br>Hardware Settings   JTAG Set<br>Select a programming hardwar<br>hardware setup applies only t | tings  <br>are setup to use whe<br>o the current progra | en programming device<br>mmer window. | ces. This programming |
|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------|-----------------------|
| Currently selected hardware:                                                                                   | ByteBlaster [Ll                                         | PT1]                                  | <b>T</b>              |
| Hardware<br>ByteBlaster                                                                                        | Server<br>Local                                         | LPT1                                  | Add Hardware          |
| L                                                                                                              |                                                         |                                       | Close                 |

Obr.21: Okno hardvérovej konfigurácie

- V zobrazenom okne, klikneme na položku Add Hardware
- V riadku Hardware Type vyberieme ByteBlasterMV or ByteBlaster II (podľa typu použitého ByteBlastra) a v riadku Port: LPT1

| Add Hardware     | X               |
|------------------|-----------------|
| Hardware type:   | MasterBlaster 💌 |
| Port:            | COM1 .          |
| Baud rate:       | 115200          |
| Server name:     | <b></b>         |
| Server port:     |                 |
| Server password: |                 |
| Auto Detect      | OK Cancel       |

- Nastavenia potvrdíme tlačidlom **OK**.
- Nastavíme JTAG mód

Obvod naprogramujeme pomocou súboru n*orhradlo.sof*, ktorý pridáme do programátora pomocou ikony **Add File** (Pridaj súbor). Po pridaní súboru programácie zaškrtneme políčko **Program/Configure** a spustíme programovanie ikonou **Start Programmer** (Štart Programovania). Po spustení sa automaticky otvorí okno hlásení, v ktorom sa objavia správy o programovaní.

## 2.3.7 ARCHIVÁCIA

V procese tvorby, kompilácie, simulácie a programovania projektu do súčiastky, návrhový prostriedok Quartus II vytvára množstvo súborov. Pri prenose projektu to môže spôsobovať problémy. Preto Quartus II obsahuje takzvanú archiváciu projektu, ktorá vytvorí jeden súbor s informáciami potrebnými k obnoveniu projektu po prenose. Po obnovení projektu a vykonaní kompilácie a simulácie dostaneme pôvodné súbory. Súbory obsahujúce informácie o simuláciách nie sú potrebne k prenosu, lebo po obnovení projektu môžeme vykonať simulácie. Potom dostaneme pôvodne súbory. Simulácia je vývojový prostriedok slúžiaci k overeniu funkčnosti návrhu. Nieje potrebný k naprogramovaniu návrhu do obvodu.

#### 2.3.7.1 POSTUP PRI ARCHIVÁCII PROJEKTU

V položke **Project** vyberieme **Archive Project**. Zobrazí sa okno podľa obr. 22. Do riadku **Active File Name** zadávame názov archivačného súboru v tomto prípade *norhradlo*, poprípade aj cestu, kde má byť súbor uložený. Potom si môžeme vybrať z troch možností, podľa toho, ktoré súbory potrebujeme pridať do archivačného súboru. Prvou možnosťou je archivácia súborov nutných k obnove projektu. Tieto súbory nám postačia v prípade, ak môžeme po obnove archivačného súboru vykonať plnú kompiláciu a simuláciu. Druhou možnosťou je vloženie súborov kompilácie a simulácie a treťou je vloženie funkcií zo systému knižníc. Archivačný súbor má príponu .*qar*. Po stlačení OK bude vygenerovaný archivačný súbor *norhradlo.qar*.

| Archive Project 🛛 🔀                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select the Quartus II Archive File for the project. The Quartus II software<br>automatically archives your source design and project files; the options<br>below allow you to include other files.Including Version-Compatible Database<br>Files may take additional time to archive the project.<br>Archive file name: |
| norhradio                                                                                                                                                                                                                                                                                                               |
| <ul> <li>Archive current active revision only</li> <li>Include database from compilation and simulation</li> <li>Include Version-Compatible Database Files</li> <li>Include functions from system libraries</li> </ul>                                                                                                  |
| Add/Remove Files OK Cancel                                                                                                                                                                                                                                                                                              |

Obr. 22: Okno archivácie projektu

Po prenose archivačného súboru, napr. na iný počítač, vyberieme v návrhovom prostriedku Quartus II možnosť z File menu->Open Project. Vyberieme archivačný súbor *norhradlo.qar*. Po jeho otvorení sa nám zobrazí dialógové okno (obr.23), kde máme názov archivačného súboru a cieľ, kam sa má projekt rozbaliť. V riadku Destination Folders nastavíme cestu k adresáru, kde sa má projekt umiestniť. Klikneme na OK.

| Restore Archived Project |    |        |
|--------------------------|----|--------|
| Archive name:            |    |        |
| D:/norhradlo.gar         |    |        |
| Show Log                 |    |        |
| Destination folder:      |    |        |
| D:/norhradlo_restored    |    |        |
|                          | ОК | Cancel |

Obr.23: Okno obnovy projektu

#### 2.4 POUŽITÍM HRADIEL OR, AND, NAND – PRÍKLAD Č.2

Vo vývojovom prostredí Quartus II realizujte projekt na rozsvietenie desatinnej bodky MSD (MSD\_dp) sedem segmentovej LED stlačením jedného z tlačidiel (PB1, PB2) na vývojovej doske UP1 CPLD. Projekt realizujte použitím hradiel OR, AND, NAND, v grafickom editore softvéru Quartus II.

#### 2.5 Riešenie

Postup riešenia bude podobný ako v prípade hradla NOR (kap. 2.2). Taktiež platí tá istá tabuľka pinov ako v prípade hradla NOR (tab.1). Opäť otvoríme nový projekt, podľa postupu uvedeného pre hradlo NOR. Rozdiel je v tom, že pri výbere prvku si nevyberieme hradlo NOR, ale hradlo OR, AND alebo NAND, podľa zadania príkladu. Priradenie pinov, kompiláciu, simuláciu a programovanie vykonáme podľa postupu popísaného v predchádzajúcich kapitolách 2.3.3 – 2.3.6.

# OR

Výsledná schéma s použitím hradla OR je na obr.24. V tomto prípade sme museli dať na výstup ešte invertor, ináč by sme dostali presne opačný efekt. LED by bola stále rozsvietená a zhasla by pri stlačení tlačidla PB1 alebo PB2.



Obr.24: Výsledné zapojenie s použitím hradla OR

| Po | vykonaní | simulácie  | dostaneme | priebehy  | podľa | obr 25  |
|----|----------|------------|-----------|-----------|-------|---------|
| 10 | vykonum  | Simulation | aostaneme | pricocity | poura | 001.25. |

| Sim | simulation Waveforms     |          |              |         |          |           |            |         |          |          |          |  |  |  |  |
|-----|--------------------------|----------|--------------|---------|----------|-----------|------------|---------|----------|----------|----------|--|--|--|--|
| Mas | Master Time Bar: 40.0 ns |          | • • Pointer: | 5.64    | us       | Interval: | 5.6 us     | Start:  | End:     |          |          |  |  |  |  |
|     |                          | Value at | 0 ps         | 5.12 us | 10.24 us | 15.36 us  | : 20.48 us | 25.6 us | 30.72 us | 35.84 us | 40.96 us |  |  |  |  |
|     | Name 40.01               |          | Dins<br>J    |         |          |           |            |         |          |          |          |  |  |  |  |
| ۲   | MSD_Dp                   | BO       |              |         |          |           |            |         |          |          |          |  |  |  |  |
| Þ   | PB1                      | BO       |              |         |          |           |            |         |          |          |          |  |  |  |  |
|     | PB2                      | BO       |              |         |          |           |            |         |          |          |          |  |  |  |  |

Obr.25: Výsledok simulácie

Naprogramovanie vykonáme podľa postupu uvedeného pri hradle NOR.

(kap. 2.3.6)

# AND

Hradlo AND realizuje logický súčin. Postup návrhu celého projektu je podobný s návrhom projektu pomocou hradla NOR. Výsledná schéma je tvorená dvojvstupovým hradlom AND, dvoma vstupmi (PB1, PB2) a jedným výstupom (LED) (obr. 26).



Obr.26: Zapojenie pomocou hradla AND

Simuláciou tohto zapojenia dostaneme priebehy podľa obr. 27.

| Sim                   | ulation Wavelo | rms  |          |          |          |          |          |         |          |          |          |  |  |  |
|-----------------------|----------------|------|----------|----------|----------|----------|----------|---------|----------|----------|----------|--|--|--|
| Master Time Bar: 0 ps |                | \$   | Pointer: | 11.86 us | Interva  | al: 1    | 1.86 us  | Start:  | End:     |          |          |  |  |  |
|                       | Value at       |      | 0 ps     | 5.12 us  | 10.24 us | 15.36 us | 20.48 us | 25.6 us | 30.72 us | 35.84 us | 40.96 us |  |  |  |
|                       | Name           | 0 ps | ps<br>J  |          |          |          |          |         |          |          |          |  |  |  |
| 0                     | LED_dp         | BO   |          |          |          |          |          |         |          |          |          |  |  |  |
|                       | PB1            | BO   |          |          |          |          |          |         |          |          |          |  |  |  |
|                       | PB2            | BO   |          |          |          |          |          |         |          |          |          |  |  |  |
|                       |                |      |          |          |          |          |          |         |          |          |          |  |  |  |

#### Obr.27: Výsledok simulácie

Programovanie projektu do súčiastky vykonáme podľa postupu uvedeného pri hradle NOR. (kap. 2.3.6)

# NAND

Hradlo NAND realizuje negovaný logický súčin. Celý návrh je podobný s návrhom ako v prípade hradla NOR. Výsledné zapojenie je tvorené jedným dvojvstupovým hradlom NAND, jedným invertorom, dvoma vstupmi (PB1, PB2) a jedným výstupom (LED) (obr.28).



Obr. 28 Výsledné zapojenie s použitím hradla NAND

| Simulation Waveforms    |        |         |                       |                                     |  |    |          |    |   |    |      |           |  |   |          |  |   |         |  |     |   |          |  |   |      |          |   |    |  |  |       |    |   |  |
|-------------------------|--------|---------|-----------------------|-------------------------------------|--|----|----------|----|---|----|------|-----------|--|---|----------|--|---|---------|--|-----|---|----------|--|---|------|----------|---|----|--|--|-------|----|---|--|
| Master Time Bar: 11.6 n |        | òns     |                       | <ul> <li>Image: Pointer:</li> </ul> |  |    | 14.33 us |    |   |    |      | Interval: |  |   | 14.32 us |  |   |         |  | Sta | t |          |  | _ | End: |          |   |    |  |  |       |    |   |  |
|                         |        |         | Value at 0 ps 5.12 us |                                     |  | 10 | ).24 u   | JS |   | 15 | 5.36 | us        |  | 2 | 20.48 us |  |   | 25.6 us |  |     |   | 30.72 us |  |   | ;    | 35.84 us |   |    |  |  | 40.96 | us |   |  |
|                         | Name   | 11.6 ns | 6 ns<br>⊒             |                                     |  |    |          |    |   |    |      |           |  |   |          |  |   |         |  |     |   |          |  |   |      |          |   |    |  |  |       |    |   |  |
| ۲                       | LED_dp | BO      |                       |                                     |  |    |          |    |   |    |      |           |  |   |          |  |   |         |  |     |   |          |  |   | Л    |          | T |    |  |  | T     | T  | 1 |  |
| Þ                       | PB1    | BO      |                       |                                     |  |    |          |    |   |    |      |           |  |   |          |  | Г |         |  |     |   |          |  |   |      |          | T | ++ |  |  | ++    | Ħ  |   |  |
| Þ                       | PB2    | BO      |                       |                                     |  |    |          |    | ſ |    |      |           |  |   |          |  | L |         |  |     |   |          |  |   | Ħ    |          | T | Ħ  |  |  | T     | Ħ  |   |  |
|                         |        |         |                       |                                     |  |    |          |    |   |    |      |           |  |   |          |  |   |         |  |     |   |          |  |   |      |          |   |    |  |  |       |    |   |  |

Po simulácii dostaneme priebehy podľa obr.29.

Obr. 29 : Výsledok simulácie

Programovanie projektu vykonáme presne podľa postupu uvedeného pri hradle NOR (kap. 2.3.6).