## DataPath

Projektovanje (Digitalnih) Integrisanih Kola

HDL Projektovanje na bazi standardnih ćelija

Datum preuzimanja: 12. maj 2021.

Datum predaje: 30. avgust 2021.

Student

Aleksa Ranđelović

Modul

ELK

Br. Indeksa

17378

```
timescale lns/lps
module dff(input rst, input clk, input d, output reg q);

always @(posedge clk or negedge rst) begin
    if (!rst)
        q <= 1'b0;
    else
        q <= d;
end
endmodule</pre>
```

Slika 1. HDL opis – kod D flip-flopa

```
`timescale 1ns/1ps
module projekat(A, B, C, CLK, RST, Y);
input A;
input B;
input C;
input CLK;
input RST;
output Y;
wire q1;
wire q2;
wire q3;
wire xorr;
wire nott;
wire nandd;
wire orr;
dff dut1(RST, CLK, A, q1);
dff dut2(RST, CLK, B, q2);
dff dut3(RST, CLK, C, q3);
```

```
dff dut1(RST, CLK, A, q1);
dff dut2(RST, CLK, B, q2);
dff dut3(RST, CLK, C, q3);

assign xorr = q1 ^ q2;
assign nott = ~q3;
assign nandd = ~(nott & xorr);
assign orr = q1 | nandd;

dff dut4(RST, CLK, orr, Y);
endmodule
```

Slika 2 i 3 – HDL kod opisanog kola

```
`timescale 1ns/1ps
 module projekat tb();
  reg clk;
  reg rst;
  reg a, b, c;
  wire y;
  projekat projekat_inst(a, b, c, clk, rst, y);
  reg[2:0] cnt;
  reg a prev;
  reg b_prev;
  reg c_prev;
initial begin
     $dumpfile("waves.vcd");
     $dumpvars(0, projekat tb);
  end
▼ initial begin
    cnt = 0;
    clk = 0;
    rst = 1;
    @(posedge clk);
    a = 0;
    b = 0;
    c = 0;
    rst = 0;
    @(posedge clk);
    rst = 1;
    repeat (2) begin
                   INS LINE ISO-8859-1 projekat tb.v
Line: 21 Col: 11
  forever begin
   cnt = cnt + 1;
if (cnt == 0) begin
     $finish();
   end
   else begin
   {a, b, c} = cnt;
@(posedge clk);
  end
 ///////
end
▼ initial begin
  @(posedge rst);
  forever begin
a_prev = a;
b_prev = b;
   c prev = c;
   @(posedge clk);
   # 1;
if (a_prev == 0 && b_prev == 1 && c_prev == 0) begin
    else begin
      $display("Provera neuspesna, a = %b, b = %b, c = %b, y = %b, vreme: %f !", a prev, b prev, c prev, y, $realtime());
     end
   end
```

Slike 4, 5 i 6 – HDL kod testbenča



Slika 7 - Rezultati simulacije



Slika 8 – RTL Sinteza

-----Generated by:
Genus(TM) Synthesis Solution 17.11-s014\_1
Generated on:
Module:
Technology library:
Operating conditions:
Wireload mode:
Area mode:
Genus(TM) Synthesis Solution 17.11-s014\_1
Aug 30 2021 02:31:11 pm
projekat
c18\_CORELIB\_WC revision 2.2
worst (balanced\_tree)
enclosed
timing library \_\_\_\_\_\_ Type Fanout Load Slew Delay Arrival Pin (fF) (ps) (ps) (ps) ------0 R (clock CLK1) launch dut4 DFCX1 1 28.6 216 +571 571 F +0 571 q\_reg/CP q reg/QN g5/A 1 2005.4 1785 +1302 1874 R INVX24 g5/Q dut4/q 1785 +14 1888 R +0 1888 R Υ <<< interconnect out port (const.sdc\_line\_28) out port ext delay +100 1988 R (clock CLK1) capture 20000 R Cost Group : 'CLK1' (path\_group 'CLK1') Timing slack: 18012ps

Slika 9 – Kašnjenje

Start-point : dut4/q reg/CP

End-point : Y

\_\_\_\_\_\_

Generated by: Genus(TM) Synthesis Solution 17.11-s014 1

Generated on: Aug 30 2021 02:31:11 pm

Module: projekat

Technology library: c18\_CORELIB\_WC revision 2.2 Operating conditions: worst (balanced\_tree)

Wireload mode: enclosed

Area mode: timing library

\_\_\_\_\_\_

| Gate                              | Instances   | Area                                 | Library                                                              |
|-----------------------------------|-------------|--------------------------------------|----------------------------------------------------------------------|
| DFCX1<br>INVX24<br>INVXL<br>OR3X3 | 4<br>1<br>1 | 259.661<br>28.224<br>5.645<br>16.934 | c18_CORELIB_WC<br>c18_CORELIB_WC<br>c18_CORELIB_WC<br>c18_CORELIB_WC |
| total                             | 7           | 310.464                              |                                                                      |

total

| Туре                                              | Instances | Area                                 | Area %                     |
|---------------------------------------------------|-----------|--------------------------------------|----------------------------|
| sequential<br>inverter<br>logic<br>physical_cells |           | 259.661<br>33.869<br>16.934<br>0.000 | 83.6<br>10.9<br>5.5<br>0.0 |
| total                                             | 7         | 310.464                              | 100.0                      |

Slika 10 - Zauzeće

\_\_\_\_\_

Generated by:
Genus(TM) Synthesis Solution 17.11-s014\_1
Generated on:
Aug 30 2021 02:31:11 pm
projekat
Technology library:
C18\_CORELIB\_WC revision 2.2
Operating conditions:
Worst (balanced\_tree)
Wireload mode:
Area mode:
timing library

\_\_\_\_\_

|          |       | Leakage   | Dynamic   | Total     |  |
|----------|-------|-----------|-----------|-----------|--|
| Instance | Cells | Power(nW) | Power(nW) | Power(nW) |  |
|          |       |           |           |           |  |
| projekat | 7     | 92.348    | 25434.679 | 25527.026 |  |
| dut4     | 2     | 44.218    | 16470.659 | 16514.876 |  |
| dut2     | 1     | 13.797    | 2320.561  | 2334.358  |  |
| dut1     | 1     | 13.795    | 2359.474  | 2373.269  |  |
| dut3     | 1     | 13.795    | 2365.141  | 2378.936  |  |
|          |       |           |           |           |  |