Python-Based DRAM Memory Controller Testbench: Pyuvm an Early Report

Authors

  • Dina Abdelbaky Department of Computer and Systems Engineering, Ain Shams, University, Elsarayat, Abbaseya, 11517, Cairo, Egypt
  • Mohamed Dessouky Department of Communication and electronics, Ain Shams, University, Elsarayat, Abbaseya, 11517, Cairo, Egypt
  • Ashraf Salem Department of Computer and Systems Engineering, Ain Shams, University, Elsarayat, Abbaseya, 11517, Cairo, Egypt

DOI:

https://doi.org/10.37934/araset.52.2.176188

Keywords:

Hardware verification, SystemVerilog, UVM, Python, Cocotb, Pyuvm, DRAM, Memory controller

Abstract

With Hardware Verification being regarded as a time-consuming complex task. Moreover, new design applications Such as machine learning are posing new challenges to hardware verification engineers. Adding on top of the above challenges the fact that the Universal Verification Methodology (UVM) has a class library that can be considered bloated. Python was suggested as an alternative to SystemVerilog, which is currently the main Hardware Verification language (HVL), used for building modern testbenches. Firstly, Cocotb was introduced almost ten years ago, then Pyuvm under two years ago. Python verification initiatives promise it is easier to learn( than traditional SystemVerilog), faster, and more productive to write. In this paper we explore the process of writing Python-based testbench, through writing DDR3 SDRAM Controller testbench. The testbench is implemented using the Pyuvm methodology running on top of Cocotb that’s used to interact with the Design under test (DUT). The motivation of this paper is to explore the capabilities of Python based verification, and how much of similarity or difference it does bear compared to traditional SystemVerilog and UVM.

Downloads

Download data is not yet available.

Author Biography

Dina Abdelbaky, Department of Computer and Systems Engineering, Ain Shams, University, Elsarayat, Abbaseya, 11517, Cairo, Egypt

g19093426@eng.asu.edu.eg

Downloads

Published

2024-09-21

How to Cite

Abdelbaky, D. ., Dessouky, M., & Salem, A. . (2024). Python-Based DRAM Memory Controller Testbench: Pyuvm an Early Report. Journal of Advanced Research in Applied Sciences and Engineering Technology, 52(2), 176–188. https://doi.org/10.37934/araset.52.2.176188

Issue

Section

Articles