

## **BAB III**

### **CODING REUSE**

#### **3.1 Tujuan**

1. Praktikan memahami konsep kode Verilog.
2. Praktikan dapat membuat kode Verilog dan mengimplementasikan pada aplikasi Vivado.
3. Praktikan dapat memahami konsep dalam coding reuse dan menerapkan pada vivado.

#### **3.2 Alat dan Bahan**

1. Laptop
2. Papan Nexys A7

#### **3.1 Dasar Teori**

1. Coding Reuse

Code reuse adalah teknik pemrograman untuk mengurangi waktu dan sumber daya dalam mengembangkan perangkat lunak. Saat mengembangkan kode untuk digunakan kembali, kode tersebut dapat digunakan untuk berbagai tujuan. Teknik ini melibatkan modularisasi, yang memungkinkan banyak individu mengembangkan kode untuk berbagai komponen sistem secara mandiri dan paralel. Teknik ini juga menyederhanakan distribusi perangkat lunak.

(sumber : <https://www.mathworks.com/help/rtw/ug/what-is-code-reuse-58d9ced3ba27.html>)

2. Half Adder

Half Adder adalah rangkaian elektronik yang bekerja melakukan perhitungan penjumlahan dari dua buah bilangan binary, yang masing-masing terdiri dari satu bit. Rangkaian ini memiliki dua input dan dua buah output, salah satu outputnya dipakai sebagai tempat nilai pindahan dan yang lain sebagai hasil dari penjumlahan.



(sumber : <https://smkmuh2klaten.sch.id/blog/pengertian-half-adder-dan-full-adder/>)

3. Full Adder

Full adder adalah rangkaian elektronik yang bekerja melakukan perhitungan penjumlahan sepenuhnya dari dua buah bilangan binary, yang masing-masing terdiri dari satu bit. Rangkaian ini memiliki tiga input dan dua buah output, salah satu input merupakan nilai dari pindahan penjumlahan, kemudian sama seperti pada half adder salah satu outputnya dipakai sebagai tempat nilai pindahan dan yang lain sebagai hasil dari penjumlahan



(sumber : <https://smkmuh2klaten.sch.id/blog/pengertian-half-adder-dan-full-adder/>)

#### 4. Multiplexer



Multiplexer adalah perangkat yang dapat membolehkan satu atau lebih sinyal analog atau digital untuk berjalan pada satu sambungan transmisi komunikasi. Tujuan dari multiplexer adalah untuk menggabungkan dan mengirimkan sinyal pada media yang tergabung untuk mengoptimasi efisiensi dan mengurangi biaya komunikasi

(sumber: <https://www.techopedia.com/definition/24124/multiplexer-mux>)

#### 5. Papan FPGA

FPGA (Field Programmable Gate Arrays) adalah sirkuit terintegrasi yang perangkat kerasnya dapat dikonfigurasi untuk memenuhi kebutuhan spesifik dari pengguna setelah proses manufaktur. Hal ini membolehkan peningkatan fitur dan perbaikan kerusakan langsung di tempat.

(Sumber:  
[https://www.arm.com/glossary/fpga#:~:text=Field%20Programmable%20Gate%20Arrays%20\(FPGAs,requirements%20after%20the%20manufacturing%20process.\)](https://www.arm.com/glossary/fpga#:~:text=Field%20Programmable%20Gate%20Arrays%20(FPGAs,requirements%20after%20the%20manufacturing%20process.))

## 3.2 Langkah Kerja

### 3.4.1 Percobaan Pertama FULL ADDER using HALF ADDER

- Buat projek baru dengan pilih file → project → new



- Tekan next



- Pilih project directory untuk penyimpanan filenya. Ganti penamaan file dengan nama "mod2\_per1\_kelxx"



#### 4. Tekan “next”



#### 5. Masuk bagian “Board”. Pada search bar, masukkan keyword “nexys”. Lalu, pilih board “Nexys A7-100T”. Lalu, next.



## 6. Tekan “Finish”



7. Buat file design sources dengan klik kanan bagian “Design Sources”. Lalu, tekan “add sources”.



8. Pilih “Add or create design source”.



9. Pilih “create files”.



10. Pada filename, isi dengan “full\_adder”. Lalu, OK.



11. Tekan finish jika sudah ada “full\_adder”.



12. Jika muncul pop up, langsung tekan OK, lalu YES.
13. Tekan bagian “Design\_source”, lalu pilih “full\_adder.v”. Masukkan source code berikut :

```
//`timescale 1ns / 1ps
module full_adder(s,co,a,b,ci);
input a,b,ci;
output s,co;
wire t,k;
half v1(t,c,a,b);
half v2(s,k,t,ci);
or (co,k,c);
endmodule

module half(s,c,a,b);
input a,b;
output s,c;
assign s=a^b;
assign c=a&b;
endmodule
```

14. Buat constraint dengan masuk ke bagian “Constraint”. Lalu, klik kanan. Pilih “add source”.



15. Pilih “add or create constraint”. Lalu, “create files”.



16. Beri nama file “nexysA7\_constraint”. klik OK. Lalu Finish.



17. Masukkan source code dibawah ini pada file yang baru saja dibuat :

```
(Input a,b,ci)
set_property -dict { PACKAGE_PIN J15      IOSTANDARD LVCMOS33 }
[get_ports { a }]; #IO_L24N_T3_RS0_15 Sch=sw[0]
set_property -dict { PACKAGE_PIN L16      IOSTANDARD LVCMOS33 }
[get_ports { b }]; #IO_L3N_T0_DQS_EMCCCLK_14 Sch=sw[1]
set_property -dict { PACKAGE_PIN M13      IOSTANDARD LVCMOS33 }
[get_ports { ci }]; #IO_L6N_T0_D08_VREF_14 Sch=sw[2]

(Output s,co,c)
set_property -dict { PACKAGE_PIN H17      IOSTANDARD LVCMOS33 }
[get_ports { s }]; #IO_L18P_T2_A24_15 Sch=led[0]
set_property -dict { PACKAGE_PIN K15      IOSTANDARD LVCMOS33 }
[get_ports { co }]; #IO_L24P_T3_RS1_15 Sch=led[1]
```

18. Untuk melihat rangkaian, klik open elaborated design kemudian pilih schematic



19. Selanjutnya, pilih “open hardware manager”, lalu “open target”, pilih “auto connect”.



20. Selanjutnya, tekan “Generate bitstream”, lalu pilih OK. Proses ini akan memakan waktu cukup lama, sampe sekitar 5 menit (tergantung spesifikasi laptop masing-masing).



21. Jika proses sudah selesai, akan muncul pop-up. Tekan “cancel”.



22. Pilih “program device” di pojok kiri bawah. Lalu, tekan board yang tertera.



23. Lalu, tekan “Program”.



24. Bolak-balikkan switch yang diprogram dan amati perbedaannya

25.

### 3.4.2 Percobaan Kedua MUX 8-1 using MUX 2-1

- Buat projek baru dengan pilih file → project → new



## 2. Tekan next



## 3. Pilih project directory untuk penyimpanan filenya. Ganti penamaan file dengan nama “mod2\_per2\_kelxx”.



#### 4. Tekan “next”



#### 5. Masuk bagian “Board”. Pada search bar, masukkan keyword “nexys”. Lalu, pilih board “Nexys A7-100T”. Pilih yang versi 1.3. Lalu, next.



## 6. Tekan “Finish”



7. Buat file design sources dengan klik kanan bagian “Design Sources”. Lalu, tekan “add sources”.



8. Pilih “Add or create design source”.



9. Pilih “create files”.



- Pada filename, isi dengan "mux\_8to1". Lalu, OK.



- Tekan finish jika sudah ada "mux\_8to1".
- Jika muncul pop up, langsung tekan OK, lalu YES.
- Tekan bagian "Design\_source", lalu pilih "mux\_8to1.v". Masukkan source code berikut :

```
//`timescale 1ns / 1ps

module mux_case(out,in,s);
output reg out;
```

```

input [1:0]in;
input s;
always @ (*)
casex(s)
1'b0 : out = in[0];
1'b1 : out = in[1];
default : out = 1'bx;
endcase
endmodule

module mux_8_1 (o,i,s);
output o;
input [7:0]i;
input [2:0]s;
wire [6:1]k;
mux_case vas1(k[1], i[1:0], s[0]);
mux_case vas2(k[2], i[3:2], s[0]);
mux_case vas3(k[3], i[5:4], s[0]);
mux_case vas4(k[4], i[7:6], s[0]);
mux_case vas5(k[5], k[2:1], s[1]);
mux_case vas6(k[6], k[4:3], s[1]);
mux_case vas7(o,k[6:5], s[2]);
endmodule

```

14. Buat constraint dengan masuk ke bagian “Constraint”. Lalu, klik kanan. Pilih “add source”.



15. Pilih “add or create constraint”. Lalu, “create files”.



16. Beri nama file “nexysA7\_constraint”. klik OK. Lalu Finish.



17. Masukkan source code dibawah ini pada file yang baru saja dibuat :

```
(Inputan i0-i7)
set_property -dict { PACKAGE_PIN J15      IOSTANDARD LVCMOS33 }
[get_ports { i[0] }]; #IO_L24N_T3_RS0_15 Sch=sw[0]
set_property -dict { PACKAGE_PIN L16      IOSTANDARD LVCMOS33 }
[get_ports { i[1] }]; #IO_L3N_T0_DQS_EMCCCLK_14 Sch=sw[1]
set_property -dict { PACKAGE_PIN M13      IOSTANDARD LVCMOS33 }
[get_ports { i[2] }]; #IO_L6N_T0_D08_VREF_14 Sch=sw[2]
set_property -dict { PACKAGE_PIN R15      IOSTANDARD LVCMOS33 }
[get_ports { i[3] }]; #IO_L13N_T2_MRCC_14 Sch=sw[3]
```

```

set_property -dict { PACKAGE_PIN R17      IOSTANDARD LVCMOS33 } [get_ports { i[4] }]; #IO_L12N_T1_MRCC_14 Sch=sw[4]
set_property -dict { PACKAGE_PIN T18      IOSTANDARD LVCMOS33 } [get_ports { i[5] }]; #IO_L7N_T1_D10_14 Sch=sw[5]
set_property -dict { PACKAGE_PIN U18      IOSTANDARD LVCMOS33 } [get_ports { i[6] }]; #IO_L17N_T2_A13_D29_14 Sch=sw[6]
set_property -dict { PACKAGE_PIN R13      IOSTANDARD LVCMOS33 } [get_ports { i[7] }]; #IO_L5N_T0_D07_14 Sch=sw[7]

(inputan Selector s0-s2)
set_property -dict { PACKAGE_PIN U12      IOSTANDARD LVCMOS33 } [get_ports { s[2] }]; #IO_L20P_T3_A08_D24_14 Sch=sw[13]
set_property -dict { PACKAGE_PIN U11      IOSTANDARD LVCMOS33 } [get_ports { s[1] }]; #IO_L19N_T3_A09_D25_VREF_14 Sch=sw[14]
set_property -dict { PACKAGE_PIN V10      IOSTANDARD LVCMOS33 } [get_ports { s[0] }]; #IO_L21P_T3_DQS_14 Sch=sw[15]

(output LED)
set_property -dict { PACKAGE_PIN H17      IOSTANDARD LVCMOS33 } [get_ports { o }]; #IO_L18P_T2_A24_15 Sch=led[0] set_property -dict { PACKAGE_PIN H17      IOSTANDARD LVCMOS33 } [get_ports { s }]; #IO_L18P_T2_A24_15 Sch=led[0]

```

18. Untuk melihat rangkaian, klik open elaborated design kemudian pilih schematic



19. Selanjutnya, pilih “open hardware manager”, lalu “open target”, pilih “auto connect”.



20. Selanjutnya, tekan “Generate bitstream, lalu pilih OK. Proses ini akan memakan waktu cukup lama, sampe sekitar 5 menit (tergantung spesifikasi laptop masing-masing).



21. Jika proses sudah selesai, akan muncul pop-up. Tekan “cancel”.



22. Pilih “program device” di pojok kiri bawah. Lalu, tekan board yang tertera.



23. Lalu, tekan “Program”.



24. Bolak-balikkan switch yang diprogram dan amati perbedaannya