



#### **Project Team**

Belal Mohamed Ibrahim Fawzy Saleh Ramadan Saleh Othman Tarek Mohamed Sayed Hussein Tarek Khaled Farouk Abdelshafi Khaled Hassan Sayed Hassan Abdelrahman Ahmed Saad Hassan

Supervised by

## Dr. Hassan Mostafa

Sponsored by

## **Siemens EDA**

A Graduation Project Thesis In Partial Fulfillment of the Requirements for the Degree of Bachelor of Science Electronics and Electrical Communications Engineering Faculty of Engineering, Cairo University Giza, Egypt July 2022

# Table of contents

| Chapter 1: Introduction                           |    |
|---------------------------------------------------|----|
| 1.1 Motivation                                    | 12 |
| 1.2 DRAM Background and DDR5                      | 12 |
| 1.2.1 DRAM Basics                                 | 12 |
| 1.2.2 DDR5 Standard                               | 15 |
| 1.3 HIGH COMPLEXITY AND THE NEED FOR VERIFICATION | 16 |
| 1.4 Thesis scope                                  | 17 |
| 1.5 Thesis organization                           | 17 |
| Chapter 2: Design                                 |    |
| 2.1 Overview                                      |    |
| 2.1.1 Basic Features                              |    |
| 2.1.2 Optional Features                           | 19 |
| 2.1.3 Excluded Features                           | 19 |
| 2.2 Scope of Our Design                           | 19 |
| 2.3 Inputs and Outputs of Top Module              | 20 |
| 2.4 Operation of Controller                       | 22 |
| 2.5 Design in Detail                              | 23 |
| 2.5.1. Command_Decoder                            | 23 |
| 2.5.2 Command_Address_FIFO                        | 28 |
| 2.5.3 Write_Data_FIFO                             | 29 |
| 2.5.4 Calculation of Depth of FIFOs               |    |
| 2.5.5 Counters                                    | 31 |
| 2.5.6 Command_FSM                                 |    |
| 2.5.7 Initialization_FSM                          | 46 |
| 2.5.8 Self Refresh_FSM                            | 51 |
| 2.6 Design Enhancement                            | 56 |
| 2.6.1 Read_FSM                                    | 57 |
| 2.6.2 Write_FSM                                   | 60 |
| 2.6.3 Selection Decoder                           | 64 |
| Chapter 3: Introduction to Cocotb                 | 67 |
| 3.1 Introduction                                  | 67 |

| 3.2 Background                                                    | 67 |
|-------------------------------------------------------------------|----|
| 3.2.1 Functional Verification                                     | 68 |
| 3.2.2 Switching to Python                                         | 69 |
| 3.3 Design Verification using Cocotb                              | 69 |
| 3.3.1 Architecture of Cocotb                                      | 70 |
| 3.3.2 Design Methodology                                          | 70 |
| 3.3.3 Cosimulation                                                | 71 |
| 3.4 Cocotb Coverage                                               | 71 |
| 3.4.1 Functional Coverage in SystemVerilog                        | 71 |
| 3.4.2 Functional Coverage with Cocotb-coverage                    | 72 |
| 3.4.3 Constrained Random Verification Features in SystemVerilog   | 73 |
| 3.4.4 Constrained Random Verification Features in cocotb-coverage | 73 |
| 3.5 Code Coverage                                                 | 74 |
| 3.5.1 Statement coverage/ Line coverage                           | 75 |
| 3.5.2 Block/ Segment coverage                                     | 75 |
| 3.5.3 Conditional coverage                                        | 75 |
| 3.5.4 Branch coverage                                             | 75 |
| 3.5.5. Toggle coverage                                            | 75 |
| 3.5.6. Path coverage                                              | 75 |
| Chapter 4: Block Level Verification                               | 76 |
| 4.1 Goals and Overview                                            | 76 |
| 4.2 Block Level Testbench Architecture                            | 76 |
| 4.3 Command Decoder Verification Plan                             | 76 |
| 4.3.1 Functional Coverage Plan                                    | 76 |
| 4.3.2 Test Cases                                                  | 77 |
| 4.3.3 Reported Bugs                                               | 80 |
| 4.3.4 Functional Coverage Results                                 | 83 |
| 4.3.5 Code Coverage Results                                       | 84 |
| 4.4 Command Finite State Machine                                  | 84 |
| 4.4.1 Functional Coverage Plan                                    | 84 |
| 4.4.2 Test Cases                                                  | 85 |
| 4.4.3 Reported Bugs                                               | 94 |
| 4.4.4 Functional Coverage Results                                 |    |

| 4.4.5 Code Coverage Results                   |  |
|-----------------------------------------------|--|
| 4.5 Self_Refresh Finite State Machine         |  |
| 4.5.1 Functional Coverage Plan                |  |
| 4.5.2 Test Cases                              |  |
| 4.5.3 Reported Bugs                           |  |
| 4.5.4 Functional Coverage Results             |  |
| 4.5.6 Code Coverage Results                   |  |
| 4.6 Initialization Finite State Machine       |  |
| 4.6.1 Functional Coverage Plan                |  |
| 4.6.2 Test Cases                              |  |
| 4.6.3 Reported Bugs                           |  |
| 4.6.4 Functional Coverage Results             |  |
| 4.6.5 Code Coverage Results                   |  |
| 4.7 Counters                                  |  |
| 4.7.1 Functional Coverage Plan                |  |
| 4.7.2 Test Cases                              |  |
| 4.7.3 Reported Bugs                           |  |
| 4.7.4 Functional Coverage Results             |  |
| 4.7.5 Code Coverage Results                   |  |
| Chapter 5: UVM VS COCOTB                      |  |
| 5.1 Introduction                              |  |
| 5.1.1 UVM verification                        |  |
| 5.1.2 UVM verification environment components |  |
| 5.2 Verification Plan                         |  |
| 5.2.1 Testing scenarios:                      |  |
| 5.3 Results from UVM verification             |  |
| 5.4 Results from COCOTB verification          |  |
| 5.5 History of verification methods:          |  |
| 5.6 Tradeoffs between using UVM and COCOTB:   |  |
| Chapter 6: Top Level Verification             |  |
| 6.1 Verification Environment                  |  |
| 6.2 Functional Coverage Plan:                 |  |
| 6.3 Reported Bugs:                            |  |
|                                               |  |

| 6.4 Functional coverage results:         | 121 |
|------------------------------------------|-----|
| 6.5 Code coverage results:               |     |
| 6.6 Final Results                        |     |
| 6.6.1 Initialization Sequence            | 122 |
| 6.6.2 Self-Refresh Sequence              |     |
| 6.6.3 Single Read after Write            |     |
| 6.6.4 Multiple Read after Multiple Write | 123 |
| 6.7 QUESTA VERIFICATION IP               | 124 |
| 6.7.1 Overview                           | 124 |
| 6.7.2 Memory Model Components            | 125 |
| 6.7.3 Configurations                     | 126 |
| Chapter 7: Conclusions and Future Work   | 129 |
| 7.1 Conclusion                           | 129 |
| 7.2 Future Work                          | 129 |
| REFERENCES                               | 130 |

# List of figures

| Figure 1: DRAM Architecture.                                                           | 12 |
|----------------------------------------------------------------------------------------|----|
| Figure 2 : Bandwidth Evolution of DRAM Standards.                                      | 14 |
| Figure 3: Comparison of DDR4 and DDR5 Key Parameters                                   | 16 |
| Figure 4: Big Picture of Design.                                                       |    |
| Figure 5 : Inputs and Outputs of Top Module                                            | 20 |
| Figure 6: Address Mapping.                                                             | 21 |
| Figure 7: Block Diagram of Top Module.                                                 | 23 |
| Figure 8: Block Diagram of Command Decoder                                             | 23 |
| Figure 9: Block Diagram of Command_Address_FIFO                                        | 28 |
| Figure 10: Block Diagram of Write_Data_FIFO                                            |    |
| Figure 11: Block Diagram of Counters.                                                  |    |
| Figure 12: Block Diagram of Command_FSM                                                | 34 |
| Figure 13: Simplified State Diagram, JEDEC Reference                                   |    |
| Figure 14: Timing Diagram for Read Burst Operation (BL16), JEDEC Reference.            |    |
| Figure 15: Timing Diagram for Write Burst Operation (BL16), JEDEC Reference.           |    |
| Figure 16: Command_FSM                                                                 |    |
| Figure 17: Block Diagram of Initialization_FSM                                         | 46 |
| Figure 18: Reset and Initialization Sequence at Power-on Ramping, JEDEC Reference      |    |
| Figure 19: Initialization _FSM                                                         |    |
| Figure 20: Block Diagram of Self-Refresh _FSM                                          | 51 |
| Figure 21: Self-Refresh Entry/Exit Timing with One-Cycle Exit Command, JEDEC Reference |    |
| Figure 22: Self-Refresh _FSM                                                           | 53 |
| Figure 23: Clock Generator isn't synthesizable                                         |    |
| Figure 24: Problem of ambiguous clock triggering                                       |    |
| Figure 25: Block Diagram of Read_FSM                                                   |    |
| Figure 26: Read_FSM                                                                    | 58 |
| Figure 27: Block Diagram of Write_FSM                                                  | 60 |
| Figure 28: Write_FSM                                                                   | 61 |
| Figure 29: Multiple Driven Problem                                                     | 63 |
| Figure 30: Block Diagram of Selection_Decoder                                          | 64 |
| Figure 31: Some Problems of Synthesis.                                                 | 66 |
| Figure 32: Schematic from Synthesis Tool (Vivado).                                     | 66 |
| Figure 33: Types of Functional Verification                                            | 68 |
| Figure 34:Architecture of Cocotb                                                       | 70 |
| Figure 35: An example of the coverage tree structure                                   | 72 |
| Figure 36: Block Level Verification Environment.                                       | 76 |
| Figure 37: Command decoder coverage section written in python.                         | 77 |
| Figure 38: Initialization FSM Enable is asserted high for only one cycle.              | 81 |
| Figure 39: Initialization FSM Enable after modification                                | 82 |
| Figure 40: Command Decoder Test Summary from Questasim.                                | 82 |
| Figure 41: Command decoder Functional Coverage XML Report                              |    |
| Figure 42: Command decoder Functional Coverage from Coverage Viewer.                   | 83 |
| Figure 43: Command decoder Code Coverage Summary from Questasim.                       | 84 |

| Figure 44: Single write operation stuck at wait write done state           | 94  |
|----------------------------------------------------------------------------|-----|
| Figure 45: Single write operation after modifying CMD FSM                  | 95  |
| Figure 46: DQS, DQT preambles aren't working properly                      | 96  |
| Figure 47: DQS, DQT preambles are working properly after modification      | 96  |
| Figure 48: CMD FSM gets stuck at wait_tRP state                            | 97  |
| Figure 49: CMD FSM works properly after modification.                      |     |
| Figure 50: Command FSM Functional Coverage from Coverage Viewer            | 98  |
| Figure 51: Command FSM Code Coverage Summary from Questasim.               | 98  |
| Figure 52: Self_Refresh sequence as specified in JESD79-5                  |     |
| Figure 53: implemented Self_Refresh waveform.                              | 100 |
| Figure 54: Self-Refresh FSM Functional Coverage XML Report                 | 100 |
| Figure 55: Self-Refresh FSM Functional Coverage from Coverage Viewer       | 101 |
| Figure 56: Self-Refresh FSM Code Coverage Summary from Questasim.          | 101 |
| Figure 57: Initialization sequence as specified in JESD79-5                |     |
| Figure 58: implemented initialization waveform                             | 103 |
| Figure 59: Initialization FSM Functional Coverage XML Report               | 103 |
| Figure 60: Initialization FSM Functional Coverage from Coverage Viewer.    | 103 |
| Figure 61: Initialization FSM Code Coverage Summary from Questasim.        | 104 |
| Figure 62: Counter Flag is asserted High for only one Clock Cycle.         | 105 |
| Figure 63: Counters Functional Coverage XML Report                         | 105 |
| Figure 64: Counters Functional Coverage from Coverage Viewer               | 106 |
| Figure 65: Counters Code Coverage Summary from Questasim.                  | 106 |
| Figure 66: Counters Test Summary from Questasim                            | 106 |
| Figure 67: UVM environment for WR_Data_FIFO block                          |     |
| Figure 68: 1st example of error from simulation                            | 109 |
| Figure 69: 2nd example of error from simulation                            | 109 |
| Figure 70: UVM Report Summary and Coverage                                 | 109 |
| Figure 71: Assertions and UVM results                                      | 110 |
| Figure 72: The assertions coverage.                                        | 110 |
| Figure 73: Result of errors from COCOTB                                    | 111 |
| Figure 74: COCOTB verification results                                     | 112 |
| Figure 75: COCOTB Functional coverage report                               | 112 |
| Figure 76: COCOTB Code coverage report                                     | 113 |
| Figure 77: Constrained-random test progress over time vs. directed testing | 114 |
| Figure 78: Programming languages Complexity.                               | 115 |
| Figure 79: FPGA verification language adoption next twelve months          | 116 |
| Figure 80: ASIC/IC verification language adoption next twelve months       | 116 |
| Figure 81 : Verification Environment of Top-Level Verification             | 117 |
| Figure 82: Block Diagram of Memory Module                                  | 118 |
| Figure 83:Top Module is stuck at WAIT_ACT state                            | 119 |
| Figure 84: Read words with length less than burst length                   | 120 |
| Figure 85: Tri-state Buffer                                                | 121 |
| Figure 86:Functional Coverage Report of Top Level                          | 121 |
| Figure 87:Code Coverage Report of Top Level                                | 122 |

| Figure 88:Waveform of Initialization Sequence from Top Level | 122 |
|--------------------------------------------------------------|-----|
| Figure 89:Waveform of Self-Refresh Sequence from Top Level   | 123 |
| Figure 90: Waveform of Single Read after Write               | 123 |
| Figure 91: Waveform of Multiple Read after Multiple Write    | 123 |
| Figure 92: Questa Memory Model Flow                          | 124 |
| Figure 93:Memory Model Components                            | 125 |
| Figure 94: Test bench using QVIP Configurator                |     |
| Figure 95 :Memory Model Configurations                       |     |
|                                                              |     |

# List of tables

| Table 1: Inputs of Top Module                                   |      |
|-----------------------------------------------------------------|------|
| Table 2: Outputs of Top Module                                  | .21  |
| Table 3: Inputs of Command Decoder                              | .23  |
| Table 4: Outputs of Command Decoder                             |      |
| Table 5: Description of Processor Commands                      |      |
| Table 6: Decoding of Processor Commands                         | . 25 |
| Table 7: Description of Enable Signals of Finite State Machines | .26  |
| Table 8: Description of Enable Signals of FIFOs                 | . 27 |
| Table 9: Inputs of Command_Address_FIFO                         | . 28 |
| Table 10: Outputs of Command_Address_FIFO                       | . 28 |
| Table 11: Inputs of Write_Data_FIFO                             | . 29 |
| Table 12: Outputs of Write_Data_FIFO                            | . 30 |
| Table 13: Initialization Timing Parameters                      | .31  |
| Table 14: Activate Timing Parameters                            | . 32 |
| Table 15: Precharge Timing Parameters                           | . 32 |
| Table 16: Reading Timing Parameters                             |      |
| Table 17: Writing Timing Parameters                             | . 32 |
| Table 18: Self-Refresh Timing Parameters                        |      |
| Table 19: Inputs of Command_FSM                                 |      |
| Table 20: Outputs of Command_FSM                                |      |
| Table 21: Scenarios of Back-to-Back Operations                  |      |
| Table 22:Storage of Activate Rows                               |      |
| Table 23: Description of each state in Command_FSM              |      |
| Table 24: Outputs of each state in Command_FSM                  |      |
| Table 25: Inputs of Initialization_FSM                          |      |
| Table 26: Outputs of Initialization_FSM                         |      |
| Table 27: Description of each state in Initialization_FSM       |      |
| Table 28: Outputs of each state in Initialization_FSM           |      |
| Table 29: Inputs of Self Refresh_FSM                            |      |
| Table 30: Outputs of Self Refresh_FSM                           |      |
| Table 31: Description of each state in Self Refresh_FSM         |      |
| Table 32: Outputs of each state in Self Refresh_FSM             |      |
| Table 33: Inputs of Read_FSM                                    |      |
| Table 34: Outputs of Read_FSM                                   |      |
| Table 35: Description of each state in Read_FSM                 |      |
| Table 36: Outputs of each state in Read_FSM                     |      |
| Table 37: Inputs of Write_FSM                                   |      |
| Table 38: Outputs of Write_FSM                                  |      |
| Table 39: Description of each state in Write_FSM                |      |
| Table 40: Outputs of each state in Write_FSM                    |      |
| Table 41: Inputs of Selection Decoder                           |      |
| Table 42: Outputs of Selection Decoder                          |      |
| Table 43: Operation of Selection Decoder                        | .64  |

| Table 44: Test cases of command decoder          | 77  |
|--------------------------------------------------|-----|
| Table 45: Test cases of command FSM.             | 85  |
| Table 46: Test cases of Self_Refresh FSM         | 99  |
| Table 47: Test cases of Initialization FSM.      |     |
| Table 48: Test cases of counters                 | 104 |
| Table 49: Description of Memory Model Components | 125 |

## List of Abbreviation

SDRAM: Synchronous Dynamic Random Access Memory **DDRx**: Double Data rate xth generation SoC: System on Chip MPSoC: Multi-Processor System on Chip **DIMM:** Dual Inline Memory Module ACT: Activate Command **PRE**: Precharge Command RD: Read Command RDA: Read Command with Auto-Precharge **WR**: Write Command WRA: Write Command with Auto-Precharge NOP: No Operation Command PREpb: Precharge bank Command PREsb: Precharge same bank Command PREab: Precharge all banks Command REFsb: same-bank Refresh **CRC**: Cyclic Redundancy Check **MP**SM: Maximum Power Saving Mode Cocotb: Co-routine Co-simulation test-bench UVM: Universal Verification Methodology FIFO: First-In First-Out FSM: Finite State Machine HDL: Hardware Description Language **RTL**: Register Transfer Level IC: Integrated Circuit **FPGA**: Field Programmable Gate Array **EDA**: Electronic Design Automation **DUT**: Design Under Test **GUI**: Graphical User Interface **VPI**: Verilog Procedural Interface VHDLPI: VHDL Procedural Interface **API**: Application Programming Interface **IP**: Intellectual Property QVIP: Questa Verification IP

## **Chapter 1: Introduction**

#### **1.1 MOTIVATION**

Currently, we see a strong need to memory-dominated Applications such as Big Data, IoT, Cloud-Data Centers, Machine Learning etc...., Thus Dynamic Random-Access Memories (DRAMs) play a large role in compute platforms. Over the last years, the number of DRAM standards specified by the JEDEC Solid State Technology Association has been growing rapidly. The most recent DRAM standard is DDR5, which was released in mid-2020, because of the large number of new features, system designers are either challenged to adopt the new standard or they can move on with well-established standards like DDR4.If DDR5 is a potential candidate for a specific application, a further challenge is the configuration of the DDR5 subsystem, which is the configuration of the DDR5 subsystem, which features a lot of parameter choices. Fast and accurate simulation models are mandatory to explore the new features and compare different configurations.

#### **1.2 DRAM BACKGROUND AND DDR5**

In this section we introduce the basic terminology of DRAM devices and their controllers and give an overview on the new features of the DDR5 standard.



#### 1.2.1 DRAM Basics



As shown in Figure 1, DRAM can be organized in a multi-hierarchical fashion of DIMMs, channels, physical ranks, devices, logical ranks, bank groups, banks, memory arrays, sub arrays, rows, and columns. Several DRAM channels can be connected to the Multi-Processor System on Chip (MPSoC). These channels are completely in-dependent of each other and have separate command/address and data buses. A channel can be composed of one or multiple physical ranks, which are sharing the data and command/address bus. A Dual Inline Memory Module (DIMM) is a small PCB that accommodates several DRAM devices, which work completely synchronously. One single device is called ×161 if it has an I/O data width of 16 bit. A DIMM is assembled for

instance out of four  $\times 16$  devices in order to have a total I/O data width n = 64 bit (called  $\times 64$ ). While the I/O data width is usually very limited, inside the DRAM a lot of data can be fetched or stored in parallel. However, the time between consecutive internal data accesses is very long due to the optimization for storage density, while the interface can be operated on much higher frequencies. To align this mismatch DRAM uses a so-called prefetching technique. For read large chunks of data are concurrently fetched to the interface and then transferred in one burst to the relpronunciation: by-sixteen quester, for a write the process is reversed. In addition, data is transferred at the doubled interface frequency (double data rate, short DDR). Current devices such as DDR4 use an 8n prefetch architecture, where n is the I/O data width, 8 the Burst Length (BL) and 8n the number of bits for an internal data transfer. That means with each DRAM access the total amount of data received or delivered is  $BL \cdot n = 8 \cdot 64$  bit = 512 bit = 64 B, which is the usual cache line size in today's computing systems. In combination with interface frequencies up to 1600 MHz or pin transfer rates up to 3200 MT/s (mega transfers per second) DDR4 reaches a maximum bandwidth of 25.6 GB/s per channel. Each device itself can consist of several 3D-stacked logical ranks, which can form several bank groups that include several banks. The concept of bank groups was introduced with DDR5 and DDR4 in order to reduce the bank switching times to support a seamless burst behavior at high data rates and therefore a high bandwidth. All banks in a whole channel can be used concurrently (so called bank parallelism). However, there are some constraints due to the shared buses. Each bank usually consists of 212 to 218 rows, and each row can usually store 512B to 2KB of data in its columns. A memory controller is composed of a front end and a back end. The front end performs arbitration and scheduling of incoming read and write requests, whereas the task of the back end is to translate these incoming requests into a sequence of DRAM commands, which have to be orchestrated with respect to the current state of the device. To access data in a row of a certain bank, an activate (ACT) command must be issued by the controller before any column access, i.e., read (RD) or write (WR) commands, can be executed. The ACT command opens an entire row of the memory array, which is transferred into the bank's row buffer [2]. It acts like a small cache that stores the most recently accessed row of the bank. The latency of a memory access to a bank largely varies depending on the state of this row buffer. If a memory access targets the same row as the currently cached row in the buffer (called row hit), it results in a low latency and low energy memory access.



Figure 2 : Bandwidth Evolution of DRAM Standards [1].

Whereas, if a memory access targets a different row as the current row in the buffer (called row miss), it results in a higher latency and energy consumption. If a certain row in a bank is active it must first be precharged (PRE) before another row can be activated. In addition to the normal RD and WR commands, there exist read and write commands with an integrated auto-precharge (RDA,

WRA). If auto-precharge is selected, the row being accessed will be precharged automatically at the end of the read or write access. Because a DRAM cell uses a capacitor with leakage effects for data storage, it usually has to be refreshed every 64ms to retain the data stored in it. Modern DRAMs are equipped with an all-bank refresh (REFab) command to perform this operation automatically on all banks of a rank in parallel. However, a prerequisite is that all banks are in a precharged state. This can be achieved by issuing a special all-bank precharge (PREab) command in advance. In addition to the commands, each DRAM standard defines a set of timing dependencies, which are temporal constraints that must be satisfied between issued commands. For example, between two ACT commands to the same bank the timing dependency tRC (row cycle time) must be satisfied. Timing dependencies can also exist on other hierarchies of the DRAM, e.g., between commands to the same bank group, to the same logical/physical rank or to different logical/physical ranks. The selection of a DRAM subsystem usually has three main dimensions: bandwidth, latency, and capacity. Bandwidth is the amount of data that can be transferred between DRAM and a computational unit within a given time. As shown in Figure 2, the maximum theoretical DRAM bandwidth is limited to the number of data pins times the interface pin data rate (number of accesses per time per pin). Latency is the time that it takes to complete an access. In fact, latency helps bandwidth, but not vice versa [4]. For instance, lower DRAM latency results in more accesses per time, and therefore higher bandwidth, whereas increasing the number of data pins increases the bandwidth without decreasing latency. In realistic scenarios, the full theoretical bandwidth is never reached due to many timing dependencies, interference between different requests, and refresh. The actual achieved bandwidth for a specific application is called sustainable bandwidth.

#### 1.2.2 DDR5 Standard

With the development of a new DRAM standard generation there are always several key parameters that should be enhanced, e.g., bandwidth, power consumption, and device capacity. Figure 3 shows a comparison between key parameters of the new DDR5 standard and its predecessor DDR4. In the following we will also describe the most important differences in more detail. For a higher bandwidth DDR5 raises the maximum pin data rate to 8400 MT/s compared to 3200 MT/s for DDR4. Because the frequency of internal data accesses stays more or less the same as a result of the capacity- and cost optimized architecture, the prefetch was incremented from 8n to 16n. When using the same 64-bit-wide data bus for one channel as all previous DDR generations, this would result in 128 B of transferred data per access. However, since the usual cache line size of modern processors is only 64 B, the data bus of each DDR5 DIMM is split up into two independent channels of 32-bit width. That way only 64 B of data are transferred per access. Theoretical transfer rates then reach a maximum of 33.6 GB/s per channel and 67.2 GB/s per DIMM compared to 25.6 GB/s per channel/DIMM for DDR4, as shown in Figure 2. At the same time supply voltages are reduced from 1.2 V to 1.1 V for an improved power consumption. The maximum number of banks per device increases from 16 to 32 distributed over 8 instead of 4 bank groups, the total capacity of a single device from 16 Gb to 64 Gb. In addition, up to 16 instead of 8 devices can now be stacked in a three-dimensional fashion (logical ranks)<sup>3</sup>. This enables stack capacities of up to 512 Gb (max.  $16 \times 32$  Gb or  $8 \times 64$  Gb because of limited address bits). One

problem that always arises with higher device capacities is the increased refresh overhead, because each cell still has to be refreshed approximately every 64 ms, as a consequence, either the controller has to issue refresh commands more frequently or the individual refresh cycles take a longer time. Since all banks of a rank cannot be accessed during an all-bank refresh, it can lead to significant performance drops. To overcome this problem, DDR5 introduces same-bank refresh (REFsb) and associated same-bank precharge (PREsb) commands as an alternative to all-bank refresh (REFab) and all-bank precharge (PREab) commands. When issuing them, only one bank in each bank group of the target rank is refreshed and inaccessible, while all other banks can still process incoming read and write requests. Most modern DRAM controllers use advanced reordering techniques for an improved performance so they can try to hide the same-bank refresh by sending requests to other banks in the meantime. Finally, DDR5 devices implement an on-die error correction to improve the data integrity[2].

| ITEMS             | DDR4                | DDR5                        |
|-------------------|---------------------|-----------------------------|
| Frequency         | 1600~3200Mbps       | 3200~8400Mbps               |
| Density           | 2Gb, 4Gb, 8Gb, 16Gb | 8Gb, 16Gb, 24Gb, 32Gb, 64Gb |
| On die ECC        | Νο                  | Yes                         |
| Bank              | 16banks             | 32banks                     |
| VDD/VDDQ          | 1.2V                | 1.1V                        |
| VPP               | 2.5V 1.8V           |                             |
| BL                | 8                   | 16                          |
| DFE               | No                  | Yes                         |
| Same bank refresh | No                  | Yes                         |

Figure 3: Comparison of DDR4 and DDR5 Key Parameters [3].

#### **1.3 HIGH COMPLEXITY AND THE NEED FOR VERIFICATION**

With advanced and complex features, there is a need for meticulous verification. Memories have a vast set of configurations that allow them to operate at various data rates with different densities. Further, these can be combined with a vast set of features such as Self-Refresh, Auto Refresh, Cyclic Redundancy Check (CRC), Post Package Repair, Maximum Power Saving Mode (MPSM), training across different settings of latencies and speeds. The permutation and combinations of these variables can grow exponentially across different memory vendors as each of these memory

vendors offer 100s of part numbers. As you can imagine, it can easily become a daunting experience for verification engineers to verify a memory subsystem.

DDR5 DIMMs adds more challenges. For example, in order to achieve higher power efficiency, voltage is reduced from 1.2V to 1.1V which brings additional complexity for DIMM vendors around noise immunity. Higher speeds raise data integrity concerns which need precise training results. This creates the need for careful verification, as modeling of real-world scenarios and visualization of those scenarios going into wire level toggling would consume a lot of time.

Measuring verification progress through functional coverage is equally important as the verification of design features. Also, performance analysis is extremely important for memories. These add a few extra cycles in the verification flow.

#### **1.4 THESIS SCOPE**

1.Design of DDR5 SDRAM Memory Controller based on JEDEC79-5 Standard.

2.Verification of DDR5 SDRAM Memory Controller using Python Language especially CoCotb library (new trend method in verification).

#### **1.5 THESIS ORGANIZATION**

The structure of the thesis is as follows:

- Chapter 2: This Chapter discusses the design of DDR5 SDRAM Memory Controller.
- Chapter 3: This Chapter presents an introduction to Cocotb and discusses The Verification Methodology.
- Chapter 4: This chapter outlines the results of Block level verification phase.
- Chapter 5: A Comparison between UVM Verification and A Cocotb Verification is discussed in this chapter.
- Chapter 6: This chapter outlines the results of Top-level verification phase.
- Chapter 7: The chapter consists of the conclusions and details possible future work

## **Chapter 2: Design**

#### **2.1 OVERVIEW**

In this chapter, we will discuss design of **DDR5 SDRAM Controller**. Our design will interface with CPU and DDR5 SDRAM Memory as shown in Figure 4:



Figure 4: Big Picture of Design.

to interface with CPU, we followed **Native Interface** and to interface with DDR5 SDRAM Memory we followed **JEDEC79-5 Standard**. For DDR5 SDRAM Memory, we chose **x16** Configuration with **3.2GHZ** input clock frequency. This choice will affect the values of timing parameters as we will illustrate. Not all the features of DDR5 SDRAM Memory in JEDEC79-5 Standard are scoped in our project. To choose features that will be implemented in our design, we divided features into three sections:

#### 2.1.1 Basic Features

- Initialization
- Activation
- > Precharge
- ➢ Reading
- ➤ Writing
- Auto Precharge
- > Burst
- Self-Refreshing

Mode Register Operations

#### 2.1.2 Optional Features

- On-Die ECC (Check Memory Error)
- DDR5 ECC Transparency and Error Scrub
- CRC (Check Bus Error)
- Write Pattern Command
- > Refreshing
- Power Down Mode

#### 2.1.3 Excluded Features

All modes related to testing, training modes such as ZQ Calibration, Read Training, Change Clock Frequency, etc.

#### **2.2 SCOPE OF OUR DESIGN**

As a first step in design, we started our design by **basic features** mentioned above in section 2.1.1 and after we verify these operations, we will extend our project based on available time with other optional features of DDR5. There are also some modes we mentioned in section 2.1.3 we excluded them as there are related if we completed our design as a product and we need to test it in hardware so we excluded them from our design as we will not reach in our project to fabrication. To implement basic features these are the memory commands that will be used:

- Activate (ACT)
- Precharge (PREpb)
- ➢ Read (RD)
- Read w/Auto Precharge (RDA)
- ➢ Write (WR)
- Write w/Auto Precharge (WRA)
- Mode Register Write (MRW)
- Self\_Refresh Entry (SRE)
- > NOP

➢ Deselect (DES)

#### 2.3 INPUTS AND OUTPUTS OF TOP MODULE

After we chose features that will be implemented, we could determine inputs and outputs of our design from Native interface and JEDEC79-5 standard as shown in Figure 5:



*Figure 5 : Inputs and Outputs of Top Module.* 

The description of each input is shown in Table 1, and also description of each output is shown in Table 2:

| Table | 1: | Inputs | of | Тор | Module | [4] |
|-------|----|--------|----|-----|--------|-----|
|-------|----|--------|----|-----|--------|-----|

| Signal     | Description                                                                                                                                                 |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| CK_t, CK_c | Differential clock of DDR5 SDRAM, all address and control input signals are sampled on the crossing of the positive edge of CK_t and negative edge of CK_c. |  |  |
| Ctrl_Reset | Control signal from CPU to controller to issue the initialization sequence to memory. It's active high reset                                                |  |  |
| Ctrl_Read  | Read request (active high).                                                                                                                                 |  |  |
| Ctrl_Write | Write request (active high).                                                                                                                                |  |  |
| Ctrl_Burst | When 1 defines alternate read/write burst mode (BC8) and when 0 defines default BL16 mode.                                                                  |  |  |

| Ctrl_Auto          | When asserted high along with Ctrl_Read or Ctrl_Write, causes the command to be issued as read with auto-precharge and write with auto-precharge, respectively.                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ctrl_ADD[30:0]     | Address that data will be read from memory or written in memory.                                                                                                                                    |
| Ctrl_DataIn[255:0] | Data that will be written in memory during writing operation.                                                                                                                                       |
| CK_double          | Clock that has double frequency of SDRAM clock, DQS signals will be<br>generated with positive edge of this clock, also data from memory will<br>be sampled also on the positive edge of this clock |

#### Table 2: Outputs of Top Module [5]

| Signal              | Description                                                                                                                                                                                               |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset_n             | Active low asynchronous reset: reset is active when reset_n is low, and inactive when reset_n is high. reset_n must be high during normal operation and takes some values during initialization sequence. |
| CS_n                | Chip Select: all commands are masked when CS_n is registered high.<br>For one cycle commands (CS_n=0), for two cycle commands (CS_n=0<br>for first cycle, CS_n=1 for second cycle).                       |
| CA[13:0]            | Command/Address Inputs: CA signals provide the command and address inputs according to the command truth table in JEDEC79-5 standard section 4.1 Table 241.                                               |
| DQ[15:0]            | Data Input/Output: Bi-directional data bus                                                                                                                                                                |
| DQS_t,DQS_c         | Data Strobe: output with read data, input with write data. Edge-aligned with read data, centered in write data. DDR5 SDRAM supports differential data strobe only and does not support single-ended.      |
| Ctrl_DataOut[255:0] | Data will be delivered from memory to CPU.                                                                                                                                                                |
| Ctrl_Busy           | Control signal is sent to CPU to tell it to stop sending reading or<br>writing requests as FIFO of commands became full or when there is<br>initialization or self refresh for memory.                    |

## ♦ Assumptions & Notes

1. We assume that Physical address that comes from CPU (Ctrl\_ADD) will be 31 bit and address mapping will be one to one mapping as shown in Figure 6:

|    | Row | Column | Bank | В | ank Group |
|----|-----|--------|------|---|-----------|
| 30 | 1   | 3      | 4    | 2 | 0         |

Figure 6: Address Mapping [5].

2. According to Native Interface data bus (Ctrl\_DataIn, Ctrl\_DataOut) is eight times the width of the SDRAM device data bus (DQ) but for simplicity we made data bus (Ctrl\_DataIn, Ctrl\_DataOut) is 16 times the width of the SDRAM device data bus (DQ) as default BL.

#### **2.4 OPERATION OF CONTROLLER**

To know blocks and detailed block diagram of our design, we could get this by defining operation of our design. We can summarize operation of memory controller in five points as follow [7]:

1. Memory controller is responsible for **queuing** requests from CPU like read and write requests and also responsible for scheduling these requests to choose which request will be executed.

2. It's responsible for **decoding** these requests into **memory commands** and issue these commands to memory keeping **timing constraints** between these commands according to period of clock of SDRAM.

3. In case of read request, it's responsible for getting data from memory to CPU and vice versa in write request.

4. As we talk about dynamic memory so it will need refresh every certain time, memory controller is responsible for issuing **self-refresh sequence** to memory.

5. Memory controller is also responsible for issuing **initialization sequence** to memory.

From red highlighted keywords we can know which blocks that we need in our design to achieve operation of DDR5 SDRAM Controller:

Queuing: Command\_Address\_FIFO, Write\_Data\_FIFO

**Decoding:** Command\_Decoder

Memory Commands: Command\_FSM

**Timing Constraints:** Counters

Self-Refresh Sequence: Self Refresh\_FSM

**Initialization Sequence:** Initialization\_FSM

So, block diagram of our design will be as shown in Figure 7 [8]:



Figure 7: Block Diagram of Top Module.

#### **2.5 DESIGN IN DETAIL**

#### 2.5.1. Command\_Decoder

#### 2.5.1.1. Block Diagram



Figure 8: Block Diagram of Command Decoder.

#### 2.5.1.2. List of Inputs and Outputs

Table 3: Inputs of Command Decoder

| Signal          | Description                                                                                                                                      |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Ctrl_Reset      | Control signal from CPU to controller to issue the initialization sequence to the SDRAM. It's active high reset                                  |
| CK_t, CK_c      | Differential clock of DDR5 SDRAM, all address and control input signals<br>are sampled on the crossing of the positive edge of CK_t and negative |
| Bank_Group[1:0] | edge of CK_c<br>Bank group address, it is Ctrl_ADD[1:0]                                                                                          |
| Ctrl_Read       | Read request (active high)                                                                                                                       |
| Ctrl_Write      | Write request (active high)                                                                                                                      |

| Ctrl_Burst          | When 1 defines alternate read/write burst mode (BC8 ) and when 0 defines default BL16 mode                                                                     |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ctrl_Auto           | When asserted high along with Ctrl_Read or Ctrl_Write, causes the command to be issued as read with auto-precharge and write with auto-precharge, respectively |
| CMD_Done            | When 1 defines that command has been executed                                                                                                                  |
| Reset_Done          | When 1 defines that initialization sequence has been executed                                                                                                  |
| SR_Done             | When 1 defines that self-refresh sequence has been executed                                                                                                    |
| Data_Transfer_Write | Input signal from command FSM, when 1 defines that we need to set<br>WR_Data_RD_En high to write data from WR_Data_FIFO to memory                              |
| tREFI               | Flag signal of self-refresh counter to issue the self-refresh sequence to memory                                                                               |
| CMD_FIFO_Empty      | Empty flag of Command_Address FIFO                                                                                                                             |

#### Table 4: Outputs of Command Decoder

| Signal          | Description                                                    |
|-----------------|----------------------------------------------------------------|
| CMD_FIFO_RD_En  | Active high read enable of Command_Address_FIFO                |
| CMD_FIFO_WR_En  | Active high write enable of Command_Address_FIFO               |
| WR_Data_RD_En   | Active high read enable of Write_Data_FIFO                     |
| WR_Data_WR_En   | Active high write enable of Write_Data_FIFO                    |
| CMD[2:0]        | Defines type of command (read/write) that will be executed     |
|                 | by Command_FSM.                                                |
| CMD_FSM_Enable  | Active high enable of Command_FSM                              |
| INIT_FSM_Enable | Active high enable of Initialization_FSM                       |
| SR_FSM_Enable   | Active high enable of Self Refresh_FSM                         |
| Same_Bank_Group | When 1 defines that bank group address of current command      |
| Same_bank_Group | is the same as address of previous command                     |
|                 | When 1 indicates that memory in initialization or self-refresh |
| Memory_Busy     | sequence. When 0 indicates that memory in normal operation     |
|                 | (reading or writing)                                           |

#### 2.5.1.3 Operation

Command Decoder is the brain of our design, we can say it's the controller of our controller so it will be responsible for four points as follow:

#### A. Decode Processor Commands:

Command Decoder decodes processor commands based on control signals from CPU (Ctrl\_Read, Ctrl\_Write, Ctrl\_Burst, Ctrl\_Auto) and sets signal CMD with code equivalent to the decoded command, the description of each processor command and it's equivalent code are shown in Table 5:

| Command                   | Description                                               | CMD |
|---------------------------|-----------------------------------------------------------|-----|
| Read                      | Read operation with default BL16 mode                     | 000 |
| Write                     | Write operation with default BL16 mode                    | 001 |
| Read_With_AutoPrecharge   | Read operation with autoprecharge with default BL16 mode  | 010 |
| Write_With_AutoPrecharge  | Write operation with autoprecharge with default BL16 mode | 011 |
| Read_Burst                | Read operation with BC8 mode                              | 100 |
| Write_Burst               | Write operation with BC8 mode                             | 101 |
| Read_Burst_AutoPrecharge  | Read operation with autoprecharge with BC8 mode           | 110 |
| Write_Burst_AutoPrecharge | Write operation with autoprecharge with BC8 mode          | 111 |

#### Table 5: Description of Processor Commands

The decoded command based on control signals from CPU is shown in Table 6:

#### Table 6: Decoding of Processor Commands

| Decoded Command           | Ctrl_Read | Ctrl_Write | Ctrl_Burst | Ctrl_Auto |
|---------------------------|-----------|------------|------------|-----------|
| Read                      | 1         | 0          | 0          | 0         |
| Write                     | 0         | 1          | 0          | 0         |
| Read_With_AutoPrecharge   | 1         | 0          | 0          | 1         |
| Write_With_AutoPrecharge  | 0         | 1          | 0          | 1         |
| Read_Burst                | 1         | 0          | 1          | 0         |
| Write_Burst               | 0         | 1          | 1          | 0         |
| Read_Burst_AutoPrecharge  | 1         | 0          | 1          | 1         |
| Write_Burst_AutoPrecharge | 0         | 1          | 1          | 1         |

#### ♦ Assumption & Notes:

As we saw that we have four control signals so we have 16 combinations of values, we showed only in Table 6 eight of them but the last eight combination will have Ctrl\_Read=1 and Ctrl\_Write=1 and this is an error from CPU and unintentional but our design deals with this error by decoding this case as read command as a default command but don't store this command in Command\_Address\_FIFO.

#### **B.** Detect Same Bank Group:

Bank\_Group signal represents bank group address; Command Decoder compares this address with address of previous command and set Same\_Bank\_Group signal high if they are equal. We need Same\_Bank\_Group signal in our design as the value of timing parameters between memory commands depends on if the two commands have the same bank group address or not.

#### C. Enable FSM:

As we made three separate FSMs (Command, Initialization, Self-Refresh), so we made three enable signals (CMD\_FSM\_Enable, INIT\_FSM\_Enable, SR\_FSM\_Enable) to choose only one FSM to work and disable the other two FSMs during working of the selected FSM. There is also signal called Memory\_Busy must be set high during working of INIT\_FSM or SR\_FSM. We can say that we have three operations Initialization, Self-Refresh and Normal Operation (reading and writing), so we should set priority for executing these operations. Priority of enabling them will be in this order: Initialization - Self Refresh - Normal. The description of each enable signal is shown in Table 7:

| Signal          | Description                                                                                                                                                                                                                                                                                                                                                            |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INIT_FSM_Enable | Command Decoder should set this signal high when comes from CPU<br>Ctrl_Reset signal then set it low to disable INIT_FSM after Reset_Done<br>becomes high noting that Reset_Done will be input from INIT_FSM that is<br>raised high when initialization sequence finishes. When INIT_FSM_Enable<br>becomes high, Memory_Busy signal is raised high                     |
| SR_FSM_Enable   | Command Decoder should set this signal high when comes from self-refresh<br>counter tREFI signal, then set it low to disable SR_FSM after SR_Done<br>becomes high noting that SR_Done will be input from SR_FSM that is<br>raised high when self-refresh sequence finishes. When SR_FSM_Enable<br>becomes high,Memory_Busy signal is raised high                       |
| CMD_FSM_Enable  | Command Decoder should set this signal high when reading enable of<br>Command_Address_FIFO becomes high then set it low to disable<br>CMD_FSM after Memory_Busy comes high or CMD_Done becomes high<br>noting that CMD_Done will be input from CMD_FSM that is raised high<br>when command finishes. When CMD_FSM_Enable becomes<br>high,Memory_Busy signal is set low |

Table 7: Description of Enable Signals of Finite State Machines

**D. Read &Write Enable Signals for FIFOs:** 

Command decoder here will be responsible for driving values of enable signals of FIFOs. The description of each enable signal is shown in Table 8:

| Table 8: Description of Enable Signals of FIFOs |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Signal                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| CMD_FIFO_RD_En                                  | Command Decoder will set this enable signal high when<br>Command_Address_FIFO is not empty and there isn't initialization or<br>self-refresh process running (i.e., Memory_Busy=0) and pervious<br>command has been executed. Command Decoder will set this signal low<br>in the next cycle of setting it high.                                                                                                                                                                                                                          |  |
| CMD_FIFO_WR_En                                  | Command Decoder will set this signal high when comes from CPU read or<br>write request, so Command Decoder will decode this request to command<br>and set this enable signal high to store this command in<br>Command_Address_FIFO and to handle error that we said before comes<br>read and write request in the same time, Command Decoder will ignore<br>this by not storing this command by disable this write enable signal in this<br>case. Command Decoder will also set this signal low in the next cycle of<br>setting it high. |  |
|                                                 | We defined signal called Data_Write_Transfer comes from<br>Command_FSM as output of WRITING_DATA state to indicate that we                                                                                                                                                                                                                                                                                                                                                                                                               |  |

need activate WR\_Data\_RD\_En to store this data in memory so Command Decoder will set read enable of Write\_Data\_FIFO high when this signal is

Command Decoder will act also as CMD FIFO WR En signal but this time, it will set this signal high when the request is write to store data that

comes with write request in Write\_Data\_FIFO and also will set it low in

raised high and set it low when this signal is lowered low.

6 515 0

#### **Assumption & Notes** ∻

WR\_Data\_RD\_En

WR Data WR En

Command Decoder set these enable signals low in the next cycle of setting it high to avoid unwanted read or write operation from FIFO, this thing isn't applied on WR Data RD En signal as we don't want to disable reading from Write Data FIFO in next cycle, we need read from it more than one cycle as memory takes data from controller with width of DQ bus(16 bit) and can't take 256 bit in one cycle. So, Write\_Data\_Transfer signal will be responsible for setting this enable signal low when transfer data from controller to memory finishes.

the next cycle of setting it high.

# 2.5.2 Command\_Address\_FIFO 2.5.2.1 Block Diagram $CMD_FIFO_Reset \longrightarrow CK_t \longrightarrow CK_t \longrightarrow CK_t \longrightarrow CMD_ADD_FIFO \longrightarrow CMD_FIFO_FULL \longrightarrow CMD_FIFO_FULL \longrightarrow CMD_FIFO_Empty$ $CMD_FIFO_RD_En \longrightarrow CMD_FIFO_WR_En \longrightarrow CMD_$

Figure 9: Block Diagram of Command\_Address\_FIFO.

## 2.5.2.2 List of Inputs & Outputs

Table 9: Inputs of Command\_Address\_FIFO.

| Signal         | Description                                                                                                                                                 |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD_FIFO_Reset | Active high reset signal for FIFO, it's raised high when initialization sequence finishes.                                                                  |
| CK_t,Ck_c      | Differential clock of DDR5 SDRAM, all address and control input signals are sampled on the crossing of the positive edge of CK_t and negative edge of CK_c. |
| CMD[2:0]       | Decoded Command comes from Command Decoder.                                                                                                                 |
| Ctrl_ADD[30:0] | Address that data will be read from memory or written in memory.                                                                                            |
| CMD_FIFO_RD_En | Read enable signal of FIFO comes from Command Decoder.                                                                                                      |
| CMD_FIFO_WR_En | write enable signal of FIFO comes from Command Decoder.                                                                                                     |

Table 10: Outputs of Command\_Address\_FIFO

| Signal         | Description                                                      |
|----------------|------------------------------------------------------------------|
| FIFO OUT[33:0] | Output of FIFO that contains information stored in FIFO (CMD and |
| FIF0 001[33.0] | Ctrl_ADD concatenated)                                           |
| CMD_FIFO_FULL  | Flag when 1 defines that FIFO is full.                           |
| CMD_FIFO_Empty | Flag when 1 defines that FIFO is empty.                          |

#### 2.5.2.3. Operation

Command decoder receives from CPU command every clock cycle but to execute the command by memory it needs more than one clock cycle as speed of CPU differs from speed of memory. Memory also does internal operations and features (i.e., self-refresh, Initialization, etc.), so memory can't always handle processor commands only. So, to avoid ignoring commands or drop of commands from CPU, we will store these commands and their related addresses from CPU in

storage then after we finish command, we will take the next from storage to execute it and so on. We followed a simple policy First Come First Serve (FIFO) in scheduling and selecting which command will be executed. There are other polices that can achieve high performance than this policy but they will be more complex in implementation.

#### ♦ Assumption & Notes

FIFO\_OUT [33:31] represents CMD and FIFO\_OUT [30:0] represents Ctrl\_ADD.



## 2.5.3 Write\_Data\_FIFO

Figure 10: Block Diagram of Write\_Data\_FIFO

#### 2.5.3.2 List of Inputs & Outputs

Table 11: Inputs of Write\_Data\_FIFO

| Signal                                                                                               | Description                                                                                                                                               |
|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| CK_t,CK_c                                                                                            | Differential clock of DDR5 SDRAM,all address and control input signals are sampled on the crossing of the positive edge of CK_t and negative edge of CK_c |
| Ctrl_DataIn[255:0]       Data comes from CPU that will be written in memory during writing operation |                                                                                                                                                           |
| WR_Data_RD_En Read enable signal of FIFO comes from Command Decoder                                  |                                                                                                                                                           |
| WR_Data_WR_En Write enable signal of FIFO comes from Command Decoder                                 |                                                                                                                                                           |

Table 12: Outputs of Write\_Data\_FIFO

|   | Signal              | Description                                                            |
|---|---------------------|------------------------------------------------------------------------|
| Ī | FIFO WR Data[255:0] | Output of FIFO that contains data stored in FIFO to store it in memory |

#### 2.5.3.3 Operation

As we discussed before why we need FIFO and answered this question that we need it to store information that comes from CPU to used it later ,in Command\_Address\_FIFO we store command and address.It's still data need to be stored when write request comes then we made Write\_Data\_FIFO and here comes question why we used two FIFOs instead of only one and we can answer this question that we need to read data from controller to store it in memory in time differs from time of reading command and address so we will need two read enables so we made better a seperate FIFO for data

#### 2.5.4 Calculation of Depth of FIFOs

FIFO depth calculation is a critical phase in the design which needs to consider the worst case in all aspects and to do some assumptions [6]:

#### ♦ Assumptions

- 1. Burst length (No. of data items to be transferred) = 120
- 2. Write frequency (Processor frequency) = 3.2 GHz
- 3. Reading frequency (Memory frequency) = 3.2 GHz
- 4. Command execution in 30 cycles (worst case)

#### ♦ Calculations:

- Time required to write one data =  $\frac{1}{3.2GHz}$  = 0.3125ns
- > Time required to read one data (execute command) =  $30*\frac{1}{3.2GHz} = 9.375$ ns
- > Time required to write all the data in the burst = 120\*0.3125 = 37.5 ms
- Number of data items can be read in a duration of  $37.5ns = \frac{37.5ns}{9.375ns} = 4$
- > The remaining no. of information to be stored in the FIFO = 120 4 = 116

Then, the **minimum depth of the FIFO in our case should be equal 116.** In our code for simplicity we used depth=16 but in practical we should use depth as we mentioned.

#### 2.5.5 Counters

2.5.5.1 Block Diagram



Figure 11: Block Diagram of Counters.

#### 2.5.5.2 Operation

There are timing parameters in our design, then we used this block that contains some counters to count these parameters. Each Counter has Enable to enable counting when we enter certain state and want to count some parameters, after we reached value of timing parameter that we count it, counter outputs a flag indicates that counting has finished and after finishing counting, reset input to counter is raised high to reset counter.

#### 2.5.5.3 List of Timing Parameters

Table 13: Initialization Timing Parameters [5]

| Timing Parameter                                                    | Symbol | Value             |
|---------------------------------------------------------------------|--------|-------------------|
| Minimum reset_n low time after completion<br>of voltage Ramp        | tINIT1 | 200 µs            |
| Minimum cs_n low time before reset_n high                           | tINIT2 | 10 ns             |
| Minimum cs_n low time after reset_n high                            | tINIT3 | 4 ms              |
| Minimum time for dram to register exit on cs_n with cmos            | tINIT4 | 2 μs              |
| Minimum cycles required after cs_n high                             | tINIT5 | 3 nCK             |
| Minimum time from exit reset to first valid configuration command   | tXPR   | 2 μs              |
| Minimum delay from MRR or MRW<br>command to any other valid command | tMRD   | max (14ns, 16nCK) |
| ZQ Calibration Time                                                 | tZQCAL | 1 µs              |
| ZQ Calibration Latch Time                                           | tZQLAT | max(30ns,8nCK)    |

| Timing Parameter                                       | Symbol | Value          |
|--------------------------------------------------------|--------|----------------|
| ACT to Precharge<br>command delay                      | tRAS   | 32 ns          |
| ACT to ACT Command delay to same bank group            | tRRD_L | Max(8nCK, 5ns) |
| ACT to ACT Command<br>delay to different bank<br>group | tRRD_S | 8nCK           |

Table 14: Activate Timing Parameters [5].

Table 15: Precharge Timing Parameters [5].

| Timing Parameter | Symbol | Value     |
|------------------|--------|-----------|
| Precharge delay  | tRP    | 13.750 ns |

#### Table 16: Reading Timing Parameters [5].

| Timing Parameter                          | Symbol         | Value             |
|-------------------------------------------|----------------|-------------------|
| Minimum Read to Read                      |                |                   |
| command delay for same                    | tCCD_L_slr     | Max(8nCK, 5ns)    |
| bank group                                |                |                   |
| Minimum Read to Read<br>command delay for | tCCD S slr     | 8 nCK             |
| different bank group                      | 100D_5_51      | 0 IICIX           |
| Minimum Read to Write                     |                |                   |
| command delay for same                    | tCCD_L_RTW_slr | 20 ns             |
| bank group                                |                |                   |
| Minimum Read to Write                     |                |                   |
| command delay for                         | tCCD_S_RTW_slr | 15 ns             |
| different bank group                      |                |                   |
| Internal Read command                     |                |                   |
| to Precharge command                      | tRTP           | Max(12nCK, 7.5ns) |
| delay                                     |                |                   |

Table 17: Writing Timing Parameters [5].

| Timing Parameter                                                    | Symbol        | Value            |
|---------------------------------------------------------------------|---------------|------------------|
| Minimum Write to Write<br>command delay for same<br>bank group      | tCCD_L_WR_slr | Max(32nCK, 20ns) |
| Minimum Write to Write<br>command delay for<br>different bank group | tCCD_S_WR_slr | 8 nCK            |

| Minimum Write to Read<br>command delay for same<br>bank group      | tCCD_L_WTR_slr | 20 ns |
|--------------------------------------------------------------------|----------------|-------|
| Minimum Write to Read<br>command delay for<br>different bank group | tCCD_S_WTR_slr | 15 ns |

Table 18: Self-Refresh Timing Parameters [5].

| Timing Parameter                                                  | Symbol      | Value  |
|-------------------------------------------------------------------|-------------|--------|
| Command pass disable delay                                        | tCPDED      | 5 ns   |
| Self-Refresh CS_n low<br>Pulse width                              | tCSL        | 10 ns  |
| Self-Refresh exit CS_n<br>high                                    | tCASRX      | 0      |
| Self-Refresh exit CS_n<br>High Pulse width                        | tCSH_SRExit | 13 ns  |
| Self-Refresh exit CS_n<br>Low Pulse width                         | tCSL_SRExit | 3 nCK  |
| Exit Self-Refresh to next<br>valid command NOT<br>requiring a DLL | tXS         | 2µs    |
| Time interval between<br>two selfrefresh<br>operations            | tREFI       | 3.9 µs |

#### ♦ Assumption &Notes

**1.** These values of timing parameters are listed in JEDEC79-5 standard in section 3.3.1 Table 11, Table 329, Table 20, Table 467, Table 520, Table 481 and Table 525.

2. Our counters count in unit of clock cycles, so we needed to convert these values of timing parameters to form of multiple of clock cycles by dividing value of timing parameter /clock period

**3.** Enable and reset signals comes from FSMs blocks.

4. Outputs of these counters will be mainly inputs to FSMs blocks.

5. As we discussed before that each counter for timing parameter has reset, enable and flag that indicated counting has finished. Naming that we use here for reset signal of timing parameter counter is named by name of timing parameter and "Reset" word attached to it(for

ex: tINIT1\_Reset) ,the same thing for enable signal but "En" word is attached to it(for ex:tINIT1\_En) and for flag has name as the name of timing parameter(for ex:tINIT1).

#### 2.5.6 Command\_FSM



Figure 12: Block Diagram of Command\_FSM

#### 2.5.6.2 List of Inputs and Outputs

Table 19: Inputs of Command\_FSM

| Signal                                                                          | Description                                                                                                                                                                                          |
|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CK_t, CK_c                                                                      | Differential clock of DDR5 SDRAM, all address and control input signals are sampled on the crossing of the positive edge of CK_t and negative edge of CK c.                                          |
| CK_double                                                                       | Clock that has double frequency of SDRAM clock, DQS signals will be<br>generated with positive edge of this clock, also data from memory will be<br>sampled also on the positive edge of this clock. |
| Ctrl_ADD[31:0] Address that data will be read from memory or written in memory. |                                                                                                                                                                                                      |
| <b>FIFO_WR_Data[15:0]</b> Output of write_data_FIFO.                            |                                                                                                                                                                                                      |
| CMD_FSM_Enable                                                                  | Enable signal of Command_FSM comes from Command Decoder.                                                                                                                                             |
| Same_Bank_Group Flag signal comes from Command Decoder.                         |                                                                                                                                                                                                      |
| CMD[2:0]         Decoded commend comes from Command Decoder.                    |                                                                                                                                                                                                      |
| Counter_Flags                                                                   | Activate parameters, Percharge parameters, Read Parameters-Write parameters.                                                                                                                         |

Table 20: Outputs of Command\_FSM

| Signal              | Description                                                                                                                                            |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ctrl_DataOut[255:0] | Data will be delivered from memory to CPU                                                                                                              |
| CA[13:0]            | Command/Address Inputs: CA signals provide the command and address<br>inputs according to the Command Truth Table in standard section 4.1<br>Table 241 |

| CS_n                                             | Chip Select: all commands are masked when cs_n is registered high. for<br>one cycle commands (cs_n=0), for two cycle commands (cs_n=0 for first<br>cycle,cs_n=1 for second cycle).                   |  |  |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| CMD_Done                                         | When 1 defines that command has been executed                                                                                                                                                        |  |  |
| Data_Transfer_Write                              | When 1 defines that we need to set WR_Data_RD_En high to write data from WR_Data_FIFO to memory.                                                                                                     |  |  |
| DQ[15:0]                                         | Data Input/Output: Bi-directional data bus.                                                                                                                                                          |  |  |
| DQS_t,DQS_c                                      | Data Strobe: output with read data, input with write data. Edge-aligned with read data, centered in write data. DDR5 SDRAM supports differential data strobe only and does not support single-ended. |  |  |
| Counter_Enable_Signals,<br>Counter_Reset_Signals | Activate parameters -Percharge Parameters-Read Parameters-Write parameters.                                                                                                                          |  |  |

## 2.5.6.3 Operation

This block will be responsible for implementing finite state machine that controls normal operation of memory (reading and writing), the simplified state diagram that describes reading and writing operation is shown in JEDEC79-5 standard in section 3.1 and Figure 13 shows this simplified state diagram.



Figure 13: Simplified State Diagram, JEDEC Reference [5].

With help of this simplified state diagram and timing diagrams in JEDEC79-5 standard section 4.7 and section 4.8 that describes reading and writing operation and the pattern of preamble and postamble of these operations and these timing diagrams are shown in Figure 14 and Figure 15. So, we could figure out the detailed state diagram for the finite state machine that controls normal operation as will be illustrated later.





Figure 15: Timing Diagram for Write Burst Operation (BL16), JEDEC Reference [5].

Before we talk about this state diagram, there is an important thing we should handle it in this FSM and it is back-to-back operations (i.e., read after read, read after write, write after write, write after read). In back-to-back operations we have three scenarios, the description of each scenario is shown in Table 21:

| Scenario | Description                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | It means that operation is done on row in bank<br>has not been activated before so in this scenario<br>we will need to activate this row in this bank |

| Bank is activated and same row      | It means that operation is done on the same row<br>in bank as the previous operation so we will<br>proceed to execute operation and no need for<br>precharge operation                                                                                                                                 |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bank is activated and different row | It means that operation is done on the same bank<br>as the previous operation but on different row so<br>here we will need to execute precharge operation<br>for row of previous operation then activate row of<br>the current operation then proceed to execute the<br>operation on the activated row |

To handle back to back operations ,we used array as storage to store activated rows in banks, the length of the array is 16 as we have 4 bank groups each has 4 banks so we have 16 banks ,the entry for this array will bank group address and group address concatenated(4 bits) and the content of each location in array will be row address and statues bit for this row to indicate row is activated or not (if 1 active and if 0 not active) so width of each location will be 19 bit (18 bits for row address and 1 bit for statues bit).the shape of array will be as shown in Table 22:

| Entry(Bank Group,Bank)(4 bits) | Row Address(18 bits)  | Status bit |
|--------------------------------|-----------------------|------------|
|                                |                       |            |
| 0000                           | XXXXXXXXXXXXXXXXXXXXX | 1          |
| 0001                           | XXXXXXXXXXXXXXXXXXXXX | 0          |
| 0010                           | XXXXXXXXXXXXXXXXXXXXX | 1          |
| 0011                           | XXXXXXXXXXXXXXXXXXXXX | 0          |
| 0100                           | XXXXXXXXXXXXXXXXXXXXX | 1          |
| 0101                           | XXXXXXXXXXXXXXXXXXXXX | 0          |
| 0110                           | XXXXXXXXXXXXXXXXXXXXX | 1          |
| 0111                           | XXXXXXXXXXXXXXXXXXXXX | 0          |
| 1000                           | XXXXXXXXXXXXXXXXXXXXX | 1          |
| •                              | XXXXXXXXXXXXXXXXXXXXX | 1          |
| •                              |                       |            |
| •                              |                       |            |

#### Table 22:Storage of Activate Rows

When row is activated, it is stored in array and its status bit is set 1 and when the row is precharged its statues bit is set 0.

Here we can show detailed state diagram for normal operations as shown in Figure 12:



Figure 16: Command\_FSM

#### The description of each state is illustrated in Table 23:

| State      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE       | In this state, CMD_FSM_Enable signal is checked if it's asserted high or not, if it's asserted high normal operation is started by going to <b>WAIT_ACT</b> state                                                                                                                                                                                                                                                                                                                                 |
| WAIT_ACT   | In this state, timing constraints are checked between<br>consecutive active commands and the timing constraints that<br>are checked will differ according the two consecutive<br>operations are in same bank group or not and we can detect this<br>through same_bank_group signal. If they are in same bank<br>group tRRD_L is checked and if they are not tRRD_S is<br>checked. If timing constraints are satisfied, normal operation<br>will be continued by going to <b>ACT_CYCLE1</b> state. |
| ACT_CYCLE1 | As active command from commands that are executed in two<br>cycles, each cycle different information is sent to memory so<br>we send information of active command in two states<br>ACT_CYCLE1 and ACT_CYCLE2 so this state is followed<br>with ACT_CYCLE2 state without checking any conditions.                                                                                                                                                                                                 |
| ACT_CYCLE2 | In this state, information of active command in the second cycle<br>is sent to memory, then it's followed by <b>BANK_ACTIVE</b> state<br>without checking any conditions                                                                                                                                                                                                                                                                                                                          |

| BANK_ACTIVE       | In this state, three different scenarios of back to back operations<br>are checked, checking if bank is not active so go to<br><b>WAIT_ACT</b> state to activate it or if bank is active then<br>checking if the row of current operation is the same as previous<br>or not. If they are the same, checking if the current operation is<br>read or write if read go to <b>WAIT_READ</b> state and if write go<br>to <b>WAIT_WRITE</b> state. If they are different, go to<br><b>WAIT_tRAS</b> state to precharge the previous row then activates<br>the current row.                                                                                                                                                                                                                                                                                                |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT_tRAS         | Before applying precharge operation, timing between active<br>command and precharge command should be checked so in this<br>state tRAS is checked and if it's satisfied, go to<br><b>PRECHARAGE</b> state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PRECHARGE         | In this state, information of precharge command is sent to<br>memory and it's one cycle command so it needs only one state<br>then go to <b>WAIT_tRP</b> state without checking any conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WAIT_tRP          | Precharge operation needs time to be executed by memory so in<br>this state this time(tRP) is checked before executing other<br>operations and if this time is satisfied, go to <b>IDLE</b> state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| WAIT_READ         | In this state, timing constraints of reading command are<br>checked. There are two timing constraints depending on if the<br>previous command was read or write. So, in this state first<br>checking if previous command was read or write. If it's read<br>timing related to read-to-read delay is checked and also here<br>timing parameter that is checked will differ if they are in same<br>bank group or not, if they are same tCCD_L_slr is checked and<br>if they are not tCCD_S_slr is checked. If it's write timing<br>related to write to read delay is checked and also here timing<br>parameter that is checked will differ if they are in same bank<br>group or not, if they are same tCCD_L_WTR_slr is checked<br>and if they are not tCCD_S_WTR_slr is checked. If these<br>timing constraints are satisfied, go to <b>READING_CYCLE1</b><br>state. |
| READING_CYCLE1    | As read command from commands that are executed in two cycles, each cycle different information is sent to memory so information of read command are sent in two states<br>READING_CYCLE1 and READING_CYCLE2 so this state is followed with <b>READING_CYCLE2</b> state without checking any conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| READING_CYCLE2    | In this state, information of read command in the second cycle<br>is sent to memory, then go to <b>WAIT_READ_LATENCY</b> state<br>without checking any conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| WAIT_READ_LATENCY | In this state, Read Latency (RL-2 clock cycles for preamble) is<br>checked as shown in Figure 10 and if it's satisfied, go to<br><b>READING_DATA</b> state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| READING_DATA       | In this state, reading operation are actually executed and this as<br>shown in Figure 10, this done by receiving preamble from<br>memory then read data with burst length that CPU has chosen it<br>,then after receiving data postamble is sent by memory to<br>controller, after receiving postamble we can say that reading<br>operation is done. This state in the beginning is implemented in<br>un synthesizable manner but as we will discuss in detail in this<br>chapter section 6 that we implemented it in synthesizable<br>manner by calling Read FSM that will perform reading<br>operation through states and after finishing it sends signal<br>called Read_Done, this signal is checked in<br>WAIT_READ_DONE state so this state is followed by<br>WAIT_READ_Done state.                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT_READ_DONE     | In this state, Read_Done signal is checked. If it's asserted high, go to <b>READ_DONE</b> state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| READ_DONE          | In this state, it's checked if the command was with<br>autoprecharge or not. If it's with auto precharge ,go to<br><b>WAIT_tRAS</b> state to apply precharge operation and if it's not<br>go to <b>BANK_ACTIVE</b> state waiting another operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| WAIT_WRITE         | In this state, timing constraints of writing command are<br>checked. There are two timing constraints depending on if the<br>previous command was read or write. So, in this state first<br>checking if pervious command was read or write. If it's write<br>timing related to write to write delay is checked and also here<br>timing parameter that is checked will differ if they are in same<br>bank group or not, if they are same tCCD_L_WR_slr is<br>checked and if they are not tCCD_S_WR_slr is checked. If it's<br>read timing related to read to write delay is checked and also<br>here timing parameter that is checked will differ if they are in<br>same bank group or not, if they are same tCCD_L_RTW_slr is<br>checked and if they are not tCCD_S_RTW_slr is checked.If<br>these timing constraints are satisfied, go to<br><b>WRITING_CYCLE1</b> state. |
| WRITING_CYCLE1     | As write command from commands that are executed in two<br>cycles, each cycle different information is sent to memory so<br>information of write command is sent in two states<br>WRITING_CYCLE1 and WRITING_CYCLE2 this state is<br>followed by <b>WRITING_CYCLE2</b> state without checking any<br>conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| WRITING_CYCLE2     | In this state, information of write command in the second cycle<br>is sent to memory, then go to <b>WAIT_WRITE_LATENCY</b><br>state without checking any conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| WAIT_WRITE_LATENCY | In this state, Write Latency (WL-2 clock cycles for preamble) is<br>checked as shown in Figure 11 and if it's satisfied, go to<br>WRITING_DATA state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| WRITING_DATA    | In this state, writing operation are actually executed and this as<br>shown in Figure 11, this done by sending preamble to memory<br>then write data with burst length that CPU has chosen it, then<br>after writing data postamble is sent by controller to memory,<br>after sending postamble we can say that writing operation is<br>done. This state in the beginning is implemented in un<br>synthesizable manner but as we will discuss in detail in this<br>chapter 2 section 6 that we implemented it in synthesizable<br>manner by calling Write FSM that will perform writing<br>operation through states and after finishing it sends signal<br>called Write_Done, this signal is checked in<br>WAIT_WRITE_DONE state this state is followed by<br>WAIT_WRITE_DONE state. |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT_WRITE_DONE | In this state, write_Done signal is checked. If it's asserted high, go to <b>Write_DONE</b> state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| WRITE_DONE      | In this state, it's checked if the command was with<br>autoprecharge or not. If it's with auto precharge, go to<br><b>WAIT_tRAS</b> state to apply precharge operation and if it's not<br>go to <b>BANK_ACTIVE</b> state waiting another operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

The outputs of each state are illustrated in Table 24:

| Table 24: Outputs of each state in Command_FSN | И |
|------------------------------------------------|---|
|------------------------------------------------|---|

| State      | Outputs                                                                                                                                                                                                                               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE       | $  tRP\_Reset = 1 $ $  tRP\_En = 1 $                                                                                                                                                                                                  |
| WAIT_ACT   | No Outputs                                                                                                                                                                                                                            |
| ACT_CYCLE1 | <ul> <li>CS_n = 0</li> <li>CA = ACT_Cycle1</li> <li>If they are same bank group</li> <li>tRRD_L_Reset = 1</li> <li>tRRD_L_En = 0</li> <li>If they are not same bank group</li> <li>tRRD_S_Reset = 1</li> <li>tRRD_S_En = 0</li> </ul> |

| ACT_CYCLE2     | Store this row in array of activated rows and set its status bit high.      |
|----------------|-----------------------------------------------------------------------------|
|                | $\succ$ CS_n = 1                                                            |
|                | $\blacktriangleright$ CA = ACT_Cycle2                                       |
|                | $\rightarrow$ tRAS_En =1                                                    |
|                | If they are same bank group                                                 |
|                | $\blacktriangleright$ tRRD_L_En = 1                                         |
|                | If they are not same bank group                                             |
|                | $\blacktriangleright$ tRRD_S_En = 1                                         |
| BANK_ACTIVE    | No Outputs                                                                  |
| WAIT_tRAS      | No Outputs                                                                  |
|                | Remove this row from array of activated rows by setting its status bit low. |
|                | $\succ$ CS_n=0                                                              |
| PRECHARGE      | ➢ CA=PREpb                                                                  |
|                | $\succ$ tRAS_Reset = 1                                                      |
|                | $\succ$ tRAS_En = 0                                                         |
|                | $\succ$ tRP_En = 1                                                          |
| WAIT_tRP       | No Outputs                                                                  |
| WAIT_READ      | No Outputs                                                                  |
|                | $\succ$ CS_n=0                                                              |
|                | CA=RD_Cycle1                                                                |
| READING_CYCLE1 | $\succ tCCD_L_WTR\_slr\_Reset=1$                                            |
|                | $\succ tCCD_S_WTR\_slr\_Reset = 1$                                          |
|                | $\succ tCCD\_L\_slr\_Reset = 1$                                             |
|                | $\succ tCCD_S\_slr\_Reset = 1$                                              |
|                | $\succ tCCD\_L\_WTR\_slr\_En = 0$                                           |

|                   | $\rightarrow$ tCCD_S_WTR_slr_En = 0               |
|-------------------|---------------------------------------------------|
|                   | $\rightarrow$ tCCD_L_slr_En = 0                   |
|                   | $\succ \text{ tCCD}_S\_\text{slr}\_\text{En} = 0$ |
|                   | ➤ CS_n=1                                          |
|                   | CA=RD_Cycle2                                      |
|                   | $ ightarrow RL_En = 1$                            |
|                   | If they are same bank group                       |
| READING_CYCLE2    | $\blacktriangleright$ tCCD_L_slr_En = 1           |
|                   | $\rightarrow$ tCCD_L_RTW_slr_En = 1               |
|                   | If they are not same bank group                   |
|                   | $\blacktriangleright$ tCCD_S_slr_En = 1           |
|                   | $\rightarrow$ tCCD_S_RTW_slr_En = 1               |
| WAIT_READ_LATENCY | No Outputs                                        |
|                   | <ul> <li>Set Pervious command as read</li> </ul>  |
|                   | $\succ$ RL_Reset = 1                              |
| READING_DATA      | $\succ$ RL_En = 0                                 |
|                   | Enable Read FSM                                   |
| WAIT_READ_DONE    | No Outputs                                        |
|                   | ➤ CMD_Done=1                                      |
| READ_DONE         | Disable Read FSM                                  |
| WAIT_WRITE        | No Outputs                                        |
|                   | $\succ$ CS_n=0                                    |
|                   | ➢ CA=WR_Cycle1                                    |
| WRITING_CYCLE1    | $\succ$ tCCD_L_RTW_slr_Reset = 1                  |
|                   |                                                   |
|                   | <pre>tCCD_S_RTW_slr_Reset =1</pre>                |

|                    | $\rightarrow$ tCCD_S_WR_slr_Reset = 1           |
|--------------------|-------------------------------------------------|
|                    | $\succ$ tCCD_L_RTW_slr_En = 0                   |
|                    | $\blacktriangleright$ tCCD_S_RTW_slr_En = 0     |
|                    | $\rightarrow$ tCCD_L_WR_slr_En =0               |
|                    | $\succ$ tCCD_S_WR_slr_En = 0                    |
|                    | $\succ$ CS_n=1                                  |
|                    | ➢ CA=WR_Cycle2                                  |
|                    | $\blacktriangleright$ WL_En = 1                 |
|                    | If they are same bank group                     |
| WRITING_CYCLE2     | $\blacktriangleright$ tCCD_L_WR_slr_En = 1      |
|                    | $\rightarrow$ tCCD_L_WTR_slr_En =1              |
|                    | If they are not same bank group                 |
|                    | $\blacktriangleright$ tCCD_S_WR_slr_En =1       |
|                    | $\rightarrow$ tCCD_S_WTR_slr_En =1              |
| WAIT_WRITE_LATENCY | No Outputs                                      |
|                    | <ul><li>Set Pervious command as write</li></ul> |
| WRITING_DATA       | $\blacktriangleright$ WL_Reset = 1              |
|                    | $\blacktriangleright$ WL_En = 0                 |
|                    | ➢ Enable Write FSM                              |
|                    | Data_Transfer_Write = 1                         |
| WAIT_WRITE_DONE    | <pre>Data_Transfer_Write = 0</pre>              |
|                    | CMD_Done=1                                      |
| WRITE_DONE         | <ul><li>Disable Write FSM</li></ul>             |

#### ♦ Assumption & Notes

1. We reset counters in the next state of finishing of counting.

2. In Table 24 of outputs, CA pins are written in form of basic commands that are in Command Truth Table in JEDEC79-5 Standard section 4.1 Table 241.

3. As we know that there are commands with auto precharge, the difference between it and without auto precharge in pattern of CA pins in second cycle of command and there is a bit called AP, we set it low in case of autoprecharge and high in case of without autoprecharge.

4. In any state, if timing constraint isn't satisfied, we will wait in this state until it's satisfied.

5. In Figure 10, RL=CL and in Figure 11 WL=CWL.



#### 2.5.7 Initialization\_FSM

Figure 17: Block Diagram of Initialization\_FSM

## 2.5.7.2 List of Inputs and Outputs

#### Table 25: Inputs of Initialization\_FSM

| Signal          | Description                                              |
|-----------------|----------------------------------------------------------|
|                 | Differential clock of DDR5 SDRAM, all address and        |
| CK_t, CK_c      | control input signals are sampled on the crossing of the |
|                 | positive edge of CK_t and negative edge of CK_c          |
| INIT_FSM_Enable | Enable signal of Initialization_FSM comes from           |
|                 | Command Decoder                                          |
| Counter_Flags   | Initialization parameters                                |

| Signal                                               | Description                                                                                                                                                                   |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset_n                                              | Active low asynchronous reset: reset is active when reset_n<br>is low, and inactive when reset_n is high. reset_n must be<br>high during normal operation.                    |
| CA[13:0]                                             | Command/Address Inputs: CA signals provide the<br>command and address inputs according to the Command<br>Truth Table in JEDEC standard section 4.1 Table 241                  |
| CS_n                                                 | Chip Select: All commands are masked when CS_n is registered high. For one cycle commands (CS_n=0), for two cycle commands (CS_n=0 for first cycle, CS_n=1 for second cycle). |
| Reset_Done                                           | When 1 defines that initialization sequence has been executed.                                                                                                                |
| Counter_Enable_Signals<br>,<br>Counter_Reset_Signals | Initialization parameters.                                                                                                                                                    |

Table 26: Outputs of Initialization\_FSM

#### 2.5.7.3 Operation

This block will be responsible for implementing finite state machine that controls initialization sequence for memory, we construct this finite state machine shown in Figure 15 based on timing diagram that describes initialization sequence in JEDEC79-5 standard section 3.3.1 and it's shown in Figure 18



*Figure 18: Reset and Initialization Sequence at Power-on Ramping, JEDEC Reference* [5].



Figure 19: Initialization \_FSM

| State      | Description                                                                      |
|------------|----------------------------------------------------------------------------------|
| IDLE       | In this state, INIT_FSM_Enable is checked if it's asserted high or not, if it's  |
|            | asserted high, go to State 1.                                                    |
| State 1    | In this state, Some outputs like CS_n, CA and Reset_n takes some values for      |
| Blutt I    | time interval tINIT1 as shown in Figure 14, then go to State 2.                  |
| State 2    | In this state, Some outputs like CS_n, CA and Reset_n takes some values for      |
| Blate 2    | time interval tINIT1-tINIT2 as shown in Figure 14, then go to State 3.           |
| State 3    | In this state, some outputs like CS_n, CA and Reset_n takes some values for time |
| State 3    | interval tINIT3 as shown in Figure 14, then go to State 4                        |
| State 4    | In this state, some outputs like CS_n, CA and Reset_n takes some values for time |
| State 4    | interval tINIT4 as shown in Figure 14, then go to <b>NOP</b> state               |
|            | In this state, we wait for three clock cycles (NOP_Count) and also Some outputs  |
| NOP        | like CS_n ,CA and Reset_n takes some values for this interval as shown in        |
|            | Figure 14 then go to Wait_MRW state                                              |
|            | In this state, some outputs like CS_n, CA and Reset_n takes some values for time |
| Wait_MRW   | interval tMRW (tXPR+tMRD+tZQCAL+tZQLAT) as shown in Figure 14, then              |
|            | go to MRW_Cycle1 state                                                           |
|            | As Mode_Register_Write command from commands that are executed in two            |
|            | cycles, each cycle different information are sent to memory information of       |
| MRW_Cycle1 | Mode_Register_Write command is sent in two states MRW_Cycle1 and                 |
|            | MRW_Cycle2 this state is followed by MRW_Cycle2 state without checking           |
|            | any conditions                                                                   |

| MRW_Cycle2 | In this state, information of Mode_Register_Write command in the second cycle<br>is sent to memory, then go to <b>IDLE</b> state without checking any conditions<br>waiting another initialization request. In this state self-refresh timer is also<br>enabled |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### Table 28: Outputs of each state in Initialization\_FSM

| State   | Outputs                           |
|---------|-----------------------------------|
|         | Reset_Done=0                      |
|         | > tINIT1_Reset=0                  |
|         | ➤ tINIT2_Reset=0                  |
| IDLE    | ➤ tINIT3_Reset=0                  |
|         | ➤ tINIT4_Reset=0                  |
|         | $\succ$ tMRW_Reset = 0            |
|         | NOP_Count_Reset=0                 |
|         | > tINIT1_En=1                     |
|         | ➢ Reset_n=0                       |
| State 1 | CS_n=don't care                   |
|         | <ul> <li>CA=don't care</li> </ul> |
|         | ➤ tINIT2_En=1                     |
|         | <pre>tINIT1_Reset=1</pre>         |
|         | ➤ tINIT1_En=0                     |
| State 2 | ➢ Reset_n=0                       |
|         | $\succ$ CS_n=0                    |
|         | ➢ CA=don't care                   |
|         | > tINIT3_En=1                     |
| State 3 | ➤ tINIT2_Reset=1                  |

|            | ➤ tINIT2_En=0                   |
|------------|---------------------------------|
|            | Reset_n=1                       |
|            | $\succ$ CS_n=0                  |
|            | <ul><li>CA=don't care</li></ul> |
|            | tINIT3_Reset=1                  |
|            | ➤ tINIT4_En=1                   |
|            | ➢ tINIT3_En=0                   |
| State 4    | Reset_n=1                       |
|            | $\succ$ CS_n=1                  |
|            | > CA=All Ones                   |
|            | tINIT4_Reset=1                  |
|            | > tINIT4_En=0                   |
| NOP        | > NOP_Count_En=1                |
|            | $\succ$ CS_n=0                  |
|            | > CA=NOP                        |
|            | NOP_Count_Reset=1               |
| Wait_MRW   | > NOP_Count_En=0                |
|            | $\succ$ tMRW_En=1               |
|            | > tMRW_Reset=1                  |
|            | > tMRW_En=0                     |
| MRW_Cycle1 | $\succ$ CS_n=0                  |
|            | CA=MRW_Cycle1                   |

|            | $\succ$ CS_n=1           |
|------------|--------------------------|
| MDW Cyclo? | ➢ CA=MRW_Cycle2          |
| MRW_Cycle2 | Reset_Done=1,tREFI_En =1 |
|            |                          |

## 2.5.8 Self Refresh\_FSM

2.5.8.1 Block Diagram





#### 2.5.8.2 List of Inputs and Outputs

#### Table 29: Inputs of Self Refresh\_FSM

| Signal        | Description                                                    |
|---------------|----------------------------------------------------------------|
|               | Differential clock of DDR5 SDRAM, all address and control      |
| CK_t, CK_c    | input signals are sampled on the crossing of the positive edge |
|               | of CK_t and negative edge of CK_c                              |
| SR_FSM_Enable | Enable signal of Self Refresh_FSM comes from Command           |
|               | Decoder                                                        |
| Counter_Flags | Self-Refresh parameters                                        |

#### Table 30: Outputs of Self Refresh\_FSM

| Signal | Description                                                                                             |
|--------|---------------------------------------------------------------------------------------------------------|
| CS_n   | Chip Select: All commands are masked when CS_n is registered high. For one cycle commands (CS_n=0), for |

|                                                  | two cycle commands(CS_n=0 for first cycle,CS_n=1 for second cycle)                                                                                           |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CA[13:0]                                         | Command/Address Inputs: CA signals provide the<br>command and address inputs according to the Command<br>Truth Table in JEDEC standard section 4.1 Table 241 |
| SR_Done                                          | When 1 defines that self-refresh sequence has been executed                                                                                                  |
| Counter_Enable_Signals,<br>Counter_Reset_Signals | Self-Refresh parameters                                                                                                                                      |

#### 2.5.8.3 Operation

This block will be responsible for implementing finite state machine that controls self-refresh sequence for memory, we construct this finite state machine shown in Figure 18 based on timing diagram that describes self-refresh sequence in JEDEC79-5 standard section 4.9 and it's shown in Figure 21



Figure 21: Self-Refresh Entry/Exit Timing with One-Cycle Exit Command, JEDEC Reference [5].



Figure 22: Self-Refresh \_FSM

| Table 31: Description | of each state in | Self Refresh_FSM |
|-----------------------|------------------|------------------|
|-----------------------|------------------|------------------|

| State            | Description                                                                                                                                                                                              |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE             | In this state, SR_FSM_Enable is checked if it is asserted high or not, if it's asserted high, go to <b>SRE</b> state.                                                                                    |
| SRE              | It's self-refresh entry command state, in this state self-<br>refresh entry command (SRE) is sent to memory then go to<br><b>DES_CMDS</b> state without checking any conditions.                         |
| DES_CMDS         | In this state amount of number of Deselect Commands are<br>sent to memory for time interval tCPDED as shown in<br>Figure 17 then go to <b>SR_Mode</b> state.                                             |
| SR_Mode          | In this state, self-refresh operation is entered. Some outputs like CS_n and CA takes some values for time interval tCSL as shown in Figure 17.If tCSL is satisfied then go to <b>WAIT_tCASRX</b> state. |
| WAIT_tCASRX      | In this state, some outputs like CS_n and CA takes some values for time interval tCASRX as shown in Figure 17. If tCASRX is satisfied then go to WAIT_tCSH_SRExit state                                  |
| WAIT_tCSH_SRExit | In this state, Some outputs like CS_n and CA takes some values for time interval tCSH_SRExit as shown in Figure 17. If tCSH_SRExit is satisfied then go to <b>NOP0</b> state                             |

| NOP0              | In this state, information of NOP command is sent to memory then it's followed by <b>NOP1</b> state without checking any conditions.                             |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NOP1              | In this state, information of NOP command is sent to<br>memory then it's followed by NOP2 state without checking<br>any conditions.                              |
| NOP2              | In this state, information of NOP command is sent to memory then it's followed by <b>CHECK_tCSL_SRExit</b> state without checking any conditions.                |
| CHECK_tCSL_SRExit | In this state, self-refresh operation is excited by checking tCSL_SRExit as shown in Figure 17. If it's satisfied then go to <b>WAIT_tXS</b> state               |
| WAIT_tXS          | In this state, tCASRX is checked. If it is satisfied then go to <b>IDLE</b> state waiting timer of self-refresh expires to start another self-refresh operation. |

Table 32: Outputs of each state in Self Refresh\_FSM.

| State    | Outputs                                                                                                            |
|----------|--------------------------------------------------------------------------------------------------------------------|
| IDLE     | <ul> <li>tXS_Reset = 1</li> <li>tXS_En = 0</li> <li>SR_Done = 0</li> </ul>                                         |
| SRE      | <ul> <li>tREFI_Reset = 1</li> <li>tREFI_En = 0</li> <li>CS_n = 0</li> <li>CA = SRE</li> <li>tCPDED_En=1</li> </ul> |
| DES_CMDS | $ CS_n = 1 $ $ CA = DES $                                                                                          |
| SR_Mode  | <ul> <li>tCPDED_Reset=1</li> <li>tCPDED_En = 0</li> </ul>                                                          |

|                   | $\succ$ tCSL_En=0                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT_tCASRX       | <ul> <li>tCSL_Reset=1</li> <li>tCSL_En = 0</li> <li>tCASRX_En=1</li> <li>CA = All Ones</li> </ul>                                                       |
| WAIT_tCSH_SRExit  | <ul> <li>tCASRX_Reset=1</li> <li>tCASRX_En = 0</li> <li>tCSH_SRExit_En=1</li> <li>CS_n = 1</li> </ul>                                                   |
| NOP0              | <ul> <li>tCSH_SRExit_Reset=1</li> <li>tCSH_SRExit_En = 0;</li> <li>tCSL_SRExit_En=1</li> <li>CS_n = 0</li> <li>CA = NOP</li> </ul>                      |
| NOP1              | <ul> <li>CS_n = 0</li> <li>CA = NOP</li> </ul>                                                                                                          |
| NOP2              | <ul> <li>CS_n = 0</li> <li>CA = NOP</li> </ul>                                                                                                          |
| CHECK_tCSL_SRExit | $\succ$ CS_n = 1                                                                                                                                        |
| WAIT_tXS          | <ul> <li>tCSL_SRExit_Reset=1</li> <li>tCSL_SRExit_En = 0</li> <li>tXS_En = 1</li> <li>If tXS is satisfied</li> <li>SR_Done = 1, tREFI_En = 1</li> </ul> |

#### ♦ Assumption & Notes

As shown in Figure 17, that there is overlapping between tCSL and tCASRX. The higher priority for tCSL, it should be satisfied first then tCASRX is checked, if it's satisfied CS\_n is raised high.to avoid making output depends on condition of tCASRX, we made two states SR\_Mode to check that tCSL is satisfied then go to WAIT\_tCASRX to check tCASRX if it's satisfied or not.

#### **2.6 DESIGN ENHANCEMENT**

There is a big difference between making the design work properly in its functionality only (the design is bit accurate and cycle accurate only) and making it fully synthesizable to model it with actual gates without any problems or violations.

There were many changes in the design to overcome synthesis problems and this is a brief of those changes:

Problem\_1:to generate CK\_t, CK\_c and CK\_double, we used block called clock generator to generate them but the fact that this isn't a synthesizable block as shown in Figure 23:

> 9 [Synth 8-6896] loop limit (65536) exceeded inside initial block, initial block items will be ignored [Clock\_Generator.sv:17] (2 more like this)

> 9 [Synth 8-6014] Unused sequential element Prev\_Reset\_reg was removed. [Command\_Decoder.sv:86] (1 more like this)

#### Figure 23: Clock Generator isn't synthesizable

- ✓ Solution\_1: remove Clock generator block and make these clocks as input and generate them by stimulus from environment.
- Problem\_2: we were relying on the cross of the differential clock to sample any information but this couldn't be understood by synthesizer and causes problem of ambiguous clock triggering as shown in Figure 24:

✓ ➡ Synthesis (4 errors)

- [Synth 8-91] ambiguous clock in event control [CMD\_FSM.sv:149]
- Synth 8-6156] failed synthesizing module 'CMD\_FSM' [CMD\_FSM.sv:1] (1 more like this)
  - [Synth 8-6156] failed synthesizing module 'Controller\_top\_level' [Controller\_top\_level.sv:23]
  - 9 [Common 17-69] Command failed: Vivado Synthesis failed

#### Figure 24: Problem of ambiguous clock triggering

- ✓ Solution\_2: make it trigger with one clock only (not the cross of the differential clock), we got rid of one of the differential clock to get understood by the synthesizer and sample information with triggering edge of the other clock.
- Problem\_3: we were doing READING\_DATA and WRITING\_DATA states by tasks which contain event blocking statements that is got used only on simulation and that weren't synthesizable.

✓ Solution\_3: exchange non-synthesizable tasks with synthesizable states in FSMs, FSM for reading operation called RD\_FSM and FSM for writing operation called WR\_FSM and made these FSMs as separate modules which are instantiated in Command\_FSM block and are enabled in READING\_DATA and WRITING\_DATA states as we mentioned in Table 23. Let us discuss briefly these modules, their block diagrams as shown in Figure 21 and Figure 23 and state diagrams for these FSMs as shown in Figure 22 and Figure 24:

#### 2.6.1 Read\_FSM



Figure 25: Block Diagram of Read\_FSM

#### 2.6.1.2 List of Inputs and Outputs

#### Table 33: Inputs of Read\_FSM

| Signal               | Description                                                                                                                   |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------|
| CK double            | Clock that has double frequency of SDRAM clock ,DQS signals will be generated with positive edge of this clock,also data from |
|                      | memory will be sampled also on the positive edge of this clock                                                                |
| burst                | Flag signal when 1 defines burst length is 8 and when 0 defines                                                               |
|                      | burst length 16                                                                                                               |
| DQ[15:0]             | Data Input/Output: Bi-directional data bus                                                                                    |
| <b>RD_FSM_Enable</b> | Enable signal of Read FSM                                                                                                     |
| Reset_Done           | When 1 defines that initialization sequence has been executed                                                                 |

#### Table 34: Outputs of Read\_FSM

| Signal              | Description                                                |
|---------------------|------------------------------------------------------------|
| Ctrl_DataOut[255:0] | Data will be delivered from memory to CPU                  |
| Read_Done           | Flag signal when 1 defines that reading operation has done |

## 2.6.1.3 Operation



Figure 26: Read\_FSM

Table 35: Description of each state in Read\_FSM

| State     | Description                                                             |
|-----------|-------------------------------------------------------------------------|
| IDLE      | In this state, RD_FSM_Enable is checked, if it's asserted high then go  |
| IDLE      | to <b>PREAMBLE</b> state.                                               |
|           | We declared counter in RD_FSM block that counts two cycles from         |
|           | CK_double that represents interval of preamble and when this counter    |
| PREAMBLE  | finishes, it outputs signal called PRE_Ctr_Done.After this signal is    |
|           | raised high this means that preamble phase has finished so we can read  |
|           | date by going to <b>RD_DATA</b> state.                                  |
|           | In this state reading data is done by transfer data from memory to      |
| RD_DATA   | controller with burst length that defined by burst signal, and there is |
| KD_DATA   | internal signal when transfer is done it's raised high called           |
|           | Data_Ctr_Done then go to <b>POSTAMBLE</b> state.                        |
|           | We declared counter in RD_FSM block that counts cycle from              |
|           | CK_double that represents interval of postamble and when this counter   |
| POSTAMBLE | finishes, it outputs signal called POST_Ctr_Done.After this signal is   |
|           | raised high this means that postamble phase has finished so we can say  |
|           | that reading date has finished then go to <b>RD_DONE</b> state.         |

| <b>RD DONE</b> | In this state, Read_Done signal is asserted high to indicate that reading |
|----------------|---------------------------------------------------------------------------|
| KD_DONE        | has finished then go to <b>IDLE</b> state waiting another read operation. |

| State     | Outputs                              |
|-----------|--------------------------------------|
|           | $\succ \text{ Read}_\text{Done} = 0$ |
|           | > RD_Enable = 0                      |
| IDLE      | $\rightarrow$ PRE_Ctr_Reset_n = 0    |
|           | $  Data_Ctr_Reset_n = 0 $            |
|           | $\rightarrow$ POST_Ctr_Reset_n = 0   |
| PREAMBLE  | $\rightarrow$ PRE_Ctr_Reset_n = 1    |
|           | $  Data_Ctr_Reset_n = 1 $            |
| RD_DATA   | $\blacktriangleright$ RD_Enable = 1  |
|           | Ctrl_DataOut<=DQ                     |
|           | $\rightarrow$ POST_Ctr_Reset_n = 1   |
| POSTAMBLE | $\succ$ RD_Enable = 0                |
| RD_DONE   | Read_Done = 1                        |

#### Table 36: Outputs of each state in Read\_FSM

#### ♦ Assumption & Notes

1. RD\_Enable is internal signal that enables reading in RD\_DATE state.

2. PRE\_Ctr\_Reset\_n and POST\_Ctr\_Reset\_n are reset signals for preamble and postamble counters respectively.

3. Data\_Ctr\_Reset\_n is rest signal for counter that counts burst length.

# 2.6.2 Write\_FSM 2.6.2.1 Block Diagram $CK_t \longrightarrow 16$ $CK_double \longrightarrow DQ$ $burst \longrightarrow WR_FSM_Enable \longrightarrow DQS_t$ $Reset_Done \longrightarrow DQS_c$

Figure 27: Block Diagram of Write\_FSM

#### 2.6.2.2 List of Inputs and Outputs

Table 37: Inputs of Write\_FSM

| Signal              | Description                                                        |
|---------------------|--------------------------------------------------------------------|
| CK_t                | One of differential clock of SDRAM DDR5                            |
|                     | Clock that has double frequency of SDRAM clock ,DQS signals        |
| CK_double           | will be generated with positive edge of this clock, also data from |
|                     | memory will be sampled also on the positive edge of this clock     |
| burst               | Flag signal when 1 defines burst length is 8 and when 0 defines    |
|                     | burst length 16                                                    |
| FIFO_WR_Data[255:0] | Data that will be written in memory                                |
| WR_FSM_Enable       | Enable signal of Write FSM                                         |
| Reset_Done          | When 1 defines that initialization sequence has been executed      |

#### Table 38: Outputs of Write\_FSM

| Signal      | Description                                                                                                                                                                                                   |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DQ[15:0]    | Data Input/Output: Bi-directional data bus                                                                                                                                                                    |  |
| Write_Done  | Flag signal when 1 defines that writing operation has done                                                                                                                                                    |  |
| DQS_t,DQS_c | Data Strobe: output with read data, input with write data. Edge-<br>aligned with read data, centered in write data.DDR5 SDRAM<br>supports differential data strobe only and does not support<br>single-ended. |  |

#### 2.6.2.3 Operation



Figure 28: Write\_FSM

Table 39: Description of each state in Write\_FSM

| State     | Description                                                            |  |
|-----------|------------------------------------------------------------------------|--|
| IDLE      | In this state, WR_FSM_Enable is checked, if it's asserted high then go |  |
|           | to <b>PREAMBLE</b> state.                                              |  |
| PREAMBLE  | We declared counter in RD_FSM block that counts two cycles from        |  |
|           | CK_double that represents interval of preamble and when this counter   |  |
|           | finishes, it outputs signal called PRE_Ctr_Done.After this signal is   |  |
|           | raised high this means that preamble phase has finished so we can      |  |
|           | write date by going to <b>WR_DATA</b> state.                           |  |
| WR_DATA   | In this state writing data is done by transfer data from controller to |  |
|           | memory with burst length that defined by burst signal, and there is    |  |
|           | internal signal when transfer is done it's raised high called          |  |
|           | Data_Ctr_Done then go to <b>POSTAMBLE</b> state.                       |  |
| POSTAMBLE | We declared counter in WR_FSM block that counts cycle from             |  |
|           | CK_double that represents interval of postamble and when this counter  |  |
|           | finishes, it outputs signal called POST_Ctr_Done.After this signal is  |  |

|                                                                                                                                                                    | raised high this means that postamble phase has finished so we can say that writing date has finished then go to <b>WR_DONE</b> state. |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>WR_DONE</b> In this state, write_Done signal is asserted high to indicate that write has finished then go to <b>IDLE</b> state waiting another write operation. |                                                                                                                                        |  |

#### Table 40: Outputs of each state in Write\_FSM

| State     | Outputs                                   |
|-----------|-------------------------------------------|
| IDLE      | Write_Done =0                             |
|           | $\blacktriangleright$ WR_Enable = 0       |
|           | $\rightarrow$ PRE_Ctr_Reset_n = 0         |
|           | $\rightarrow$ Data_Ctr_Reset_n = 0        |
|           | $\rightarrow$ POST_Ctr_Reset_n = 0        |
|           | $\rightarrow$ PRE_Ctr_Reset_n = 1         |
| PREAMBLE  | $ TataIn_LD = 1 $                         |
| WR_DATA   | $PRE\_Ctr\_Reset\_n = 1$                  |
|           | $\rightarrow$ Data_Ctr_Reset_n = 1        |
|           | $\blacktriangleright$ WR_Enable = 1       |
|           | $\rightarrow$ DQ_Transfer_En = 1          |
|           | DQ<=Ctrl_DataOut                          |
| POSTAMBLE | $\rightarrow$ PRE_Ctr_Reset_n = 1         |
|           | $\rightarrow$ POST_Ctr_Reset_n = 1        |
|           | $\blacktriangleright$ WR_Enable = 0       |
|           | $\blacktriangleright$ DQ_Transfer_En <= 0 |
| WR_DONE   | Write_Done = 1                            |

#### ♦ Assumption & Notes

1. WR\_Enable is internal signal that enables writing in RD\_DATE state.

2. PRE\_Ctr\_Reset\_n and POST\_Ctr\_Reset\_n are reset signals for preamble and postamble counters respectively.

3. Data\_Ctr\_Reset\_n is rest signal for counter that counts burst length.

4. DataIn\_LD is signal that loads data from WR\_Data\_FIFO to register called DataIn.

5. DQ\_Transfer\_En is signal that enables transfer from DataIn register to DQ during WR\_DATA state.

Problem\_4: due to the fact that there are many features the memory doing them and our controller handling them so there are many blocks drive the same signal based on what operation is handled like CA signal which leads to synthesis problem (multiple driven) as shown in Figure 29:

| 🗸 📪 Synthesis (45 critical warnings)                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------|
| 9 Synth 8-6859] multi-driven net on pin CA_OBUF[13] with 1st driver pin 'init_FSM/CA_reg[13]/Q' [INIT_FSM.sv:145] (44 more like this |
| (9) [Synth 8-6859] multi-driven net on pin CA_OBUF[13] with 2nd driver pin 'SR_FSM/CA_reg[13]/Q' [SR_FSM.sv;203]                     |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[13] with 3rd driver pin 'cmd_fsm/CA_reg[13]/Q' [CMD_FSM.sv:490]                     |
| [4] [Synth 8-6859] multi-driven net on pin CA_OBUF[12] with 1st driver pin 'init_FSM/CA_reg[12]/Q' [INIT_FSM.sv:145]                 |
| Osynth 8-6859] multi-driven net on pin CA_OBUF[12] with 2nd driver pin 'SR_FSM/CA_reg[12]/Q' [SR_FSM.sv:203]                         |
| O [Synth 8-6859] multi-driven net on pin CA_OBUF[12] with 3rd driver pin 'cmd_fsm/CA_reg[12]/Q' [CMD_FSM.sv:490]                     |
| (9) [Synth 8-6859] multi-driven net on pin CA_OBUF[11] with 1st driver pin 'init_FSM/CA_reg[11]/Q' [INIT_FSM.sv:145]                 |
| (9) [Synth 8-6859] multi-driven net on pin CA_OBUF[11] with 2nd driver pin 'SR_FSM/CA_reg[11]/Q' [SR_FSM.sv:203]                     |
| [9] [Synth 8-6859] multi-driven net on pin CA_OBUF[11] with 3rd driver pin 'cmd_fsm/CA_reg[11]/Q' [CMD_FSM.sv:490]                   |
| (9) [Synth 8-6859] multi-driven net on pin CA_OBUF[10] with 1st driver pin 'init_FSM/CA_reg[10]/Q' [INIT_FSM.sv:145]                 |
| O [Synth 8-6859] multi-driven net on pin CA_OBUF[10] with 2nd driver pin 'SR_FSM/CA_reg[10]/Q' [SR_FSM.sv:203]                       |
| Osynth 8-6859] multi-driven net on pin CA_OBUF[10] with 3rd driver pin 'cmd_fsm/CA_reg[10]/Q' [CMD_FSM.sv:490]                       |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[9] with 1st driver pin 'init_FSM/CA_reg[9]/Q' [INIT_FSM.sv:145]                     |
| [9] [Synth 8-6859] multi-driven net on pin CA_OBUF[9] with 2nd driver pin 'SR_FSM/CA_reg[9]/Q' [SR_FSM.sv:203]                       |
| Osynth 8-6859] multi-driven net on pin CA_OBUF[9] with 3rd driver pin 'cmd_fsm/CA_reg[9]/Q' [CMD_FSM.sv:490]                         |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[8] with 1st driver pin 'init_FSM/CA_reg[8]/Q' [INIT_FSM.sv:145]                     |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[8] with 2nd driver pin 'SR_FSM/CA_reg[8]/Q' [SR_FSM.sv:203]                         |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[8] with 3rd driver pin 'cmd_fsm/CA_reg[8]/Q' [CMD_FSM.sv:490]                       |
| () [Synth 8-6859] multi-driven net on pin CA_OBUF[7] with 1st driver pin 'init_FSM/CA_reg[7]/Q' [INIT_FSM.sv:145]                    |
| () [Synth 8-6859] multi-driven net on pin CA_OBUF[7] with 2nd driver pin 'SR_FSM/CA_reg[7]/Q' [SR_FSM.sv:203]                        |
| () [Synth 8-6859] multi-driven net on pin CA_OBUF[7] with 3rd driver pin 'cmd_fsm/CA_reg[7]/Q' [CMD_FSM.sv:490]                      |
| [9] [Synth 8-6859] multi-driven net on pin CA_OBUF[6] with 1st driver pin 'init_FSM/CA_reg[6]/Q' [INIT_FSM.sv:145]                   |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[6] with 2nd driver pin 'SR_FSM/CA_reg[6]/Q' [SR_FSM.sv:203]                         |
| (b) [Synth 8-6859] multi-driven net on pin CA_OBUF[6] with 3rd driver pin 'cmd_fsm/CA_reg[6]/Q' [CMD_FSM.sv:490]                     |
| [9] [Synth 8-6859] multi-driven net on pin CA_OBUF[5] with 1st driver pin 'init_FSM/CA_reg[5]/Q' [INIT_FSM.sv:145]                   |
| 🐠 [Synth 8-6859] multi-driven net on pin CA_OBUF[5] with 2nd driver pin 'SR_FSM/CA_reg[5]/Q' [SR_FSM.sv:203]                         |
| [5] [Synth 8-6859] multi-driven net on pin CA_OBUF[5] with 3rd driver pin 'cmd_fsm/CA_reg[5]/Q' [CMD_FSM.sv:490]                     |
|                                                                                                                                      |

Figure 29: Multiple Driven Problem.

✓ Solution\_4:by putting MUX before multiple driven signals and select the right output based on select lines that come from a decoder that decodes internal signals. So we added to blocks in our design Selection Decoder and MUX used in Top Module before multiple driven signals, let us discuss Selection Decoder block.

#### 2.6.3 Selection Decoder

2.6.3.1 Block Diagram



Figure 30: Block Diagram of Selection\_Decoder.

#### 2.6.3.2 List of Inputs and Outputs

Table 41: Inputs of Selection Decoder.

| Signal          | Description                              |  |
|-----------------|------------------------------------------|--|
| INIT_FSM_Enable | Active high enable of Initialization_FSM |  |
| SR_FSM_Enable   | Active high Enable of Self Refresh_FSM   |  |
| CMD_FSM_Enable  | Active high Enable of CMD_FSM            |  |

#### Table 42: Outputs of Selection Decoder.

| Signal   | Description                                                                                                       |  |
|----------|-------------------------------------------------------------------------------------------------------------------|--|
| Sel[1:0] | Selection signal that will be selection signal for multiplexers<br>that are placed before multiple driven signals |  |

#### 2.6.3.3 Operation

Table 43: Operation of Selection Decoder.

| Enable Signal   | Sel |
|-----------------|-----|
| INIT_FSM_Enable | 0   |
| SR_FSM_Enable   | 1   |
| CMD_FSM_Enable  | 2   |

Problem\_5: inferring latches, we don't need latches in our design due to the complexity of calculating timings of latches at synthesis tools (checking timing violations is very complex).

- ✓ Solution\_5: we remove all latches and either return them to their equivalent combinational logic at the case of unintentional latches or exchange it with registers at the case of using it as storing element.
- Problem\_6: sometimes synthesis tools remove registers due to they think that these registers will never be used.
- ✓ **Solution\_6:** we added a load signal for registers that may be removed to make the tool understand that it actually used when this load gets activated then register a new value.
- **Problem\_7:** clock cycle uncertainty between blocks in top module.
- Solution\_7: we made a global initialization for all blocks and counters based on initialization feature of memory and also made counters to be aligned in counting with other blocks.
- **Problem\_8:** Reset signals have not highest priority in counters and other blocks.
- ✓ **Solution\_8:** we redefined all counters and blocks and chose to model counters with global reset, set priority counters to get instantiated with the optimized version of it after synthesis and that is by putting asynchronous reset at the top with the highest priority then even counts incrementing the counter when enabled or keeps the old one.
- Problem\_9: There are bits in address vector may be removed by tool as it thinks that they won't be used and this due to that not all bits in Address vector, defined by the standard, is used in our design.
- ✓ Solution\_9: we needed to redefine address vector to make all its bits get used from the design and not letting the tool to remove any signal with its own.
- Problem\_10: there are non-synthesizable statements on System-Verilog HDL like wildcard equality operator "= = ="
- ✓ **Solution\_10:** we exchanged all these statements with synthesizable statement like logical equality operator "= =".

Some of these problems that we discussed are shown in Figure 31:

✓ ■ Synthesis (302 warnings)

- > 9 [Synth 8-6014] Unused sequential element Prev\_Reset\_reg was removed. [Command\_Decoder.sv:83] (28 more like this)
- > (Synth 8-87] always\_comb on 'WR\_Data\_WR\_En\_reg' did not result in combinational logic [Command\_Decoder.sv:206] (87 more like this)
- > 9 [Synth 8-5788] Register DataOut\_reg[15] in module RD\_FSM is has both Set and reset with same priority. This may cause simulation mismatches. Consider rewriting code [RD\_FSM.sv288] (61 more like this)
- > 0 [Synth 8-589] replacing case/wildcard equality operator === with logical equality operator == [CMD\_FSM.sv.203] (4 more like this)
- > 9 [Synth 8-327] inferring latch for variable 'WR\_Data\_WR\_En\_reg' [Command\_Decoder.sv.206] (93 more like this)
- 9 [Synth 8-3936] Found unconnected internal register 'Command\_reg' and it is trimmed from '7' to '3' bits. [Command\_Decoder.sv:66]
- > [Synth 8-3331] design CMD\_FSM has unconnected port Address[4] (1 more like this)
- > 9 [Synth 8-3332] Sequential element (DQ\_regi\_130) is unused and will be removed from module WR\_FSM. (15 more like this)
- > 9 [Synth 8-264] enable of latch \cmd\_fsm/WR\_FSM\_Enable\_reg is always disabled (3 more like this)

#### Figure 31: Some Problems of Synthesis.

Finally, all problems were solved and the design get synthesized properly. And the schematic from synthesis tool is shown in Figure 32:

#### ♦ Assumption &Notes

- 1. We used System Verilog HDL to describe our design.
- 2. Tools that we used in design through project Vivado ,Modelsim,etc.
- 3. There are changes in design based on bugs that verification found will be discussed later.



Figure 32: Schematic from Synthesis Tool (Vivado).

## **Chapter 3: Introduction to Cocotb**

#### **3.1 INTRODUCTION**

Modern system-on-chip (SoC) designs have been evolving towards heterogeneous compositions of general purpose and specialized computing fabrics as Dennard scaling has ended and Moore's law has slowed. This heterogeneity makes the already difficult work of SoC design and verification much more difficult. Multiple generations of open-source hardware modelling frameworks have attempted to address the growing complexity of hardware design and verification. Comprehensive, productive, and open-source verification procedures that decrease our necessary to build completely validated hardware blocks are a critical missing component in the open-source hardware ecosystem. Verification of open-source hardware has numerous substantial hurdles as compared to closed-source hardware. Closed source hardware, for starters, is typically owned and maintained by firms with specialized verification teams. These verification engineers often have a lot of expertise with constraint-based random testing using commercial System Verilog simulators utilizing a universal verification methodology (UVM). Open-source hardware teams, on the other hand, typically use an agile test-driven design method borrowed from the open-source software community, in which the designer is also responsible for writing the tests. Furthermore, due to the high learning curve and limited support in existing open-source tools, open-source hardware teams seldom employ the UVM-based method. Instead of replicating closed-source hardware testing frameworks, the open-source hardware industry deliberately needs an alternate way for verifying open-source hardware. The top-down approach offered by UVM does not work well for complex multimedia IP blocks like image signal processing pipeling, video codec, neural processing unit etc. due to the algorithmic/system architecture complexity. An SoC chain can contain more than 20 blocks, which a verification testbench is expected to handle. There is a need for SoC DV to be able to take a portion of the IP DV environment and be able to re-run valid semi-randomized scenarios at SoC level. To fully address SoC-level verification, a solution must extend from UVM and allow for vertical (IP to SoC) reuse and horizontal (verification engine portability) reuse. A solution must provide a way to capture, share, and automatically amplify use cases to speed testcase creation and leverage fast verification engines.

#### **3.2 BACKGROUND**

Design Verification is a process in which a design is compared against a given design specification before tape-out. This happens along with the development of the design and can start from the time the design architecture definition is completed. The main goal of verification is to ensure functional correctness of the design. However, with increasing design complexities, the scope of verification is also evolving to include much more than functionality. This includes verification of performance and power targets, security and safety aspects of design and complexities with multiple asynchronous clock domains. Simulation of the design model (RTL) remains the primary vehicle for verification, power-aware simulations, emulation/FPGA prototyping, static and dynamic checks, etc. are also used for efficiently verifying all aspects of design. The Verification process is considered very critical as part of design life cycle as any serious bugs in design not discovered before tape-out can lead to the need of newer steppings and increasing the overall cost of design process.

#### **3.2.1 Functional Verification**

The known as functional verification. Functional verification does not confirm the correctness of the design specification and instead assumes that it is correct. It is one of the most difficult steps in the IC design cycle and the primary cause of IC re-spin. The main objectives are: Functional correctness of individual IPs, Internal module communication, External module communication, End to end functional paths, Clock and reset circuits, Power up and down sequence, Complete integration of all IPs. Different types of Functional Verification methods are shown in Figure 33.



Figure 33: Types of Functional Verification

1) Static Verification: It is the process of checking a design against some predefined rules without running it. It enables validation of design at an early stage, without any stimulus or setup, and is thus performed early in the IC design cycle, that is, as soon as the RTL code is available. It doesn't do any timing checks. The earlier a bug is discovered, the easier it is to fix it. The goal of static verification is to decrease the verification effort at the RTL level.

2) Functional Simulation: The process of simulating a design's functional behavior in software is known as functional simulation. It is not useful in software development because it does not account for the timing delays of internal logic or interconnects. The goal of simulation is to validate the individual IPs or blocks of the IC. Functional simulation does not allow for system-level verification.

3) FPGA Prototyping: FPGA prototyping is the process of testing the functionality of an integrated circuit (IC) on FPGAs. With the increasing complexity of ICs and the increasing demand to reduce IC time to market, FPGA prototyping remains a critical solution. The goal of FPGA prototyping is to ensure that the design works as expected when driven with live data and that all of its external interfaces are operational.

4) Emulation: Emulation, also known as pre-silicon validation, is the process of testing the system's functionality on a hardware device known as an emulator. An emulator can handle both system-level and RTL designs (written in C, C++, or SystemC) (in Verilog or VHDL). Simulators take much longer to run than emulators. A design that takes days to simulate will only take hours to emulate. Emulation is used to find issues in system level design using live data, to verify system integration and to develop embedded software.

5) Universal Verification Methodology (UVM): UVM is a well-defined set of coding guidelines with a well-defined testbench structure. It's written in SystemVerilog and comes with a SystemVerilog base class library for creating advanced reusable verification components. It was

created with significant guidance and input from Mentor by the Accellera Systems Initiative, an EDA standards body. IPs are extremely complex, and fully verifying them takes time. The standard test benches are not reusable, so verification engineers must build them from scratch. Due to time constraints, a verification methodology is highly recommended. UVM has a fixed testbench architecture, which makes the testbench highly reusable and saves time.

#### 3.2.2 Switching to Python

SystemVerilog is a fairly complex programming language. The SystemVerilog specification is almost a thousand pages long. There are 221 keywords in the language, compared to 83 in C++. It's a powerful tool, but it takes some time to master. UVM has comparable concerns with complexity. There are numerous ways to accomplish the same task. Again, highly powerful, but difficult to master. Ergo, SV-UVM is powerful but complicated. So, hardware description languages are kept for designing whereas for developing testbenches, a high-level, general-purpose language with object-oriented programming is considerably more beneficial. Thus, Cocotb was created.

#### **3.3 DESIGN VERIFICATION USING COCOTB**

Cocotb automatically connects to a variety of HDL simulators (such as Icarus, Modelsim, Questasim, and others) and allows you to control the signals in your design straight from Python. The whole testbench may be written in Python, and automation and randomization are simple to implement, resulting in increased productivity. Cocotb does not necessitate the use of any additional RTL code. In the simulator, the top level is instantiated as the Design Under Test. Python is used to provide stimulation to the DUT's inputs and monitor the outputs. Given that it does not necessitate knowledge of HDLs, it can be of great help to those who are unfamiliar with it. Python is also an object-oriented scripting language. Cocotb has certain significant advantages over HDL testing techniques since it uses Python for verification:

- Python is an extremely productive language that allows one to write code quickly
- Python makes it simple to connect to other languages.
- Python contains a large library of pre-existing code that can be reused.

• Python is an interpreted language, which means that tests can be modified and rerun without having to recompile the design or exit the simulator GUI.

• Python is widely used; significantly more engineers are familiar with it than SystemVerilog or VHDL.

#### 3.3.1 Architecture of Cocotb

A normal Cocotb testbench does not necessitate any additional RTL code. Without any wrapper code, the Design Under Test (DUT) is instantiated as the simulator's top level. Cocotb applies stimuli to the DUT's inputs (or lower in the hierarchy) and monitors the outputs directly from Python. Cocotb acts as a bridge between the simulator and Python as shown in Figure 34 [9]. Verilog Procedural Interface (VPI) or VHDL Procedural Interface (VHDLPI) is used (VHPI).



Figure 34: Architecture of Cocotb.

A test is merely a Python function. The await keyword indicates when control of execution should be returned to the simulator. A test can start numerous coroutines, permitting separate execution flows. Python testbench code has the ability to [10]:

- Traverse the DUT hierarchy and update values.
- Wait for the simulation timer to run out.
- Wait for a signal's rising or falling edge.

## 3.3.2 Design Methodology

The cocotb framework is made to be a goal-directed design verification tool. The following steps are included in the python-based verification flow [11].

1) Capture the IP-level actions needed to create a desired use case, if not already captured.

2) Compose the desired use case in text format.

3) Use cocotb for vector generation: cocotb allows constrained randomization through which all the parameters of the IP core can be randomized.

4) Verify the resulting vectors on a golden reference: These vectors can be run on a C test design and the validity of vectors can be checked.

#### 3.3.3 Cosimulation

It is the independent simulation of the design and testbench. Communication is accomplished using VPI/VHPI interfaces, which are represented by cocotb 'triggers'. The simulation time does not advance while the Python function is running. When a trigger is delivered, the testbench suspends execution until the triggered condition is met before restarting execution. Some triggers availed are [9]:

- Timer (time, unit): Waits for a given amount of simulation time to pass before acting.
- Edge(signal): Waits for a signal's state to change (rising or falling edge).
- RisingEdge(signal): Waits for a signal's rising edge.
- FallingEdge(signal): Waits for a signal's falling edge.
- ClockCycles(signal, num): Waits for a certain number of clocks to cycle (transitions from 0 to 1).

#### **3.4 COCOTB COVERAGE**

#### 3.4.1 Functional Coverage in SystemVerilog

In SystemVerilog a fundamental coverage unit is a *coverpoint*. It contains several bins and each bin may contain several values. Every *coverpoint* is associated with a variable or signal. At sampling event, the *coverpoint* variable value is compared with each defined bin. If there is a match, then the number of hits of the particular bin is incremented. *Coverpoints* are organized in *covergroups*, which are specific class-like structures. A single *covergroup* may have several instances and each instance may collect coverage independently. A *covergroup* requires sampling, which may be defined as a logic event (e.g., a positive clock edge). Sampling may also be called implicitly in the testbench procedural code by invoking a *sample()* method of the *covergroup* instance. A bin may be also defined as an *ignore\_bins*, which means its match does not increase a coverage count, or an *illegal\_bins*, which results in error when hit during the test execution.

Another coverage construct in SystemVerilog is a *cross*. It automatically generates a Cartesian product of bins from several *coverpoints*. It is a useful feature simplifying the functional coverage generation. As it may be difficult or unnecessary to cover all the cross-bins, some of them may be excluded from the analysis. This is possible using the *binsof* ... *intersect* syntax.

The most important limitations of the SystemVerilog functional coverage features are:

- straightforward bins matching criteria only satisfied by equality or inclusion relation;
- bins may be only constants or transitions (possibly wildcard);
- flat coverage structure cover groups cannot contain other cover groups, which would correspond better to a verification plan scheme;

• not possible to get the detailed coverage information in real time (e.g., when a specific bin was hit).

#### 3.4.2 Functional Coverage with Cocotb-coverage

The general assumptions for the architecture of the functional coverage features are as follows:

- functional coverage structure should better match a real verification plan;
- its syntax should be more flexible, but a separation between coverage and executable code should be maintained;
- features for analyzing the coverage during test execution should be added or extended;
- coverage primitives should be able to monitor testbench objects at a higher level of abstraction.

The implemented mechanism is based on the idea of decorator design pattern. In Python, a decorator syntax is readable and easy to use. Instead of sampling coverage items by an additional method, decorators are by default invoked at each decorated function call. As it is easy to create functions in Python (for example anonymous functions can be created as lambda expressions<lambda> – single-line function definitions), this is a convenient solution. The coverage structure is based on a prefix tree (a *trie*). The main coverage primitive is a CoverItem, which corresponds to a SystemVerilog covergroup. CoverItem may contain other CoverItems<CoverItem> or objects extending CoverItems<br/>CoverItem> base class, which are CoverItems</br/>CoverItem> are created automatically, the user defines only CoverPoint or CoverCross primitives (the lowest level nodes in the trie). Each created primitive has a unique ID – a dot-separated string. This string denotes the position of an object in the coverage trie. For example, a CoverItem. The structure of the coverage tree is presented below in figure 35.



Figure 35: An example of the coverage tree structure [12].

### 3.4.3 Constrained Random Verification Features in SystemVerilog

SystemVerilog users may define random variables using the *rand/randc* modifier. Calling *randomize()* function on a class instance (object) results in picking random values of the defined random variables, satisfying given constraints. Also a *with* modifier can be used together with *randomize()* which allow for appending additional constraints dynamically. Constraints are defined in a special section in the class named *constraint*. They describe a range values that a single variable may have or a relation between variables. It is also possible to define solution ranges with weights (using *dist* modifier). The *solve* ... *before* is an additional construction which organizes variable randomization order.

Constraints are unique constructs of SystemVerilog. They are class members, but they are not functions or objects. Basic operations can be performed on constraints, such as enable/disable or inheritance. Soft constraints have been introduced in SystemVerilog 2012. They are resolved only when it is possible to satisfy them together with all other hard constraints. Every SystemVerilog simulator must implement a constraint solver. Although many open-source constraint solvers are available, testbench designers cannot use them, as they have no control over the simulator engine. The most important limitations of the existing constrained randomization features are related to their fixed syntax.

In cocotb-coverage, it is assumed that a constraint may be any callable object – an arbitrary function or a class with \_\_\_\_\_\_ method. It allows for creating various functionalities quite easily and manipulating them in a flexible way [12].

#### 3.4.4 Constrained Random Verification Features in cocotb-coverage

The main assumption for the constrained randomization features was to provide only a flexible API, and let the testbench designer to adjust it depending on project needs. There is an open-source based hard constraint solver used by this framework: python-constraint.

The general idea of Cocotb-coverage is that all classes that intended to use randomized variables should extend the base class Randomized. Afterwards, random variables and their ranges should be defined. Constraints are just arbitrary functions with only one requirement: their argument names must match class member names. It is possible to define two types of constraints:

functions that return a True/False value, corresponding to SystemVerilog hard constraints;

functions that return a numeric value, corresponding to a variable's distribution (or crossdistribution) which also may be used as soft constraints.

The Randomized class API consists of the following functions:

- add\_rand(var, domain)<add\_rand> specifies var as a randomized variable taking values from the domain list;
- add\_constraint(cstr)<add\_constraint> adds a constraint function to the solver;

- del\_constraint(cstr)<del\_constraint> removes a constraint function from the solver;
- solve\_order(vars0, vars1 ...)<solve\_order> optionally specifies the order of randomizing variables (can be used for problem decomposition or in case some random variables must be fixed before randomizing the others);
- pre\_randomize function called before randomize/randomize\_with, corresponding to similar function in SV;
- post\_randomize function called after randomize/randomize\_with, corresponding to similar function in SV;
- randomize() main function that picks random values of the variables satisfying added constraints;
- randomize\_with(cstr0, cstr1 ...)<randomize\_with> similar to randomize(), but satisfies additional given constraints.

A more complex example is presented below. The class TripleInt contains three unsigned integer members, y and z are randomized. The first defined constraint combines all variables (random and non-random). The second constraint defines a triangular distribution for variable z. It is achieved by defining a function that has its maximum in the middle of the variable range (for solution z = 500). The third one is a cross-distribution of variables y and z. The weight function defines higher probability for solutions with higher difference between both variables. The last one is a kind of a soft constraint – very low probability is set for condition x > y, which means that solutions satisfying  $x \le y$  will be strongly preferred.

```
class TripleInt(crv.Randomized):
    def __init__(self, x):
        crv.Randomized.__init__(self)
        self.x = x # this is a non-random value, determined at class instance creation
        self.y = 0
        self.z = 0
        add_rand(y, list(range(1000))) # 0 to 999
        add_rand(z, list(range(1000))) # 0 to 999
        add_constraint(lambda x, y, z: x+y+z=1000) # hard constraint
        add_constraint(lambda z: 500 - abs(500-z)) # triangular distribution of z variable
        add_constraint(lambda y, z: 100 + abs(y-z)) # multi-dimensional distribution
        add_constraint(lambda x, y: 0.01 if (y > x) else 1) # soft constraint
```

It is assumed that only one hard constraint and one distribution may be associated with each set of random variables. So, for the example presented above, it is possible to define no more than six constraint functions: separately for variables y and z and both (y and z). It means that constraints may be overwritten, for example by randomize\_with() function arguments.

### **3.5 CODE COVERAGE**

Code Coverage testing determines how much code is tested. Code coverage is a metric that describes the extent to which the program's source code has been tested. It is given by the Eqn. 1:

 $Code \ Coverage = \frac{Number \ of \ lines \ of \ code \ excuted}{Total \ number \ of \ lines \ of \ code} \ * \ 100 \ \% \ (1)$ 

There are several coverage types, which are as follows [13]:

#### 3.5.1 Statement coverage/ Line coverage

Statement coverage, often known as line coverage, is the simplest to comprehend sort of coverage. Statement coverage measures how many statements/lines are covered in the simulation.

### 3.5.2 Block/ Segment coverage

The nature of the statement and block coverage seems to be similar. The distinction is that block coverage takes into account branching blocks of if/else, case branches, wait, while, for, and so on. The dead code (lines which never get executed) is revealed by analyzing block coverage.

#### 3.5.3 Conditional coverage

Conditional coverage, also known as expression coverage, shows how variables or expressions in conditional statements are assessed. Only expressions using logical operators are taken into account. Conditional coverage is the ratio of number of cases checked to the total number of instances present.

#### 3.5.4 Branch coverage

Branch coverage, also known as decision coverage, reports the true or false of conditions such as if-else, case, and ternary operator statements. Decision coverage for an 'if' statement will report if the 'if' statement is examined in both true and false instances, even if a 'else' statement does not exist.

#### 3.5.5. Toggle coverage

It ensures how many times variables and nets are toggled (flipping between logic high and logic low). Toggle coverage is just the ratio of toggled nodes to total nodes.

#### 3.5.6. Path coverage

Due to conditional statements such as if-else, a different path is generated in the design, diverting the flow of input to the specific path. Path coverage is regarded to be more comprehensive than branch coverage since it can detect flaws in the order of operations.

#### 3.5.7. FSM coverage

As it works on the design's behavior, it is the most complex sort of code coverage. In a finite state machine, this evaluates how often states are visited, transited, and how many sequences are covered.

## **Chapter 4: Block Level Verification**

### 4.1 GOALS AND OVERVIEW

The goal of this chapter is to write a block level verification plan to ensure the functionality of each block, report the critical bugs of each block and how it was fixed, measure the functional coverage and the code coverage of each block to ensure the completeness of the written testbenches, which are written in python using Cocotb Coverage library as mentioned in chapter3.

### **4.2 BLOCK LEVEL TESTBENCH ARCHITECTURE**

The test bench architecture is based on Self-checking coverage-Driven Constraint Random-Based Functional Verification Methodology, the function of each block as follows:

Generator: generates constrained random test cases.

**Driver**: drives the test cases to the Device under test and the Reference Model concurrently.

**Reference Model**: provides the expected output according to the current testcase.

**Checker**: compares the predicted output with the DUT output.

**Scoreboard**: prints the failed test cases and the passed ones.

**Coverage**: samples the test inputs to collect the features that have been tested.



Figure 36: Block Level Verification Environment.

### 4.3 COMMAND DECODER VERIFICATION PLAN

#### 4.3.1 Functional Coverage Plan

The important features that should be covered to ensure the correctness of the Command decoder functionality are the following:

- 1. Reset.
- 2. Self-Refresh.
- 3. Reset and Self\_Refresh/command in the same time to ensure the priority of reset.

- 4. self-refresh and command in the same time to ensure the priority of self-Refresh.
- 5. Write.
- 6. Read.
- 7. Write with AP.
- 8. Read with AP.
- 9. Write Burst.
- 10. Read Burst.
- 11. Write Burst with AP.
- 12. Read Burst with AP.
- 13. Write after Read in same Bank Group.
- 14. Write after Read in different Bank Group.



Figure 37: Command decoder coverage section written in python.

### 4.3.2 Test Cases



| Test Item    | Test Case                                                                                                                                    | Expected Result                                                                                                                      | Covered      | Bug<br>Free  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
| Reset        | Ctrl_Reset signal is<br>asserted high for only<br>one clock cycle then low.                                                                  | <ul> <li>INIT_FSM_Enable<br/>signal should be<br/>asserted high.</li> <li>Memory_Busy Signal<br/>should be asserted high.</li> </ul> | $\checkmark$ | $\checkmark$ |
| Reset        | Reset_Done is signal is<br>asserted high for only<br>one clock cycle then low.                                                               | <ul> <li>INIT_FSM_Enable<br/>signal should be<br/>asserted low.</li> <li>Memory_Busy Signal<br/>should be asserted low.</li> </ul>   | $\checkmark$ | $\checkmark$ |
| Self-Refresh | <ul> <li>tREF1 signal is asserted<br/>high for only one clock<br/>cycle then low.</li> <li>Ctrl_Reset signal is<br/>asserted low.</li> </ul> | <ul> <li>SR_FSM_Enable signal<br/>should be asserted high.</li> <li>Memory_Busy Signal<br/>should be asserted high.</li> </ul>       | $\checkmark$ | $\checkmark$ |

| Self-Refresh     | SR_Done is asserted high<br>for only one clock cycle<br>then low.                                                                                                                                                                                                                                                                                                                                                                                                                                   | <ul> <li>SR_FSM_Enable signal<br/>should be asserted low.</li> <li>Memory_Busy Signal<br/>should be asserted low.</li> </ul>                                                                                            | $\checkmark$ | $\checkmark$ |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
| Write            | <ul> <li>Ctrl_Write signal is<br/>asserted high for only<br/>one clock cycle.</li> <li>Ctrl_Read signal is<br/>asserted low for only one<br/>clock cycle.</li> <li>Ctrl_Burst is asserted low<br/>for only one clock.</li> <li>Ctrl_Auto is asserted low<br/>for only one clock cycle.</li> <li>Bank_Group signal is<br/>asserted to a certain value<br/>'x' for only one clock<br/>cycle.</li> <li>Data_Transfer_Write is<br/>asserted to a certain value<br/>for only one clock cycle.</li> </ul> | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>WR_Data_WR_En signal should be asserted high</li> <li>CMD signal should be asserted '001'.</li> <li>First_Command should be asserted high.</li> </ul>  |              |              |
| Read             | <ul> <li>Ctrl_Read signal is<br/>asserted high.</li> <li>Ctrl_Write signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>low.</li> <li>Ctrl_Auto is asserted<br/>low.</li> <li>Bank_Group signal is<br/>asserted to a certain value<br/>'x'.</li> </ul>                                                                                                                                                                                                                                  | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>CMD signal should be asserted '000'.</li> <li>Same_Bank_Group should be asserted high.</li> </ul>                                                      |              |              |
| Write With<br>AP | <ul> <li>Ctrl_Write signal is<br/>asserted high.</li> <li>Ctrl_Read signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>low.</li> <li>Ctrl_Auto is asserted<br/>low.</li> <li>Bank_Group signal is<br/>asserted to a certain value<br/>'y'.</li> </ul>                                                                                                                                                                                                                                  | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>WR_Data_WR_En signal should be asserted high</li> <li>CMD signal should be asserted '011'.</li> <li>Same_Bank_Group should be asserted low.</li> </ul> |              |              |

| Read With   | <ul> <li>Data_Transfer_Write is<br/>asserted to a certain<br/>value.</li> <li>Ctrl_Read signal is</li> </ul>                                                                                                                                                                                                                         | ≻ CMD_FIFO_WR_En                                                                                                                                                       |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| AP          | <ul> <li>asserted high.</li> <li>Ctrl_Write signal is asserted low.</li> <li>Ctrl_Burst is asserted low.</li> <li>Ctrl_Auto is asserted high.</li> <li>Bank_Group signal is asserted to a certain value.</li> </ul>                                                                                                                  | <ul> <li>CMD_ITPO_WK_En</li> <li>signal should be asserted high.</li> <li>CMD signal should be asserted '010'.</li> </ul>                                              |  |
| Write Burst | <ul> <li>Ctrl_Write signal is<br/>asserted high.</li> <li>Ctrl_Read signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>high.</li> <li>Ctrl_Auto is asserted<br/>low.</li> <li>Bank_Group signal is<br/>asserted to a certain<br/>value.</li> <li>Data_Transfer_Write is<br/>asserted to a certain<br/>value.</li> </ul> | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>WR_Data_WR_En signal should be asserted high</li> <li>CMD signal should be asserted '101'.</li> </ul> |  |
| Read Burst  | <ul> <li>Ctrl_Read signal is<br/>asserted high.</li> <li>Ctrl_Write signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>high.</li> <li>Ctrl_Auto is asserted<br/>low.</li> <li>Bank_Group signal is<br/>asserted to a certain<br/>value.</li> </ul>                                                                      | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>CMD signal should be asserted '100'.</li> </ul>                                                       |  |

| Write Burst<br>with AP | <ul> <li>Ctrl_Write signal is<br/>asserted high.</li> <li>Ctrl_Read signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>high.</li> <li>Ctrl_Auto is asserted<br/>high.</li> <li>Bank_Group signal is<br/>asserted to a certain<br/>value.</li> <li>Data_Transfer_Write is<br/>asserted to a certain<br/>value.</li> </ul> | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>WR_Data_WR_En signal should be asserted high</li> <li>CMD signal should be asserted '111'.</li> </ul> |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Read Burst<br>with AP  | <ul> <li>Ctrl_Read signal is<br/>asserted high.</li> <li>Ctrl_Write signal is<br/>asserted low.</li> <li>Ctrl_Burst is asserted<br/>high.</li> <li>Ctrl_Auto is asserted<br/>high.</li> <li>Bank_Group signal is<br/>asserted to a certain<br/>value.</li> </ul>                                                                      | <ul> <li>CMD_FIFO_WR_En signal should be asserted high.</li> <li>CMD signal should be asserted '110'.</li> </ul>                                                       |  |

**Note:** all signal is asserted at positive edge the clock CK\_t in order to be sampled and lasts for only on clock cycle then changes.

### 4.3.3 Reported Bugs



FSM Enables are asserted high for only one cycle although it should be high until a FSM done signal is asserted high, for example: Initialization FSM Enable is asserted high for only one cycle, although it should be high until Reset\_Done signal (which comes from the initialization FSM when it finishes) is asserted high.



Initialization \_FSM \_Enable is stored in a **prev** \_**Reset** Register in order to modify the condition that assert the Initialization FSM Enable high based on this register for illustration:

When Ctrl\_Reset is asserted high for only one cycle: INIT\_FSM\_Enable will be asserted high as INIT\_FSM\_Enable=! Reset\_Done;

When Ctrl\_Reset is asserted low at the next clock cycle: INIT\_FSM\_Enable will be asserted high as INIT\_FSM\_Enable= prev\_Reset;

When the initialization FSM finishes it will assert Reset\_Done low for only one cycle: INIT\_FSM\_Enable will be asserted low as INIT\_FSM\_Enable=! Reset\_Done; if(Ctrl\_Reset || Reset\_Done)
begin
 INIT\_FSM\_Enable=!Reset\_Done;
 Memory\_Busy=!Reset\_Done;
 SR\_FSM\_Enable=0;
 CMD\_FSM\_Enable=0;
end
else if(Ctrl\_Reset==0 && Reset\_Done==0)
begin
 INIT\_FSM\_Enable=Prev\_Reset;
 Memory\_Busy=Prev\_Reset;

```
SR_FSM_Enable=0;
CMD_FSM_Enable=0;
```

#### When Reset\_Done is asserted low at the next clock cycle:

INIT\_FSM\_Enable will be asserted low as INIT\_FSM\_Enable= prev\_Reset;



Figure 38: Initialization FSM Enable is asserted high for only one cycle.



Figure 39: Initialization FSM Enable after modification.

```
top.Write : <cocotb_coverage.coverage.CoverPoint object at 0x000000003D96940>, coverage=2,
```

```
BIN 1 : 10000
  BIN 0 : 10000
number of randomized testcases 19999
Test Passed: Command_Decoder_Test
Passed 1 tests (0 skipped)
** TEST
                 PASS/FAIL SIM TIME(NS) REAL TIME(S) RATIO(NS/S) **
4.62 **
** Command decoder.Command Decoder Test PASS
                       1999.96
                              433.35
......
**
                                    * *
               ERRORS : 0
**
              SIM TIME : 1999.96 NS
                                    **
              REAL TIME : 433.43 S
**
                                    **
           SIM / REAL TIME : 4.61 NS/S
**
                                    **
```

Figure 40: Command Decoder Test Summary from Questasim.

### 4.3.4 Functional Coverage Results

| .0 |                              |                          |                      |            |                      |
|----|------------------------------|--------------------------|----------------------|------------|----------------------|
|    | © Read @size=2 @coverage=2   | @cover_percentage=100.0  | @abs_name=top.Read   | @weight=1  | @at_least=1          |
| (  | Write @size=2 @coverage=2    | @cover_percentage=100.0  | @abs_name=top.Write  | @weight=1  | @at_least=1          |
|    | Reset @size=2 @coverage=2    | @cover_percentage=100.0  | @abs_name=top.Reset  | @weight=1  | @at_least=1          |
| (  | Burst @size=2 @coverage=2    | @cover_percentage=100.0  | @abs_name=top.Burst  | @weight=1  | @at_least=1          |
| (  | CMD_Done @size=2 @coverag    | ge=2 @cover_percentage=1 | 00.0 @abs_name=top.0 | CMD_Done   | @weight=1 @at_least= |
|    | Reset_Done @size=2 @coverage | ge=2 @cover_percentage=3 | 00.0 @abs_name=top.  | Reset_Done | @weight=1 @at_least  |
| (  | tREFI @size=2 @coverage=2    | @cover_percentage=100.0  | @abs_name=top.tREF]  | @weight=1  | @at_least=1          |
|    | Auto @size=2 @coverage=2 @   | @cover_percentage=100.0  | @abs_name=top.Auto   | @weight=1  | @at_least=1          |
| (  | SR_Done @size=2 @coverage    | =2 @cover_percentage=100 | 0.0 @abs_name=top.SF | R_Done @we | eight=1 @at_least=1  |
| (  | CMD @size=8 @coverage=8      | @cover_percentage=100.0  | @abs_name=top.CMD    | @weight=1  | @at_least=1          |
|    | C Enable FSM                 |                          |                      |            |                      |
|    | @size=32 @coverage=32 @cove  | r_percentage=100.0 @abs_ | _name=top.Enable_FSM | @weight=1  | @at_least=1          |
|    | Commands @size=16 @covera    | ge=16 @cover_percentage= | 100.0 @abs_name=top  | o.Commands | @weight=1 @at_least  |

Figure 41: Command decoder Functional Coverage XML Report.

| 🦸 Functional Coverage | —  |        | $\times$ |
|-----------------------|----|--------|----------|
| File                  |    |        |          |
| top                   | 10 | 0.0%   |          |
| Read                  |    | 100.0% |          |
| Write                 |    | 100.0% |          |
| Reset                 |    | 100.0% |          |
| Burst                 |    | 100.0% |          |
| CMD_Done              |    | 100.0% |          |
| Reset_Done            |    | 100.0% |          |
| tREFI                 |    | 100.0% |          |
| Auto                  |    | 100.0% |          |
| SR_Done               |    | 100.0% |          |
| CMD                   |    | 100.0% |          |
| Enable_FSM            |    | 100.0% |          |
| Commands              |    | 100.0% |          |
|                       |    |        |          |

Figure 42: Command decoder Functional Coverage from Coverage Viewer.

### 4.3.5 Code Coverage Results

|                           | Instance: /Command_Decoder                                                               |                    |
|---------------------------|------------------------------------------------------------------------------------------|--------------------|
| Instance Path             | /Command_Decoder                                                                         |                    |
| Design Unit               | work.Command_Decoder                                                                     |                    |
| Language                  | Verilog                                                                                  |                    |
| Source File               | D:/GP/Block_Level_Verification/command_decoder/hdl/Command_Decoder.sv                    |                    |
| ocal Instance Cover       | rage Details ( 97.73% )                                                                  |                    |
| ocal Instance Cover       | rage Details(97.73%)                                                                     |                    |
| ocal Instance Cover       | rage Details(97.73%)                                                                     | Ξ                  |
| ocal Instance Cover       | rage Detalls ( <b>97.73%</b> )<br>Bins Hits Misses                                       |                    |
|                           |                                                                                          | Coverage<br>Search |
| Coverage Type ↑           | Bins     Hits     Misses       T     Search     T     Search     T       31     31     0 | Coverage           |
| Coverage Type ↑<br>Search | Bins Hits Misses<br>▼ Search ▼ Search ▼ Search ▼                                         | Coverage<br>Search |

Figure 43: Command decoder Code Coverage Summary from Questasim.

### **4.4 COMMAND FINITE STATE MACHINE**

CMD FSM is responsible for **handling the sequence of operation that should be done in order to execute write or read operations** with or without Auto precharge in same or different bank group address as implemented in 2.5.6 as specified in JESD79-5 section 3.1 and providing the appropriate status signal to SDRAM as specified in JESD79-5 section 4.1 Table 241.

#### 4.4.1 Functional Coverage Plan

The important features that should be covered to ensure the correctness of the Command FSM functionality are the following:

- 1. All types of write command (write, write Burst, write with AP, write burst with AP).
- 2. All types of read command (read, read Burst, read with AP, read burst with AP).
- 3. Two consecutive writes (write, write with AP) in same bank group.
- 4. Two consecutive writes (write, write with AP) in different bank group.
- 5. Two consecutive reads (read, read with AP) in same bank group.
- 6. Two consecutive reads (read, read with AP) in different bank group.
- 7. Read after write in same bank group.
- 8. Read after write in different bank group.
- 9. Write after read in same bank group.
- 10. Write after read in different bank group.

### 4.4.2 Test Cases

Table 45: Test cases of command FSM.

| Test Item               | Test Case                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Expected Result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Covered | Bug<br>Free |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------|
| Write<br>Write<br>Burst | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'001'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'100'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>CMD signal is asserted<br/>'100'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul> | <ul> <li>IDLE outputs.</li> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRIT_WRITE_LATENCY<br/>outputs.</li> <li>WRIT_WRITE_DONE (A<br/>cycles) outputs.</li> <li>WRITE_DONE outputs.</li> <li>WRITE_DONE outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>IDLE outputs.</li> <li>MAIT_CYCLE1 outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WRIT_WRITE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRITING_DATA outputs.</li> <li>WRIT_WRITE_DONE (A-8)<br/>cycles outputs.</li> <li>WRITE_DONE outputs.</li> <li>WAIT_WRITE_DONE (A-8)<br/>cycles outputs.</li> </ul> |         |             |
| Write with AP           | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'011'.</li> <li>First_Command signal is<br/>asserted high.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <ul> <li>IDLE outputs.</li> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |             |

|                           | <ul> <li>all counter flags are asserted high.</li> <li>Ctrl_ADD signal is asserted a certain value.</li> </ul>                                                                                                                                                                                                                  | <ul> <li>WAIT_WRITE_LATENCY outputs.</li> <li>WRITING_DATA outputs.</li> <li>WAIT_WRITE_DONE (A) cycles outputs.</li> <li>WRITE_DONE outputs</li> <li>WRITE_DONE outputs</li> <li>PRECHARGE outputs</li> <li>WAIT_tRP outputs</li> <li>IDLE outputs</li> </ul>                                                                                                                                                                                                                |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Write<br>Burst with<br>AP | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'111'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul> | <ul> <li>IDLE outputs.</li> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRIT_WRITE_LATENCY outputs.</li> <li>WRITING_DATA outputs.</li> <li>WRIT_WRITE_DONE (A-8) cycles outputs.</li> <li>WRITE_DONE outputs</li> <li>PRECHARGE outputs</li> <li>WAIT_tRP outputs</li> <li>IDLE outputs</li> </ul> |  |
| Read                      | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'000'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.<br/>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul>      | <ul> <li>IDLE outputs</li> <li>WAIT_ACT outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A<br/>Cycles) outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> </ul>                                                        |  |

| Deed                       | CMD ESM Erable                                                                                                                                                                                                                                                                                                                                          | DIE outputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Read<br>Burst<br>Read with | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'100'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> <li>CMD_FSM_Enable</li> </ul> | <ul> <li>IDLE outputs</li> <li>WAIT_ACT outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A-8)<br/>cycles outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> <li>IDLE outputs</li> </ul>                                                    |   |
| AP                         | <ul> <li>CIVID_FSIV_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'010'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.<br/>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul>                           | <ul> <li>MDLE outputs</li> <li>WAIT_ACT outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A<br/>cycles) outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> <li>PRECHARGE outputs</li> <li>WAIT_tRP outputs</li> <li>IDLE outputs</li> </ul> |   |
| Read<br>Burst with<br>AP   | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'110'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.<br/>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul>                              | <ul> <li>IDLE outputs</li> <li>WAIT_ACT outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY outputs</li> <li>READING_DATA outputs</li> </ul>                                                                                                                                                                                       |   |

|                        |                                                                                                                                                                                                                                                                                                                                 | <ul> <li>WAIT_READ_DONE (A-8)<br/>cycles outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> <li>PRECHARGE outputs</li> <li>WAIT_tRP outputs</li> <li>IDLE outputs</li> </ul>                                                                                                                                                                                                           |              |              |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
| write                  | > CMD_FSM_Enable                                                                                                                                                                                                                                                                                                                | ➢ IDLE outputs.                                                                                                                                                                                                                                                                                                                                                                                          |              |              |
| after write<br>in same | <ul> <li>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> </ul>                                                                                                                                                                                                                               | <ul> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> </ul>                                                                                                                                                                                                                                                                                                          | $\checkmark$ | $\checkmark$ |
| Row address            | CMD signal is asserted                                                                                                                                                                                                                                                                                                          | BANK_ACTIVE outputs.                                                                                                                                                                                                                                                                                                                                                                                     |              |              |
|                        | <ul> <li>'001'.</li> <li>First_Command signal is asserted high.</li> <li>all counter flags are asserted high.</li> <li>Ctrl_ADD signal is asserted a certain value.</li> <li>Wait until CMD_Done is asserted high.</li> </ul>                                                                                                   | <ul> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WAIT_WRITE_LATENCY outputs.</li> <li>WRITING_DATA outputs.</li> <li>WAIT_WRITE_DONE (A cycles) outputs.</li> <li>WRITE_DONE outputs.</li> <li>BANK_ACTIVE outputs.</li> </ul>                                                                                                                    |              |              |
|                        | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted High.</li> <li>CMD signal is asserted<br/>'011'.</li> <li>First_Command signal is<br/>asserted Low.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul> | <ul> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WAIT_WRITE_LATENCY outputs.</li> <li>WRITING_DATA outputs.</li> <li>WAIT_WRITE_DONE (A cycles) outputs.</li> <li>WRITE_DONE outputs.</li> <li>BANK_ACTIVE outputs.</li> </ul> |              |              |

| Write        | > CMD_FSM_Enable                           | > IDLE outputs.                         |
|--------------|--------------------------------------------|-----------------------------------------|
|              | signal is asserted <b>high</b> .           | > WAIT_ACT outputs.                     |
| after write  | <ul> <li>Same_Bank_Group</li> </ul>        | > ACT_CYCLE1 outputs.                   |
| in different | signal is asserted <b>Low</b> .            | > ACT_CYCLE2 outputs.                   |
| Row address  | <ul> <li>CMD signal is asserted</li> </ul> | BANK_ACTIVE outputs.                    |
|              | <b>'001'</b> .                             | <ul> <li>WAIT_WRITE outputs.</li> </ul> |
|              | First_Command signal is                    | > WRITING_CTCLE1 outputs.               |
|              | asserted <b>high</b> .                     | > WRITING_CYCLE2 outputs.               |
|              | > all counter flags are                    | > WAIT_WRITE_LATENCY                    |
|              | asserted <b>high</b> .                     | outputs.                                |
|              | Ctrl_ADD signal is                         | > WRITING_DATA outputs.                 |
|              | asserted <b>a certain value</b> .          | > WAIT_WRITE_DONE (A)                   |
|              |                                            | cycles outputs.                         |
|              | Wait until CMD_Done is                     | > WRITE_DONE outputs                    |
|              | asserted <b>high</b> .                     | > PRECHARGE outputs                     |
|              | 0                                          | > WAIT_tRP outputs                      |
|              |                                            | > IDLE outputs                          |
|              | CMD_FSM_Enable                             |                                         |
|              | signal is asserted <b>high</b> .           | > WAIT_ACT outputs.                     |
|              | Same_Bank_Group                            | > ACT_CYCLE1 outputs.                   |
|              | signal is asserted <b>low</b> .            | > ACT_CYCLE2 outputs.                   |
|              | CMD signal is asserted                     | ► BANK_ACTIVE outputs.                  |
|              | <b>'011''</b> .                            | > WAIT_WRITE outputs.                   |
|              | First_Command signal is                    | > WRITING_CTCLE1 outputs.               |
|              | asserted <b>Low</b> .                      | > WRITING_CYCLE2 outputs.               |
|              | all counter flags are                      | > WAIT_WRITE_LATENCY                    |
|              | asserted High.                             | outputs.                                |
|              | Ctrl_ADD signal is                         | WRITING_DATA outputs.                   |
|              | asserted a certain value.                  | ➢ WAIT_WRITE_DONE (A                    |
|              |                                            | cycles) outputs.                        |
|              |                                            | WRITE_DONE outputs.                     |
|              |                                            | BANK_ACTIVE outputs.                    |
|              |                                            |                                         |
| read         | > CMD FSM Enable                           | ➢ IDLE outputs                          |
| itau         | signal is asserted <b>high</b> .           | <ul> <li>WAIT_ACT outputs</li> </ul>    |
| after read   | <ul> <li>Same_Bank_Group</li> </ul>        | > ACT_CYCLE1 outputs                    |
| in same Row  | signal is asserted <b>Low</b> .            | > ACT_CYCLE2 outputs                    |
| address      | <ul> <li>CMD signal is asserted</li> </ul> | ► BANK_ACTIVE outputs                   |
| auui C55     | <b>'000'</b> .                             | ➢ WAIT_READ outputs                     |
|              | <ul><li>First_Command signal is</li></ul>  | READING_CTCLE1 outputs                  |
|              | asserted <b>high</b> .                     | READING_CYCLE2 outputs                  |
|              | usserieu mign.                             | > WAIT_READ_LATENCY                     |
|              |                                            | outputs                                 |

| · · · · · · · · · · · · · · · · · · · |                                         |                                                             | I | 1 1 |
|---------------------------------------|-----------------------------------------|-------------------------------------------------------------|---|-----|
|                                       | all counter flags are                   | READING_DATA outputs                                        |   |     |
|                                       | asserted <b>high</b> .                  | ➢ WAIT_READ_DONE (A                                         |   |     |
|                                       | Ctrl_ADD signal is                      | Cycles) outputs                                             |   |     |
|                                       | asserted a certain value.               | READ_DONE outputs                                           |   |     |
|                                       |                                         | BANK_ACTIVE outputs                                         |   |     |
|                                       | Wait until CMD_Done is                  |                                                             |   |     |
|                                       | asserted <b>high</b> .                  | ➢ WAIT_READ outputs                                         |   |     |
|                                       | 0                                       | <ul> <li>READING CTCLE1 outputs</li> </ul>                  |   |     |
|                                       |                                         | <ul> <li>READING_CYCLE2 outputs</li> </ul>                  |   |     |
|                                       | CMD_FSM_Enable                          | <ul> <li>WAIT_READ_LATENCY</li> </ul>                       |   |     |
|                                       | signal is asserted <b>high</b> .        | outputs                                                     |   |     |
|                                       | 0                                       | <ul> <li>READING_DATA outputs</li> </ul>                    |   |     |
|                                       | Same_Bank_Group                         | <ul> <li>WAIT_READ_DONE (A</li> </ul>                       |   |     |
|                                       | signal is asserted <b>High</b> .        | Cycles) outputs                                             |   |     |
|                                       | CMD signal is asserted                  | <ul> <li>READ_DONE outputs</li> </ul>                       |   |     |
|                                       | <b>'010'</b> .                          | <ul> <li>BANK ACTIVE outputs</li> </ul>                     |   |     |
|                                       | First_Command signal is                 | > Dram_retrie outputs                                       |   |     |
|                                       | asserted Low.                           |                                                             |   |     |
|                                       | all counter flags are                   |                                                             |   |     |
|                                       | asserted high.                          |                                                             |   |     |
|                                       | Ctrl_ADD signal is                      |                                                             |   |     |
|                                       | asserted a certain value.               |                                                             |   |     |
| read                                  | CMD_FSM_Enable                          | IDLE outputs                                                |   |     |
| after read                            | signal is asserted high.                | WAIT_ACT outputs                                            |   |     |
| aner reau                             | Same_Bank_Group                         | ACT_CYCLE1 outputs                                          |   |     |
| in                                    | signal is asserted Low.                 | ACT_CYCLE2 outputs                                          |   |     |
| 1.00                                  | CMD signal is asserted                  | BANK_ACTIVE outputs                                         |   |     |
| different                             | <b>'000'</b> .                          | WAIT_READ outputs                                           |   |     |
| Row address                           | > <b>First_Command signal</b> is        | READING_CTCLE1 outputs                                      |   |     |
|                                       | asserted <b>high</b> .                  | READING_CYCLE2 outputs                                      |   |     |
|                                       | <ul><li>all counter flags are</li></ul> | > WAIT_READ_LATENCY                                         |   |     |
|                                       | asserted <b>high</b> .                  | outputs                                                     |   |     |
|                                       | <ul> <li>Ctrl_ADD signal is</li> </ul>  | READING_DATA outputs                                        |   |     |
|                                       | asserted <b>a certain value</b> .       | WAIT_READ_DONE (A available) outputs                        |   |     |
|                                       | assenteu a centann value.               | <ul><li>cycles) outputs</li><li>READ_DONE outputs</li></ul> |   |     |
|                                       | Wait until CMD Dana in                  |                                                             |   |     |
|                                       | Wait until CMD_Done is                  | BANK_ACTIVE outputs                                         |   |     |
|                                       | asserted <b>high</b> .                  | > PRECHARGE outputs                                         |   |     |
|                                       |                                         | WAIT_tRP outputs                                            |   |     |
|                                       | CMD FOM F                               | IDLE outputs                                                |   |     |
|                                       | CMD_FSM_Enable                          |                                                             |   |     |
|                                       | signal is asserted <b>high</b> .        | > WAIT_ACT outputs                                          |   |     |
|                                       | Same_Bank_Group                         | > ACT_CYCLE1 outputs                                        |   |     |
|                                       | signal is asserted <b>low</b> .         | ACT_CYCLE2 outputs                                          |   |     |
|                                       |                                         | BANK_ACTIVE outputs                                         |   |     |

|                                                        | <ul> <li>CMD signal is asserted<br/>'010'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted Low.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A<br/>cycles) outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |              |
|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| Read after<br>write in<br>same Row<br>address          | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'001'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> <li>Wait until CMD_Done is<br/>asserted high.</li> <li>Wait until CMD_Done is<br/>asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted High.</li> <li>Same_Bank_Group<br/>signal is asserted High.</li> <li>CMD signal is asserted<br/>'000'.</li> <li>First_Command signal is<br/>asserted Low.</li> <li>all counter flags are<br/>asserted high.</li> <li>CTrl_ADD signal is<br/>asserted Low.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted high.</li> </ul> | <ul> <li>IDLE outputs.</li> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WRITING_DATA outputs.</li> <li>WRIT_WRITE_DONE (A cycles) outputs.</li> <li>WRITE_DONE outputs.</li> <li>BANK_ACTIVE outputs.</li> <li>WAIT_READ outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY outputs</li> <li>READING_DATA outputs</li> <li>READING_DATA outputs</li> <li>READING_CYCLE2 outputs</li> <li>READING_CYCLE2 outputs</li> <li>READING_CYCLE2 outputs</li> <li>READING_CYCLE2 outputs</li> <li>READING_DATA outputs</li> <li>READING_DATA outputs</li> <li>READING_DATA outputs</li> <li>READING_DATA outputs</li> <li>BANK_ACTIVE outputs</li> <li>BANK_ACTIVE outputs</li> </ul> |              |
| Read after<br>write in<br>different<br>Row<br>address. | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>IDLE outputs.</li> <li>WAIT_ACT outputs.</li> <li>ACT_CYCLE1 outputs.</li> <li>ACT_CYCLE2 outputs.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | $\checkmark$ |

|                                                | <ul> <li>CMD signal is asserted<br/>'001'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> <li>Wait until CMD_Done is<br/>asserted high.</li> <li>Wait until CMD_Done is<br/>asserted high.</li> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted low.</li> <li>CMD signal is asserted<br/>'000'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted Low.</li> <li>Ctrl_ADD signal is</li> </ul> | <ul> <li>BANK_ACTIVE outputs.</li> <li>WAIT_WRITE outputs.</li> <li>WRITING_CTCLE1 outputs.</li> <li>WRITING_CYCLE2 outputs.</li> <li>WAIT_WRITE_LATENCY<br/>outputs.</li> <li>WRITING_DATA outputs.</li> <li>WRITE_DONE (A)<br/>cycles outputs.</li> <li>WRITE_DONE outputs</li> <li>PRECHARGE outputs</li> <li>WAIT_tRP outputs</li> <li>IDLE outputs</li> <li>IDLE outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A</li> </ul> |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write after<br>read in same<br>Row<br>address. | <ul> <li>CMD_FSM_Enable<br/>signal is asserted high.</li> <li>Same_Bank_Group<br/>signal is asserted Low.</li> <li>CMD signal is asserted<br/>'000'.</li> <li>First_Command signal is<br/>asserted high.</li> <li>all counter flags are<br/>asserted high.</li> <li>Ctrl_ADD signal is<br/>asserted a certain value.</li> </ul>                                                                                                                                                                                                                                                                                   | <ul> <li>IDLE outputs</li> <li>WAIT_ACT outputs</li> <li>ACT_CYCLE1 outputs</li> <li>ACT_CYCLE2 outputs</li> <li>BANK_ACTIVE outputs</li> <li>WAIT_READ outputs</li> <li>READING_CTCLE1 outputs</li> <li>READING_CYCLE2 outputs</li> <li>WAIT_READ_LATENCY<br/>outputs</li> <li>READING_DATA outputs</li> <li>WAIT_READ_DONE (A<br/>Cycles) outputs</li> <li>READ_DONE outputs</li> <li>BANK_ACTIVE outputs</li> </ul>                                                                                                                                                                                                                                                   |

|             |                                            |                                  | τ |   |
|-------------|--------------------------------------------|----------------------------------|---|---|
|             | Wait until CMD_Dom                         |                                  |   |   |
|             | asserted <b>high</b> .                     | ➢ WAIT_WRITE outputs.            |   |   |
|             |                                            | WRITING_CTCLE1 outputs.          |   |   |
|             |                                            | WRITING_CYCLE2 outputs.          |   |   |
|             | CMD_FSM_Enable                             | ➢ WAIT_WRITE_LATENCY             |   |   |
|             | signal is asserted high                    | a. outputs.                      |   |   |
|             | Same_Bank_Group                            | <b>WRITING_DATA</b> outputs.     |   |   |
|             | signal is asserted <b>Hig</b>              |                                  |   |   |
|             | > CMD signal is asserted                   |                                  |   |   |
|             | <b>'001'</b> .                             | ➢ WRITE_DONE outputs.            |   |   |
|             | First_Command sign                         | -                                |   |   |
|             | asserted Low.                              |                                  |   |   |
|             | > all counter flags are                    |                                  |   |   |
|             | asserted <b>high</b> .                     |                                  |   |   |
|             | <b>Ctrl_ADD</b> signal is                  |                                  |   |   |
|             | asserted <b>a certain val</b>              | 116                              |   |   |
| Write after | CMD_FSM_Enable                             | > IDLE outputs                   |   |   |
| read in     | signal is asserted <b>high</b>             | ÷                                |   |   |
| different   | <ul> <li>Same_Bank_Group</li> </ul>        | $\rightarrow$ ACT_CYCLE1 outputs |   | V |
| Row address | signal is asserted Low                     |                                  |   |   |
|             | <ul> <li>CMD signal is asserted</li> </ul> |                                  |   |   |
|             | <b>'000</b> '.                             | ► WAIT_READ outputs              |   |   |
|             | <ul> <li>First_Command sign</li> </ul>     | ► READING_CTCLE1 outputs         |   |   |
|             | asserted <b>high</b> .                     | READING_CYCLE2 outputs           |   |   |
|             | <ul><li>all counter flags are</li></ul>    | WAIT_READ_LATENCY                |   |   |
|             | 0                                          | outputs                          |   |   |
|             | asserted <b>high</b> .                     | READING_DATA outputs             |   |   |
|             | Ctrl_ADD signal is                         | ➢ WAIT_READ_DONE (A              |   |   |
|             | asserted a certain val                     | cycles) surputs                  |   |   |
|             |                                            | READ_DONE outputs                |   |   |
|             | Wait until CMD_Dom                         |                                  |   |   |
|             | asserted high.                             | PRECHARGE outputs                |   |   |
|             |                                            | ➢ WAIT_tRP outputs               |   |   |
|             |                                            | IDLE outputs                     |   |   |
|             | > CMD_FSM_Enable                           |                                  |   |   |
|             | signal is asserted high                    |                                  |   |   |
|             | Same_Bank_Group                            | ACT_CYCLE2 outputs.              |   |   |
|             | signal is asserted <b>low</b> .            |                                  |   |   |
|             | CMD signal is asserted                     | $\succ$ WAIT_WRITE outputs.      |   |   |
|             | <b>'001'</b> .                             | WRITING_CTCLE1 outputs.          |   |   |
|             | First_Command sign                         | nal is > WRITING_CYCLE2 outputs. |   |   |
|             | asserted high.                             | WAIT_WRITE_LATENCY               |   |   |
|             | all counter flags are                      | outputs.                         |   |   |
|             | asserted <b>Low</b> .                      | > WRITING_DATA outputs.          |   |   |

| Ctrl_ADD signal is        | ➢ WAIT_WRITE_DONE (A   |  |
|---------------------------|------------------------|--|
| asserted a certain value. | cycles) outputs.       |  |
|                           | WRITE_DONE outputs.    |  |
|                           | ➢ BANK_ACTIVE outputs. |  |

**Note:** In consecutive operations, the red colored statements represent the operations of the first command, while the blue colored statements represent the operations of the second command.

### 4.4.3 Reported Bugs



CMD FSM gets stuck at wait\_write\_done state while executing write operation, and at wait\_read\_done state while executing read operation as well.



Figure 44: Single write operation stuck at wait write done state.



After tracing signals, write\_Done signal which is the status signal that FSM determine the next state based on it, was found to be asserted high and returned low before the positive edge of the CK\_t, so CMD FSM couldn't sample it, so it stuck at this state.

As write\_Done signal comes from a WR FSM which instantiated in this block but its operating frequency is **double** the frequency of the CMD FSM, write\_Done signal is asserted high for two clock cycles of the double clock by adding extra state (WR\_DONE2) which WR FSM goes to it unconditionally, the same solution was done to **Read\_Done signal** in RD FSM.

|        | WR_DONE1:<br>begin                             |
|--------|------------------------------------------------|
| 1<br>1 | <pre>Write_Done = 1'bl;<br/>end</pre>          |
| 0      | WR_DONE2:<br>begin                             |
| 5      | <pre>Write_Done = 1'bl;<br/>end</pre>          |
| y<br>e | default:<br>begin<br>Write_Done = 1'b0;<br>end |
| -      | endcase                                        |
|        | end: output_logic                              |



Figure 45: Single write operation after modifying CMD FSM.





Figure 46: DQS, DQT preambles aren't working properly.

Modification: The always block which generates DQS, is changed.

|                             | Mag               |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    |    |
|-----------------------------|-------------------|----------|---|---|---|----|---|----|-----|-------|---|--------|---|---|---|----|----|----------|---|-------|-------|-----|------|---|----|---|----|----|
| N/0K_t                      | 1 <sup>°</sup> h0 |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    |    |
| l/CK_double                 | ihi               | <u> </u> | n | n | n | nn | n | nn | n   | n     | h | hu     | n | n | n | nn | hu | n        | n | n     |       | n   | nn   | n | nn | n | ·n |    |
| /DQS_t                      | 1140              |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    | <u>h</u> |   |       |       |     |      |   |    |   |    |    |
| /DQS_c                      |                   |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    |    |
| l/cmd_fsm/WR/State          | IDLE              | IDLE     |   |   |   |    |   |    | PRE | AMBLE |   | WR DAT | - |   |   |    |    |          |   | (POST | AMBLE | t r | IDLE |   |    |   |    |    |
|                             |                   |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    |    |
| s/cmd_fsm/WR/DQS_clk_Enable | 1140              |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    | 23 |
|                             |                   |          |   |   |   |    |   |    |     |       |   |        |   |   |   |    |    |          |   |       |       |     |      |   |    |   |    |    |

*Figure 47: DQS, DQT preambles are working properly after modification.* 



**Bug #3:** CMD FSM gets stuck at wait\_tRP state.



Figure 48: CMD FSM gets stuck at wait\_tRP state.

**Modification:** it was a trivial error in the next state decoder, as next state was wait\_tRP at the two branches of the condition on tRP signal.

|             | Msgs      |                 |           |                               |                            |                                   |
|-------------|-----------|-----------------|-----------|-------------------------------|----------------------------|-----------------------------------|
| 101.1       | 18-1      |                 |           |                               |                            |                                   |
| I/UK_t      | 101       |                 |           |                               |                            |                                   |
| 1/CK_double | 151       |                 |           | ╊╸┝╼ <mark>┲┿┯┯┿┯┯┿┓</mark> ╖ |                            |                                   |
| (cit_obdoic | ****      |                 |           |                               |                            |                                   |
| ı/State     | PRECHARGE | WAIT WRITE DONE | PRECHARGE | I WAIT IRP                    | IDLE IWAIT ACT TACT CYCLE1 | ACT CYCLE2 BANK ACTIVE WAIT WRITE |
|             |           |                 |           |                               |                            |                                   |

Figure 49: CMD FSM works properly after modification.

#### 4.4.4 Functional Coverage Results



Figure 50: Command FSM Functional Coverage from Coverage Viewer.

### 4.4.5 Code Coverage Results

|                                                      | Questa Instance Coverage                                                   |                    |
|------------------------------------------------------|----------------------------------------------------------------------------|--------------------|
|                                                      | Instance: /CMD_FSM                                                         |                    |
| Instance Path                                        | /CMD_FSM                                                                   |                    |
| Design Unit                                          | work.CMD_FSM                                                               |                    |
| Language                                             | Verilog                                                                    |                    |
| Source File                                          | C:/Users/Belal/Downloads/cmdfsm-20220712T180321Z-001/cmdfsm/hdl/CMD_FSM.sv |                    |
|                                                      |                                                                            |                    |
| ocal Instance Coverag                                | e Details ( 97.28% )                                                       |                    |
|                                                      | e Details ( 97.28% )<br>Bins Hits Misses                                   | Coverage           |
| ocal Instance Coverag<br>Coverage Type ↑<br>Branches |                                                                            | Coverage<br>95.55% |

Figure 51: Command FSM Code Coverage Summary from Questasim.

### 4.5 SELF\_REFRESH FINITE STATE MACHINE

One of the main limitations of dynamic CMOS circuits such as SDRAMS is the signal integrity issues, so it needs refreshing every certain period to defeat signal integrity issues affected by reading from the cell or leakage current by adjusting and updating its internal average periodic refresh interval, as needed, based on its own temperature sensor (does not require any external control), after the interval time passed, tREF counter will be asserted high and the command decoder will assert SR\_FSM\_Enable high to enable only the SR\_FSM, which is responsible for **doing the sequence of operations** which specified in in JESD79-5 section 4.6, that should be done **in order to complete self-Refreshing**.

#### 4.5.1 Functional Coverage Plan

The important features that should be covered to ensure the correctness of the Self\_Refresh FSM functionality are the following:

- 1. Cover point to cover SR\_FSM\_Enable.
- 2. Cover Points to Cover Conter\_Flags to grantee that FSM is behaving correctly in case of they are high and low.

#### 4.5.2 Test Cases

| Test Item    | Test Case                                                                                                        | Expected Result                                                                   | Covered      | Bug<br>Free  |
|--------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------|--------------|
| Self_Refresh | <ul> <li>SR_FSM_Enable signal<br/>is asserted high.</li> <li>all counter flags are<br/>asserted high.</li> </ul> | The sequence of CA and<br>CS_n as shown in<br>Figure 55 specified in<br>JESD79-5. | $\checkmark$ | $\checkmark$ |



Figure 52: Self\_Refresh sequence as specified in JESD79-5 [5].

|                | Msgs    |      |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
|----------------|---------|------|--------|----|--------|------|---------|-----|--------|---------|--------|---------|------|------|------|-------|-------|---------|-------|---------|---|--|
| /CK_c          | 1'h1    | ·    |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
| /CK_t          | 1'h0    |      |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
| /CS_n          | 1ĥ0     |      |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
| /CA            | 14h001f |      | 0217   |    |        |      |         |     |        | 3fff    |        |         |      | 001f |      |       |       |         |       |         |   |  |
| JNext          | NOP2    | SRE  | DES CM | DS | SR N   | lode |         | WAI | tCASRX | WAI     | tcsh s | NOP     | 0    | NOP1 | NOP2 | CHECK | CSL S | WAIT tX | S     | IDLE    |   |  |
| /SR_Done       | 1'h0    |      |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
| /SR_FSM_Enable | ihi     |      |        |    |        |      |         |     |        |         |        |         |      |      |      |       |       |         |       |         |   |  |
| /State         | NOP1    | IDLE | SRE    |    | DES CM | os   | SR Mode |     |        | WAIT to | ASRX   | WAIT to | SH S | NOP0 | NOP1 | NOP2  |       | CHECK t | CSL S | WAIT to | S |  |

*Figure 53: implemented Self\_Refresh waveform.* 

#### 4.5.3 Reported Bugs



### 4.5.4 Functional Coverage Results



Figure 54: Self-Refresh FSM Functional Coverage XML Report.

| 🌾 Functional Coverage | _ |                | $\times$ |
|-----------------------|---|----------------|----------|
| File                  |   |                |          |
| top                   | 1 | 00.0%          |          |
| SR_FSM_Enable         |   | 100.0%         | 6        |
| tCPDED                |   | <b>100.0</b> % | 6        |
| tCSL                  |   | <b>100.0</b> % | 6        |
| tCASRX                |   | <b>100.0</b> % | 6        |
| tCSH_SRExit           |   | <b>100.0</b> % | 6        |
| tCSL_SRExit           |   | <b>100.0</b> % | 6        |
| tXS                   |   | 100.0%         | 6        |

Figure 55: Self-Refresh FSM Functional Coverage from Coverage Viewer.

### 4.5.6 Code Coverage Results

|                                                                      | Questa Design Unit Coverage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |  |  |  |  |  |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|--|--|
|                                                                      | Design Unit: work.SR_FSM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |  |  |  |  |  |
| Design Unit                                                          | work.SR_FSM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |  |  |  |  |  |
| anguage                                                              | Verilog                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |  |  |  |  |  |
| Source File D:/GP/Block Level Verification/Refresh FSM/hdl/SR FSM.sv |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |  |  |  |  |  |
|                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |  |  |  |  |  |
| esign Unit Coverage                                                  | Details ( 98.83% )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | =             |  |  |  |  |  |
| esign Unit Coverage<br>Coverage Type ↑                               | Details ( 98.83% ) Bins Hits Misses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Coverage      |  |  |  |  |  |
|                                                                      | Details ( 98.83% ) Bins Hits Misses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Coverage<br>T |  |  |  |  |  |
| esign Unit Coverage<br>Coverage Type ↑<br>Search                     | Details ( 98.83% )          Bins       Hits       Misses         Y       Search       Y       Search | Coverage      |  |  |  |  |  |

Figure 56: Self-Refresh FSM Code Coverage Summary from Questasim.

### 4.6 INITIALIZATION FINITE STATE MACHINE

Initialization FSM is responsible for doing Set of Sequences as specified in JESD79-5 section 3.3 that should be done in order to power on in a well-known state, starting from power on and ending with loading the mode registers with the default values.

### 4.6.1 Functional Coverage Plan

The important features that should be covered to ensure the correctness of the

#### Initialization FSM functionality are the following:

- 1. Cover point to cover INIT\_FSM\_Enable.
- 2. Cover Points to Cover Conter\_Flags to grantee that FSM is behaving correctly in case of they are high and low.

#### 4.6.2 Test Cases



| Test Item      | Test Case                                                                                                          | Expected Result                                                                  | Covered      | Bug<br>Free  |
|----------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------|--------------|
| Initialization | <ul> <li>INIT_FSM_Enable<br/>signal is asserted high.</li> <li>all counter flags are<br/>asserted high.</li> </ul> | The sequence of CA and<br>CS_n as shown in<br>Figure 3 specified in<br>JESD79-5. | $\checkmark$ | $\checkmark$ |



Figure 57: Initialization sequence as specified in JESD79-5 [5].

|              | Msg       | s            |         |        |        |        |        |      |  |          |           |           |      |
|--------------|-----------|--------------|---------|--------|--------|--------|--------|------|--|----------|-----------|-----------|------|
| 4/CK_c       | 1'h0      |              |         |        |        |        |        |      |  |          |           |           |      |
| 1/CK_t       | 1h1       |              |         |        |        |        |        |      |  |          |           |           |      |
| I/INIT_FSM_E | 1h1       |              |         |        |        |        |        |      |  |          |           |           |      |
| 1/CS_n       | 1h1       |              |         |        |        |        |        |      |  |          |           |           |      |
| 1/CA         | 14h0002   |              |         |        |        |        | (3fff  | 001f |  |          |           | 0005      | 0002 |
| 1/State      | MRW_Cyde2 | IDLE         | State 1 |        | State2 | State3 | State4 | NOP  |  |          | Wait MRW  | MRW Cyde1 | MRW. |
| 1/Next       | MRW_Cyde2 | IDLE State 1 |         | State2 | State3 | State4 | NOP    |      |  | Wait MRW | MRW Cyde1 | MRW Cyde2 |      |
| 1/NOP_Count  | 1'h1      |              |         |        |        |        |        |      |  |          |           |           |      |

Figure 58: implemented initialization waveform.

### 4.6.3 Reported Bugs

FREE OF BUGS

### 4.6.4 Functional Coverage Results

| 🗢 to | .)<br>  |           |           |             |                  |           |               |            |            |           |             |
|------|---------|-----------|-----------|-------------|------------------|-----------|---------------|------------|------------|-----------|-------------|
|      |         | SM_Enable | @size=2   | @coverage=2 | @cover_percent   | age=100.0 | @abs_name=to  | p.INIT_FSA | \_Enable ( | @weight=1 | @at_least=1 |
|      | OtiNIT1 | @size=2   | @coverage | e=2 @cover_ | percentage=100.0 | @abs_nar  | me=top.tINIT1 | @weight=1  | @at_least  | =1        |             |
|      | OtINIT2 | @size=2   | @coverage | e=2 @cover_ | percentage=100.0 | @abs_nar  | me=top.tINIT2 | @weight=1  | @at_least  | =1        |             |
|      | OtINIT3 | @size=2   | @coverage | e=2 @cover_ | percentage=100.0 | @abs_nar  | me=top.tINIT3 | @weight=1  | @at_least  | =1        |             |
|      | OtINIT4 | @size=2   | @coverage | e=2 @cover_ | percentage=100.0 | @abs_nar  | ne=top.tINIT4 | @weight=1  | @at_least  | =1        |             |





*Figure 60: Initialization FSM Functional Coverage from Coverage Viewer.* 

### 4.6.5 Code Coverage Results

| irch                 |                                                 | Questa Design Unit Coverage                                                    |
|----------------------|-------------------------------------------------|--------------------------------------------------------------------------------|
| work.INIT_FSM (100%) |                                                 | Design Unit: work.INIT_FSM                                                     |
|                      | Design Unit                                     | work.INIT_FSM                                                                  |
|                      | Language                                        | Verilog                                                                        |
|                      |                                                 |                                                                                |
|                      | Source File Design Unit Covera                  | D:/GP/Block_Level_Verification/INIT_FSM/hdl/INIT_FSM.sv rrage Details ( 100% ) |
|                      |                                                 |                                                                                |
|                      |                                                 | rage Details ( 100% )                                                          |
|                      | Design Unit Covera                              | rage Details ( 100% )                                                          |
|                      | Design Unit Covera                              | rage Details ( 100% )<br>E<br>Bins Hits Misses Coverag                         |
|                      | Design Unit Covera<br>Coverage Type ↑<br>Search | Trage Details ( 100% )                                                         |

Figure 61: Initialization FSM Code Coverage Summary from Questasim.

### 4.7 COUNTERS

#### 4.7.1 Functional Coverage Plan

The important features that should be covered to ensure the correctness of the

Counter functionality are the following:

- 1. Cover point to cover Counter Enable.
- 2. Cover point to cover Reset.
- 3. Cross Coverage Points to cover Reset and Enable at the same time.

#### 4.7.2 Test Cases

#### Table 48: Test cases of counters.

| Test Item | Test Case                                                                                                  | Expected Result                                                                                                                                                 | Covered      | Bug<br>Free  |
|-----------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
| Enable    | <ul> <li>Counter_Enable signal is asserted high.</li> <li>Counter_Reset signal is asserted Low.</li> </ul> | <ul> <li>After a specific number<br/>of clock cycles<br/>according to value of<br/>timing parameter</li> <li>Counter Flag will be<br/>asserted High.</li> </ul> | $\checkmark$ | $\checkmark$ |

| Reset | <ul> <li>Counter_Enable signal is<br/>asserted low.</li> <li>Counter_Reset signal is<br/>asserted High.</li> </ul> | Counter Flag will be asserted low immediately. | $\checkmark$ | $\checkmark$ |
|-------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------|--------------|
|-------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------|--------------|

### 4.7.3 Reported Bugs

| 2893.90ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | oy:215 in Co | unter_test  |                        | Enable | : 1        |           |                 |                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------|-----------------|--------------|-------------|------------------------|--------|------------|-----------|-----------------|---------------------------|
| 2893.90ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | py:216 in Co | unter_test  |                        | Reset: | 0          |           |                 |                           |
| 2893.90ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | py:83 in No  | ofCycles    |                        | Initia | lization ( | Counter_4 | is being T      | ested                     |
| 3214.10ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | oy:223 in Co | unter_test  |                        | DUT ou | tput: 0    |           |                 |                           |
| 3214.10ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | oy:224 in Co | unter_test  |                        | Refren | ce output  | : 1       |                 |                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                  |                    |                 |              |             |                        |        |            |           |                 |                           |
| 3214.10ns INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cocotb.test                                                      |                    | Counter_Test.   | py:229 in Co | unter_test  |                        | Testca | se Failed  |           |                 |                           |
| 3214.10ns INFO<br>이 · 글 별 글 글 : & 맥이<br>법 급 는 또 둔 군 도 급                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | •• <u>1</u> 2-1 •••                                              | <br>₩ 22 ] 40 XI • | _               | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | 9 <b>] ] • • 1</b>     |        |            |           | <b>, a</b> th   |                           |
| ┙╹┛┙╝╝╝<br>┺┺╝╝╝┙╝                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | •• <u>1</u> 2-1 •••                                              | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 |                        |        |            |           | ▝▝▋᠅╨           |                           |
| n . <b>m</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ua 12:12   ♥ * 6<br> ] 3+ • +€ • 3+                              | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | o∏ <b>:</b> : i        |        |            |           | <b>₹ ⊡</b> \$ Ш | . <u>:Li</u>   <b>B</b> D |
| ╝╺┢╸┫╶┙═╵Ѧ╺═<br>┇╏╶┠╶┨┠╶┨┠╶┨<br>┛╸                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ■ <u>12</u>   ● • •<br>  ] <b>3+ • +€ • 3+</b>  <br>  Maga       | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | 5   : •• :             |        |            |           |                 |                           |
| Ů╹╋╋╋╡╤╦┆ᇮ┉┉<br>┇┇┇┖╼┇┠┨┇┇<br>┫╸<br>╱(contens/DC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | tha<br>→ 12 - 12   • • •<br>→ +€ • 3+  <br>Maga<br>Maga          | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | ⊃    <b>: •• :</b> : ! |        |            |           |                 | , <u>10</u>   <b>0</b> 0  |
| U • De Tel 2 ⊂ Certes(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counters(DK):<br>Counter | Cal 12 12   ↓ • • C                                              | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | 3    I • <b>4</b> I    |        |            |           |                 | . <u>10</u>   <b>8</b> 0  |
| A Countery(DICT), Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | E2:2   ♥ • I       3+ • +€ • 3+         Mops       th1       th0 | <br>               | T 🖛 🖛   💵   100 | pa 💽 🖬 🖬 🖬   | 2 😽   🖄 🔟 🖞 | 5    1 ** 1            |        |            |           |                 | . <u>10</u>   <b>8</b> 0  |
| A Countery(DICT), Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | E2:2   ♥ • I       3+ • +€ • 3+         Mops       th1       th0 | <br>               | T 🖛 🖛   💵   100 | pa 💽 🗐 🗐 🗐   | 2 😽   🖄 🔟 🖞 | 9    I •• I            |        |            |           |                 | , <u>10</u>   <b>0</b>    |

Figure 62: Counter Flag is asserted High for only one Clock Cycle.

### 4.7.4 Functional Coverage Results

| C Enable @size=2                                                                                                | @coverage=2                            | @cover_percentage=100.0 | @abs_name=top.Enable | @weight=1  | @at_least=1   |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------|-------------------------|----------------------|------------|---------------|
| Reset @size=2                                                                                                   | @coverage=2                            | @cover_percentage=100.0 | @abs_name=top.Reset  | @weight=1  | @at_least=1   |
| EnXRst @size=4                                                                                                  | @coverage=4                            | @cover_percentage=100.0 | @abs_name=top.EnXRs  | t @weight= | 1 @at_least=1 |
| bin0 :                                                                                                          |                                        |                         |                      |            |               |
| @bin=(True, Tr<br>@hits=11                                                                                      | rue)                                   |                         |                      |            |               |
| @abs_name=top                                                                                                   | p.EnXRst.bin0                          |                         |                      |            |               |
| Ø bin1 :                                                                                                        |                                        |                         |                      |            |               |
|                                                                                                                 |                                        |                         |                      |            |               |
| @bin=(True, Fa                                                                                                  | lse)                                   |                         |                      |            |               |
| @bin=(True, Fa<br>@hits=27                                                                                      |                                        |                         |                      |            |               |
| @bin=(True, Fa                                                                                                  |                                        |                         |                      |            |               |
| @bin=(True, Fa<br>@hits=27                                                                                      |                                        |                         |                      |            |               |
| @bin=(True, Fa<br>@hits=27<br>@abs_name=top<br>bin2 :<br>@bin=(False, Tr                                        | p.EnXRst.bin1                          |                         |                      |            |               |
| @bin=(True, Fa<br>@hits=27<br>@abs_name=top<br>bin2 :<br>@bin=(False, Tr<br>@hits=34                            | p.EnXRst.bin1<br>rue)                  |                         |                      |            |               |
| ©bin=(True, Fa<br>©hits=27<br>@abs_name=to<br>⊅bin2 :<br>@bin=(False, Tr<br>@hits=34<br>@abs_name=to            | p.EnXRst.bin1<br>rue)                  |                         |                      |            |               |
| ©bin=(True, Fa<br>@hits=27<br>@abs_name=top<br>bin2 :<br>@bin=(False, Tr<br>@hits=34<br>@abs_name=top<br>bin3 : | p.EnXRst.bin1<br>rue)<br>p.EnXRst.bin2 |                         |                      |            |               |
| ©bin=(True, Fa<br>©hits=27<br>@abs_name=to<br>⊅ bin2 :<br>@bin=(False, Tr<br>@hits=34<br>@abs_name=to           | p.EnXRst.bin1<br>rue)<br>p.EnXRst.bin2 |                         |                      |            |               |

*Figure 63: Counters Functional Coverage XML Report.* 



Figure 64: Counters Functional Coverage from Coverage Viewer.

#### 4.7.5 Code Coverage Results

| h                      |                                  | Questa Design Unit Coverage<br>Design Unit: work.Counters |          |
|------------------------|----------------------------------|-----------------------------------------------------------|----------|
| vork.Counters (98.83%) |                                  |                                                           |          |
|                        | Design Unit                      | work.Counters                                             |          |
|                        | Language                         | Verilog                                                   |          |
|                        |                                  |                                                           |          |
|                        | Source File                      | D:/GP/Block_Level_Verification/Counters/hdl/Counters.sv   |          |
|                        | Source File Design Unit Coverage |                                                           |          |
|                        |                                  |                                                           | =        |
|                        |                                  |                                                           | Coverage |
|                        | Design Unit Coverage             | e Details ( 98.83% )                                      |          |

Figure 65: Counters Code Coverage Summary from Questasim.

| # 76872.70ns                          | INFO | cocotb.test                                    | Counter Test.py:83  | in N |
|---------------------------------------|------|------------------------------------------------|---------------------|------|
| oofCycles<br>#                        |      | Initialization Counter_4 is be:                |                     |      |
| # 76873.70ns<br>ounter_test<br>#      | INFO | cocotb.test<br>DUT output: 0                   | Counter_Test.py:208 | in C |
| # 76873.70ns<br>ounter_test<br>#      | INFO | cocotb.test<br>Refrence output: 0              | Counter_Test.py:209 | in C |
| # 76873.70ns<br>ounter_test<br>#      | INFO | cocotb.test<br>Testcase Passed                 | Counter_Test.py:211 | in C |
| <pre># 76873.70ns ounter_test #</pre> | INFO | cocotb.test<br>no of Passed Testcases: 100     | Counter_Test.py:217 | in C |
| <pre># 76873.70ns ounter_test #</pre> | INFO | cocotb.test<br>no of Failed Testcases: 0       | Counter_Test.py:219 | in C |
| # 76873.71ns<br>score_test<br>#       | INFO | cocotb.regression<br>Test Passed: Counter_test | regression.py:364   | in _ |
| # 76873.71ns                          | INFO | cocotb.regression                              | regression.py:487   | in _ |

Figure 66: Counters Test Summary from Questasim.

## **Chapter 5: UVM VS COCOTB**

### **5.1 INTRODUCTION**

In order to compare between UVM verification and COCOTB verification we choose block from our design which is the FIFO and test it with UVM and COCOTB.

### 5.1.1 UVM verification

A key concept for any modern verification methodology is the layered test bench. Although this process may seem to make the test bench more complex, it actually helps to make the task easier by dividing the code into smaller pieces that can be developed separately. The proposed UVM-based verification architecture for WR\_Data\_FIFO block is shown in Figure 67 [14].



Figure 67: UVM environment for WR\_Data\_FIFO block [14].

#### 5.1.2 UVM verification environment components

#### UVM verification environment is composed of different components such as [15]:

- **Driver** which drives the DUT's inputs as it runs single commands, such as bus read or write.
- **Monitor** which is driven by the DUT's output as it that takes signal transitions and groups them together into commands.
- Assertions which cross the command/signal layer, as they look at individual signals.
- **Sequencer** which takes sequence items from a sequence and passes them to the driver.
- **Functional coverage** measures the progress of all tests in fulfilling the verification plan requirements.

#### **5.2 VERIFICATION PLAN**

First step in verification process is to make the verification plan which is derived from the hardware specification and contains a description of what features need to be exercised and the techniques to be used. These steps may include directed or random testing and assertions.

So, we make verification plan for testing FIFO which is to:

- Ensure that we can write and read from FIFO and make sure that it follows first input data is the first output data
- Ensure that full flag is high when FIFO is full and ensure that empty flag is high when FIFO is empty
- Ensure that read, write pointer, full, empty flag are reset when Reset is high.

Then we make testing scenarios and ensure that our tests provide 100% coverage of the entire verification plan.

#### 5.2.1 Testing scenarios:

- 1. Write 16 data packets until the FIFO is full then read all 16 data packets and compare whether the data is same as what have been written previously.
- 2. Write and read data randomly for 50 times.
- 3. Using system Verilog assertions for:
  - Asserting for that Read pointer, write pointer, FIFO counter, full flag and empty flag are now reset when Reset is high.
  - Asserting for that FIFO full flag is high when FIFO has no space to write in.
  - Asserting for writing in a full FIFO and FIFO full flag is high.
  - Asserting for that FIFO empty flag is high when all data have been read.
  - Asserting for trying to read from empty FIFO and FIFO empty flag is high.

#### **5.3 RESULTS FROM UVM VERIFICATION**

There were some few errors that we have discovered from results of simulation such as:

```
# RD_En is high
# UVM_INFO C:/fifo/FIF0_UVM.sv(328) @ 580: uvm_test_top.f_env.f_scb [Read Data] examdata: 3a FIF0_WR_Data: 0 empty: 0
# ------ Fail! -------
# ------ Check empty -------
```

*Figure 68: 1st example of error from simulation.* 

The solution of this error was editing the size of Read Pointer to be 4 bits as FIFO depth is 16.



Figure 69: 2nd example of error from simulation.

The solution of this error was editing the condition for FIFO full flag to be high only if FIFO counter equals 16. Etc.

We solved all design errors and the final UVM Report Summary and Coverage is shown in Figure 70.

| Instance In | 🕼 sim - Default                                                                                                                                                                                               |                                                                                                |                                                                                                                              | + # ×                                                                               | 📰 Wave - Default |                                                                                        | <br>ы× |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------|--------|
| Image: State top       f.ter       SYClastics       Top (State State                                                          | ▼ Instance                                                                                                                                                                                                    | △ Design unit Tr                                                                               | otal coverage Design unit typ                                                                                                | e Top C 🔺                                                                           | <b>2</b> .       | Msgs                                                                                   |        |
| Iterary N I Project N Q sm N       Iterary N I Project N Q sm N       Iterary N I Project                                                 | Jun test top       | f_test<br>tb(fast)<br>tb(fast)<br>WR_Data<br>f_interface<br>uvm_pkg(f<br>FIPO_UVM<br>questa_uv | SVClassitem<br>85.71% Module<br>Process<br>85.71% Module<br>Interface<br>VPackage<br>83.66% VPackage<br>VPackage<br>VPackage | TB Cc<br>DU In<br>-<br>DU In<br>DU In<br>Packa<br>Packa<br>Packa<br>Packa<br>Statis |                  | 256/h0000000<br>1h0<br>1h0<br>256/h0000000<br>1h0<br>->@100730 rs<br>100740 rs<br>0 rs |        |
| Transvot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                               |                                                                                                |                                                                                                                              |                                                                                     |                  |                                                                                        |        |
| <pre>* UVM Report Summary * * Report counts by severity * UVM_INFO : 5003 * UVM_IARAINED : 0 * UVM_IARAINED : 0 * UVM_IARAINED : 0 * UVM_IARAINED : 0 * * Report counts by id * (RestTRIST] 1 * [ReatTRIST] 1 * [ReatTRIST] 264 * [IEST_COMED 1 * [L=sequence] 3 </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                               |                                                                                                |                                                                                                                              | <u> </u>                                                                            |                  | J                                                                                      |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <pre>** Report Summary ** Report counts by severity UVM_INTO: 5005 UVM_EAROR: 0 UVM_EAROR: 0 UVM_EAROR: 0 ** Report counts by id [Questa UVM] 2 [RNTST] 1 [Read Data] 2464 [IEST_DONE] 1 [[_eequence] 3</pre> |                                                                                                |                                                                                                                              |                                                                                     |                  |                                                                                        |        |

Figure 70: UVM Report Summary and Coverage

Also, all assertions are passed as shown in Figure 71. And the assertions coverage is shown in Figure 72.

| Transcript                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| File Edit View Bookmarks Window Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| The second secon |          |
| W En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <u> </u> |
| # UVM INFO C:/fifo/FIFO UVM.sv(328) @ 270: uvm test top.f env.f scb [write Data] WR En: 1 RD En: 0 Ctrl DataIn: a9 full: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |
| # 270: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # 280: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # WR_En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| # UVM_INFO C:/fifo/FIFO_UVM.sv(328) @ 290: uvm_test_top.f env.f scb [write Data] WR_En: 1 RD_En: 0 Ctrl_DataIn: 0 full: 0<br># 290: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |
| <ul> <li>Assertion Passed: The design passed the file not full condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |
| WR En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |
| # UVM_INFO C:/fifo/FIFO_UVM.sv(328) @ 310: uvm_test_top.f_env.f_scb [write Data] WR_En: 1 RD_En: 0 Ctrl_DataIn: b5 full: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |
| # 310: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # UVM_INFO C:/fifo/FIFO_UVM.sv(290) 0 320: uvm_test_top.f_env.f_agt.f_seqr00f_seq [f_sequence] ******** Generate 16 Read REQs ********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |
| # 320: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # WR_En is high<br># UVM INFO C:/fifo/FIFO UVM.sv(328) @ 330: uvm test top.f env.f scb [write Data] WR En: 1 RD En: 0 Ctrl DataIn: 51 full: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |
| 4 330: Assertion Passed: The design passed the fife should go full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |
| <ul> <li>330: Assertion Passed: The design passed the fife should go full condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| 340: Assertion Passed: The design passed the fifo full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |
| # 350: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # RD_En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| # UVM_INFO C:/fifo/FIFO_UVM.sv(333) @ 360: uvm_test_top.f_env.f_scb [Read Data] examdata: 3a FIFO_WR_Data: 3a empty: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |
| # Pass!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| <ul> <li>360: Assertion Passed: The design passed the fifo not full condition.</li> <li>370: Assertion Passed: The design passed the fifo not full condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |
| # RD En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| # UVM INFO C:/fifo/FIFO UVM.sv(333) @ 380: uvm test top.f env.f scb [Read Data] examdata: 85 FIFO WR Data: 85 empty: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |
| + Pass!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # 380: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # 390: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # RD_En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| <pre># UVM_INFO C:/fifo/FIFO_UVM.sv(333) @ 400: uvm_test_top.f_env.f_scb [Read Data] examdata: df FIFO_WR_Data: df empty: 0 #</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |
| # 400: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| 4 410: Assertion Passed: The design passed the fifo not full condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| # RD_En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
| # UVM_INFO C:/fifo/FIFO_UVM.sv(333) @ 420: uvm_test_top.f_env.f_scb [Read Data] examdata: a2 FIFO_WR_Data: a2 empty: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |
| # Pass!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |
| <ul> <li>420: Assertion Passed: The design passed the fifo not full condition.</li> <li>430: Assertion Passed: The design passed the fifo not full condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |
| # AD is high<br># RD En is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -        |





Figure 72: The assertions coverage.

#### **5.4 RESULTS FROM COCOTB VERIFICATION**

We did verification for WR\_Data\_FIFO block also with COCOTB and we get the same errors results as that we got from UVM verification as shown in Figure and the results are shown in Figure 73.

| 0.65ns INFO | Data written to fifo: C4776B1B                                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0.85ns INFO | Data written to fifo: 71FEEB625                                                                                                                     |
| 1.05ns INFO | Data written to fifo: 4B62C794B                                                                                                                     |
| 1.25ns INFO | Data written to fifo: 7D562376F                                                                                                                     |
| 1.45ns INFO | Data written to fifo: 58699AC0A                                                                                                                     |
| 1.65ns INFO | Data written to fifo: 6F0B6AB17                                                                                                                     |
| 1.85ns INFO | Data written to fifo: 2AA7827C9                                                                                                                     |
| 2.05ns INFO | Data written to fifo: 5D78CC64E                                                                                                                     |
| 2.25ns INFO | Data written to fifo: 52EC776F8                                                                                                                     |
| 2.45ns INFO | Data written to fifo: A941C580                                                                                                                      |
| 2.65ns INFO | Data written to fifo: 78AB95DAD                                                                                                                     |
| 2.85ns INFO | Data written to fifo: 42CE2789F                                                                                                                     |
| 3.05ns INFO | Data written to fifo: 5BD0123C9                                                                                                                     |
| 3.25ns INFO | fifo_test failed                                                                                                                                    |
|             | Traceback (most recent call last):                                                                                                                  |
|             | File "C:\Users\Belal\Downloads\fifooo\fifofinal\tests\fifo_test.py", line 114, in fifo_test                                                         |
|             | <pre>assert(data -= fifo_model.pop())</pre>                                                                                                         |
|             | AssertionError: assert 0 == 25580231248                                                                                                             |
|             | + where 25580231248 = <built-in 0x000000006d74a00="" at="" collections.deque="" method="" object="" of="" pop="">()</built-in>                      |
| 26,]).pop   | + where <built-in 0x000000006d74a00="" at="" collections.deque="" method="" object="" of="" pop=""> = deque([24645805001, 17932908703, :</built-in> |
| 3.25ns INFO | ••••••••••••••••••••••••                                                                                                                            |
|             | ** TEST STATUS SIM TIME (ns) REAL TIME (s) RATIO (ns/s) **                                                                                          |
| T.          | ••••••••••••••••••••                                                                                                                                |
| I           | ** fifo_test.fifo_test FAIL 3.25 0.01 259.87 **                                                                                                     |
|             |                                                                                                                                                     |

Figure 73: Result of errors from COCOTB.

After solving all design errors, the final COCTB Report which shows that tests are passed is shown in Figure 74.

| #  | 976.65ns INFO | Data NOT written, fifo FULL!    |
|----|---------------|---------------------------------|
| #  | 976.85ns INFO | Data read from fifo: F9CAA964   |
| #  | 977.05ns INFO | Data written to fifo: 3D7191419 |
| #  | 977.25ns INFO | Data NOT written, fifo FULL!    |
| #  | 977.45ns INFO | Data NOT written, fifo FULL!    |
| #  | 977.65ns INFO | Data read from fifo: 28654EB9D  |
| #  | 977.85ns INFO | Data read from fifo: 4385B1C38  |
| #  | 978.05ns INFO | Data written to fifo: 4FC1FD279 |
| #  | 978.25ns INFO | Data read from fifo: 7C8A43FD4  |
| #  | 978.45ns INFO | Data written to fifo: 280F2FBF6 |
| #  | 978.65ns INFO | Data read from fifo: 24131BEAF  |
| #  | 978.85ns INFO | Data written to fifo: 688CF0D11 |
| #  | 979.05ns INFO | Data read from fifo: 7540373D9  |
| #  | 979.25ns INFO | Data written to fifo: 793DE148E |
| #  | 979.45ns INFO | Data written to fifo: 196169EA2 |
| ## | 979.65ns INFO | Data NOT written, fifo FULL!    |
| #  | 979.85ns INFO | Data NOT written, fifo FULL!    |
| #  | 980.05ns INFO | Data read from fifo: 4876cC345  |
| #  | 980.25ns INFO | Data written to fifo: 4A4728542 |
| #  |               |                                 |

| CONTRACTOR AND A DESCRIPTION OF A DESCRIPTION OF |                                                                                                                                                      |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1000.05ns INFO                                   | top : <cocotb_coverage.coverage.coveritem 0x000000006c379d0="" at="" object="">, coverage=8, size=8</cocotb_coverage.coverage.coveritem>             |
| 1000.05ns INFO                                   | top.fifo_full : <cocotb_coverage.coverage.coverpoint 0x000000006c37b20="" at="" object="">, coverage=2, size=2</cocotb_coverage.coverage.coverpoint> |
| 1000.05ns INFO                                   | BIN True : 2138                                                                                                                                      |
| 1000.05ns INFO                                   | BIN False : 2862                                                                                                                                     |
| 1000.05ns INFO                                   | top.rw : <cocotb_coverage.coverage.coverpoint 0x000000006c37910="" at="" object="">, coverage=2, size=2</cocotb_coverage.coverage.coverpoint>        |
| 1000.05ns INFO                                   | BIN True : 1168                                                                                                                                      |
| 1000.05ns INFO                                   | BIN False : 3832                                                                                                                                     |
| 1000.05ns INFO                                   | top.rwxfull : <cocotb_coverage.coverage.covercross 0x000000006637b50="" at="" object="">, coverage=4, size=4</cocotb_coverage.coverage.covercross>   |
| 1000.05ns INFO                                   | BIN (True, True) : 498                                                                                                                               |
| 1000.05ns INFO                                   | BIN (True, False) : 670                                                                                                                              |
| 1000.05ns INFO                                   | BIN (False, True) : 1640                                                                                                                             |
| 1000.05ns INFO                                   | BIN (False, False) : 2192                                                                                                                            |
| 1000.05ns INFO                                   | fifo_test passed                                                                                                                                     |
| 1000.05ns INFO                                   |                                                                                                                                                      |
|                                                  | ** TEST STATUS SIM TIME (ns) REAL TIME (s) RATIO (ns/s) **                                                                                           |
|                                                  |                                                                                                                                                      |
|                                                  | ** fifo_test.fifo_test PASS 1000.05 3.16 316.33 **                                                                                                   |
|                                                  |                                                                                                                                                      |
|                                                  | ** TESTS=1 PASS=1 FAIL=0 SKIP=0 1000.05 3.18 314.78 **                                                                                               |
|                                                  |                                                                                                                                                      |

Figure 74: COCOTB verification results

Functional coverage percentage is 100% as shown in Figure 75 and Code coverage percentage is 99.09% as shown in Figure 76.

```
▼<top abs name="top" size="8" coverage="8" cover percentage="100.0">
  v<rw size="2" coverage="2" cover_percentage="100.0" abs_name="top.rw" weight="1" at_least="1">
     <bin0 bin="True" hits="1168" abs_name="top.rw.bin0"/>
     <bin1 bin="False" hits="3832" abs_name="top.rw.bin1"/>
   </rw>
  v<fifo full size="2" coverage="2" cover percentage="100.0" abs name="top.fifo full" weight="1"</pre>
   at least="1">
     <bin0 bin="True" hits="2138" abs name="top.fifo full.bin0"/>
     <bin1 bin="False" hits="2862" abs_name="top.fifo_full.bin1"/>
   </fifo full>
  v<rwXfull size="4" coverage="4" cover percentage="100.0" abs name="top.rwXfull" weight="1"</pre>
   at least="1">
     <bin0 bin="(True, True)" hits="498" abs name="top.rwXfull.bin0"/>
     <bin1 bin="(True, False)" hits="670" abs_name="top.rwXfull.bin1"/>
     <bin2 bin="(False, True)" hits="1640" abs_name="top.rwXfull.bin2"/>
     <bin3 bin="(False, False)" hits="2192" abs_name="top.rwXfull.bin3"/>
   </rwXfull>
 </top>
```

Figure 75: COCOTB Functional coverage report

|                                                     | Instance /                         | WR_Data_FIFO        |                 |         |                                    |
|-----------------------------------------------------|------------------------------------|---------------------|-----------------|---------|------------------------------------|
|                                                     | mstance. j                         |                     |                 |         |                                    |
| Instance Path                                       | /CMD                               |                     |                 |         |                                    |
| Design Unit                                         | work.CMD                           |                     |                 |         |                                    |
| Language                                            | Verilog                            |                     |                 |         |                                    |
|                                                     |                                    |                     |                 |         |                                    |
| Source File                                         | C:/Users/Belal/Downloads/fifooo/fi | fofinal/tests/WR_Da | ta_FIFO.sv      |         |                                    |
| ocal Instance Coverag                               | e Details ( <b>99.81%</b> )        |                     |                 |         |                                    |
| ocal Instance Coverage                              | : Details ( <b>99.81%</b> )        | Bins                | Hits            | Misses  | Coverage                           |
| ocal Instance Coverage<br>Coverage Type ↑<br>Search | • Details ( 99.81% )               | Bins<br>▼ Search    | Hits<br>T Searc |         |                                    |
| Coverage Type ↑                                     |                                    |                     |                 |         | Coverage                           |
| Coverage Type ↑<br>Search                           |                                    | ₹ Search            | ₹ Searc         | h 🍸 Sea | Coverage<br>arch                   |
| Coverage Type ↑<br>Search<br>Branches               |                                    | TSearch16           | Searc           | h T Sea | Coverage<br>arch T<br>100%         |
| Coverage Type ↑<br>Search<br>Branches<br>Conditions |                                    | TSearch1610         | YSearch1610     | h T Sea | Coverage<br>arch T<br>100%<br>100% |

Figure 76: COCOTB Code coverage report

### **5.5 HISTORY OF VERIFICATION METHODS:**

In order to understand why using COCOTB we should first know the History of verification methods. Traditionally, when faced with the task of verifying the directed tests method is used by writing stimulus vectors that exercise the features in the DUT. Then simulating the DUT with these vectors and manually reviewing the resulting log files and waveforms to make sure the design work properly. The problem with the directed tests method is when the design complexity doubles, it takes twice as long to complete or requires twice as many people to implement it.

So, the second method which is Constrained-Random Stimulus is used as constrained-random test bench is now finding bugs faster than the many directed ones as shown in Figure 77 [13]. Another advantage is that directed test finds the bugs you expect to be in the design, whereas a random test can find bugs you never anticipated. When using random stimuli, you need functional coverage to measure verification progress. Furthermore, once you start using automatically generated stimuli, you need an automated way to predict the results generally a scoreboard or reference model. Building the test bench infrastructure, including self-prediction, takes a significant amount of work. A layered test bench helps you control the complexity by breaking the problem into manageable pieces.



Figure 77: Constrained-random test progress over time vs. directed testing [13].

AS higher-level language concepts (like OOP) are useful when writing layered and complex test benches so they Added higher level programming features to a hardware description language (System Verilog). So UVM (Universal Verification Methodology) libraries written in System Verilog.

The SV/UVM approach is powerful, but complicated. Since the Verification test benches are software, not hardware problem so the COCOTB's developers tried a different approach which is using a high-level, general-purpose language (Python) for developing test benches.

#### **5.6 TRADEOFFS BETWEEN USING UVM AND COCOTB:**

- 1) The SV/UVM approach is powerful, but complicated as system Verilog has around 250 keywords and its reference has around 1300 pages as shown in Figure 78 [16].
- 2) COCOTB's developers, Chris Higgs and Stuart Hodgson, tried a different approach:
  - Keep the hardware description languages for what they're good at-design!
  - Use a high-level, general-purpose language for developing test benches.
  - Object oriented programming is much more natural in general purpose languages!
  - They picked Python as their language of choice: Python is simple (only 35 keywords) and easy to learn, but very powerful.
  - The Python reference is around 160 pages.
  - Python has a large standard library and a huge ecosystem; lots of existing libraries.
  - Python is well documented and popular: lots of resources online.
  - The Python test bench can read or change the value of any internal signal.
  - COCOTB can be used for post-synthesis simulations too!
  - Tests can call other methods and functions, just like normal Python

3) Also, now there are developers making the Universal Verification Methodology (UVM) implemented in Python to get advantage of reusable components which is provided by UVM.



Figure 78: Programming languages Complexity.

#### **5.7 FUTURE OF PYTHON IN VERIFICATION:**

Here are two studies from Siemens were made in 2020. first study is about FPGA verification language adoption next twelve months which shows that using of python in verification has increased over the years and it exceeds 20% in usage with respect to other languages as shown in Figure 79 [17].

Second study is about ASIC/IC verification language adoption next twelve months which shows that using of python in verification has increased over the years and it reaches around 30% in usage with respect to other languages as shown in Figure 80 [17].



#### FPGA Verification Language Adoption Next Twelve Months





#### ASIC/IC Verification Language Adoption Next Twelve Months

Figure 80: ASIC/IC verification language adoption next twelve months [17].

So, it is clear that using of python in verification is increasing and after implementing UVM in Python it is predictable that using of python will increase more.

# **Chapter 6: Top Level Verification**

#### **6.1 VERIFICATION ENVIRONMENT:**

The environment is the same as environment of block level verification except new item is added called slave model as shown in Figure 81 [18]:



Figure 81 : Verification Environment of Top-Level Verification [18].

Slave model is added to verification environment in order to check the functionality of the controller. It represents model of DDR5 SDRAM Memory to captures the Read/Read\_With\_AutoPrecharge/Read\_Burst/Read\_Burst\_AutoPrecharge/Write/Write\_With\_AutoPre charge/Write\_Burst/Write\_Burst\_AutoPrecharge/ACT/Precharge request from the controller. The Memory Module concatenates the requested address for write or read from Read/Write/ACT commands which are sent to the memory module. For the Write command the write data which is captured from DQ and DQS pins is stored in an associate array in required address. For the Read command the memory module send read data by DQ and DQS pins to controller. For the Precharge command the memory module deactivate the row in requested bank. So, by The Memory Module which is shown in Figure 82 we can compare the data sent from generator to the controller is equal to data received.





#### **6.2 FUNCTIONAL COVERAGE PLAN:**

The important features that should be covered to ensure the correctness of the Top-Level functionality are the following:

- 1. Reset.
- 2. Self-Refresh.
- 3. Reset and Self\_Refresh/command in the same time to ensure the priority of reset.
- 4. All types of write command (write, write Burst, write with AP, write burst with AP).
- 5. All types of read command (read, read Burst, read with AP, read burst with AP).
- 6. Two consecutive writes (write, write with AP) in same bank group.
- 7. Two consecutive writes (write, write with AP) in different bank group.
- 8. Two consecutive reads (read, read with AP) in same bank group.
- 9. Two consecutive reads (read, read with AP) in different bank group.
- 10. Read after write in same bank group.
- 11. Read after write in different bank group.
- 12. Write after read in same bank group.
- 13. Write after read in different bank group.
- 14. All types of write command (write, write Burst, write with AP, write burst with AP).
- 15. All types of read command (read, read Burst, read with AP, read burst with AP).
- 16. Two consecutive writes (write, write with AP) in same bank group.
- 17. Two consecutive writes (write, write with AP) in different bank group.
- 18. Two consecutive reads (read, read with AP) in same bank group.
- 19. Two consecutive reads (read, read with AP) in different bank group.
- 20. Read after write in same bank group.
- 21. Read after write in different bank group.
- 22. Write after read in same bank group.
- 23. Write after read in different bank group.
- 24. Multiple read after multiple write in different bank group.
- 25. Multiple read after multiple write in different bank group.

#### **6.3 REPORTED BUGS:**



First command after initialization stuck at WAIT\_ACT state in Command\_FSM as shown in Figure 83. This happened as in this state timing between consecutive active commands is checked, so it won't be satisfied as this is the first command and there are not previous commands to count these timings.



Figure 83:Top Module is stuck at WAIT\_ACT state

**Modification:** This problem is not related only to timing of active commands; it's also related to read and write timing parameters. We solved this problem by adding status register to store 1 after initialization indicating that the command will be executed later is the first command and no need for checking timing between consecutive commands in Command\_FSM.



Bug #2: Same\_Bank\_Group Signal

The value of Same\_Bank\_Group signal changes each cycle as controller receives commands from CPU each clock cycle, so we lose this information as it's not stored like commands, addresses and data in FIFO which leads strange performance.

**Modification:** Same\_Bank\_Group signal is also stored with command and address in Command\_Address\_FIFO.



**Bug #3:** Read Words with length less than burst length as shown in Figure 84 due to mistake counters which are used in Read\_FSM block.

| ∳ /Controller_top_level/CK_t        | 1ħ1            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
|-------------------------------------|----------------|----------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|------|------|-------------|------------------|---------------|-------------|----------------------|
| 👍 /Controller_top_level/CK_c        | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 4/Controller_top_level/CK_double    | 1ĥ0            | டி       |                                         |                                         |                                         |                                         |      | þ.n. | hn          |                  | hn            |             |                      |
| 👍 /Controller_top_level/Ctrl_Reset  | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 👍 /Controller_top_level/Ctrl_Read   | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 👍 /Controller_top_level/Ctrl_Write  | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 👍 /Controller_top_level/Ctrl_Auto   | 1ħ0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 👍 /Controller_top_level/Ctrl_Burst  | 1ħ0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 🛃 🎝 /Controller_top_level/Ctrl_ADD  | 31h00000000    | 00000000 |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 🛃 /Controller_top_level/Ctrl_DataIn | 256h000000000  | 00000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 00000000000000                          | 0000 |      |             |                  |               |             |                      |
| 🔩 /Controller_top_level/Ctrl_busy   | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
|                                     | 256°h000000000 | 00000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 0000 |      | 00000000000 | 1000 1000 1000 1 | 0001000100010 | 00100010001 | 000 1000 1000 1000 1 |
| 🔩 /Controller_top_level/Reset_n     | 1h0            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| E-4 /Controller_top_level/CA        | 14h0000        | 0000     |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |
| 4. /Controller_top_level/CS_n       | 1ħ1            |          |                                         |                                         |                                         |                                         |      |      |             |                  |               |             |                      |

Figure 84: Read words with length less than burst length

Modification: Counters in Read\_FSM are fixed with correct values

**Bug #4:** The Memory Module and the Controller can drive DQ and DQS pins in Write or Read operations so this produces a bug as DQ and DQS pins have now multiple drivers.



The solution for this bug is by using 3-State Buffer or more commonly a Tri-state Buffer as shown in Figure 85. A Tri-state Buffer can be thought of as an input-controlled switch with an output that can be electronically turned "ON" or "OFF" by means of an external "Control" or "Enable" (EN) signal input. This control signal can be either logic "0" or a logic "1" type signal resulting in the Tri-state Buffer being in one state allowing its output to operate normally producing the required output or in another state where its output is blocked or disconnected.



Figure 85: Tri-state Buffer.

When activated into its third state it disables or turns "OFF" its output producing an open circuit condition that is neither at a logic "HIGH" or "LOW", but instead gives an output state of very high impedance, High-Z, or more commonly Hi-Z.

#### **6.4 FUNCTIONAL COVERAGE RESULTS:**

| Functional Coverage                                                                                                                                                        | 1 <u>444</u> |                            | ×  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------|----|--|--|
| File                                                                                                                                                                       |              |                            |    |  |  |
| top Management                                                                                                                                                             | 9            | 7.14%                      |    |  |  |
| inintialization                                                                                                                                                            |              | 100.0                      | 0% |  |  |
| Read_Auto_Pre                                                                                                                                                              |              | 100.0                      | 0% |  |  |
| Write_Auto_Pre                                                                                                                                                             |              | 100.0                      | 0% |  |  |
| Refresh                                                                                                                                                                    |              | 100.0                      | 0% |  |  |
| Burst16                                                                                                                                                                    |              | 100.0%                     |    |  |  |
| Burst8                                                                                                                                                                     | 100.0%       |                            |    |  |  |
| Diff_BankGroups                                                                                                                                                            |              | 88.89%<br>100.0%<br>100.0% |    |  |  |
| Same_BankGroups                                                                                                                                                            |              |                            |    |  |  |
| Write_to_Read                                                                                                                                                              |              |                            |    |  |  |
| Read_to_Write                                                                                                                                                              |              | 100.0                      | 0% |  |  |
| Read_to_Read                                                                                                                                                               |              | 100.0                      | 0% |  |  |
| Write_to_Write                                                                                                                                                             |              | 100.0                      | 0% |  |  |
| inintialization<br>Read_Auto_Pre<br>Write_Auto_Pre<br>Refresh<br>Burst16<br>Burst8<br>Diff_BankGroups<br>Same_BankGroups<br>Write_to_Read<br>Read_to_Write<br>Read_to_Read |              | 100.0                      | 0% |  |  |
|                                                                                                                                                                            |              | 100.0                      | 0% |  |  |

Figure 86: Functional Coverage Report of Top Level

#### 6.5 CODE COVERAGE RESULTS:



Figure 87:Code Coverage Report of Top Level

# 6.6 FINAL RESULTS 6.6.1 Initialization Sequence

|                       | Msgs             |             |         |        |        |        |        |      |  |          |              |           |      |
|-----------------------|------------------|-------------|---------|--------|--------|--------|--------|------|--|----------|--------------|-----------|------|
| I/CK_c                | 1 <b>h</b> 0     |             |         |        |        |        |        |      |  |          |              |           | -44  |
| 1/CK_t                | 1h1              |             |         |        |        |        |        |      |  |          |              |           | _††  |
| N/INIT_FSM_E          | 1h1              |             |         |        |        |        |        |      |  |          |              |           |      |
| I/CS_n                | 1h1              |             |         |        |        |        |        |      |  |          |              |           |      |
| 1/CA                  | 14'h0002         |             |         |        |        |        | 3fff   | 001f |  |          |              | 0005      | 0002 |
| 1/State               | MRW_Cyde2        | IDLE        | State 1 |        | State2 | State3 | State4 | NOP  |  |          |              | MRW Cyde1 | MRW  |
| I/Next<br>I/NOP_Count | MRW_Cyde2<br>1h1 | IDLE State1 |         | State2 | State3 | State4 | NOP    |      |  | Wait MRW | MRW Cyde1    | MRW Cyde2 |      |
| ·                     |                  |             |         | Junez  | ,56605 | 3661   |        |      |  |          | A PIKW CYCCI |           |      |

Figure 88:Waveform of Initialization Sequence from Top Level

### 6.6.2 Self-Refresh Sequence



Figure 89:Waveform of Self-Refresh Sequence from Top Level

### 6.6.3 Single Read after Write



Figure 90: Waveform of Single Read after Write



# 6.6.4 Multiple Read after Multiple Write

Figure 91: Waveform of Multiple Read after Multiple Write

#### **6.7 QUESTA VERIFICATION IP**

#### 6.7.1 Overview

After we have verified our design using our verification environment, as a sanity check we used Questa Verification IP (QVIP) DDR5 Memory Model to verify our design. The DDR5 Questa memory model provides the infrastructure to create models of various DDR5 memory devices that you can connect to a memory controller designs under test (DUTs). it includes parameterized SystemVerilog modules that you instantiate in a Verilog or UVM test bench and connect it to a design under test (DUT).it provides various APIs for configuration, callback, backdoor, and other operations, which you can use in a test as required. For example, use the configuration API set\_delay to change certain delay timing values of the memory model during runtime. To load a memory image for initialization or at any other point in the test case, use a backdoor or memory access API. During runtime, the instantiated memory model responds to the signal-level protocol for front-door access. The model responds to the APIs and provides full functionality and timing accuracy for the supported memory device.it also includes built-in assertions, performance statistics collection, and transaction logging features to identify issues. These debug features abstract the memory accesses to high-level transactions, which makes it easier to analyze the data. The typical memory model flow is shown in Figure 92 [19] :



Figure 92: Questa Memory Model Flow

#### **6.7.2 Memory Model Components**

The DDR5 Questa memory model is based on the Questa Memory Library architecture. This architecture supports features to instantiate and configure a model in your test bench, and debug functional verification issues. The main components of the memory model are shown in Figure 93 [19]:



Figure 93: Memory Model Components

The description of each component is shown in Table 49 [19]:

| Component                         | Description                                                                                                                                                                                            |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory Bus Functional Model (BFM) | Implements a transaction-based bus function<br>model with a SystemVerilog interface                                                                                                                    |
| Data Storage Array                | Acts as the memory of the model                                                                                                                                                                        |
| Front-door Access                 | Implements the interface over the memory<br>protocol to access the contents of the memory<br>At runtime, access to the memory takes place<br>using the signals of the protocol front-end<br>interface. |
| Backdoor Access                   | Loads or unloads the contents of the memory<br>At runtime, data is transferred in and out of<br>the storage array using the backdoor and<br>memory access APIs.                                        |

Table 49: Description of Memory Model Components

| Protocol Checker                 | Implements runtime assertion checks to<br>determine how the memory protocol responds<br>to transactions                                                                 |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Performance Statistics Collector | Collects statistics of various performance parameters                                                                                                                   |
| Functional Coverage Collector    | Collects information about DUT coverage at the transaction-level model                                                                                                  |
| Transaction Logger               | Logs transaction details in a file This<br>component is disabled by default. You can<br>enable the component when you configure the<br>memory model for your test bench |

#### 6.7.3 Configurations

We used the graphical user interface of QVIP Configurator (Configurator) to configure and create the model, which can then be instantiated in an existing test bench. Configurator also provides the option to create the complete test bench where the memory controller and the memory model instance are connected and configured according to requirements. We connected Memory Model with our DUT as shown in Figure and configured Memory Model by choosing configuration of device x16 and speed 3.2 GHZ as shown in Figure 94 [19]:



Figure 94: Test bench using QVIP Configurator

| 🛱 DDR5_) | ×16_0  | 🕒 top_c     | lk_gen (          | <pre>b top_reset_gen</pre>              |                     |                                         |                         |
|----------|--------|-------------|-------------------|-----------------------------------------|---------------------|-----------------------------------------|-------------------------|
| 🗞 RTL Po | rt 🕏   | BFM         |                   |                                         |                     |                                         |                         |
| Memory   |        |             |                   |                                         |                     |                                         |                         |
| MEM      |        |             |                   |                                         |                     |                                         |                         |
| MEM-     |        |             |                   |                                         |                     |                                         |                         |
| A block  | c of M | EM.         |                   |                                         |                     |                                         | 4 0 2<br>4 0 2<br>4 0 2 |
| 📃 🖃 d    | dr5_v  | ars MEN     | и <u>'{'</u> {JED | EC,DDR5_x16_8G_3200A,                   | 3b8,16,3200A,1,0,0  | 0,0,0,0,0,8'h00,0,0,1,0,2               | 00,625fs,85,4           |
|          | dd     | r5_cfg      | cfg               | '{JEDEC,DDR5_x16_8G                     | 3200A,Gb8,16,320    | 0A,1,0,0,0,0,0,0,8'h00,0,               | 0,1,0,200,625           |
|          | dd     | r5 delay    | delay             | '{'{625ps,1ns},'{'{'{2                  | 2 20} '{-1 -1} '{-1 | -1} '{-1 -1}} '{0.952 1                 | .01 ns}}'{'{            |
|          |        | .5_00.03    | aciaj             | [[[[]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]] |                     | , ., .,, .,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                         |
|          | +      | ddr5_ctrl_  | time_mir          | _max                                    | tCKAVG              |                                         | '{625ps,1               |
|          | +      | ddr5_cl_lis | st                |                                         | valid_cl            | [9:0]                                   | '{'{'{22,               |
|          | +      | ddr5_cl_lis | st                |                                         | valid_cl_3ds        | [9:0]                                   | '{'{'{22,               |
|          | +      | ddr5_ctrl_  | time_mir          | I.                                      | tINIT1              |                                         | '{1{20000               |
|          | +      | ddr5_ctrl_  | time_mir          | I.                                      | tINIT2              |                                         | '{1{1000                |
|          | Ŧ      | ddr5_ctrl_  | time_mir          | I.                                      | tINIT3              |                                         | '{1{40000               |
|          | +      | ddr5_ctrl_  | time_mir          | I.                                      | tINIT4              |                                         | '{1{2000r               |
|          | +      | ddr5_ctrl   | int_min           |                                         | tINIT5              |                                         | '{1{3}}                 |
|          | Ŧ      | ddr5 ctrl   | time mir          | 1                                       | tPW RESET           |                                         | '{1{1000                |
|          | -      | ddr5_ctrl   |                   |                                         | tZOCAL              |                                         | ·/ 1 / 1000/*           |
|          | _      |             |                   |                                         |                     |                                         |                         |

Figure 95 : Memory Model Configurations

#### 6.7.3 Results

QVIP reported bugs, we will present some of them:

**Bug #1:** DQ should be high "Z "during self-refresh, however is observed as" X".

**Modification:** This is intentional bug made by us, we replaced Z with X as Questa simulation tool reports error in compiling when it founds Z.



**Bug #2:** Minimum Value of timer tCSH\_SREXIT is "13 ns" however, timer is configured as "10 ns".

**Modification:** We edited the value of this parameter in Counters block with the correct value.



**Bug #3:** Any valid command like read or write for bank that is not activated can be issued only after tRP (interval for precharge of current row) has been elapsed.

**Modification:** we solved this bug by founding that value of tRP is not as configured by tool, so we edited with value configured by tool.

# **Chapter 7: Conclusions and Future Work**

#### **7.1 CONCLUSION**

In this thesis, we have seen the need of new DDR protocol (DDR5) and its applications in industry. We have discussed basic features of DDR5 SDRAM Memory controller through design of blocks that implemented these features and verified the functionality of this design on blocks level and top module level and yielded to results that meet performance needed by JEDEC79-5 standard. We also have discussed a comparison between verification using UVM and Python based verification (COCOTB).

#### **7.2 FUTURE WORK**

This section provides ideas for further research and extension to the thesis work proposed. These are possibilities to improve the DDR5 SDRAM Memory Controller design and verification in order to increase the functionality.

- Adding optional features mentioned in section 2.1.2 to design of controller.
- Performing full system emulation to test DDR5 SDRAM Memory Controller design by porting on FPGA.
- Enhancing the test environment by adding more constraints random test cases.
- Measuring coverage by Questa Verification IP.
- Modelling the existing verification environment of top level to a class based UVM environment.
- Publish a paper on comparison between UVM and COCOTB.

### REFERENCES

[1] Lukas Steiner, Dr.-Ing.Matthias Jung Exploration of DDR5 with the Open-Source Simulator DRAMSys 2021,.Available: <u>https://ieeexplore.ieee.org/abstract/document/9399718</u>

[2] Nitin, Bhagwath, et al. "DDR5 design challenges." 2018 IEEE 22nd Workshop on Signal and Power Integrity (SPI). IEEE, 2018. Available: <u>https://ieeexplore.ieee.org/abstract/document/8401666/</u>

[3] <u>https://news.skhynix.com/why-ddr5-is-the-industrys-powerful-next-gen-memory/</u> accessed at September 2021.

[4] Native interface Standard, chapter 3 LogiCORE IP UltraScale Architecture-Based FPGAs Memory Interface Solutions v4.2. Available: <u>https://www.xilinx.com/content/dam/xilinx/support/documents/ip\_documentation/ultrascale\_memory\_i</u> <u>p/v1\_4/pg150-ultrascale-memory-ip.pdf</u>

[5] DDR5 JEDEC Standard Oct. 2021 Available: <u>https://www.jedec.org/standards-documents/docs/iesd79-5a</u>

[6] Taraate, V. (2022). Case Study: FIFO Design. In: Digital Logic Design Using Verilog. Springer, Singapore. <u>https://doi.org/10.1007/978-981-16-3199-3\_23</u>

[7] Jain, Abhishek Kumar, Scott Lloyd, and Maya Gokhale. "Microscope on memory: MPSoC-enabled computer memory system assessments." 2018 IEEE 26th Annual International Symposium on Field-Programmable Custom Computing Machines (FCCM). IEEE, 2018.

**[8]** Islam, Md Ashraful, Md Yeasin Arafath, and Md Jahid Hasan. "Design of DDR4 SDRAM controller." 8th International Conference on Electrical and Computer Engineering. IEEE, 2014.

[9] Cocotb's documentation, https://docs.cocotb.org/en/stable/.

**[10]** S. Jiang, Y. Ou, P. Pan, K. Cheng, Y. Zhang and C. Batten, "PyH2: Using PyMTL3 to Create Productive and Open-Source Hardware Testing Methodologies," in IEEE Design & Test, vol. 38, no. 2, pp. 53-61, April 2021, doi: 10.1109/MDAT.2020.3024144.

**[11]** S. Jiang, P. Pan, Y. Ou and C. Batten, "PyMTL3: A Python Framework for Open-Source Hardware Modeling, Generation, Simulation, and Verification," in IEEE Micro, vol. 40, no. 4, pp. 58-66, 1 July-Aug. 2020, doi: 10.1109/MM.2020.2997638.

**[12]** Cieplucha, Marek, and Witold Pleskacz. "New architecture of the object-oriented functional coverage mechanism for digital verification." 2016 1st IEEE International Verification and Security Workshop (IVSW). IEEE, 2016.

**[13]** C. Spear, "Systemverilog for verification, second edition: A guide to learning the testbench language features," 3rd ed. 2012 Edition.

**[14]** Apoorva H M, Dr. Kiran Bailey, 2020, UVM based Design Verification of FIFO, INTERNATIONAL JOURNAL OF ENGINEERING RESEARCH & TECHNOLOGY (IJERT) Volume 09, Issue 06 (June 2020),

**[15]** T. M. Pavithran and R. Bhakthavatchalu, "UVM based testbench architecture for logic sub-system verification," 2017 International Conference on Technological Advancements in Power and Energy (TAP Energy), 2017, pp. 1-5, doi: 10.1109/TAPENERGY.2017.8397323.

[16] <u>http://www.fivecomputers.com/language-specification-length.html</u>

**[17]** 2020 Wilson Research Group functional verification study. Available: <u>https://resources.sw.siemens.com/en-US/white-paper-2020-wilson-research-group-functional-verification-study-ic-asic-functional-verification-trend-report</u> accessed at April 2022.

**[18]** Vutukuri, Venkatesh, et al. "Verification of SDRAM controller using SystemVerilog." 2020 IEEE International Conference on Electronics, Computing and Communication Technologies (CONECCT). IEEE, 2020.

**[19]** Questa VIP user manual: <u>https://resources.sw.siemens.com/en-US/fact-sheet-questa-verification-ip-for-ddr5-memory</u>