diff --git a/docs/testbenches/project_based/template/index.rst b/docs/testbenches/project_based/template/index.rst index 8ca56a46..0360e0ec 100644 --- a/docs/testbenches/project_based/template/index.rst +++ b/docs/testbenches/project_based/template/index.rst @@ -8,33 +8,49 @@ Project based test bench template Overview ------------------------------------------------------------------------------- +**\*This section must contain: the purpose of the testbench/ type of interface +it's validating, the corresponding hdl project and the HDL Github documentation +page.**\ \* + Block design ------------------------------------------------------------------------------- +**\*Mention the HDL and SV components of the testbench .**\ \* + Block diagram ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -.. - MUST: Use SVG format for the diagram +If the testbench has multiple configurations that change the block design +itself, then make subsections for each of these configuration-block design +pairs. +Example: project is configured in serial mode or parallel mode. If there are +many configuration options on how the block design looks, try to find ways to +generalize them (eg. multiple interfaces of the same type are enabled by a +parameter). -.. - TIP: Block diagrams should contain subtitles only if there are at least two - different diagrams +\**\* KEEP THIS PARAGRAPH \**\* +The data path and clock domains are depicted in the below diagram: .. image:: ../template/project_based_template_bd.svg :width: 800 :align: center :alt: Template/Testbench block diagram +\*\* MUST: Use SVG format for the diagram \*\* + +\*\* TIP: Block diagrams should contain subtitles only if there are at least two +different diagrams \*\* + Configuration parameters and modes ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -.. - MENTION IF ANY MODES ARE AVAILABLE FOR CONFIGURATION +\**\* MENTION IF THERE ARE ANY CONFIGURATION PARAMETERS AND/OR MODES \**\* Build parameters ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +\**\* THIS IS JUST AN EXAMPLE \**\* + The following are the parameters of this project that can be configured: - CLK_MODE: defines clocking mode of the device's digital interface: @@ -53,8 +69,9 @@ The following are the parameters of this project that can be configured: Configuration files ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -.. - MENTION IF ANY CONFIGURATION FILES ARE AVAILABLE FOR TESTS +\**\* MENTION IF ANY CONFIGURATION FILES ARE AVAILABLE\**\* + +\**\* THIS IS JUST AN EXAMPLE \**\* The following are available configurations for the test bench: @@ -119,12 +136,64 @@ cfg_pi test_program_pi make CFG=cfg_pi TST=test_program_pi Clock scheme ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +\**\* MENTION IF ANY CLOCKING CONFIGURATIONS ARE BEING USED\**\* + CPU/Memory interconnects addresses ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +\**\* THIS IS JUST AND EXAMPLE \**\* + +Below are the CPU/Memory interconnect addresses used in this project: + +===================== =========== +Instance Address +===================== =========== +spi_ad7616_axi_regmap 0x44A0_0000 +axi_ad7606x_dma 0x44A3_0000 +spi_clkgen 0x44A7_0000 +ad7606_pwm_gen 0x44B0_0000 +===================== =========== + Interrupts ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +\**\* THIS IS JUST AND EXAMPLE \**\* + +Below are the Programmable Logic interrupts used in this project: + +=============== === +Instance name HDL +=============== === +axi_ad7606_dma 13 +spi_ad7606 12 +=============== === + +Test stimulus +------------------------------------------------------------------------------- + +\**\* LIST AND EXPLAIN ALL THE TESTS COMPRISED IN THE test_program FILE \**\* + +\**\* THIS IS JUST AND EXAMPLE \**\* + +The test program is structured into several tests as follows: + +Environment Bringup +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The steps of the environment bringup are: + +* Create the environment +* Start the environment +* Start the clocks +* Assert the resets + +Sanity Test +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +This test is used to check the communication with the AXI REGMAP module of the +AD7606 SPI Engine interface, by reading the core VERSION register, along with +writing and reading the SCRATCH register. + Building the test bench ------------------------------------------------------------------------------- @@ -184,16 +253,103 @@ Then the subfolder under ``runs`` name will be: ``cfg_pi`` -Test stimulus -------------------------------------------------------------------------------- - Resources ------------------------------------------------------------------------------- +HDL related dependencies +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +\**\* THIS IS JUST AND EXAMPLE \**\* + +.. list-table:: + :widths: 30 45 25 + :header-rows: 1 + + * - IP name + - Source code link + - Documentation link + * - SYNC_BITS + - :git-hdl:`library/util_cdc/sync_bits.v ` ** + - --- + * - AD_EDGE_DETECT + - :git-hdl:`library/common/ad_edge_detect.v ` + - --- + * - AXI_AD7606x + - :git-hdl:`library/axi_ad7606x ` * + - :dokuwiki:`[Wiki] ` + * - AXI_CLKGEN + - :git-hdl:`library/axi_clkgen ` + - :external+hdl:ref:`here ` + * - AXI_DMAC + - :git-hdl:`library/axi_dmac ` + - :external+hdl:ref:`here ` + * - AXI_HDMI_TX + - :git-hdl:`library/axi_hdmi_tx ` + - :external+hdl:ref:`here ` + * - AXI_I2S_ADI + - :git-hdl:`library/axi_i2s_adi ` + - --- + * - AXI_PWM_GEN + - :git-hdl:`library/axi_pwm_gen ` + - :external+hdl:ref:`here ` + * - AXI_SPDIF_TX + - :git-hdl:`library/axi_spdif_tx ` + - --- + * - AXI_SYSID + - :git-hdl:`library/axi_sysid ` + - :external+hdl:ref:`here ` + * - AXI_SPI_ENGINE + - :git-hdl:`library/spi_engine/axi_spi_engine ` ** + - :external+hdl:ref:`here ` + * - SPI_ENGINE_EXECUTION + - :git-hdl:`library/spi_engine/spi_engine_execution ` ** + - :external+hdl:ref:`here ` + * - SPI_ENGINE_INTERCONNECT + - :git-hdl:`library/spi_engine/spi_engine_interconnect ` ** + - :external+hdl:ref:`here ` + * - SPI_ENGINE_OFFLOAD + - :git-hdl:`library/spi_engine/spi_engine_offload ` ** + - :external+hdl:ref:`here ` + * - SYSID_ROM + - :git-hdl:`library/sysid_rom ` + - :external+hdl:ref:`here ` + * - UTIL_I2C_MIXER + - :git-hdl:`library/util_i2c_mixer ` + - --- + * - UTIL_CPACK2 + - :git-hdl:`library/util_pack/util_cpack2 ` * + - :external+hdl:ref:`here ` + +.. admonition:: Legend + :class: note + + - ``*`` instantiated only for INTF=0 (parallel interface) + - ``**`` instantiated only for INTF=1 (serial interface) + + +Testbenches related dependencies +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + .. include:: ../../common/dependency_common.rst Testbench specific dependencies: +\**\* THIS IS JUST AND EXAMPLE \**\* + +.. list-table:: + :widths: 30 45 25 + :header-rows: 1 + + * - SV dependency name + - Source code link + - Documentation link + * - ADI_REGMAP_CLKGEN_PKG + - :git-testbenches:`library/regmaps/adi_regmap_clkgen_pkg.sv` + - --- + * - ADI_REGMAP_DMAC_PKG + - :git-testbenches:`library/regmaps/adi_regmap_dmac_pkg.sv` + - --- + .. include:: ../../../common/more_information.rst .. include:: ../../../common/support.rst