原创 BMD参考设计层次结构(7x)

2019-8-2 17:43 3847 23 2 分类: FPGA/CPLD 文集: PCIE
xapp1052给出的7x参考设计层次结构是基于PIO的,没有更新BMD,下面是我依据PIO层次结构手动 修改到BMD设计:

xilinx_pcie_2_1_ep_7x
 |
 |--pcie_7x_0 (Core Top level module Generated by Vivado in synth directory)
 |  |--pcie_7x_v3_0_top (Static Top level file)
 |     |--pcie_7x_v3_0_core_top
 |        |
 |        |--pcie_7x_0_pcie_top
 |        |  |
 |        |  |--pcie_7x_0_axi_basic_top
 |        |  |  |
 |        |  |  |--pcie_7x_0_axi_basic_rx
 |        |  |  |  |
 |        |  |  |  |--pcie_7x_0_axi_basic_rx_pipeline
 |        |  |  |  |--pcie_7x_0_axi_basic_rx_null_gen
 |        |  |  |
 |        |  |  |--pcie_7x_0_axi_basic_tx
 |        |  |     |
 |        |  |     |--pcie_7x_0_axi_basic_tx_pipeline
 |        |  |     |--pcie_7x_0_axi_basic_tx_thrtl_ctl
 |        |  |
 |        |  |--pcie_7x_0_pcie_7x
 |        |  |  |
 |        |  |  |--pcie_7x_0_pcie_bram_top_7x
 |        |  |  |  |
 |        |  |  |  |--pcie_7x_0_pcie_brams_7x (an instance each for Rx & Tx)
 |        |  |  |     |
 |        |  |  |     |--pcie_7x_0_pcie_bram_7x
 |        |  |  |
 |        |  |  |--PCIE_2_1 (Integrated Block Instance)
 |        |  |
 |        |  |--pcie_7x_0_pcie_pipe_pipeline
 |        |     |
 |        |     |--pcie_7x_0_pcie_pipe_misc
 |        |     |--pcie_7x_0_pcie_pipe_lane (per lane)
 |        |
 |        |--pcie_7x_0_gt_top
 |           |
 |           |--pcie_7x_0_gt_rx_valid_filter
 |           |
 |           |--pcie_7x_0_pipe_wrapper
 |           |  |
 |           |  |--pcie_7x_0_pipe_clock
 |           |  |--pcie_7x_0_pipe_reset
 |           |  |--pcie_7x_0_qpll_reset
 |           |  |--pcie_7x_0_pipe_user
 |           |  |--pcie_7x_0_pipe_rate
 |           |  |--pcie_7x_0_pipe_sync
 |           |  |--pcie_7x_0_pipe_drp
 |           |  |--pcie_7x_0_pipe_eq
 |           |  |  |--pcie_7x_0_rxeq_scan
 |           |  |  |
 |           |  |--pcie_7x_0_gt_common
 |           |  |  |--pcie_7x_0_qpll_drp
 |           |  |  |--pcie_7x_0_qpll_wrapper
 |           |  |
 |           |  |--pcie_7x_0_gt_wrapper
 |
 |--pcie_app_7x (BMD design, in example_design directory)
    |
    |--BMD
    |  |
    |  |--BMD_EP
    |  |  |
    |  |  |--BMD_EP_MEM_ACCESS
    |  |  |  |
    |  |  |  |--EP_MEM
    |  |  |     |
    |  |  |--BMD_GEN2      
    |  |  |
    |  |  |--BMD_128_RX_ENGINE
    |  |  |--BMD_128_TX_ENGINE
    |  |  |   |--BMD_INTR_CTRL
    |  |  |--BMD_RD_THROTTLE
    |  |--BMD_TO_CTRL
    |  |--BMD_CFG_CTRL
    |--axi_trn_top
        |--axi_trn_rx
        |--axi_trn_tx  


摘抄一些论坛上对PIO参考设计的描述:

PIO example design is provided to exercise only basic core functionality. It has very small BRAMs (back-end memory) and will only respond to 1DW payload data (4 Bytes) per packet. Anything larger (or burst) is not supported.

 

Below are some details of the PIO example design:

***************************************************************************************************************************

1. The PIO design is a simple target-only application that interfaces with the Endpoint for PCIe cores Transaction (TRN) interface.
2. The PIO design only supports single DWORD payload Read and Write PCI Express transactions to 32/64 bit address memory spaces and IO space with support for completion TLPs.
3. The example design supports one IO space BAR, one 32-bit Memory space (that cannot be the Expansion ROM space), and one 64-bit Memory space. If these limits are exceeded, only the first space of a given type will be activeaccesses to the other spaces will not result in completions.
4. Each space is implemented with a 2 kB memory. If the corresponding BAR is configured to a wider aperture, accesses beyond the 2 kB limit wrap around and overlap the 2 kB memory space.
5. The PIO design successfully processes single DWORD payload Memory Read and Write TLPs and IO Read and Write TLPs. Memory Read or Memory Write TLPs of lengths larger than one DWORD are not processed correctly by the PIO design; however, the core does accept these TLPs and passes them along to
the PIO design. If the PIO design receives a TLP with a length of greater than 1 DWORD, the TLP is received completely from the core and discarded. No corresponding completion is generated.
6. PIO design handles Memory writes and IO TLP writes in different ways: the PIO design responds to IO writes by generating a Completion Without Data (cpl), a requirement of the PCI Express specification.
7. The PIO_32_TX_ENGINE and PIO_64_TX_ENGINE modules generate completions for received memory and IO read TLPs. The PIO design does not generate outbound read or write requests. However, users can add this functionality to further customize the design.

***************************************************************************************************************************


作者: coyoo, 来源:面包板社区

链接: https://mbb.eet-china.com/blog/uid-me-1010859.html

版权声明:本文为博主原创,未经本人允许,禁止转载!

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
我要评论
0
23
关闭 站长推荐上一条 /3 下一条