# CSE 2600 Intro. To Digital Logic & Computer Design

Bill Siever & Michael Hall

#### This week

- Hw 4A requires an in-person demo (during office hours) for full credit
- All remaining Hw are likely to require in-person demos
- Office hours update:
  - Monday 5-7pm room changed to Jubel 121
- Hw 4B will be posted today / drop boxes by Thursday

# **Chapter 4**

#### Review: HDLs Describe Hardware

- Uses
  - "Synthesis": Transformation to real hardware
    - · Like compilers used for programming languages
  - · Simulation: Confirm modules work together
- Use <u>modules</u> for hierarchical design important part of managing complexity
- Description Styles
  - Structure (connect 2 input AND to ...)
  - Behavior (if x then y)

## (System) Verilog Module: Review

```
a — SystemVerilog c — y Module
```

```
module example(input logic a, b, c, output logic y);

// module body goes here
endmodule
```

## (System) Verilog

Conditionals via Ternary operator (? :)



#### 8-bit mux2: Hierarchical

```
| d0[7:0] | 3:01 | d0[3:0] | y[3:0] | d1[7:0] | y[7:0] | d1[3:0] |
```

mux2

# **Sequential Logic**

#### always: Based on Events

- Concept of "event" is related to simulation and "event driven programming"
- JLS uses events: An OR gate "reacts" to events and schedules an update
   See <u>here</u>

#### **Discrete Time Event Simulator**

- Computes all activities / updates for "now"
  - They cause new activities that need to be handled in the future (at: now + prop delay). Those are put in a queue at for that time.
     Ex: Update an or-gate's output at now+4
- Now Queue of updates

  Time is simulated in discrete units

  Time

  Time

#### **Discrete Time Event Simulator**

- Updating values in current turn: Incrementally or all at once at end of turn
  - Ex: Assume x is 1 and y is 0
  - Incremental:

$$x = 0$$

$$y = x$$

x's final value is 0
 y's final value is 0 too

All at once / end of turn

$$x <= 0$$

x's final value is 0
y's final value is 1

# SystemVerilog Standard

- Why all the simulation details?
- Quick intro to SystemVerilog Standard
  - Section 9 / 9.2

#### always **Statement**

- Form: always @(sensitivity <u>list</u>) statement;
- When event in sensitivity list occurs, statement is executed
- Ex: always @(posedge clock) statement;
- Verilog: Don't use this in here

#### always **Statement**

- Form:
   always @(sensitivity list)
   statement;
- When event in sensitivity list occurs, statement is executed
- · Verilog: Don't use this in here

#### always in 2600

 Form 1: Comb logic always\_comb statement;

Use blocking assignment (=)

- Statement(s) are (complex) combinational logic. Like if/else or case.
   Updates when any (relevant/used) input changes
- Form 2: Registered (synchronous, synthesize able, sequential) logic always\_ff @(sensitivity list) statement;
  - Often @(posedge clock) used

Use non-blocking assignment (<=)

# **Assignments**

- Form 1: Continuous Assignment assign var = expression;
  - Continuously assigned! Largely a wired connection
- Forms 2 & 3 in Procedures (in some form of always\*):
  - Blocking (=): Will be "instant" in terms of simulation
    - always\_comb
  - Non-Blocking (<=): Will occur at end of turn all at once</li>
    - always\_ff

# **Rules for Assignments**

- Synchronous sequential logic
   use always\_ff @(posedge clk) and nonblocking assignments (<=)
   always\_ff @(posedge clk)
   q <= d; // nonblocking</li>
- Simple combinational logic use continuous assignments (assign) assign y = a & b;
- Complex Combinational Logic use always comb and blocking assignments (=)
- Assign signals in only one always or assign statement!

## Verilog: D Flip-Flop



## Resettable D-Flip-Flop 1



#### Resettable D-Flip-Flop 2



#### Resettable D-Flip-Flop 3



# always and Combinational Logic

always\_comb
begin
 y = a & b...
end

Block of assignments

Could have been done with individual assigns

Notice = ("blocking assignment"), not <= ("non-blocking assignment")

#### always\_comb has nice features

- case: Selection between several options
   Great for state machines!
  - Must describe all possible combinations to be comb logic. Use default

## Verilog FSMs

- Three parts
  - Next state logic (arrows / next state table)
  - State register (active bubble)
  - Output logic (output equations)



# **Divide by 3 Counter**



# Verilog

```
module divideby3FSM(input logic clk, input logic reset, output logic q);

typedef enum logic [1:0] {S0, S1, S2} statetype; statetype state, nextstate;

// state register always_ff @(posedge clk, posedge reset) if (reset) state <= $0; else state <= nextstate;

// next state logic always_comb case (state)
S0: nextstate = $1; S1: nextstate = $2; S2: nextstate = $0; default: nextstate = $0; endcase

// output logic assign q = (state == $0); endmodule
```





#### **Parameterized Modules: Declaration**

- Way to specify additional details for an instance of a generic part
  - Commonly the "width" of the part

#### Parameterized Modules: Use

• Default or specify parameter for instance:

```
mux2 myMux(d0, d1, s, out);
mux2 #(12) lowmux(d0, d1, s, out);
```

#### Ports: Positional vs. Named

Default or specify parameter for instance:

# Test Bench: Overview & Concept (Simple w/ Asserts)

Hw4A: simple\_comb\_tb



#### **FPGA**

- Field Programmable
- Gate Array
  - Lattice iCE40 UP5k: Architecture Overview
    - RAMs, (Dual and Single Port)
    - Look Up Tables (LUTs): 4 inputs
    - D Flip Flops
    - Lots: ~5,000

# Playground: Combinational logic, hardware, synthesis, and parameters

## **Examples**

- Leds assignment(s)
- Using keys and assign / logic
- Spinner module
  - Adjusting parameters
  - Multiple spinners

#### Studio / Hw

- Hw4B posted tonight
- Studio: Bring hardware kit + cable!

#### Questions

- How advanced can you design hardware in Verilog? Is there a point where it will break?
- How does the nonblocking assignments work? (I know they are done concurrently, but it is not obvious to me how this translates into sequential logic)
- I'm still unclear how SystemVerilog "runs" compared to normal software—since hardware
  updates concurrently, but code is written line-by-line, how should I think about blocking = vs
  non-blocking <= in practice?</li>
- The difference between wire, logic, and net is confusing, not sure what is meant by driver.
- Is it okay to think of parametrized modules like functions in a programming language, or is that not a very good analogy?