## FWC RTL ASSIGNMENT-1

#### A.CHINNAPA REDDY

November 22, 2022

### 1 Module Code

```
'timescale 1ns / 1ps
module downcounter(
// Inputs
input
        wire
                  [7:0]
                          in,
input
        wire
                          clk,
input
        wire
                          latch,
input
        wire
                          dec,
input
        wire
                          div,
// Outputs
output
        wire
                          zero,
// Internal
output reg
                 [7:0]
                          count
);
always @(posedge clk)
begin
    if (latch)
        count <= in;</pre>
    else if (dec)
        count \ll (count = 8'd0)?8'd0:count - 1;
    else if (div)
        count \ll count \gg 1;
end
assign zero = (count == 0);
endmodule
```

### 2 Testbench Code

```
'timescale 1ns / 1ps
'include "downcounter.v"
module downcounter$_$tb;
reg
        [7:0]
                 in;
                 clk, latch, dec, div;
reg
wire
         [7:0]
                 count;
wire
                 zero;
downcounter UUT(
    .in(in),
    .clk(clk),
    .latch(latch),
    . dec(dec),
    . div (div),
    .count(count),
    .zero(zero)
);
initial begin
    clk = 1'b0;
    forever #1 clk = ~clk;
end
initial begin
    in= 8'd16; latch = 1'b1; dec = 1'b0; div = 1'b0;
    \#2 \text{ in} = 8'd0; latch = 1'b0;
    #4.5 div = 1'b1;
    #6.5
           div=1'b0;
    #5 $finish;
end
endmodule
```

## 3 Timing Circuit



## 4 Device diagram



# 5 Schematic diagram

