## **MODUL V**

# Implementasi Rangkaian Digital dengan FPGA

- 1 Tujuan
- 2 Alat dan Bahan
- 3 Dasar Teori

programmable logic devices dan FPGA Entri desain

### 3.1 Pengenalan Quartus Prime

Quartus Prime merupakan perangkat lunak CAD (computer-assisted design) yang digunakan untuk desain rangkaian digital. Quartus Prime dikembangkan oleh Altera. Versi Lite dari Quartus Prime dapat diunduh secara gratis pada laman Altera<sup>1</sup>. Quartus Prime dapat dijalankan pada platform Windows dan Linux. Jendela utama dari Quartus Prime Lite dapat dilihat pada Gambar 1.

Dengan menggunakan CAD, setidaknya ada dua cara untuk mendesain rangkaian digital:

- schematic capture, dengan membuat skematik dari rangkaian yang diinginkan.
- menggunakan Hardware Description Language (HDL). Dua jenis HDL yang paling populer adalah Verilog dan VHDL. Kedua bahasa tersebut telah diadopsi sebagai IEEE Standard. Pada tulisan ini akan digunakan Verilog.

Kita akan mulai dengan menggunakan skematik.

#### 3.2 Menambahkan skematik baru

Skematik baru dapat ditambahkan ke dalam project dengan memilih menu **File**  $\rightarrow$  **New**. Pilih **New Diagram/Schematic File**, kemudian **OK**.

<sup>1</sup>http://dl.altera.com/?edition=lite



Gambar 1: Tampilan jendela utama Quartus Prime Lite



File skematik kosong akan terbuka pada tab baru dengan nama **Block1.bdf**. Kita dapat membuat skematik yang kita inginkan pada file ini.



Untuk menambahkan komponen, dapat dilakukan dengan cara mengklik toolbar Symbol Tool.



Komponen yang ingin ditambahkan pada skematik dapat diperoleh dengan ekspasi node **Libraries**, mencari komponen tersebut, dan memilihnya. Misalkan kita ingin menambahkan gerbang AND dengan dua input, maka dapat dipilih pada **primitives**  $\rightarrow$  **logic**  $\rightarrow$  **and2**. Klik **OK** setelah komponen yang diinginkan telah dipilih.



Pemilihan komponen juga dapat dilakukan dengan mengetikkan nama komponen yang diinginkan pada isian **Name**, misalnya **jkff** untuk J-K flip-flop.

Khusus untuk menambahkan komponen input dan output, dapat juga digunakan toolbar Pin Tool.



Untuk menghubungkan antara satu komponen dengan komponen yang lain, dapat digunakan **Orthogonal Node Tool**.



Berikut ini adalah contoh skematik untuk multiplexer 2-to-1:



Skematik ini kemudian dapat digunakan untuk proses lebih lanjut seperti simulasi dan download ke hardware FPGA.

Menkonversi ke skematik ke simbol/blok sehingga dapat digunakan sebagai bagian dari skematik lainnya: gunakan menu File  $\rightarrow$  Create/Update  $\rightarrow$  Create Symbol Files for Current File.



### 3.3 Bahasa Deskripsi Hardware: Verilog

Selain menggunakan skematik, desain rangkaian digital juga dapat dilakukan dengan menggunakan HDL (hardware description language) seperti Verilog dan VHDL. Pada kesempatan kali ini kita akan menggunakan Verilog.

Verilog pada awalnya dikembangkan sebagai alat untuk simulasi serta verifikasi dari rangkaian digital. Verilog dikembangkan oleh Gateway Design Automation, yang sekarang menjadi bagian dari Cadence Design Systems. Pada awal perkembangannya Verilog merupakan bahasa proprietary, akan tetapi pada tahun 1990 Verilog dilepaskan ke domain publik. Sejak saat itu Verilog menjadi salah satu bahasa yang populer untuk mendeskripsikan rangkaian digital. Pada tahun 1995 Verilog diadopsi sebagai IEEE Standard, yaitu standard 1364-1995. Pada tahun 2001, versi terbaru dari Verilog yang dikenal dengan Verilog 2001 diadopsi menjadi IEEE Standard 1364-2001.

Pada Quartus Prime, file Verilog dapat ditambahkan ke Project dengan memilih menu **File**  $\rightarrow$  **New** dan pilih **Verilog HDL File**.



Gambar 2: New File Verilog HDL

File Verilog merupakan file teks sehingga kita dapat menggunakan teks editor apa saja untuk mengedit file ini.

#### 3.3.1 Representasi rangkaian digital dengan Verilog

Terdapat dua pendekatan yang akan kita gunakan untuk mendesain rangkaian digital dengan Verilog pada praktikum ini

- struktural: rangkaian digital dideskripsikan dengan struktur rangkaian tersebut, membangunnya dengan elemen-elemen rangkaian seperti gerbang logika, dan mendefisinikan bagaimana elemen-elemen tersebut saling terhubung satu sama lainnya.
- perilaku (behavioral): rangkaian digital dideskripsikan dengan perilaku rangkaian tersebut, bukan dengan struktur rangkaiannya secara langsung. Pendekatan ini dilakukan dengan menggunakan konstruksi pemrograman Verilog seperti konstruksi if, switch, dan for yang juga biasa ditemukan pada bahasa pemrograman komputer. Kompiler Verilog akan melakukan translasi dari konstruksi pemrograman tersebut menjadi rangkaian digital yang sesuai.z

#### Representasi struktural

Verilog memiliki gerbang logika primitif yang merepresentasikan gerbang logika yang biasa dipakai pada rangkaian.

Gerbang AND dengan dua input,  $x_1$  dan  $x_2$ , dan output y, misalnya dapat dinyatakan dengan kode Verilog sebagai berikut.

```
and( y, x1, x2 );
```

Gerbang OR dengan 4 input

Beberapa gerbang primitif pada Verilog dapat diberikan pada tabel berikut ini.

| Nama | Deskripsi                           | Penggunaan              |  |  |  |  |  |
|------|-------------------------------------|-------------------------|--|--|--|--|--|
| and  | $f = (a \cdot b \cdots)$            | and(f, a, b,)           |  |  |  |  |  |
| nand | $f = \overline{(a \cdot b \cdots)}$ | <pre>nand(f,a,b,)</pre> |  |  |  |  |  |
| or   | $f = (a + b + \cdots)$              | or(a,b,)                |  |  |  |  |  |
| nor  | $f = \overline{(a+b+\cdots)}$       | nor(a,b,)               |  |  |  |  |  |
| xor  | $f = a \oplus b \oplus \cdots$      | xor(a,b,)               |  |  |  |  |  |
| xnor | $f = a \odot b \odot \cdots$        | <pre>xnor(a,b,)</pre>   |  |  |  |  |  |
| not  | $f = \bar{a}$                       | not(f,a)                |  |  |  |  |  |

Tabel 1: Beberapa gerbang primitif pada Verilog

Rangkaian digital yang lebih kompleks dapat direpresentasikan dengan menggunakan gerbang primitif tersebut.

Dalam tulisan ini, penjelasan mengenai Verilog akan diberikan melalui contoh.



Gambar 3: Multiplexer

Contoh 1 Multiplexer pada Gambar 3 dapat dijelaskan dengan kode Verilog berikut.

```
module mux2( x1, x2, s, f );
  input x1, x2, s;
  output f;

  not(k,s);
  and(g,k,x1);
  and(h,s,x2);
  or(f,g,h);
endmodule
```

Dalam Verilog, rangkaian logika diberikan dalam bentuk modul, didefinisikan dengan kata kunci **mo-dule**. Suatu modul dapat terdiri dari input dan output yang disebut sebagai *port*. Pada contoh di atas, modul dengan nama **mux2** didefinisikan. Modul **mux2** memiliki 4 port yang bernama x1, x2, s, dan f. Pernyataan modul ini diakhiri dengan titik koma. Pada pernyataan berikutnya, x1, x2 dan

 ${f s}$  dinyatakan sebagai sinyal input, sedangkan f sebagai sinyal output. Empat baris kode berikutnya menyatakan struktur dari rangkaian.

Variabel k, g, dan h tidak dideklarasikan pada kode di atas. Secara default tipe dari variabel tersebut adalah wire.

Contoh 2 Perhatikan rangkaian berikut.



Gambar 4: Rangkaian untuk Contoh 2

Rangkaian ini memiliki 4 input, yaitu  $x_1$ ,  $x_2$ ,  $x_3$ , dan  $x_4$ , serta 3 output, yaitu f, g, dan h. Rangkaian ini mengimplementasikan fungsi logika berikut.

$$g = x_1 x_3 + x_2 x_4$$

$$h = (x_1 + \bar{x_3})(\bar{x_2} + x_4)$$

$$f = q + h$$

Rangkaian ini dapat diimplementasikan dengan menggunakan kode berikut. Pada kode ini operator digunakan sebagai pengganti gerbang NOT.

```
module Contoh2( x1, x2, x3, x4, f, g, h );
  input x1, x2, x3, x4;
  output f, g, h;

and( z1, x1, x3 );
  and( z2, x2, x4 );
  or( g, z1, z2 );
  or( z3, x1, ~x3 );
  or( z4, ~x2, x4 );
  and( h, z3, z4 );
  or( f, g, h );
endmodule
```

#### Representasi behavioral

Menggunakan gerbang logika primitif pada Verilog untuk rangkaian yang kompleks dapat menjadi tugas yang sulit. Sebagai alternatif, kita dapat menggunakan ekspresi logika dan level abtraksi yang

lebih tinggi serta kontruksi pemrograman Verilog untuk mendeskripsikan rangkaian berdasarkan perilaku dari suatu rangkaian.

Sebagai contoh, output dari multiplexer pada Gambar 3 dapat dijelaskan dengan persamaan logika berikut.

$$f = \bar{s}x_1 + sx_2$$

Dalam Verilog, persamaan ini dapat dinyatakan dengan kode berikut.

```
module mux2_logic_expr( x1, x3, s, f );
  input x1, x2, s;
  output f;

assign f = ( ~s & x1 ) | ( s & x2 );
endmodule
```

Pada kode tersebut, operasi AND dan OR dilakukan dengan menggunakan operator "&" dan " $\mid$ ". Kata kunci **assign** berarti *continuous assignment* untuk sinyal f. Ketika ada sinyal pada ruas kanan yang berubah, maka f akan dievaluasi ulang. Jika tidak, maka f akan tetap pada nilai sebelumnya. Dengan menggunakan ekspresi logika, rangkaian pada Gambar 4 dapat dituliskan sebagai berikut.

```
module Contoh2_logic_expr( x1, x2, x3, x4, f, g, h );
  input x1, x2, x3, x4;
  output f, g, h;

assign g = ( x1 & x3 ) | ( x2 & x4 );
  assign h = ( x1 | ~x3 ) & ( ~x2 & x4 );
  assign f = g | h;
endmodule
```

Penggunaan ekspresi logika dapat mempermudah penulisan kode Verilog. Akan tetapi level abstraksi yang lebih tinggi juga dapat digunakan dengan cara memberikan spesifikasi mengenai perilaku dari rangkaian. Rangkaian ini juga dapat dideskripsikan dengan menyatakan perilakunya sebagai berikut.

- $f = x_1$  jika s = 0, dan
- $f = x_2$  jika s = 1

Dalam Verilog, perilaku ini dapat dijelaskan dengan menggunakan pernyataan **if-else** seperti pada kode berikut.

```
module mux2_behavioral( x1, x2, f );
  input x1;
  input x2;
  output f;

reg f;

always @(x1 or x2 or s)
  if( s == 0 )
    f = x1;
  else
    f = x2;
endmodule
```

Beberapa hal yang perlu diperhatikan terkait kode di atas.

• Pernyataan **if-else** pada Verilog termasuk dalam *pernyataan prosedural*. Verilog mengha-

ruskan pernyataan prosedural diletakkan pada blok **always**, seperti pada kode di atas. Setiap

blok always dapat terdiri dari satu pernyataan, seperti pada contoh di atas, atau bebera-

pa pernyataan prosedural. Suatu modul Verilog dapat memiliki beberapa blok always yang

masing-masing blok tersebut menyatakan suatu bagian dari rangkaian yang sedang dimodelk-

an.

• Pernyataan dalam blok **always** akan dievaluasi sesuai dengan urutan yang diberikan dalam

kode. Hal ini kontras dengan pernyataan continuous assignment yang dievaluasi secara paralel

dan tidak bergantung pada urutan yang diberikan di kode.

• Pada blok always, setelah simbol, dalam tanda kurung, disebut dengan sensitivity list. Per-

nyataan pada blok **always** akan dieksekusi jika satu atau lebih dari sinyal yang ada pada sen-

sitivity list berubah. Hal ini berguna pada waktu simulasi, di mana simulator tidak perlu meng-

eksekusi pernyataan setiap waktu. Untuk keperluan sintesis, sensitivity list memberitahu com-

piler sinyal apa saja yang secara langsung mempengaruhi keluaran yang diberikan oleh blok

always.

• Jika suatu sinyal diberikan suatu nilai dengan menggunakan pernyataan prosedural, Verilog

mengharuskan sinyal tersebut dideklarasikan sebagai variabel. Hal ini dilakukan dengan cara

menggunakan kata kunci reg.

4 Praktikum

4.1 Pengenalan IO: LED dan push button

Perlu gambar board FPGA yang akan digunakan

Beberapa daftar port dari board FPGA yang digunakan:

9

Tabel 2: Beberapa port yang digunakan pada board FPGA

| erapa port yang digui |         |  |  |  |  |  |
|-----------------------|---------|--|--|--|--|--|
| Clock                 | PIN_23  |  |  |  |  |  |
| Reset Push Button     | PIN_25  |  |  |  |  |  |
| Buzzer                | PIN_110 |  |  |  |  |  |
| IR                    | PIN_100 |  |  |  |  |  |
| Push Button           |         |  |  |  |  |  |
| key1                  | PIN_88  |  |  |  |  |  |
| key2                  | PIN_89  |  |  |  |  |  |
| key3                  | PIN_90  |  |  |  |  |  |
| key4                  | PIN_91  |  |  |  |  |  |
| LED                   |         |  |  |  |  |  |
| LED1                  | PIN_87  |  |  |  |  |  |
| LED2                  | PIN_86  |  |  |  |  |  |
| LED3                  | PIN_85  |  |  |  |  |  |
| LED4                  | PIN_84  |  |  |  |  |  |
| Seven-segmen          | t LED   |  |  |  |  |  |
| DIG1                  | PIN_133 |  |  |  |  |  |
| DIG2                  | PIN_135 |  |  |  |  |  |
| DIG3                  | PIN_136 |  |  |  |  |  |
| DIG4                  | PIN_137 |  |  |  |  |  |
| SEG0                  | PIN_128 |  |  |  |  |  |
| SEG1                  | PIN_121 |  |  |  |  |  |
| SEG2                  | PIN_125 |  |  |  |  |  |
| SEG3                  | PIN_129 |  |  |  |  |  |
| SEG4                  | PIN_132 |  |  |  |  |  |
| SEG5                  | PIN_126 |  |  |  |  |  |
| SEG6                  | PIN_124 |  |  |  |  |  |
| SEG7                  | PIN_127 |  |  |  |  |  |
|                       |         |  |  |  |  |  |

Untuk PIN assignment, buat skematik atau file Verilog terlebih dahulu, kemudian compile. Buka PIN assignment, set pin yang diperlukan.

Prosedur ini diberikan pada contoh menyalakan LED.

#### 4.1.1 LED

Buat file baru dengan nama **led\_light.v**, misalnya. Kemudian ketik kode Verilog berikut pada file tersebut. Kode Verilog ini memberikan nilai logika ke tiap LED (hardwired, tanpa ada input).

```
module led_light(led);
  output[3:0] led;
  assign led = 4'b0000; // coba ubah-ubah nilai ini untuk tiap LED
endmodule
```

Compile file ini dengan cara klik icon **Compile** atau dengan menu **Processing -> Start Compilation** atau menggunakan shortcut **Ctrl + L**.

Jika tidak ada kesalahan pada saat proses kompilasi, maka langkah selanjutnya adalah melakukan PIN assignment, yang dapat dilakukan dengan memilih menu **Assignment -> Pin Planner** atau menggunakan shortcut **Ctrl + N**. Atur PIN assignment sesuai dengan Tabel 2.



Gambar 5: PIN Assignment untuk 4 LED

#### Compile lagi file tersebut.

Jika tidak ada pesan error, langkah selanjutnya adalah mendownload program ini ke FPGA. Proses ini dapat dilakukan dengan cara memilih menu **Tools -> Programmer**. Klik button **Add File** untuk menambahkan file led\_light.sof. File ini biasanya ada di dalam subdirektori output dari direktori proyek. Pastikan juga hardware telah terdeteksi. Jika belum terdeteksi, tambahkan melalui dengan mengklik button **Hardware Setup**.



Gambar 6: Tampilan tool Programmer

#### **Catatan Verilog**

Misalkan pada board FPGA yang digunakan urutan LED dari kiri ke kanan adalah LED1, LED2,

LED3, dan LED4.

Misalkan memberikan assignment sebagai berikut.

- LED1 diwakili dengan led[0]
- LED2 diwakili dengan led[1]
- LED3 diwakili dengan led[2]
- LED4 diwakili dengan led[3]

Misalkan juga kita memberikan nilai logika pada led dengan kode Verilog berikut.

```
led = 4'b1010;
```

Maka nilai 0 (nilai bit paling kanan atau LSB) diberikan pada led[0] atau LED1. Nilai pada bit kedua dari kanan diberikan untuk led[1], bit ketiga untuk led[2], dan bit keempat (paling kiri atau MSB) untuk led[3].

Bagian output [3:0] led pada kode di atas dapat diganti dengan output [1:4] led untuk memudahkan assignment nilai logika sesuai dengan urutan LED di board yang digunakan. Sehingga kita dapat melakukan assigment sebagai berikut.

- LED1 diwakili dengan led[1]
- LED2 diwakili dengan led[2]
- LED3 diwakili dengan led[3]
- LED4 diwakili dengan led[4]

Cobalah bereksprimen dengan cara mengganti-ganti nilai logika dari led, kemudian isilah tabel berikut.

| Nilai logika | Keadaan LED (on/off) |  |  |  |  |  |
|--------------|----------------------|--|--|--|--|--|
| 0            |                      |  |  |  |  |  |
| 1            |                      |  |  |  |  |  |

#### 4.1.2 Push buttons

Buat project baru, dan buat file Verilog dengan mendefiniskan satu modul dengan input dari push button dan output ke LED.

```
module test_buttons( buttons, led );
  input [3:0] buttons;
  output [3:0] led;
  assign led = buttons;
endmodule
```

| Α | В | С     | LED |  |  |
|---|---|-------|-----|--|--|
| 0 | 0 | 0     | 0   |  |  |
| 0 | 0 | 0 1 : |     |  |  |
| 0 | 1 | 0     | 1   |  |  |
| 0 | 1 | 1     | 0   |  |  |
| 1 | 0 | 0     | 1   |  |  |
| 1 | 0 | 1     | 0   |  |  |
| 1 | 1 | 0     | 0   |  |  |
| 1 | 1 | 1     | 1   |  |  |

Bisa juga menggunakan potongan kode berikut.

```
assign led[0] = buttons[0];
assign led[1] = buttons[1];
assign led[2] = buttons[2];
assign led[3] = buttons[3];
```

Cobalah bereksperimen dengan kode Verilog yang ada dan juga menggukan operator Verilog seperti

| Nilai logika | Keadaan PB |
|--------------|------------|
| 0            |            |
| 1            |            |

### 4.1.3 Seven segments

Lihat Modul 1.

### 4.2 Rangkaian kombinasional

Membuat rangkaian logika digital sederhana dengan spesifikasi sebagai berikut.

- input push button sebanyak 3 buah, misalkan bernama A, B dan C
- output berupa satu LED dengan nama led
- LED akan menyala jika jumlah push button yang ditekan ganjil

Misalkan ketika push button ditekan nilai logikanya adalah 0 dan LED akan menyala jika nilai logika adalah 0, maka dapat diperoleh tabel sebagai berikut.

$$LED = ABC + \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}\bar{C}$$

Kode Verilog yang mengimplementasikan persamaan logika di atas adalah sebagai berikut.

```
module deteksi_ganjil_3(
  input wire A,
  input wire B,
```

```
input wire C,
output wire led );

assign led = (A & B & C) | (~A & ~B & C) | (~A & B & ~C) | (A & ~B & ~C) | (A & ~B & ~C);
```

endmodule

### 4.3 Converter BCD ke seven-segment

Input BCD (dari ) ke output seven segment. Buat tabel kebenaran dan rangkaian (dalam skematik atau Verilog struktural). Minimisasi persamaan logika yang diperoleh dengan menggunakan metode Karnaugh *mapping*.

| Input |     |     |     | Output |   |   |   |   |   |   |    |
|-------|-----|-----|-----|--------|---|---|---|---|---|---|----|
| PB1   | PB2 | PB3 | PB4 | а      | b | С | d | е | f | g | dp |
| 0     | 0   | 0   | 0   |        |   |   |   |   |   |   |    |
| 0     | 0   | 0   | 1   |        |   |   |   |   |   |   |    |
| 0     | 0   | 1   | 0   |        |   |   |   |   |   |   |    |
|       |     |     |     |        |   |   |   |   |   |   |    |
| 1     | 1   | 1   | 1   |        |   |   |   |   |   |   |    |

# 5 Tugas Pendahuluan

- Tabel BCD (atau hexadesimal?) ke seven segment