## RTL-Assignment 1

### November 25, 2022

# Sampath Govardhan FWC22071

### Contents

| 1        | Module Code       | 1 |
|----------|-------------------|---|
| <b>2</b> | Test Bench Code   | 3 |
| 3        | Timing diagram    | 4 |
| 4        | Schematic diagram | 5 |
| 5        | Design diagram    | 6 |

### 1 Module Code

// Revision:

```
// Revision 0.01 -  File Created
// Additional Comments:
module counter (
   input [7:0] in,
   input clk,
   input latch,
   input div,
   input dec,
   output reg [7:0] count,
   output reg zero
    );
   always @(posedge clk)
   case({latch, dec})
   2'b10: begin
   count <= in;
   end
   2'b01: begin
   if (count==8'b00000000) begin
   zero = 1;
   end
    else begin
   count < = count - 1;
   end
   end
   2'b11: begin
   count<=in;
   if (count = 8'b00000000) begin
   zero = 1;
   end
    else begin
   count < = count - 1;
   end
   end
   2'b00: begin
   if (div) begin
   count = count / 2;
   end
   end
   endcase
   end
```

### 2 Test Bench Code

```
'timescale 1ns / 1ps
// Company:
// Engineer:
// Create Date: 11/23/2022 02:21:29 PM
// Design Name:
// Module Name: counter_tb
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
// Dependencies:
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
module counter_tb();
reg CLK, LATCH, DIV, DEC;
reg [7:0] IN;
wire [7:0] COUNT;
wire ZERO;
counter dut(.in(IN),.clk(CLK),.latch(LATCH),.div(DIV),.dec(DEC),.count(COUNT),.z
initial begin
CLK = 0;
forever #5 CLK = ~CLK;
initial begin
IN=8'b00010000; LATCH=1; DEC=0;
#10
IN=8'd0; LATCH=0; DEC=0; DIV=1;
IN=8'b00000010; LATCH=0; DEC=0; DIV=1;
#10
```

```
IN=8'd11;LATCH=0;DEC=0;DIV=1;
#10
LATCH=0;DEC=1;DIV=0;
#10
IN=1;LATCH=0;DEC=1;DIV=0;
#10
LATCH=0;DEC=1;DIV=0;
#10
$stop;
end
endmodule
```

## 3 Timing diagram



Figure 1: Timing diagram

## 4 Schematic diagram



Figure 2: Netlist

## 5 Design diagram



Figure 3: Design diagram