#### Rochester Institute of Technology

### **RIT Digital Institutional Repository**

Theses

12-2019

### UVM Verification of a Floating Point Multiplier

Nicholas J. Marsaw njm3706@rit.edu

Follow this and additional works at: https://repository.rit.edu/theses

#### **Recommended Citation**

Marsaw, Nicholas J., "UVM Verification of a Floating Point Multiplier" (2019). Thesis. Rochester Institute of Technology. Accessed from

This Master's Project is brought to you for free and open access by the RIT Libraries. For more information, please contact repository@rit.edu.

#### UVM VERIFICATION OF A FLOATING POINT MULTIPLIER

by

Nicholas J. Marsaw

#### GRADUATE PAPER

Submitted in partial fulfillment of the requirements for the degree of MASTER OF SCIENCE in Electrical Engineering

Approved by:

Mr. Mark A. Indovina, Senior Lecturer Graduate Research Advisor, Department of Electrical and Microelectronic Engineering

Dr. Sohail A. Dianat, Professor Department Head, Department of Electrical and Microelectronic Engineering

DEPARTMENT OF ELECTRICAL AND MICROELECTRONIC ENGINEERING KATE GLEASON COLLEGE OF ENGINEERING ROCHESTER INSTITUTE OF TECHNOLOGY ROCHESTER, NEW YORK

December, 2019

I dedicate this work to my elementary school teacher Darrel Dupra, who passed away in 2010. He took time to encourage me to think critically and to enjoy the journey as I progressed throughout my academics, and played a crucial role in my pursuit of Electrical Engineering.

## Declaration

I hereby declare that except where specific reference is made to the work of others, that all contents of this Graduate Paper are original and have not been submitted in whole or in part for consideration for any other degree or qualification in this, or any other University. This Graduate Project is the result of my own work and includes nothing which is the outcome of work done in collaboration, except where specifically indicated in the text.

Nicholas J. Marsaw December, 2019

### Acknowledgements

I want to thank Mark A. Indovina for his support, advice, and guidance throughout my graduate research and education. Your passion for the engineering field and dedication to your students is truly valuable. I would also like thank my family for their encouragement as I've worked through my education. You have been extremely patient and loving.

Lastly, I would like to thank Anna for her love and support over the past few years as I have been finishing up my academics. You're very special to me, and I couldn't have accomplished this without you.

### Abstract

Increased design complexity has resulted in the need for efficient verification. The verification process is crucial for discovering and fixing bugs prior to fabrication and system integration. However, as designs increase in complexity, the use of traditional verification techniques with VHDL and Verilog may fall short to provide a proper toolset. Especially when performing verification on designs involving audio signal processing, untested corner cases and bugs may result in significant and sometimes undiscovered processing errors. This paper explores the use of SystemVerilog and the universal verification methodology (UVM) class library to verify a pipelined floating-point multiplier (FMULT) within the adaptive differential pulse code modulation (AD-PCM) specification.

# Contents

| Co | ontent  | ts            |               |                       | ,   | V |
|----|---------|---------------|---------------|-----------------------|-----|---|
| Li | st of l | Figures       |               |                       | i   | X |
| Li | st of ] | <b>Fables</b> |               |                       | 3   | X |
| 1  | Intr    | oductio       | n             |                       |     | 1 |
|    | 1.1     | Resear        | ch Goals .    |                       | ••• | 2 |
|    | 1.2     | Contri        | butions       |                       | ••• | 2 |
|    | 1.3     | Organi        | zation        |                       | ••• | 3 |
| 2  | Bibl    | iograph       | ical Reseau   | rch                   | ,   | 4 |
| 3  | Ada     | ptive D       | ifferential I | Pulse Code Modulation | ,   | 7 |
| 4  | UVN     | M Over        | view          |                       | 1.  | 3 |
|    | 4.1     | UVM           | Hierarchy .   |                       | 1   | 3 |
|    |         | 4.1.1         | Sequencin     | g                     | 1   | 3 |
|    |         |               | 4.1.1.1       | Sequence Item         | 1:  | 5 |
|    |         |               | 4.1.1.2       | Sequence              | 1:  | 5 |
|    |         |               | 4.1.1.3       | Sequencer             | 1:  | 5 |

|   |                           | 4.1.2                                                                                  | Interface                          | 15                                                                                                                                                                                                                                                                                                                     |
|---|---------------------------|----------------------------------------------------------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                           | 4.1.3                                                                                  | Driver                             | 16                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.4                                                                                  | Monitor                            | 16                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.5                                                                                  | Agent                              | 16                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.6                                                                                  | Environment                        | 16                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.7                                                                                  | Scoreboard                         | 17                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.8                                                                                  | Test                               | 17                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.1.9                                                                                  | Тор                                | 17                                                                                                                                                                                                                                                                                                                     |
|   | 4.2                       | Testbe                                                                                 | nch Operation                      | 17                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.2.1                                                                                  | Build Phase                        | 18                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.2.2                                                                                  | Run-time Phase                     | 18                                                                                                                                                                                                                                                                                                                     |
|   |                           | 4.2.3                                                                                  | Clean Up Phase                     | 18                                                                                                                                                                                                                                                                                                                     |
|   |                           |                                                                                        |                                    |                                                                                                                                                                                                                                                                                                                        |
| 5 | Desi                      | ign and                                                                                | Test Methodology                   | 19                                                                                                                                                                                                                                                                                                                     |
| 5 | <b>Desi</b><br>5.1        | i <b>gn and</b><br>FMUL                                                                | Test Methodology                   | <b>19</b><br>19                                                                                                                                                                                                                                                                                                        |
| 5 | <b>Desi</b><br>5.1<br>5.2 | i <b>gn and</b><br>FMUL<br>Testbe                                                      | Test Methodology         T Design  | <b>19</b><br>19<br>20                                                                                                                                                                                                                                                                                                  |
| 5 | <b>Desi</b><br>5.1<br>5.2 | ign and<br>FMUL<br>Testbe<br>5.2.1                                                     | Test Methodology         T Design  | <b>19</b><br>19<br>20<br>22                                                                                                                                                                                                                                                                                            |
| 5 | <b>Desi</b><br>5.1<br>5.2 | ign and<br>FMUL<br>Testbe<br>5.2.1                                                     | Test Methodology         JT Design | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>22</li> </ol>                                                                                                                                                                                                                                                 |
| 5 | <b>Desi</b><br>5.1<br>5.2 | ign and<br>FMUL<br>Testbe<br>5.2.1                                                     | Test Methodology         .T Design | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> </ol>                                                                                                                                                                                                                         |
| 5 | <b>Desi</b><br>5.1<br>5.2 | ign and<br>FMUL<br>Testbe<br>5.2.1<br>5.2.2                                            | Test Methodology         JT Design | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> </ol>                                                                                                                                                                                                 |
| 5 | <b>Desi</b><br>5.1<br>5.2 | <b>ign and</b><br>FMUL<br>Testbe<br>5.2.1<br>5.2.2<br>5.2.2                            | Test Methodology         JT Design | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> <li>22</li> </ol>                                                                                                                                                                         |
| 5 | <b>Desi</b><br>5.1<br>5.2 | <b>ign and</b><br>FMUL<br>Testbe<br>5.2.1<br>5.2.2<br>5.2.3<br>5.2.4                   | Test Methodology         JT Design | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> </ol>                                                                                                                                                 |
| 5 | <b>Desi</b><br>5.1<br>5.2 | <b>ign and</b><br>FMUL<br>Testbe<br>5.2.1<br>5.2.2<br>5.2.3<br>5.2.4<br>5.2.5          | Test Methodology         T Design  | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>23</li> </ol> |
| 5 | <b>Desi</b><br>5.1<br>5.2 | <b>ign and</b><br>FMUL<br>Testbe<br>5.2.1<br>5.2.2<br>5.2.3<br>5.2.4<br>5.2.5<br>5.2.6 | Test Methodology         J Design  | <ol> <li>19</li> <li>19</li> <li>20</li> <li>22</li> <li>23</li> </ol>                                                                                                 |

|    |                                                                             | 5.2.8 Test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                              |
|----|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
|    |                                                                             | 5.2.9 Top                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 4                                              |
|    |                                                                             | 5.2.10 DPI Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4                                              |
|    |                                                                             | 5.2.11 Watermark                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4                                              |
| 6  | Resu                                                                        | ilts and Discussion 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5                                              |
|    | 6.1                                                                         | RTL and Gate Level Simulation Results                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5                                              |
|    | 6.2                                                                         | RTL and Gate Level Synthesis Results                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7                                              |
|    | 6.3                                                                         | Discussion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9                                              |
| 7  | Con                                                                         | clusion 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1                                              |
|    | 7.1                                                                         | Future Work                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                                              |
| Re | feren                                                                       | ces 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                                              |
|    |                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |
| Ι  | Sour                                                                        | rce Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                              |
| Ι  | Sour<br>I.1                                                                 | rce Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>1</b><br>1                                  |
| Ι  | Sour<br>I.1<br>I.2                                                          | rce Code I-<br>FMULT Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>1</b><br>1<br>1                             |
| Ι  | Sour<br>I.1<br>I.2<br>I.3                                                   | I-         FMULT Design       I-         Interface       I-1         Input Sequence Item       I-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1<br>1<br>1<br>2                               |
| Ι  | Sour<br>I.1<br>I.2<br>I.3<br>I.4                                            | rce Code I-   FMULT Design I   Interface I-1   Input Sequence Item I   Output Sequence Item I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1<br>1<br>2<br>3                               |
| I  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5                                     | FMULT Design I   Interface I   Interface I   Input Sequence Item I   Output Sequence Item I   Inference Model I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1<br>1<br>2<br>3<br>4                          |
| Ι  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5<br>I.6                              | rce Code I-   FMULT Design I   Interface I-1   Input Sequence Item I   Output Sequence Item I   Reference Model I   Input Sequence I   Input Seq                                                                                                       | 1<br>1<br>2<br>3<br>4<br>6                     |
| I  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5<br>I.6<br>I.7                       | FMULT Design I   Interface I   Interface I   Input Sequence Item I   Output Sequence Item I   Reference Model I   Input Sequence Item | 1<br>1<br>2<br>3<br>4<br>6<br>7                |
| Ι  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5<br>I.6<br>I.7<br>I.8                | rce Code I-   FMULT Design I-   Interface I-1   Input Sequence Item I-1   Output Sequence Item I-1   Reference Model I-1   Sequencer I-1   Driver I-1   Monitor I-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1<br>1<br>2<br>3<br>4<br>6<br>7                |
| Ι  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5<br>I.6<br>I.7<br>I.8<br>I.9         | rce Code I-   FMULT Design I-   Interface I-1   Input Sequence Item I-1   Output Sequence Item I-1   Reference Model I-1   Sequencer I-1   Driver I-1   Monitor I-2   Agent I-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1<br>1<br>2<br>3<br>4<br>6<br>7<br>1<br>0      |
| I  | Sour<br>I.1<br>I.2<br>I.3<br>I.4<br>I.5<br>I.6<br>I.7<br>I.8<br>I.9<br>I.10 | FMULT Design I-   FMULT Design I-1   Interface I-1   Input Sequence Item I-1   Output Sequence Item I-1   Reference Model I-1   Sequencer I-1   Driver I-1   Monitor I-2   Agent I-3   Environment I-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1<br>1<br>2<br>3<br>4<br>6<br>7<br>1<br>0<br>2 |

| I.12 ′ | Тор |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | I- | .3 | 5 |
|--------|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----|----|---|
|--------|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----|----|---|

# **List of Figures**

| 3.1 | PCM Encoding Process            | 8  |
|-----|---------------------------------|----|
| 3.2 | ADPCM Encoder Block Diagram [1] | 10 |
| 3.3 | ADPCM Decoder Block Diagram [1] | 10 |
| 3.4 | APRSC Block Diagram [1]         | 12 |
| 4.1 | Basic UVM Testbench Hierarchy   | 14 |
| 5.1 | Pipelined FMULT Timing Diagram  | 20 |
| 5.2 | FMULT Testbench Design          | 21 |
| 6.1 | RTL Code Coverage               | 28 |
| 6.2 | Gate-Level Code Coverage        | 28 |
| 6.3 | Wall Time vs. Watermark         | 29 |
| 6.4 | Area Per Gate Size              | 30 |
| 6.5 | Number of Gates Per Gate Size   | 30 |

# **List of Tables**

| 3.1 | ADPCM Data Rates                       | 9  |
|-----|----------------------------------------|----|
| 6.1 | Simulation Results                     | 26 |
| 6.2 | RTL Simulation Coverage Results        | 26 |
| 6.3 | Gate-Level Simulation Coverage Results | 26 |
| 6.4 | Synthesis Results                      | 27 |

# Chapter 1

# Introduction

When an intellectual property (IP) chip is taped out, bugs and design flaws are found in the hardware and require re-spin. In order to mitigate time and cost spent on reworking chip designs, verification is used to catch these issues prior to tape out. Verification has become increasingly necessary as gate sizing has decreased, allowing for increased design complexity in smaller chips. In the past few decades, the hardware description languages (HDL) most commonly used did not present sufficient verification constructs, and as a result many engineers made use of other languages such as OpenVera in order to attain the level of functionality their testbenches required. Other engineers and companies designed their own verification languages and libraries as well. In 2005, SystemVerilog (SV), an object-oriented programming language, was adopted as an IEEE standard with the goal of unifying verification and design, and providing a language for verification that has readability, reusability and efficiency.

Following the adoption of SV, the open verification methodology (OVM), a class library written in SV, was created. OVM provides automation and transaction level modeling for SystemVerilog testbench designs. The testbench structure provided by OVM allows for reusability in other verification environments and makes use of tools provided in SystemVerilog such as code

coverage, assertions, and DPI. OVM would later evolve into the universal verification methodology (UVM), which combines various verification practices to make up the first standardized verification methodology. This paper explores the use of SV and UVM for verifying the floating point multiplier (FMULT) used in the G.726 Adaptive Differential Pulse-Code Modulation (ADPCM) design specification [1], which consists of multiplying an 11-bit floating point binary number with a 16-bit floating point binary number, resulting in a 16-bit product. The FMULT was designed in Verilog with a pipelined architecture using one adder for the necessary additions.

### **1.1 Research Goals**

The goal of this paper is to research and develop a testbench using SystemVerilog and UVM, verifying the floating point multiplier (FMULT). The testbench is a multi-layered, self-checking design. For success, the following goals are considered:

- Understanding ADPCM operation and how the FMULT relates to the overall specification
- Designing a test environment in UVM with self-checking using a reference model and random stimulus
- Running simulations for RTL and gate-level designs
- · Collecting coverage results and test results

### **1.2** Contributions

The major contributions for the paper are as follows:

• A floating point multiplier (FMULT) designed in Verilog

- Verification of the FMULT using a multi-layered testbench written in SystemVerilog and UVM
- Reusable UVM components to conduct verification on other parts of the ADPCM

### 1.3 Organization

The organization of the paper is as follows:

- Chapter 2: This chapter provides context to the UVM through research
- Chapter 3: This chapter discusses adaptive differential pulse code modulation and where the FMULT is used in the design
- Chapter 4: This chapter provides an overview to UVM and the main components used in a multi-layered testbench
- Chapter 5: This chapter discusses the architecture of the testbench and the design integration
- Chapter 6: The results of the tests are provided and discussed
- Chapter 7: The paper concludes here and possible future work is discussed

# Chapter 2

# **Bibliographical Research**

Prior to the introduction of verification methodologies, engineers used traditional verification techniques to verify intellectual property (IP) before tape out. These traditional techniques had their limitations; the testbench design affected code reuse and reapplication in future designs [2]. Another drawback with the use of traditional verification was its inability to test complex systems due to the lack of a strong tool set. This time consuming process would take up over 70% of the time spent on the designs, and the introduction of verification methodologies in the following decades would serve to help lower the time and effort put into chip verification [3]. These methodologies aimed at providing a verification language, library, and/or tool set with reusability. One way these methodologies accomplished this was through the use of object oriented programming (OOP), which was found in the Advanced Verification Methodology (AVM) [4], Universal Reuse Methodology (URM), *e* Reuse Methodology (eRM), Open Verification Methodology (OVM) and the universal verification methodology (UVM). Using OOP allowed the testbench to be broken up into smaller components, providing increased flexibility, simplicity, and reusability lacking in traditional verification techniques [5]. Of the various methodologies created and adopted, UVM is gaining ground and becoming popular among verification engineers. UVM is

also the first methodology to be standardized.

One of the stepping stones to the development of UVM was SystemVerilog (SV). SV sought to address some of the issues in the verification process across the industry, some of which being the lack of unified design, specification, and verification [6]. The verification language was designed to fully support backwards compatibility with Verilog as well as Verilog constructs. In essence, SV was an expansion to the Verilog HDL, providing more robustness in verification. As a language capable of both design and verification, or a hardware description and verification language (HDVL), SV was adopted by IEEE as a standard in 2005 [7]. SV also included several tools beneficial for thorough verification of complex designs: assertions, coverage, DPI, and supported data types not present in Verilog. Assertions and coverage are two components of UVM inherited from SV, and are critical tools used for verification.

Assertions are used to indicate an error if a particular event occurs during simulation run time. The event typically involves output comparison or the behavior of the design under test (DUT) during verification (i.e. enable is not active when it should be, etc). There are 2 types of assertions in SV: concurrent and immediate [8]. Concurrent assertions involve conditions that must be satisfied by the design at all times. Immediate assertions however are checked periodically, typically after an event. SV provides the assertion tool set through System Verilog Assertions (SVA), which can be added and synthesized within the design for debugging and verification. [9] explores synthesizing assertions in a design, stating that the assertions are not treated as the code, but as properties that must hold up in the design. The proposed design was run in parallel with assertion checking from Synopsys OpenVera Assertions (OVA) checker, producing the same results. The simulation for the proposed design ran faster than that of the OVA checker. While the floating-point multiplier (FMULT) proposed in this paper did not include synthesized assertions, this is an area that could be beneficial to explore in future work for both debugging and run time purposes. SVA has also been used for assertion-based verification (ABV), which

has been proven to increase efficiency and lower effort in catching corner cases when verifying the design [10].

Coverage is a measurement used in verification for determining the quality of the testing done on the DUT [11]. Quantified as a percentage, the higher coverage is, the more of the design was tested. This includes corner cases, functional coverage, toggling, and user-defined coverage groups. In SV these are known as cover groups. The goal is to reach 100% percent coverage if possible, as untested code could result in defects and extraneous costs after tape out [12].

The UVM is a powerful verification methodology written in SV, providing functionality found in AVM, OVM, URM and eRM [13]. UVM maintains transaction-level modeling (TLM) found in SV and includes a separate component for handling testbench stimulus known as a sequence, which is separated from the testbench structure [14]. There is value to this, as it allows for flexibility for stimulus generation within a testbench design. A class library is used to provide the building blocks for the methodology [15]. Typically used as a multi-layered design, the UVM provides reusability, but tends to be too complicated for simple designs requiring verification. Its flexible framework however proves valuable for complicated designs with mixed-signal verification capabilities [16].

# Chapter 3

# Adaptive Differential Pulse Code Modulation

Adaptive differential pulse code modulation (ADPCM) is a process of encoding and decoding audio signals from analog to digital and vice versa. It expands on both pulse-code modulation (PCM) and differential pulse-code modulation (DPCM). Converting these audio signals to digital has several benefits: lower costs per data line, ease of maintenance, and high quality signal regeneration at repeaters [17]. ADPCM was first introduced in 1973 by Bell Labs, supporting encoding and decoding for bit rates including 24 kb/s and 32 kb/s. In 1980 Bell Labs published a paper expanding on the ADPCM described in [17], discussing the algorithmic nature and architecture of the ADPCM in depth [18]. ADPCM was released as a specification in 1984, and is commonly used today as the G.726 specification [1].

PCM is the bare-bones modulation approach. Figure 3.1 illustrates the process of encoding a signal using PCM. The process starts with sampling the signal at a frequency typically set to twice the maximum frequency of the analog signal. If the sampling frequency is higher, oversampling can occur which might require signal reconstruction. If the sampling frequency is lower, then

the signal will be under-sampled and the data can be misinterpreted. Following sampling, the data is then quantized, placing it in a digital-friendly format. The data sampled is quantized as an approximation of the analog signal, representing the magnitude of the analog signal in binary.



Figure 3.1: PCM Encoding Process

The quantization is determined by the minimum and maximum frequencies, in addition to the sampling frequency. While there are an infinite number of amplitudes that can occur within the minimum and maximum frequency range, the amplitudes are broken up into known values, distributed into *L* number of evenly-spaced regions. This allows for a constrained range of values that can be used for the approximation of the sampled waveform. The result produces a staircase waveform parallel to the analog waveform from the input function. Following quantization, the data is then encoded in accordance with the G.711 specification [19], which relies on the encoding law used for the data received. There are 2 laws covered within the specification;  $\mu$ -law and A-law. One distinction between the two is that  $\mu$ -law uses 13 bits, whereas A-law only uses 12 bits for quantization, and as a result requires a different encoding and decoding process.

The sampling and quantization processes both have potential for error in PCM. Data sampled and quantized can result in an inaccurate approximate, either undershooting or overshooting the sample point on the original analog frequency. DPCM worked to mitigate this error. Instead of simply quantizing and encoding the analog signal, DPCM takes the difference between the current sample and a predicted sample. This predicted sample originates from calculations performed on the previous sample, utilizing the assumption that the change between 2 samples will be small. The result is no longer a sampled value, but rather a difference between 2 sampled values [20]. This difference mapped alongside the analog waveform will form a staircase as well,

| Data Rate | Quantizer Bit Width |  |  |  |  |  |  |
|-----------|---------------------|--|--|--|--|--|--|
| 16 kb/s   | 2-bit               |  |  |  |  |  |  |
| 24 kb/s   | 3-bit               |  |  |  |  |  |  |
| 32 kb/s   | 4-bit               |  |  |  |  |  |  |
| 40 kb/s   | 5-bit               |  |  |  |  |  |  |

 Table 3.1: ADPCM Data Rates

but with smaller values, which allows for more adaptation [21]. One of the benefits DPCM has over PCM in addition to mitigating sample error is the requirement of smaller register sizes used in quantization.

ADPCM is similar to DPCM and is outlined in the G.726 and G.722 specifications [1, 22]. Instead of a defined step size for sampling like in PCM and DPCM, ADPCM is designed with variability to accomodate both large and small changes in the sampled signal. Also, in accordance with the G.726 specification, the ADPCM can be used for handling multiple data rates. The bit width of the quantizer output is scaled based on the data rate. Table 3.1 illustrates the data rates present, and the resulting output of the quantizer relative to the data rate. Figures 3.2 and 3.3 show the diagram for the encoder and decoder in the ADPCM, respectively. The quantization process is enhanced in order to provide this functionality. In addition to the quantizer, the ADPCM has a quantizer scale factor adaptation (QSFA), which is used to compute the quantizer output and the output of the adaptation speed control. In order to compute the scale factor, the QSFA calculates both a slow ( $y_1(k)$ ) and a fast ( $y_u(k)$ ) scale factor. Equations 3.1 and 3.2 illustrate the fast and slow scale factor equations, respectively. W[I(k)] makes use of a lookup table, y(k) is the scaling factor, and  $a_I(k)$  is the adaptation speed control.



Figure 3.2: ADPCM Encoder Block Diagram [1]



Figure 3.3: ADPCM Decoder Block Diagram [1]

$$y_u(k) = (1 - 2^{-5})y(k) + 2^{-5}W[I(k)]$$
(3.1)

$$y_l(k) = (1 - 2^{-6})y_l(k - 1) + 2^{-6}y_u(k)$$
(3.2)

$$y(k) = a_l(k)y_u(k-1) + [1 - a_l(k)]y_l(k-1)$$
(3.3)

As noted in equation 3.3, the scale factor sent to the quantizer uses the slow and fast factors calculated from the previous sampled value, making use of previously collected data to predict the output and sample size necessary to encode the input signal properly. The adaptation speed control operation is documented in [1]. Due to the dynamic stepping of the quantizer in the ADPCM, it proves to be both an economic and efficient digital coding solution for speech compression [23].

In addition to the QSFA, the adaptive predictor and reconstructed signal calculator (APRSC) blocks are utilized to generate the predicted signal which is compared to the current PCM signal. The APRSC is a multi-step, algorithmic design that contains both a sixth order predictor used for modeling zeros, and a second order predictor used for modeling poles of the predicted input signal [1]. Within the APRSC, each order of the predictors requires the use of a floating-point multiplier (FMULT), which produces each of the outputs required for constructing the predicted signal. The FMULT design implemented in this paper is discussed in section 5.1. The FMULT has a 16-bit input and an 11-bit input, and produces a 16-bit output. Both inputs are converted from two's compliment to floating point format and multiplied. The result is then converted back to two's compliment and sent to the accumulator. For the sixth-order predictor, the FMULT multiplies the predictor coefficient *Bn* with the quantized difference signal *DQn*. For the second-order predictor, the FMULT multiplies the predictor coefficient *An* with the reconstructed signal



SRn. In total, the FMULT block is used 8 times in the APRSC.

Figure 3.4: APRSC Block Diagram [1]

# **Chapter 4**

# **UVM Overview**

The basic UVM testbench hierarchy is discussed in this chapter. UVM provides a multi-layered testbench architecture where components of each layer communicate through transactions, inheriting concepts and functionality from OVM, URM, eRM, and VMM.

### 4.1 UVM Hierarchy

Figure 4.1 illustrates the basic UVM testbench hierarchy. These components are crucial for testbench operation, and UVM optimizes operation in each related to their function.

#### 4.1.1 Sequencing

This is a functionality that differs between UVM and SV. There are 3 parts to sequencing: sequence item, sequence, and sequencer.



Figure 4.1: Basic UVM Testbench Hierarchy

#### 4.1.1.1 Sequence Item

The sequence item is the component used for transactions between the sequencer and driver. The sequence item is a customizable transaction packet, and is a key component for the sequence and sequencer. The sequence item extends from class *uvm\_sequence\_item*.

#### 4.1.1.2 Sequence

The sequence is a UVM class used for the generation of stimulus for the testbench. This is typically found at the test-level. The sequence will generate random stimulus and will interact with the driver through the sequencer, sending the data in the form of a sequence item. The sequence extends from *uvm\_sequence*.

#### 4.1.1.3 Sequencer

The sequencer is a different UVM class than the sequence, and is instantiated within the agent. A sequence will use the sequencer as the medium to handle transactions within the testbench, specifically the driver. The sequencer extends from class *uvm\_sequence*.

#### 4.1.2 Interface

The interface is a UVM component used to connect a DUT or other component to the testbench. Typically, a clock is passed to the interface from the top level instead of using the driver to manage it. Virtual interfaces are commonly used to provide one peripheral for all UVM components to either drive or collect data from the DUT.

#### 4.1.3 Driver

The driver serves the purpose of driving the DUT and, if present, reference models through transactions. The data used by the driver for driving the DUT and models comes from the sequencer in the form of a sequence item. The driver will get the data from the sequencer, and will then send the data to the DUT via a virtual interface tied to the DUT. Reference models can be driven using *uvm\_put\_ports*. The driver extends from class *uvm\_driver*.

#### 4.1.4 Monitor

The monitor is used for managing output transactions and coverage. It will send the collected data to the scoreboard, comparator (if present), or other components for verification. The monitor can also serve the purpose of asserting output conditions as well as verifying the design. The monitor extends class *uvm\_monitor*.

#### 4.1.5 Agent

An agent is used to handle transactions through an interface to a design, and a testbench can have multiple agents. Typically, the agent will have the driver, monitor, and sequencer instantiated within it. The agent is also used to connect the driver to the sequencer as well as any reference models, if present. The agent extends class *uvm\_agent*.

#### 4.1.6 Environment

The environment contains any agents, the scoreboard, and reference models (if present). Similar to the agent, the environment is also used to handle connections between various components, typically the sequencer to the driver, and if a reference model is present, connecting it to the

driver as well as the monitor through a FIFO; UVM's mailbox. The environment extends class *uvm\_env*.

#### 4.1.7 Scoreboard

The scoreboard receives data from the monitor and will typically run comparisons on the data received from the monitor, acting as a comparator. The scoreboard also will keep track of the results, which can be accessed during the report phase of the UVM testbench.

#### 4.1.8 Test

This layer instantiates the test environment and the sequence. This layer encapsulates all lower level components in each layer. The test layer is a component extending the UVM class *uvm\_test*.

#### 4.1.9 Top

The top level of the UVM testbench is a SV module that instantiates the DUT, interfaces and the test to be performed. Operations such as resets and clock frequencies can be set at this level. The UVM test to perform is also selected at this level.

### 4.2 Testbench Operation

A UVM testbench consists of 3 main phases: build phase, run-time phase, and clean up phase. These phases are inherited from the class *uvm\_component* and provide an organizational structure to the testbench.

#### 4.2.1 Build Phase

The build phase is executed at the start of the simulation. There are 4 functions within the build phase, of which the *build\_phase* and *connect\_phase* are most used. During *build\_phase*, components are created locally or connected to virtual components. During *connect\_phase*, FIFOs, get ports, and put ports are connected to higher or lower level components. 2 other functions exist in the build phase: *start\_of\_simulation\_phase* and *end\_of\_elaboration\_phase*. These are used for setting the initial run time and making final adjustments to the testbench prior to simulation, respectively. The build phase executes prior to the actual simulation, and takes up 0 simulation time.

#### 4.2.2 **Run-time Phase**

The run-time phase is executed during the simulation. Operations such as driving, monitoring, and checking occur during the run-time phase, and are called in the task *run\_phase*. The run-time phase also has several functions used for handling DUT resets, configurations, and shutdown.

#### 4.2.3 Clean Up Phase

The clean up phase occurs last before the simulation ends. The purpose of this phase is to check the data collected by the testbench (via the scoreboard) at the end of simulation, and determine whether the test has either passed or reached sufficient coverage. 2 functions used in the clean up phase are the *report\_phase* and the *final\_phase*. The *report\_phase* is useful for printing out any results from the test, and the *final\_phase* will complete any tasks not already completed by earlier phases. One factor to be mindful of, however, is that the clean up phase operates bottom-up, so report phases of lower level components will execute before higher level components. A way to avoid clutter for the report phase is to utilize the phase from one of the higher level components.

# Chapter 5

# **Design and Test Methodology**

This chapter discusses the design used for the FMULT as well as the testbench architecture used to verify the FMULT.

### 5.1 FMULT Design

The final step in the APRSC involves accumulating the values calculated by each of the 8 FMULTs used in the hierarchical design (See Figure 3.4). As an option to help lower the resources required for this step, the FMULT was designed with a pipelined architecture and a single resource adder written in Verilog. The design had 2 data inputs: *An* and *SRn*, which were 16-bits and 11-bits, respectively. In order to incorporate the single-resourced adder design, the FMULT required the use of a state machine to manage the 2 additions required per the G.726 design specification [1]. In order to properly pipeline this design, the inputs to the FMULT must have 1 clock cycle between each new set of input stimulus, otherwise the pipeline will lag and the additions will fall out of sync. Figure 5.1 illustrates the timing diagram of the proposed FMULT design as well as the values driven to the adder within the FMULT, resulting in a 6-stage

|         | Stage 1  | Stage 2 | Stage 3   | Stage 4  | Stage 5   | Stage 6  | Stage 7   | Stage 8  |
|---------|----------|---------|-----------|----------|-----------|----------|-----------|----------|
| An      | An1      |         | An2       |          | An3       |          | An4       |          |
| SRn     | SRn1     |         | SRn2      |          | SRn3      |          | SRn4      |          |
| AnMAG   | AnMAG1   |         | AnMAG2    |          | AnMAG3    |          | AnMAG4    |          |
| SRnMAG  | SRnMAG1  |         | SRnMAG2   |          | SRnMAG3   |          | SRnMAG4   |          |
| AnEXP   |          | AnEXP1  |           | AnEXP2   |           | AnEXP3   |           | AnEXP4   |
| SRnEXP  | SRnEXP1  |         | SRnEXP2   |          | SRnEXP3   |          | SRnEXP4   |          |
| AnMANT  |          | AnMANT1 |           | AnMANT2  |           | AnMANT3  |           | AnMANT4  |
| SRnMANT | SRnMANT1 |         | SRnMANT2  |          | SRnMANT3  |          | SRnMANT4  |          |
| WAnS    | WAnS1    |         | WAnS2     |          | WAnS3     |          | WAnS4     |          |
| WAnEXP  |          |         |           | WAnEXP1  |           | WAnEXP2  |           | WAnEXP3  |
| WAnMANT |          |         |           |          | WAnMANT1  |          | WAnMANT2  |          |
| WAnMAG  |          |         |           |          |           | WAnMAG1  |           | WAnMAG2  |
| WAn     |          |         |           |          |           | WAn1     |           | WAn2     |
|         |          |         |           |          |           |          |           |          |
| AddA    |          | AnEXP1  | Product1  | AnEXP2   | Product2  | AnEXP3   | Product3  | AnEXP4   |
| AddB    |          | SRnEXP1 | 6'b110000 | SRnEXP2  | 6'b110000 | SRnEXP3  | 6'b110000 | SRnEXP4  |
| Sum     |          |         | WAnEXP1   | WAnMANT1 | WAnEXP2   | WAnMANT2 | WAnEXP3   | WAnMANT3 |

Figure 5.1: Pipelined FMULT Timing Diagram

pipeline. The design also incorporated several flip flops to maintain data values through pipeline stages (not pictured in Figure 5.1).

The state machine used in the FMULT has only 2 states, one for each of the additions. The first state adds *AnEXP* and *SRnEXP*, and the second state adds *AnMANT* \* *SRnMANT* and 48. The FMULT performs the first addition during the second stage of the pipeline, and the second addition during the third stage, and will continue to go back and forth between these states during operation.

### 5.2 Testbench Design

The testbench follows the basic UVM testbench architecture with adjustments to the monitor, operating as the scoreboard in addition to monitoring the outputs and coverage. Also, a reference model written in C is incorporated to provide a baseline for the DUT's operation.

This section discusses each of the components used in the testbench and their functionality.



Figure 5.2: FMULT Testbench Design

#### **5.2.1** Sequence Items

#### 5.2.1.1 in\_sqr\_item

This sequence item is used within the *uvm\_sequence* to generate random stimulus necessary to drive both the DUT and the reference model. There are 2 pieces of data sent in this transaction packet: *An* and *SRn*.

#### 5.2.1.2 out\_sqr\_item

This sequence item is used by the reference model to send data to the monitor via transactions. There is one piece of data sent in this transaction packet: *WAn*.

#### 5.2.2 Sequence

The sequence generates random stimulus for *SRn* and *An*. The stimulus generated is used by both the DUT and the reference model initially sent to the driver.

#### 5.2.3 Interface

The interface contains a clock, reset, scan insertion cells and the FMULT inputs and output *An*, *SRn* and *WAn*. The clock is passed through the interface from a clock generated at the top level and is used to synchronize the testbench with the DUT.

#### 5.2.4 Driver

The driver performs 2 primary tasks: get the transaction from the sequencer, and use the received stimulus to drive the DUT and the reference model. A *uvm\_put\_port* is used to send the data

from the driver to the reference model, which is a layer up from the driver. In order for the driver to interact with the DUT, a virtual interface is used.

#### 5.2.5 Monitor

The monitor, in addition to monitoring coverage and receiving the output from the DUT and reference model, also handles the comparison of data and simulation duration. The scoreboard is also included in the monitor; data is sent to the monitor from the DUT through the interface, and from the reference model via a *uvm\_put\_port*. The monitor does not require the use of *try\_put*, and reads the data every time the FIFO is filled. However, in order to take into account the 6-stage pipeline, the monitor delays comparing values for 6 clock cycles.

The monitor also includes a *report\_phase*, providing simulation information including run time, coverage, tests run and the pass rate.

The monitor serves as both the monitor and scoreboard due to the simplicity of the testbench design.

#### 5.2.6 Agent

The agent instantiates the driver, monitor, and sequencer. The agent also handles the connection between the sequencer and the driver.

#### 5.2.7 Environment

The environment contains an instantiation of the agent and reference model. In addition, a *connect\_phase* is used to connect the driver to the reference model, and reference model to the monitor. A report phase is also used in the environment to display the number of passes and number of fails, which included the functionality of the scoreboard in addition to monitoring the

outputs and coverage.

#### 5.2.8 Test

The environment and sequence are instantiated here. The sequence used involves random stimulus generation using the variables within the *in\_sqr\_item*.

#### 5.2.9 Top

The top level entity instantiates the interface used to connect to the DUT, resets it, and also drives the clock. Within the top level, the test to run is also chosen.

#### 5.2.10 DPI Functions

DPI functions, written in C, are implemented in the monitor to keep track of wall time for the simulation, generate a text report, and email the results. This proved to be a valuable tool to keep track of test results.

#### 5.2.11 Watermark

A configuration file is used to determine how many random stimulus will be generated and checked by the sequencer, and the monitor keeps track of this. Once the watermark is reached, the monitor drops the objection and the simulation ends.
## Chapter 6

# **Results and Discussion**

The results of the FMULT are in this chapter. The design was simulated using both RTL and gate-level simulations, and passed for all stimulus.

#### 6.1 **RTL and Gate Level Simulation Results**

The DUT was simulated using Cadence electronic design automation (EDA) tools [24]. The simulation ran until a watermark of random stimulus was met. Table 6.1 displays simulation results and timing. Tables 6.2 and 6.3 show the coverage results for RTL and gate-level, respectively.

The ultimate goal is to achieve 100% functional coverage, and when using random stimulus this is typically seen with higher test runs. Because *An* is a 16-bit number, there are 65,356 possible combinations for the randomly generated input. Therefore, at least 65,356 test runs would be required, assuming the random stimulus hit each combination once. 100,000 cases was not sufficient to reach full coverage, but using a watermark of 1,000,000 or higher attained 100% functional coverage. Figure 6.1 illustrates the relationship between watermark. and coverage results for RTL, and Figure 6.2 for gate.

|           | RTL          |               | Gate-Level   |               |
|-----------|--------------|---------------|--------------|---------------|
| Test Runs | Passing Rate | Wall Time (s) | Passing Rate | Wall Time (s) |
| 10        | 100% 0.0069  |               | 100%         | 0.058         |
| 100       | 100%         | 0.069         | 100%         | 0.146         |
| 1000      | 100%         | 0.454         | 100%         | 0.6140        |
| 10000     | 100%         | 1.313         | 100%         | 2.009         |
| 100000    | 100%         | 11.108        | 100%         | 16.117        |
| 1000000   | 100%         | 93.140        | 100%         | 150.133       |
| 1000000   | 100%         | 918.027       | 100%         | 1489.162      |

Table 6.1: Simulation Results

Table 6.2: RTL Simulation Coverage Results

| Test Runs | Code Coverage | Functional Coverage | An Coverage | SRn Coverage |
|-----------|---------------|---------------------|-------------|--------------|
| 10        | 90.27%        | 50.15%              | 0.02%       | 0.59%        |
| 100       | 92.35%        | 51.28%              | 0.16%       | 4.98%        |
| 1000      | 95.22%        | 59.99%              | 1.52%       | 38.13%       |
| 10000     | 96.15%        | 78.29%              | 13.90%      | 99.27%       |
| 100000    | 96.15%        | 94.29%              | 77.14%      | 100%         |
| 1000000   | 96.15%        | 100%                | 100%        | 100%         |
| 1000000   | 96.15%        | 100%                | 100%        | 100%         |

Table 6.3: Gate-Level Simulation Coverage Results

| Test Runs | Code Coverage | Functional Coverage | An Coverage | SRn Coverage |
|-----------|---------------|---------------------|-------------|--------------|
| 10        | 95.92%        | 50.15%              | 0.02%       | 0.59%        |
| 100       | 96.94%        | 51.28%              | 0.16%       | 4.98%        |
| 1000      | 96.94%        | 60.12%              | 1.52%       | 38.96%       |
| 10000     | 96.94%        | 78.29%              | 13.90%      | 99.27%       |
| 100000    | 96.94%        | 94.31%              | 77.25%      | 100%         |
| 1000000   | 96.94%        | 100%                | 100%        | 100%         |
| 1000000   | 96.94%        | 100%                | 100%        | 100%         |

Another important factor in simulation is timing. The simulation ran fairly quickly, but higher watermarks required more time to be allotted for the conclusion of the simulation. Figure 6.3 shows the relationship between watermark and time, and Table 6.1 includes the run time for each watermark.

While the testbench is able to verify the behavior of the design, a c model with the desired operation was required to verify the correctness of the DUT. Each random test stimulus was processed by a C-model and the DUT, and each test passed for every test set, which did not require significant processing time.

#### 6.2 RTL and Gate Level Synthesis Results

The FMULT was synthesized and simulated for gate sizes of 32 nm, 65 nm, 90 nm and 180 nm using Synopsys design compiler [25]. The synthesis results are recorded in Table 6.4. Figure 6.4 displays the area per gate size, and Figure 6.5 shows the number of gates as well.

|                  |                             | Gate Size         |          |                   |           |
|------------------|-----------------------------|-------------------|----------|-------------------|-----------|
| Category         | Component                   | 32 nm             | 65 nm    | 90 nm             | 180 nm    |
|                  | Combinational Area          | 1084.432          | 1111.320 | 4382.208          | 8325.979  |
|                  | Buff/Inv Area               | 80.310            | 65.520   | 387.072           | 578.794   |
| Area $(\mu m^2)$ | Non-Comb Area               | 724.31            | 867.24   | 2984.141          | 6566.314  |
|                  | Total Cell Area             | 1808.743          | 1978.560 | 7366.349          | 14892.293 |
|                  | Gate Count                  | 1186              | 1374     | 1332              | 1492      |
| Power            | Internal Power $(\mu W)$    | 34.239            | 53.800   | 33.417            | 95.900    |
|                  | Switching Power $(\mu W)$   | 3.272             | 4.980    | 16.126            | 409.000   |
|                  | Leakage Power ( <i>nW</i> ) | $1.650 * 10^{11}$ | 82.018   | $3.190 * 10^{10}$ | 80.464    |
|                  | Total Power $(\mu W)$       | 202.086           | 58.900   | 81.430            | 505.000   |
| Coverage         | Test Coverage               | 99.98%            | 99.97%   | 99.98%            | 99.98%    |
| Timing           | Worst Path Delay (ns)       | 19.805            | 19.730   | 19.840            | 19.496    |

Table 6.4: Synthesis Results



Figure 6.1: RTL Code Coverage



Figure 6.2: Gate-Level Code Coverage



Figure 6.3: Wall Time vs. Watermark

### 6.3 Discussion

This testbench design using UVM was able to verify the functionality of the FMULT. Several points can be observed following verification:

- 1. The DUT did not fail for any test set of random stimulus
- 2. Higher watermarks/test runs require exponentially more time to complete
- 3. As the watermark increased, the functional coverage also increased
- 4. A watermark of around 1,000,000 is needed for the design to reach 100% functional coverage
- 5. As the gate size decreased, the area of the device also decreased as expected



Figure 6.4: Area Per Gate Size



Figure 6.5: Number of Gates Per Gate Size

## Chapter 7

# Conclusion

The FMULT was successfully verified using UVM and a multi-layered testbench approach. The testbench was able to achieve 100% functional coverage at watermarks exceeding 1,000,000, thoroughly verifying the design. The approach and results are documented in the previous chapters. The FMULT was tested using random input stimulus and the outputs were compared with a reference model written in C, in which the FMULT passed for every test set.

### 7.1 Future Work

The testbench structure provided proved to be a useful and efficient form of verification for the FMULT. However, this approach is not limited to only the FMULT. Suggestions to continue the work presented in this paper are below:

- The FMULT is one of several components within the APRSC. This verification approach can be used to test the remaining low-level components, as well as the APRSC
- The RTL can be redesigned without a single-resource adder, allowing the design to be pipelined with new stimulus every clock cycle

• An implementation using UVM and the G.726 test sequences specification [26] would be valuable for verifying the ADPCM

# References

- 40, 32, 24, 16 kbit/s ADAPTIVE DIFFERENTIAL PULSE CODE MODULATION (AD-PCM). Recommendation G.726. *International Telecommunications Union (ITU)*, 1990.
- W. Ramirez, H. Gomez, and E. Roa. On UVM Reliability in Mixed-Signal Verification. In 2019 IEEE 10th Latin American Symposium on Circuits Systems (LASCAS), pages 233– 236, Feb 2019. doi:10.1109/LASCAS.2019.8667543.
- [3] E. M. Hamed, K. Salah, A. H. Madian, and A. G. Radwan. An Automated Lightweight UVM Tool. In 2018 30th International Conference on Microelectronics (ICM), pages 136– 139, Dec 2018. doi:10.1109/ICM.2018.8704037.
- [4] G. Renuka, V. Ushashree, and P. C. Reddy. Verification of communication based SoC using advanced verification methodology. In 2016 International Conference on Communication and Signal Processing (ICCSP), pages 0010–0013, April 2016. doi:10.1109/ICCSP. 2016.7754162.
- [5] Y. Oh and Gi-Yong Song. Simple hardware verification platform using SystemVerilog. In TENCON 2011 - 2011 IEEE Region 10 Conference, pages 1414–1417, Nov 2011. doi: 10.1109/TENCON.2011.6129042.

- [6] IEEE Approved Draft Standard for System Verilog–Unified Hardware Design, Specification, and Verification Language. *IEEE P1800/D6, August 2012*, pages 1–1312, Dec 2012.
- [7] G. Tumbush and Chris Spear. SystemVerilog for Verification, Third Edition: A Guide to Learn- ing the Testbench Language Features. Springer, 2012.
- [8] H. El-Kharashy, M. Khami, A. Sala, and M. Korany. A novel assertions-based code coverage automatic CAD tool. In *IEEE EUROCON 2017 -17th International Conference on Smart Technologies*, pages 277–281, July 2017. doi:10.1109/EUROCON.2017.8011119.
- [9] S. Das, R. Mohanty, P. Dasgupta, and P. P. Chakrabarti. Synthesis of System Verilog Assertions. In *Proceedings of the Design Automation Test in Europe Conference*, volume 2, pages 1–6, March 2006. doi:10.1109/DATE.2006.243776.
- [10] R. Sebastian, S. R. Mary, M. Gayathri, and A. Thomas. Assertion based verification of SG-MII IP core incorporating AXI Transaction Verification Model. In 2015 International Conference on Control Communication Computing India (ICCC), pages 585–588, Nov 2015. doi:10.1109/ICCC.2015.7432965.
- [11] J. Sanguinetti and E. Zhang. The relationship of code coverage metrics on high-level and RTL code. In 2010 IEEE International High Level Design Validation and Test Workshop (HLDVT), pages 138–141, June 2010. doi:10.1109/HLDVT.2010.5496649.
- [12] A. Tran, M. Smith, and J. Miller. A Hardware-Assisted Tool for Fast, Full Code Coverage Analysis. In 2008 19th International Symposium on Software Reliability Engineering (ISSRE), pages 321–322, Nov 2008. doi:10.1109/ISSRE.2008.22.
- [13] IEEE Standard for Universal Verification Methodology Language Reference Manual. *IEEE Std 1800.2-2017*, pages 1–472, May 2017. doi:10.1109/IEEESTD.2017.7932212.

- [14] Ray Salemi. *The UVM Primer: An Introduction to the Universal Verification Methodology*. Number 4. Boston Light Press, 2013.
- [15] Universal Verification Methodology (UVM) 1.2 Class Reference. pages 1–938, June 2014.
- [16] K. Salah. A UVM-based smart functional verification platform: Concepts, pros, cons, and opportunities. In 2014 9th International Design and Test Symposium (IDT), pages 94–99, Dec 2014. doi:10.1109/IDT.2014.7038594.
- [17] P. Cummiskey, N. S. Jayant, and J. L. Flanagan. Adaptive quantization in differential PCM coding of speech. *The Bell System Technical Journal*, 52(7):1105–1118, Sep. 1973. doi:10.1002/j.1538-7305.1973.tb02007.x.
- [18] J. R. Boddie, J. D. Johnston, C. A. McGonegal, J. W. Upton, D. A. Berkley, R. E. Crochiere, and J. L. Flanagan. Digital signal processor: Adaptive differential pulse-code-modulation coding. *The Bell System Technical Journal*, 60(7):1547–1561, Sep. 1981. doi:10.1002/ j.1538-7305.1981.tb00283.x.
- [19] Pulse Code Modulation (PCM) of Voice Frequencies ITU-T Recommendation G.711. International Telecommunication Union (ITU), 1988.
- [20] Takenori Yoshimura, Kei Hashimoto, Keiichiro Oura, Yoshihiko Nankaku, and Keiichi Tokuda. Speaker-dependent Wavenet-based Delay-free ADPCM Speech Coding. ICASSP 2019 - 2019 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), 2019. doi:10.1109/icassp.2019.8682264.
- [21] N. S. Jayant. Digital coding of speech waveforms: PCM, DPCM, and DM quantizers.
   Proceedings of the IEEE, 62(5):611–632, 1974. doi:10.1109/proc.1974.9484.
- [22] ITU-T Recommendation G.722, 7 kHz Audio-Coding Within 64 kbit/s. ITU-T, Nov 1988.

- [23] P. Cummiskey, N. S. Jayant, and J. L. Flanagan. Adaptive Quantization in Differential PCM Coding of Speech. *The Bell System Technical Journal*, 1973.
- [24] Synopsys Design Compiler, 2019. URL: https://www.cadence.com/.
- [25] Cadence EDA Tools, 2019. URL: https://www.synopsys.com/.
- [26] Description of the Digital Test Sequences for the Verification of the G.726 40, 32, 24 and 16 kbit/s ADPCM Algorithm. 1990.

# Appendix I

# **Source Code**

## I.1 FMULT Design

| 1  | module FMU | LT (                   |
|----|------------|------------------------|
| 2  |            | reset,                 |
| 3  |            | clk,                   |
| 4  |            | <pre>scan_in0 ,</pre>  |
| 5  |            | scan_en,               |
| 6  |            | test_mode,             |
| 7  |            | <pre>scan_out0 ,</pre> |
| 8  | An,        |                        |
| 9  | SRn,       |                        |
| 10 |            | WAn                    |
| 11 | );         |                        |
| 12 |            |                        |
| 13 | input      |                        |

```
14
                                 // system reset
     reset,
15
       clk;
                                  // system clock
16 input wire [15:0]
17
      An;
18 input wire [10:0] // ALSO Bn; Memory Input
19
       SRn; // Reconstructed Signal Input
20 input
21
       scan in0,
                                  // test scan mode data input
                                  // test scan mode enable
22
       scan_en,
23
      test_mode;
                                  // test mode select
24
25 output
scan_out0;
                                 // test scan mode data output
27 output reg [15:0]
28
      WAn; // Partial Product/Signal Estimate Output
29
30 wire [13:0] AnMAG;
31 reg [3:0] AnEXP;
32 reg [5:0] AnMANT;
33
34 wire [3:0] SRnEXP;
35 wire [5:0] SRnMANT;
36
37 reg [11:0] SRnAnMult;
38
```

- 39 wire WAnS;
- 40 reg WAnS1, WAnS2, WAnS3, WAnS4;
- 41 reg [4:0] WAnEXP, WAnEXP1, WAnEXP2, WAnEXP3;
- 42 **reg** [7:0] WAnMANT;
- 43 reg [15:0] WAnMAG;
- 44
- 45 reg [11:0] A;
- 46 reg [5:0] B;
- 47 reg state;
- 48 wire [11:0] SUM;
- 49
- 50 // parameter STATE1 = 0;
- 51 // parameter STATE2 = 1;
- 52
- 53 // Adder
- 54 assign SUM = A + B;
- 55
- 56 // SRnEXP and SRnMANT Calc
- 57 assign SRnEXP = SRn[9:6];
- 58 assign SRnMANT = SRn[5:0];
- 59
- 60 // WAnS Calc
- 61 assign WAnS = SRn[10] ^ An[15];
- 62
- 63 // AnMAG Calc

```
64 \text{ assign AnMAG} = \text{An}[15]? (16'd16384 - (An[15:2])) & 14'd8191 :
      An[15:2];
65
66 // Pipeline Stage 1 - ASynchronous Calculations
67 always@(posedge clk or posedge reset)
68 begin
69
       if (reset) begin
70
     AnEXP
              = 4'b0000;
71
     AnMANT <= 6' b000000;
72
       end
73
74
       else begin
75
     // AnEXP and AnMANT Calculations
76
77
     casez (AnMAG)
     13'b00000000000: begin
78
79
         AnEXP = 4'b0000;
         AnMANT <= 6' b 100000;
80
81
          end
     13'b000000000001: begin
82
83
         AnEXP = 4'b0001;
84
         AnMANT <= (\{AnMAG[13:0], 6, b000000\})>>AnEXP;
85
          end
     13'b00000000001?: begin
86
87
         AnEXP = 4'b0010;
```

| 88  | AnMANT <= $({AnMAG[13:0], 6'b000000})$ >>AnEXP;    |
|-----|----------------------------------------------------|
| 89  | end                                                |
| 90  | 13'b0000000001??: begin                            |
| 91  | AnEXP = $4'b0011;$                                 |
| 92  | AnMANT <= ({AnMAG[13:0],6'b000000})>>AnEXP;        |
| 93  | end                                                |
| 94  | 13'b000000001???: begin                            |
| 95  | AnEXP = $4'b0100;$                                 |
| 96  | AnMANT <= ({AnMAG[13:0],6'b000000})>>AnEXP;        |
| 97  | end                                                |
| 98  | 13'b00000001????: begin                            |
| 99  | AnEXP = $4'b0101;$                                 |
| 100 | AnMANT <= ({AnMAG[13:0],6'b000000})>>AnEXP;        |
| 101 | end                                                |
| 102 | 13'b0000001????: begin                             |
| 103 | AnEXP = $4'b0110;$                                 |
| 104 | AnMANT <= $({AnMAG[13:0], 6', b000000})$ >>AnEXP;  |
| 105 | end                                                |
| 106 | 13'b0000001?????: begin                            |
| 107 | AnEXP = $4'b0111;$                                 |
| 108 | AnMANT <= ({AnMAG[13:0],6'b000000})>>AnEXP;        |
| 109 | end                                                |
| 110 | 13'b000001??????: begin                            |
| 111 | AnEXP = $4'b1000;$                                 |
| 112 | AnMANT <= $(\{AnMAG[13:0], 6, b000000\})$ >>AnEXP; |

| 113 | end                                               |
|-----|---------------------------------------------------|
| 114 | 13'b00001??????: begin                            |
| 115 | AnEXP = $4' b 1001;$                              |
| 116 | AnMANT <= $({AnMAG[13:0], 6'b000000})$ >>AnEXP;   |
| 117 | end                                               |
| 118 | 13'b0001???????: begin                            |
| 119 | AnEXP = $4' b 1010;$                              |
| 120 | AnMANT <= $({AnMAG[13:0], 6', b000000})$ >>AnEXP; |
| 121 | end                                               |
| 122 | 13'b001????????: begin                            |
| 123 | AnEXP = $4'b1011;$                                |
| 124 | AnMANT <= $({AnMAG[13:0], 6'b000000})$ >>AnEXP;   |
| 125 | end                                               |
| 126 | 13'b01????????: begin                             |
| 127 | AnEXP = $4' b 1 100;$                             |
| 128 | AnMANT <= $({AnMAG[13:0], 6', b000000})$ >>AnEXP; |
| 129 | end                                               |
| 130 | 13'b1?????????: begin                             |
| 131 | AnEXP = $4'b1101;$                                |
| 132 | AnMANT <= $({AnMAG[13:0], 6'b000000})$ >>AnEXP;   |
| 133 | end                                               |
| 134 | endcase                                           |
| 135 | end                                               |
| 136 | end                                               |
| 137 |                                                   |

```
138
    // Pipeline Stage 2 - Adder (1st Iteration)
139
140
    always@(posedge clk or posedge reset)
141
    begin
142
        if (reset) begin
143
      SRnAnMult <= 11'b0000000000;
144
      WAnS1
                 <= 16'b000000000000000;
145
            // state <= STATE1:</pre>
146
            // save_state <= STATE1;</pre>
147
        end
148
        else begin
149
            // save_state <= ~save_state;</pre>
150
            // state <= save_state;</pre>
151
      SRnAnMult <= SRnMANT * AnMANT;</pre>
152
      WAnS1
                 \leq WAnS;
153
        end
154 end
155
156
   // Pipeline Stage 3,4 - Adder (2nd Iteration)
157
    always@(posedge clk or posedge reset)
158
159 begin
160
        if (reset) begin
      WAnS2
161
              162
      WAnS3
              <= 16'b0000000000000000;
```

- 163 WAnS4 <= 16'b000000000000000;
- 164 WAnEXP1 <= 5'b00000;
- 165 WAnEXP2 <= 5'b00000;
- 166 WAnEXP3 <= 5'b00000;
- 167 end
- 168 else begin
- 169 WAnEXP1 <= WAnEXP;
- 170 WAnEXP2  $\leq$  WAnEXP1;
- 171 WAnEXP3  $\leq$  WAnEXP2;
- 172 WAnS2  $\leq$  WAnS1;
- 173 WAnS3 <= WAnS2;
- 174 WAnS4  $\leq$  WAnS3;
- 175 end
- 176 end
- 177

178

- 179 // Pipeline Stage 5 Output
- 180 always@(posedge clk or posedge reset)
- 181 begin
- 182 if (reset) begin

- 185 state <= 1'b1;
- 186 end
- 187 else begin

```
188
           state <= ~ state;</pre>
189
      if (WAnEXP1 <= 26) begin
190
         WAnMAG = (\{WAnMANT[7:0], 7, b0000000\}) >>(6, d26-WAnEXP1);
191
     end
192
      else begin
193
         & 16'b011111111111111;
194
     end
195
     WAn \leq WAnS4 ? (17'd65536 - WAnMAG) : WAnMAG;
196
       end
197 end
198
199
200
   // Pipeline -> Adder Block
   always@(posedge clk or posedge reset)
201
202 begin
203
      if (reset) begin
204
                <= 11'b000000000;
     А
205
     В
                <= 6'b000000;
206
     WAnMANT
                <= 8'b0000000;
207
     WAnEXP
                <= 5'b00000;
208
       end
209
       else begin
210
           casez(state)
211
         1'b0: begin
```

| 212 | WAnEXP    | <= SUM;            |
|-----|-----------|--------------------|
| 213 | А         | <= SRnAnMult;      |
| 214 | В         | <= 6'b110000;      |
| 215 | end       |                    |
| 216 | 1'b1:     | begin              |
| 217 | WAnMAN    | $T \le SUM[11:4];$ |
| 218 | А         | <= SRnEXP;         |
| 219 | В         | <= AnEXP;          |
| 220 | end       |                    |
| 221 | endcase   |                    |
| 222 | end       |                    |
| 223 | end       |                    |
| 224 |           |                    |
| 225 | endmodule |                    |

### I.2 Interface

```
1 interface intf(input clk);
     logic reset;
2
3
     logic scan_in0;
     logic scan_en;
4
     logic test_mode;
5
     logic scan_out0;
6
7
     logic [15:0] An;
8
     logic [10:0] SRn;
     logic [15:0] WAn;
9
10
11 endinterface: intf
```

## I.3 Input Sequence Item

```
1 class in_sqr_item extends uvm_sequence_item;
     rand logic [15:0] An;
2
3
     rand logic [10:0] SRn;
4
     'uvm_object_utils_begin(in_sqr_item)
5
       'uvm_field_int(An, UVM_ALL_ON | UVM_HEX)
6
7
       'uvm_field_int(SRn, UVM_ALL_ON | UVM_HEX)
     'uvm_object_utils_end
8
9
     function new(string name = "in_sqr_item");
10
11
       super.new(name);
     endfunction
12
13
14 endclass: in_sqr_item
```

## I.4 Output Sequence Item

```
1 class out_sqr_item extends uvm_sequence_item;
2
     logic [15:0] WAn;
3
4
     'uvm_object_utils_begin(out_sqr_item)
5
       'uvm_field_int(WAn, UVM_ALL_ON | UVM_HEX)
6
     'uvm_object_utils_end
7
8
9
     function new(string name = "out_sqr_item");
       super.new(name);
10
     endfunction
11
12
13 endclass: out_sqr_item
```

### I.5 Reference Model

```
1 #include <stdio.h>
2 #include <math.h>
3
4 extern int
5 fmult(x, y1)
6 int x, y1;
7 {
8
     // printf ("REFMOD Inputs \%x, \%x \setminus n^{"}, x, y1);
9
     int xs, xmag, xexp, xmant;
10
     int ys, yexp, ymant;
11
     int wxs, wx, wxexp, wxmant, wxmag, i;
12
13
     xs = (x >> 15) \& 1;
     xmag = xs? (16384 - (x >> 2)) & 8191 : x >> 2;
14
     xexp = 0;
15
16
     for (i = 0; i \le 13; i += 1) {
17
        if (!(xmag >> i)) {
18
          xexp = i;
          break;
19
20
       }
21
       if (i = 13)
          printf("mag didn't get set in fmult\n");
22
23
     }
```

```
24
     xmant = xmag ? (xmag << 6) >> xexp : 1 << 5;
25
26
     ys = (y1 >> 10) \& 1;
27
     yexp = (y1 >> 6) \& 15;
     ymant = y1 \& 63;
28
29
     wxs = ys \wedge xs;
30
31
     wxexp = yexp + xexp;
     wxmant = ((ymant * xmant) + 48) >> 4;
32
     wxmag = wxexp > 26 ? ((wxmant << 7) << (wxexp - 26)) & 32767
33
          : (wxmant << 7) >> (26 - wxexp);
34
     wx = wxs ? (65536 - wxmag) & 65535 : wxmag & 65535;
35
36
37
     return(wx);
38 }
```

### I.6 Sequencer

```
class seq_in extends uvm_sequence #(in_sqr_item);
1
       'uvm_object_utils(seq_in)
2
3
       int An, SRn;
       function new(string name="seq_in");
4
           super.new(name);
5
6
       endfunction: new
7
       task body;
8
9
           in_sqr_item tx;
10
           forever begin
11
                tx = in_sqr_item :: type_id :: create("tx");
12
                start_item(tx);
13
                assert(tx.randomize());
14
                finish_item(tx);
15
16
           end
       endtask: body
17
18 endclass: seq_in
```

### I.7 Driver

```
1 typedef virtual intf intf_vif;
2
  class driver extends uvm_driver #(in_sqr_item);
3
4
     'uvm_component_utils(driver)
5
6
7
     uvm_put_port #(in_sqr_item) icp;
     intf_vif vif;
8
9
     event begin_record , end_record ;
10
11
12
     covergroup cov_in;
13
       dut_An : coverpoint vif.An
14
              \{bins An[] = \{[0:65535]\};\}
15
       dut_SRn : coverpoint vif.SRn
16
              \{bins SRn[] = \{[0:2047]\};\}
17
     endgroup
18
19
     function new(string name = "driver", uvm_component parent =
        null);
20
       super.new(name, parent);
       icp = new("icp", this);
21
22
       cov_in = new();
```

```
23
     endfunction
24
     virtual function void build_phase(uvm_phase phase);
25
26
       super.build_phase(phase);
       void '(uvm_resource_db#(intf_vif)::read_by_name(.scope("ifs"
27
          ),.name("intf_vif"),.val(vif)));
28
     endfunction
29
     virtual task run_phase(uvm_phase phase);
30
31
       super.run_phase(phase);
32
       fork
33
         reset_signals();
34
         drive (phase);
35
       join
     endtask
36
37
     virtual protected task reset_signals();
38
39
       forever begin
40
         vif.reset
                        = 1;
         vif.scan_in0 = 0;
41
         vif.scan_en
42
                        = 0;
43
         vif.test_mode = 0;
44
         @(negedge vif.clk);
45
         @(negedge vif.clk);
46
         @(negedge vif.clk);
```

```
47
         @(negedge vif.clk);
          vif.reset = 0;
48
49
         @(posedge vif.reset);
50
        end
51
     endtask
52
     virtual protected task drive(uvm_phase phase);
53
        $display("Waiting");
54
55
        wait(vif.reset === 1);
        $display("Reset Asserted");
56
57
       @(negedge vif.reset);
       $display("Reset De-asserted");
58
       @(posedge vif.clk);
59
60
        forever begin
          seq_item_port.get(req);
61
         -> begin_record;
62
63
          write_it(req);
64
        end
65
     endtask
66
     virtual protected task write_it(in_sqr_item tr);
67
68
        vif.An \leq tr.An;
69
        vif.SRn <= tr.SRn;
70
        // display("An \rightarrow \%d nSRn \rightarrow \%d n", tr.An, tr.SRn);
71
        icp.put(tr);
```

```
@(posedge vif.clk)
72
       @(posedge vif.clk)
73
       cov_in.sample();
74
       -> end_record;
75
76
     endtask
77
     virtual task record_tr();
78
79
       forever begin
         @(begin_record);
80
         begin_tr(req, "driver");
81
         @(end_record);
82
83
         end_tr(req);
84
       end
     endtask
85
86
87 endclass
```

### I.8 Monitor

```
class monitor \#(type T = out sqr item) extends uvm monitor;
 1
2
     typedef monitor #(T) this_type;
3
     'uvm_component_param_utils(this_type)
4
     const static string type_name = "monitor #(T)";
5
6
7
     uvm put imp \#(T, this type) from rm;
     intf_vif vif;
8
9
     in_sqr_item tr;
     out_sqr_item exp;
10
11
12
     int start_time , run_time ;
13
     int hrs, min, sec;
14
     int watermark, wmfile, wmstring;
15
16
     logic free;
17
     int count, num_matches, num_mismatches;
18
     event begin_delay , end_delay , endsimulation , compared ;
19
20
     covergroup cov_out;
21
       DUT_0 : coverpoint vif.WAn[0];
       DUT_1 : coverpoint vif.WAn[1];
22
23
       DUT_2 : coverpoint vif.WAn[2];
```

| 24 | DUT_3         | : | coverpoint | vif.WAn[3];  |
|----|---------------|---|------------|--------------|
| 25 | DUT_4         | : | coverpoint | vif.WAn[4];  |
| 26 | DUT_5         | : | coverpoint | vif.WAn[5];  |
| 27 | DUT_6         | : | coverpoint | vif.WAn[6];  |
| 28 | DUT_7         | : | coverpoint | vif.WAn[7];  |
| 29 | DUT_8         | : | coverpoint | vif.WAn[8];  |
| 30 | DUT_9         | : | coverpoint | vif.WAn[9];  |
| 31 | DUT_10        | : | coverpoint | vif.WAn[10]; |
| 32 | DUT_11        | : | coverpoint | vif.WAn[11]; |
| 33 | DUT_12        | : | coverpoint | vif.WAn[12]; |
| 34 | DUT_13        | : | coverpoint | vif.WAn[13]; |
| 35 | DUT_14        | : | coverpoint | vif.WAn[14]; |
| 36 | DUT_15        | : | coverpoint | vif.WAn[15]; |
| 37 |               |   |            |              |
| 38 | REF_0         | : | coverpoint | exp.WAn[0];  |
| 39 | REF_1         | : | coverpoint | exp.WAn[1];  |
| 40 | REF_2         | : | coverpoint | exp.WAn[2];  |
| 41 | REF_3         | : | coverpoint | exp.WAn[3];  |
| 42 | REF_4         | : | coverpoint | exp.WAn[4];  |
| 43 | REF_5         | : | coverpoint | exp.WAn[5];  |
| 44 | REF_6         | : | coverpoint | exp.WAn[6];  |
| 45 | REF_7         | : | coverpoint | exp.WAn[7];  |
| 46 | REF_8         | : | coverpoint | exp.WAn[8];  |
| 47 | REF_9         | : | coverpoint | exp.WAn[9];  |
| 48 | <b>REF_10</b> | : | coverpoint | exp.WAn[10]; |

| 49 | REF_11 : coverpoint exp.WAn[11];              |
|----|-----------------------------------------------|
| 50 | REF_12 : coverpoint exp.WAn[12];              |
| 51 | REF_13 : coverpoint exp.WAn[13];              |
| 52 | REF_14 : coverpoint exp.WAn[14];              |
| 53 | REF_15 : coverpoint exp.WAn[15];              |
| 54 |                                               |
| 55 | CC_0 : cross DUT_0, REF_0                     |
| 56 | {bins pass = binsof(DUT_0) && binsof(REF_0);} |
| 57 | CC_1 : cross DUT_1, REF_1                     |
| 58 | {bins pass = binsof(DUT_1) && binsof(REF_1);} |
| 59 | CC_2 : cross DUT_2, REF_2                     |
| 60 | {bins pass = binsof(DUT_2) && binsof(REF_2);} |
| 61 | CC_3 : cross DUT_3, REF_3                     |
| 62 | {bins pass = binsof(DUT_3) && binsof(REF_3);} |
| 63 | CC_4 : cross DUT_4, REF_4                     |
| 64 | {bins pass = binsof(DUT_4) && binsof(REF_4);} |
| 65 | CC_5 : cross DUT_5, REF_5                     |
| 66 | {bins pass = binsof(DUT_5) && binsof(REF_5);} |
| 67 | CC_6 : cross DUT_6, REF_6                     |
| 68 | {bins pass = binsof(DUT_6) && binsof(REF_6);} |
| 69 | CC_7 : cross DUT_7, REF_7                     |
| 70 | {bins pass = binsof(DUT_7) && binsof(REF_7);} |
| 71 | CC_8 : cross DUT_8, REF_8                     |
| 72 | {bins pass = binsof(DUT_8) && binsof(REF_8);} |
| 73 | CC_9 : cross DUT_9, REF_9                     |

| 74 | {bins pass = binsof(DUT_9) && binsof(REF_9);}               |
|----|-------------------------------------------------------------|
| 75 | CC_10 : cross DUT_10, REF_10                                |
| 76 | {bins pass = binsof(DUT_10) && binsof(REF_10);}             |
| 77 | CC_11 : cross DUT_11, REF_11                                |
| 78 | {bins pass = binsof(DUT_11) && binsof(REF_11);}             |
| 79 | CC_12 : cross DUT_12, REF_12                                |
| 80 | {bins pass = binsof(DUT_12) && binsof(REF_12);}             |
| 81 | CC_13 : cross DUT_13, REF_13                                |
| 82 | {bins pass = binsof(DUT_13) && binsof(REF_13);}             |
| 83 | CC_14 : cross DUT_14, REF_14                                |
| 84 | {bins pass = binsof(DUT_14) && binsof(REF_14);}             |
| 85 | CC_15 : cross DUT_15, REF_15                                |
| 86 | {bins pass = binsof(DUT_15) && binsof(REF_15);}             |
| 87 | endgroup                                                    |
| 88 |                                                             |
| 89 | <pre>function new(string name, uvm_component parent);</pre> |
| 90 | <pre>super.new(name, parent);</pre>                         |
| 91 | <pre>from_rm = new("from_rm", this);</pre>                  |
| 92 | exp = new("exp");                                           |
| 93 | $cov_out = new();$                                          |
| 94 | count = 0;                                                  |
| 95 | <pre>num_mismatches = 0;</pre>                              |
| 96 | $num_matches = 0;$                                          |
| 97 | free $= 0;$                                                 |
| 98 | endfunction                                                 |
```
99
100
      virtual function void build_phase(uvm_phase phase);
101
        super.build_phase(phase);
102
        void '(uvm_resource_db#(intf_vif)::read_by_name(.scope("ifs"
           ),
103
              .name("intf_vif"), .val(vif)));
        tr = in_sqr_item :: type_id :: create("tr", this);
104
105
      endfunction
106
107
      virtual function string get_type_name();
108
        return type_name;
109
      endfunction
110
      virtual function int get_watermark();
111
        wmfile = $fopen("src/watermark.param","r");
112
113
        wmstring = $fscanf(wmfile, "%d", watermark);
        if (watermark == "") return 0;
114
        else $display("Running to Watermark of: %d", watermark);
115
116
        return 1;
      endfunction
117
118
119
      virtual task run_phase(uvm_phase phase);
120
        phase.raise_objection(this);
121
        super.run_phase(phase);
122
        fork
```

```
123
          compare_transactions(phase);
124
          end_sim(phase);
125
        join
      endtask
126
127
128
      virtual task end_sim(uvm_phase phase);
129
        @(endsimulation)
130
        phase.drop_objection(this);
131
      endtask
132
      virtual task put (out_sqr_item t);
133
134
        exp.copy(t);
135
      endtask
136
137
      virtual function bit try_put(out_sqr_item t);
        exp.copy(t);
138
139
        return 1;
140
      endfunction
141
142
      virtual function bit can_put();
143
        return free;
144
      endfunction
145
146
      virtual task compare_transactions(uvm_phase phase);
147
        a1 : assert (get_watermark() == 1);
```

```
148
        start_time = get_time();
        wait (vif. reset == 1);
149
150
        @(negedge vif.reset);
151
152
        -> begin_delay;
153
        do begin
          @(negedge vif.clk);
154
155
          count++;
156
        end while (count != 6);
        -> end_delay;
157
158
159
        forever begin
160
          @(negedge vif.clk);
161
          if (exp.WAn !== vif.WAn) begin
            num_mismatches++;
162
163
            uvm_report_warning(get_type_name(), $sformatf("Output
               Mismatch RM: %h DUT: %h (%f mismatches)", exp.WAn, vif.
               WAn, num_mismatches), UVM_NONE);
164
          end
165
          else begin
            // uvm_report_info(get_type_name(), $sformatf("Output
166
               match RM: %h DUT: %h (%f mismatches)", exp.WAn, vif.WAn
                , num mismatches), UVM NONE);
167
            num matches++;
168
          end
```

```
169
          cov_out.sample();
170
          @(negedge vif.clk);
171
          \rightarrow compared;
172
173 // Uncomment for Coverage-Based functionality instead of
       Watermark
174 /*
          if (((num matches + num mismatches) \% 10000) == 0) begin
175
      $display("%d Runs", num_matches + num_mismatches);
176
177
      if ($get_coverage() >= 100) begin
178
              -> endsimulation;
179
            end
          end
180
181 */
182 // Uncomment for Watermark-Based Functionality instead of
       Coverage
183 ///*
184
          if ((num_matches + num_mismatches) == watermark) begin
185
            -> endsimulation;
186
          end
187 // */
188
189
        end
190
      endtask
191
```

| 192 | <pre>function void report_phase(uvm_phase phase);</pre>                |
|-----|------------------------------------------------------------------------|
| 193 | <pre>\$display("Simulation Ended. Number of Tests: %d",</pre>          |
|     | <pre>num_matches + num_mismatches);</pre>                              |
| 194 | <pre>\$display("Total Coverage: %.2f",\$get_coverage());</pre>         |
| 195 | <pre>\$display("Num Passes: %d\nNum Fails: %d",num_matches,</pre>      |
|     | num_mismatches);                                                       |
| 196 | <pre>run_time = get_time() - start_time;</pre>                         |
| 197 | hrs = run_time / 3600;                                                 |
| 198 | $min = (run_time - (hrs * 3600)) / 60;$                                |
| 199 | $sec = (run_time - (hrs * 3600) - (min * 60));$                        |
| 200 | <pre>\$display("Run Time: %d Hrs %d Min %d Sec", hrs, min, sec);</pre> |
| 201 | generate_report (num_matches, num_mismatches, watermark, $0, 0, 0$ ,   |
|     | <pre>run_time , \$get_coverage());</pre>                               |
| 202 | email_report();                                                        |
| 203 | endfunction                                                            |
| 204 |                                                                        |
| 205 | endclass                                                               |
|     |                                                                        |

## I.9 Agent

```
1 class agent extends uvm_agent;
2
     sequencer sqr;
3
     driver
                dvr;
4
               #(out_sqr_item) mtr;
     monitor
5
6
     uvm_put_port #(in_sqr_item) icp;
7
8
     'uvm component utils (agent)
9
     function new(string name = "agent", uvm_component parent =
10
        null);
11
       super.new(name, parent);
12
       icp = new("icp", this);
13
     endfunction
14
15
     virtual function void build_phase(uvm_phase phase);
16
       super.build_phase(phase);
17
       sqr = sequencer::type_id::create("sqr",this);
       dvr = driver::type_id::create("dvr",this);
18
       mtr = monitor#(out_sqr_item)::type_id::create("mtr",this);
19
20
     endfunction
21
22
     virtual function void connect_phase(uvm_phase phase);
```

```
23 super.connect_phase(phase);
24 dvr.icp.connect(icp);
25 dvr.seq_item_port.connect(sqr.seq_item_export);
26 endfunction
27
28 endclass
```

## I.10 Environment

```
1 class env extends uvm env;
2
3
     agent
                mstr;
4
     refmod
                rm;
5
     uvm_tlm_analysis_fifo #(in_sqr_item) to_rm;
6
7
     'uvm component utils(env)
8
9
     function new(string name, uvm_component parent = null);
10
       super.new(name, parent);
11
       to_rm = new("to_rm", this);
12
     endfunction
13
     virtual function void build_phase(uvm_phase phase);
14
15
       super.build_phase(phase);
16
                   agent::type_id::create("mstr", this);
       mstr =
                  refmod :: type_id :: create ("rm", this);
17
       rm
            =
18
     endfunction
19
20
     virtual function void connect_phase(uvm_phase phase);
21
       super.connect_phase(phase);
       // Sequencer to Ref Mod FIFO
22
23
       mstr.icp.connect(to_rm.put_export);
```

```
24
       // Ref Mod FIFO to Ref Mod
25
26
       rm.in.connect(to_rm.get_export);
27
28
       // Ref Mod to Monitor
29
       rm.out.connect(mstr.mtr.from_rm);
     endfunction
30
31
32
     virtual function void end_of_elaboration_phase(uvm_phase
        phase);
33
       super.end_of_elaboration_phase(phase);
34
     endfunction
35
36
     virtual function void report_phase(uvm_phase phase);
37
       super.report_phase(phase);
       'uvm_info(get_type_name(), $sformatf("Reporting Matched %0d
38
          ", mstr.mtr.num_matches), UVM_NONE)
39
       if (mstr.mtr.num_mismatches) begin
40
         'uvm_error(get_type_name(), $sformatf("Saw %0d mismatched
            samples", mstr.mtr.num_mismatches))
41
       end
42
     endfunction
43
44 endclass
```

## I.11 Test

```
1 class FMULT_test extends uvm_test;
2
     env env_h;
3
     seq_in sqr_h;
4
     'uvm_component_utils (FMULT_test)
5
     function new(string name,uvm_component parent = null);
6
7
       super.new(name, parent);
     endfunction
8
9
     virtual function void build_phase(uvm_phase phase);
10
11
       super.build_phase(phase);
       env_h = env::type_id::create("env_h", this);
12
       sqr_h = seq_in :: type_id :: create ("sqr_h", this);
13
     endfunction
14
15
16
     task run_phase(uvm_phase phase);
       sqr_h.start(env_h.mstr.sqr);
17
18
     endtask
19
20 endclass
```

## I.12 Top

```
1
2 'include "uvm_macros.svh"
3 'include "intf.sv"
4
5 'include "FMULT_pkg.sv"
6
7
8 module test;
9
10
     import uvm_pkg::*;
     import FMULT_pkg::*;
11
12
     logic clk;
13
14
15
     intf vif(clk);
16
17
     initial begin
           = 0;
18
       clk
19
      vif.reset = 0;
20
     end
21
     always #5 clk = \sim clk;
22
23
```

| 24 | initial begin                                                     |
|----|-------------------------------------------------------------------|
| 25 | \$timeformat(-9,2,"ns",16);                                       |
| 26 | 'ifdef SDFSCAN                                                    |
| 27 | <pre>\$sdf_annotate("sdf/FMULT_tsmc18_scan.sdf", test.top);</pre> |
| 28 | 'endif                                                            |
| 29 | <pre>uvm_resource_db#(intf_vif)::set(.scope("ifs"),.name("</pre>  |
|    | <pre>intf_vif"),.val(vif));</pre>                                 |
| 30 | <pre>\$set_coverage_db_name("FMULT");</pre>                       |
| 31 | run_test("FMULT_test");                                           |
| 32 | end                                                               |
| 33 |                                                                   |
| 34 | FMULT top(vif.reset,                                              |
| 35 | clk,                                                              |
| 36 | vif.scan_in0,                                                     |
| 37 | vif.scan_en,                                                      |
| 38 | vif.test_mode,                                                    |
| 39 | vif.scan_out0,                                                    |
| 40 | vif.An,                                                           |
| 41 | vif.SRn,                                                          |
| 42 | vif.WAn);                                                         |
| 43 |                                                                   |
| 44 | endmodule                                                         |