# Logic and Computer Design Fundamentals Verilog

Part 4 – Chapter 7 – Registers and Counters

#### **Charles Kime & Thomas Kaminski**

© 2004 Pearson Education, Inc.

Terms of Use

(Hyperlinks are active in View Show mode)

## **Overview**

### Part 4

- Registers
- Shift Registers
- Counters
- Example
  - 4-bit Left Shift Register with Reset
  - 4-bit Binary Counter with Reset

## Verilog for Registers and Counters

Register – same as flip-flop except multiple

```
bits: reg[3:0] Q;
    input[3:0] D;
   always@(posedge CLK or posedge RESET)
   begin
          if (RESET) Q \leq 4'b0000;
          else Q \leq D;
   end
```

Shift Register – use concatenate:

```
Q \le \{Q[2:0], SI\};
```

Counter – use increment/decrement:

```
count <= count + 1; or count <= count - 1</pre>
```

## **Verilog Description of Left Shift Register**

```
// 4-bit Shift Register always@(posedge CLK or
  with Reset
                                        posedge RESET)
module srg 4 r v (CLK,
                           begin
  RESET, SI, Q, SO);
                              if (RESET)
   input CLK, RESET, SI;
                                 Q \le 4'b0000;
   output [3:0] Q;
   output SO;
                              else
   req [3:0] Q;
                                 Q \le \{Q[2:0], SI\};
   assign SO = Q[3];
                           end
                           endmodule
```

## **Verilog Description of Binary Counter**

```
always@(posedge CLK or
// 4-bit Binary Counter with
                                posedge RESET)
  Reset
                              begin
module count 4 r v (CLK,
                                 if (RESET)
  RESET, EN, Q, CO);
                                    count <= 4'b0;
   input CLK, RESET, EN;
                                 else if (EN)
   output [3:0] Q;
                                    count <= count + 1;
   output CO;
                              end
                              endmodule
   reg [3:0] count;
   assign Q = count;
   assign CO = (count ==
  4'b1111 & EN == 1'b1) ? 1
  : 0;
```

## Terms of Use

- © 2004 by Pearson Education, Inc. All rights reserved.
- The following terms of use apply in addition to the standard Pearson Education <u>Legal Notice</u>.
- Permission is given to incorporate these materials into classroom presentations and handouts only to instructors adopting Logic and Computer Design Fundamentals as the course text.
- Permission is granted to the instructors adopting the book to post these materials on a protected website or protected ftp site in original or modified form. All other website or ftp postings, including those offering the materials for a fee, are prohibited.
- You may not remove or in any way alter this Terms of Use notice or any trademark, copyright, or other proprietary notice, including the copyright watermark on each slide.
- Return to Title Page