-
Notifications
You must be signed in to change notification settings - Fork 0
uvm_ref_flow_1.1
License
Apache-2.0, LGPL-3.0 licenses found
Licenses found
Apache-2.0
README_Apache_License.txt
LGPL-3.0
README_GNU_LGPL_License.txt
hao310rui140326/uvm_ref_flow_1.1
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
UVM Reference Flow - Ver 1.1 April 2012 ****************************************************************************** Terms and Conditions For Use ****************************************************************************** Please refer to the README_terms_and_conditions.txt file located under <Reference Flow Install_area>/README_terms_and_conditions.txt ****************************************************************************** Product Information ****************************************************************************** The UVM Reference Flow applies the Universal Verification Methodology (UVM) on a realistic set of examples, which begin by showing aspects of the verification of a block, a Universal Asynchronous Receiver Transmitter (UART). It then shows how to verify a cluster design (a APB subsystem) into which the UART gets integrated along with other design components (viz. SPI, GPIO, Power Controller, Timers etc) ****************************************************************************** What's New ****************************************************************************** - For UVM sv reference flow This release of the UVM Reference Flow is completely aligned with the Universal Verification Methodology UVM 1.1 (uvm-1.1) as released by Accellera. - For UVM e reference flow This release also includes a UVM-e Reference Flow which applies the Universal Verification Methodology in e (UVM-e developed by Cadence) to the same block and cluster level Verification of UART and APB subsystem.The sample verification environments (both block and cluster level) contain UVCs based on eRM as well as using UVM-e. Both eRM and UVM-e compatible UVC's can be nicely integrated together and can work seamlessly. Thus, it ensures that all exiting eRM compliant environments need not to be re-coded to work with an UVM compatible environment. Usage of UVM-e Scoreboard package is also included in this release. ****************************************************************************** UVM Reference Flow Design Overview ****************************************************************************** The UVM Reference Flow design is based on an Ethernet Switch System-on-Chip (SoC). The SoC has the following key components 1. An Open RISC Processor 2. Open Core Ethernet Media Access controller (MAC) 3. AMBA AHB network interconnect 4. Address Look up table (ALUT) 5. Support and Control functions. For instance power management and peripherals like UART, SPI, GPO, timer etc 6. On-chip Memories and memory controllers ****************************************************************************** Getting Started ****************************************************************************** ------------------------------ For IES System Verilog users only ------------------------------ The Makefile uses "-uvmhome" switch to compile the uvm_pkg released by Accellera as uvm-1.1. You need UVM library i.e. uvm-1.1 to be able to run the UVM reference flows. Note: All the flows in this release have been validated on the above mentioned library release and Incisive Enterprise Simulator (IES 11.1) Once you have untarred and installed the UVM library, do the following Set the UVM_HOME environment variable to the UVM Library install area - In csh % setenv UVM_HOME <UVM Library install area>/uvm-1.1 - In bash % UVM_HOME=<UVM Library install area>/uvm-1.1 % export UVM_HOME ------------------------------ For Specman 'e' users only ------------------------------ For Cadence customers, IES 11.1 is required to run the UVM e flow UVM Reference Flow Setup: ------------------------- Once you have installed the UVM reference Flow, please do the following in a terminal Set the UVM_REF_HOME variable to the installation folder and source the env.[c]sh - In csh %> setenv UVM_REF_HOME <Reference_Flow_install_dir> %> source $UVM_REF_HOME/env.csh - In bash %> UVM_REF_HOME=<Reference_Flow_install_dir> %> export UVM_REF_HOME %> . $UVM_REF_HOME/env.sh ****************************************************************************** Running a Simulation using Incisive Enterprise Simulator (IES) ****************************************************************************** Module level simulation for UVM System Verilog flow : % $UVM_REF_HOME/soc_verification_lib/sv_cb_ex_lib/uart_ctrl/demo.sh Module level simulation for UVM e flow : % $UVM_REF_HOME/soc_verification_lib/uvm_e_ex_lib/uart_ctrl/demo.csh Cluster level simulation for UVM System Verilog flow : % $UVM_REF_HOME/soc_verification_lib/sv_cb_ex_lib/apb_subsystem/demo.sh Cluster level simulation for UVM e flow : % $UVM_REF_HOME/soc_verification_lib/uvm_e_ex_lib/apb_subsystem/demo.csh ****************************************************************************** Documentation ****************************************************************************** Ethernet Switch SoC Design $UVM_REF_HOME/doc/uvm_flow_topics/uvm_ref_flow_design/ethernet_switch.pdf Open Core IP documentation uart16550 : $UVM_REF_HOME/doc/opencores/uart16550/UART_spec.pdf or1200 : $UVM_REF_HOME/doc/opencores/or1200/doc/openrisc1200_spec.pdf $UVM_REF_HOME/doc/opencores/or1200/doc/openrisc_arch.pdf spi : $UVM_REF_HOME/doc/opencores/spi/spi.pdf ethmac : $UVM_REF_HOME/doc/opencores/ethmac/eth_design_document.pdf $UVM_REF_HOME/doc/opencores/ethmac/eth_speci.pdf $UVM_REF_HOME/doc/opencores/ethmac/ethernet_datasheet_OC_head.pdf $UVM_REF_HOME/doc/opencores/ethmac/ethernet_product_brief_OC_head.pdf User Guides For UVM sv Flow : $UVM_REF_HOME/doc/uvm_flow_topics/uvm_sv/uvm_sv_ref_flow_ug.pdf For UVM e Flow : $UVM_REF_HOME/doc/uvm_flow_topics/uvm_e/uvm_e_ref_flow_ug.pdf ****************************************************************************** Directory Structure ****************************************************************************** Design Hierarchy designs/socv/rtl/rtl_lpw | +-- ahb2apb : AMBA AHB to AMBA APB bridge | +-- alut : Address Lookup Table | +-- apb_subsystem : AMBA APB Subsystem | +-- cdn_busmatrix : AMBA AHB bus matrix | +-- dma : Direct Memory access controller | +-- gpio : General Purpose I/O | +-- opencores | |-- ethmac : Ethernet MAC | |-- or1200 : Open RISC processor | |-- spi : Serial Peripheral Interface | |-- uart16550 : Universal Asynchronous Receiver Transmitter | +-- padframe | +-- power_ctrl : Power Control module | +-- rom_subsystem : ROM Controller | +-- smc : Memory Controller | +-- socv : SoC Top level | +-- sram_subsystem : SRAM subsystem | +-- ttc : Triple timer controller | +-- wb_to_ahb : Wishbone to AHB bridge Verification Environment: soc_verification_lib/sv_cb_ex_lib/ | | +-- interface_uvc_lib | +-- ahb | +-- apb | +-- spi | +-- gpio | +-- uart | +-- uart_ctrl | +-- examples | +-- sv contains reusable design verif files: monitor, scoreboard, env, virtual sequencer,etc | +-- tb/ | +-- scripts/ run.sh, Makefiles, tcl commands, etc | +-- sv/ non-reusable code for this (testbench, top) | +-- tests/ library of tests for the design | +-- apb_subsystem | +-- examples | +-- sv contains reusable design verif files: monitor, scoreboard, env, virtual sequencer,etc | +-- tb/ | +-- scripts/ run.sh, Makefiles, tcl commands, etc | +-- sv/ non-reusable code for this (testbench, top) | +-- tests/ library of tests for the design soc_verification_lib/uvm_e_ex_lib/ | | +-- interface_uvc_lib | +-- ahb | +-- apb | +-- spi | +-- gpio | +-- uart | +-- uart_ctrl | +-- e contains reusable design verif files: monitor, scoreboard, env, virtual sequence,etc | +-- sve/ | +-- scripts/ run.sh, tcl commands, etc | +-- e/ non-reusable code for this (testbench, top) | +-- tests/ library of tests for the design | +-- testbench/ Verilog files for the testbench | +-- apb_subsystem | +-- e/ contains reusable design verif files: monitor, scoreboard, env, virtual sequence,etc | +-- sve/ | +-- scripts/ run.sh, tcl commands, etc | +-- e/ non-reusable code for this (testbench, top) | +-- tests/ library of tests for the design | +-- testbench/ Verilog files for the testbench ****************************************************************************** Release Version :1.1 ****************************************************************************** - UVM sv flow The UVM Reference UVM Reference Flow 1.1 release is tested with UVM 1.1 Library (uvm-1.1) (from Accellera) and Incisive Enterprise Simulator (IES) 11.1. It should be possible to run the UVM sv Reference Flow on any IEEE 1800 Compliant Simulator which supports UVM. - UVM e flow The UVM e Reference Flow (UVM Reference Flow Version 1.1) is tested with Incisive Enterprise Simulator (IES) 11.1. It should be possible to run the UVM e Reference Flow on any IEEE 1647 Compliant simulator which supports UVM. For more information about using the UVM Reference Flow please contact [email protected].
About
uvm_ref_flow_1.1
Resources
License
Apache-2.0, LGPL-3.0 licenses found
Licenses found
Apache-2.0
README_Apache_License.txt
LGPL-3.0
README_GNU_LGPL_License.txt
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published