#### **ECE 351**

## Verilog and FPGA Design

Week 1\_1: Course overview

Introduction to SystemVerilog RTL and gate-level models FPGAs, ASICs, ASSPs, SoCs

Roy Kravitz
Electrical and Computer Engineering Department
Maseeh College of Engineering and Computer Science





3 Instructor and T/A Instructor: Roy Kravitz, roy.kravitz@pdx.edu, 503.913.1678 (M) T/A and Grader: T/A: Tyler Hull, thull@pdx.edu Grader: Tiffani Shilts Hartman, <a href="mailto:tshilts2@pdx.edu">tshilts2@pdx.edu</a> (Virtual)Office Hours: Roy: ☐ Mon, 3:00 PM - 4:30 PM (https://pdx.zoom.us/j/83621459358) □ Tue, 10:30 AM - Noon (<a href="https://pdx.zoom.us/j/87343138815">https://pdx.zoom.us/j/87343138815</a>) □ Wed, 7:00 PM - 7:30 PM (https://pdx.zoom.us/j/82409406710) Tyler: □ TBD All office hours will be conducted via Zoom meetings Students will enter the Waiting room to be admitted We will also take appointments outside normal office hours. Email to set date/time Portland State ECE 351

## Course objectives

By the end of this course, you should be able to:

- Describe complex digital designs using the SystemVerilog Hardware Description Language
- Implement basic testbenches needed to functional verify digital designs
- Apply design automation tools to synthesize designs in FPGAs
- Describe good coding practices for efficient synthesized designs in FPGAs
- Describe how embedded systems are implemented in FPGAs (including the role of vendor-specific, 3<sup>rd</sup> party, and custom IP)

Portland State

#### Course overview

- Lecture orientation
  - Lectures covering SystemVerilog for synthesis, testbenches, FPGA design flows, IP block, JTAG, embedded systems in SoC's
- Assignments:
  - Homework Problem solving but there may be some short answer, multiple choice, or True/False questions...you will be writing/simulating SystemVerilog programs
  - FPGA mini-project More effort than the homework. Will rely on commercial EDA tools
    - ☐ My hope is to have you execute your design on the FPGA boards in the labs...if the labs reopen before the end of the term
  - All assignments will be done individually and submitted to D2L for grading
- Quizzes and Exams (all given remotely):
  - Quizzes and/or graded exercises during class meeting times
  - Midterm exam Thu, 06-May (week 6) from 2:00 PM 4:30 PM
  - Final exam on Tue, 08-Jun from 2:00 PM 4:30 PM (week 11)

Portland State

ECE 351

#### Course website

- ☐ Can access from your *my.pdx.edu* login or <a href="https://d2l.pdx.edu/">https://d2l.pdx.edu/</a>
- Login with your ODIN username and password
  - Announcements and course calendar
  - Lecture notes and reading material
  - Links to Zoom class meetings and recordings
  - Project releases and dropbox(es) for submissions
  - Discussion forums
  - Links

Do NOT send email from D2L – We cannot reply to it. Use your pdx.edu email address and send email to our pdx.edu email address



#### **Textbooks**

□ Required Textbook:



RTL Modeling with SystemVerilog for Simulation and Synthesis by Stuart Sutherland. Publisher: CreateSpace, An Amazon Company; ISBN-13: 978-154677634

- □ Technical Documentation:
  - Mentor Graphics QuestaSim user documentation
  - Xilinx Vivado user documentation
  - Digilent Nexys A7 documentation
  - Technical papers, reports, datasheets, and application notes as posted to class web page

Portland State

ECE 351

## Textbooks (cont'd)

Reference (optional – no readings assigned):



Logic Design and Verification Using SystemVerilog (Revised) by Donald Thomas. Publisher: CreateSpace, An Amazon.com Company; ISBN-13: 978-1523364022 (Available from the PSU Bookstore, Amazon.com and other retail outlets)



Designing Digital Systems with SystemVerilog:v2.0) by Brent E. Nelson. Independently published (June 2019); ISBN-13: 978-1075968433 (Available from Amazon.com)

ECE 351



## QuestaSim on MCECS systems

- Available remotely from PSU downtown campus and WCC
  - Intel PC Lab: FAB Basement
  - Capstone/Digital Circuits Lab: FAB Basement
  - Workstations in WCC Lab (WCC 313)
- ☐ Remote access through VPN (Virtual Private Network)
  - https://cat.pdx.edu/services/network/vpn-services/
  - Can set up local drives, drag/drop to copy, etc.
    - □ Secure shell and FTP (or scp)
- Remote access through Spark View (RDP)
  - Web-based no VPN connection needed
  - https://rdp.cecs.pdx.edu/
- CAT preference is for students to remote login to one of the lab PC's or the Intel Lab and not through Spark View for anything other than short simulations
  - https://cat.pdx.edu/2021/01/12/remote-access-to-mcecs-computer-labs-2
  - Remember to logout when you are finished

ECE 351



## **Details**

Syllabus: ..\..\syllabus\ece351sp21 syllabus r1 0.pdf

Weekly Schedule: ..\..\syllabus\ece351sp21 tentative weekly schedule r1 0.pdf

ECE 351





## What is SystemVerilog?

- SystemVerilog is a language and a simulator for digital systems
  - Enables a designer to model a digital system as interconnected blocks of logic (incl. primitive gates like AND, OR, ...)
  - Specifies how logic values are propagated through digital system as a function of time
- Single design language to describe, model, synthesize (turn into optimized logic blocks) and simulate simple and complex electronic digital systems
  - Attempts to merge the rich verification features and abstraction features of VHDL with the relative simplicity of describing hardware in Verilog
- Provides rich environment for verifying that a digital system functions correctly



## Why SystemVerilog?

- New features for high level design, RTL design, and verification
- Additional constructs, features
  - Reusability, Conciseness
  - Improved error detection and reporting
- □ Greatly improved/enhanced support for verification of complex designs (assertions, constrained randomization, support for Object Oriented Programming, ...
- □ More consistent behavior between synthesized hardware and simulated result

...all this...and more...yet it retains backwards compatibility w/ Verilog 2001 syntax

Portland State

## Why SystemVerilog in ECE 351?

- □ There is no more "Verilog"
  - Verilog spec was incorporated into SystemVerilog spec
  - Last standalone specification was Verilog 2001
  - SystemVerilog is the new name for what used to be Verilog
- ECE department has standardized on SystemVerilog as the Hardware Description Language we teach
  - ECE 571, 4/581, ECE 590, ECE Design Verification and Validation graduate track all teach/use it
  - SystemVerilog is a "better" language for expressing hardware behavior concisely
  - New SystemVerilog constructs and simulation kernel pretty much eliminate the race conditions that made simulation frustrating at times (...exactly how do I interpret this result?)
- Commercial simulation and synthesis tools support
   SystemVerilog constructs

Portland State

ECE 351

## Key Features: Design

- □ Data types:
  - wire, reg, integer, tri, ... (inherited from Verilog 2001)
  - logic (the more generic, go-to type)
  - C-like data types (ex: int)
  - User-defined types (ex: typedef)
  - Enumerated types (ex: enum)
  - Structures and unions (ex: struct and union)
  - Typecasting
- □ Logical and arithmetic operations
  - ~, +, -, \*, /, %, |, &, ^, !, &&, ||, ...
  - ++, --, += and other assignment operators
- ☐ Explicit constructs for combinatorial, latch-based, and flip-flop-based designs
- Packages for definitions shared by multiple design blocks
- □ Interfaces to encapsulate communication and protocol checking



ECE 351

Key Features: Verification

Data Types
Strings
Dynamic arrays, associative arrays, queues
Object Oriented Programming (e.g. Classes)
Constrained Random Generation
Assertions
Coverage
Synchronization

17

ECE 351

わ Portland State





## SystemVerilog levels of abstraction (cont'd)

- **Behavioral** or **Transaction Level** Highest level of abstraction. A module is implemented with little (or no) concern for hardware-implementation details (function-only)
  - Very similar to C programming
- □ Register Transfer Level function-only w/ clock cycle timing
- ☐ Gate Level Module is implemented in terms of logic gates and interconnection between the gates
  - Similar to a logic schematic
- **Switch Level** Lowest level of abstraction. Module is implemented with switches, storage nodes and the interconnect between them

Portland State

## D Flip-Flop gate level model

```
module DFF (
  output logic q,
   input logic d,
   input logic clk, reset
);
logic s, sbar, r, rbar, q, qbar;
logic clkbar, cbar;
not inv1(cbar, clear);
not inv2(clkbar, clk);
nand sr1g1(sbar,rbar, s);
nand srig2(s, sbar, cbar, clkbar);
nand sr2g1(r, rbar, clkbar,s);
nand sr2g2(rbar, r, cbar, d);
nand sr3g1(q, s, qbar);
nand sr3g2(qbar, q, r, cbar);
endmodule
ECE 351
```





## D Flip-Flop RTL model

```
// module DFF with asynchronous reset
module DFF(
    output logic q,
    input logic d, clk, reset,
    logic q
);

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

Portland State

ECE 351

22

# Gate level modeling

Source material drawn from:

- Palnitkar ( some figures from online edition)
- Brown and Veranasic
- ECE 351 lecture slides

## Gate level modeling

- SystemVerilog supports gate level modeling
  - Can replace gate level schematics and you can simulate and debug the design!
  - Provides explicit directions for synthesis tool
- □ Basic Gate Types primitives
  - and, or, xor, nand, nor, xnor logic gates
  - buf, not non-inverting and inverting buffers
  - bufif1, notif1, bufif0, notif0 tri-state buffers
  - pulldown, pullup, nmos, pmos, cmos,...



ECE 351

## Gate level Mmodeling (cont'd)

- □ Syntax is the same for all instantiations
  - < <gate\_type> <gate\_instance>(out, in1, in2, ..., inn);

```
nand n1(OUT, IN1, IN2);

| The standard of th
```

- Single output, but gates w/ more than 2 inputs (NAND, NOR, etc) are instantiated by simply adding more input ports
- Gate instance name is optional



ECE 351

# Verilog gate types

| Name   | Description                              | Usage                                            |
|--------|------------------------------------------|--------------------------------------------------|
| and    | $f = (a \cdot b \cdot)$                  | $\mathbf{and}(f,a,b,\ldots)$                     |
| nand   | $f = \overline{(a \cdot b \cdot)}$       | $\mathbf{nand}(f,a,b,\ldots)$                    |
| or     | $f=(a+b+\cdots)$                         | or $(f,a,b,)$                                    |
| nor    | $f = \overline{(a+b+\cdots)}$            | $\mathbf{nor}(f, a, b, \dots)$                   |
| xor    | $f=(a\oplus b\oplus\cdots)$              | $\mathbf{xor}(f,a,b,\ldots)$                     |
| xnor   | $f = \overline{(a \odot b \odot \cdot)}$ | $\mathbf{xnor}(f,a,b,\ldots)$                    |
| not    | $f = \overline{a}$                       | $\mathbf{not}(f,a)$                              |
| buf    | f = a                                    | <b>buf</b> $(f,a)$                               |
| notif0 | $f = (!e?\overline{a}: 'bz)$             | <b>notif0</b> ( <i>f</i> , <i>a</i> , <i>e</i> ) |
| notif1 | $f = (e?\underline{a}: bz)$              | <b>notif1</b> ( <i>f</i> , <i>a</i> , <i>e</i> ) |
| bufif0 | $f = (!e?\overline{a}: 'bz)$             | <b>bufif0</b> ( <i>f</i> , <i>a</i> , <i>e</i> ) |
| bufif1 | f = (e?a: bz)                            | <b>bufif1</b> ( <i>f</i> , <i>a</i> , <i>e</i> ) |

Portland State

ECE 351

26

## Truth tables for logic gates

- ☐ SystemVerilog is a 4 valued logic simulator
  - 0, 1, x, z
- x is unknown that means it can either be a 1 or a 0
- z essentially mean open circuit, so, for example, a z input to a nand() gate has an uncertain output

| and | 0 | 1 | Х | Z |
|-----|---|---|---|---|
| 0   | 0 | 0 | 0 | 0 |
| 1   | 0 | 1 | Х | Х |
| X   | 0 | X | Х | X |
| Z   | 0 | X | х | X |

| xnor | 0 | 1 | Х | Z |
|------|---|---|---|---|
| 0    | 1 | 0 | Х | Х |
| 1    | 0 | 1 | Х | Х |
| X    | X | X | X | X |
| Z    | X | X | X | X |



## Example

```
g1
                                 sum
ci.
            n2
        g3
```

```
module gate_adder (
  input wire a, b, ci,
  output wire sum, co
);
wire n1, n2, n3;
               g1 (n1, a, b);
xor
xor #1.3
               g2 (sum, n1, ci);
and
               g3 (n2, a, b);
               g4 (n3, n1, ci);
and
or #(1.5,1.8) g5 (co, n2, n3);
endmodule: gate_adder
```

ECE 351

Sutherland Figure 1-4, Example 1-1



## Technology overview

#### Source material drawn from:

- ASIC Design Methodology Primer, IBM ASIC Products Application Note, Initial publication 5/98
- Wikipedia
- Slideware provided by Xilinx
- Dr Song's lecture notes
- Verilog workshop and other lecture material by Roy

### ASIC's, ASPP's and full custom IC's

- Application Specific Integrated Circuit a custom chip designed for a very specific purpose.
  - Ex: a chip with a DSP front-end designed for a specific model of cardiac monitor made by only one manufacturer
  - Companies implement their ASIC designs in a single silicon die by mapping their functionality to a set of predesigned and verified library of circuits provided by the ASIC vendor. The components of the library are described in the ASIC vendor's databook
- Application Specific Standard Product a semi-custom chip designed for a specific application and sold to multiple customers
  - Ex: an integrated circuit that does video or audio encoding/decoding
- □ Full custom chip an integrated circuit designed by a single company for a specific application, usually huge volumes
  - Ex: an Intel CPU
  - Full-custom chips are developed for a specific semiconductor technology, often with huge teams of architects, logic designers, circuit designers, validation engineers, layout designers, et. al. and take several years to design

Portland State

#### FPGA's

- □ Field Programmable Gate Array An integrated circuit designed to be configured by a customer or a designer after manufacturing—hence field-programmable
  - The FPGA configuration is generally specified using a hardware description language (HDL)
  - FPGAs can be used to implement any logical function that an ASIC can perform but the ability to update the functionality after shipping and the low non-recurring engineering costs relative to an ASIC design offer advantages for many applications
  - FPGAs contain programmable logic components called "configurable logic blocks" and a hierarchy of reconfigurable interconnects that allow the blocks to be "wired together" when the FPGA is configured (and reconfigured...and reconfigured...and reconfigured...)

Portland State

## SoC's

- System on Chip or SOC An integrated circuit (IC) that integrates all components of a computer or other electronic system into a single chip.
  - Ex: an embedded system such as a cell phone or cable box
  - SoC's may contain digital, analog, mixed-signal, and often radiofrequency functions—all on a single chip substrate
- An SoC can be implemented as an ASIC or as an ASSP or in an FPGA or as a full custom chip
  - Roy's definition: An SoC contains at least one embedded CPU running an application interfaced to one or more vendor-supplied, 3<sup>rd</sup> party or custom IP blocks



ECE 351

SiFive FE310-G002 top-level block diagram

Portland State







## **Next Time**

- □ Topics:
  - SystemVerilog language rules
- You should:
  - Read Sutherland Ch 1, and Ch 2
- Homework, projects and quizzes
  - Graded in-class exercises scheduled for Wed, 8-Apr
  - Homework #1 will be assigned Tue, 13-Apr

Portland State

ECE 351