aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/n3xx/n310_bist_image_core.yml
blob: ec7e6653416bd2153fdd5e320683d2c5cef3d70d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# General parameters
# -----------------------------------------
schema: rfnoc_imagebuilder_args         # Identifier for the schema used to validate this file
copyright: >-                           # Copyright information used in file headers
  Copyright 2023 Ettus Research, a National Instruments Brand
license: >-                             # License information used in file headers
  SPDX-License-Identifier: LGPL-3.0-or-later
version: '1.0'                          # File version
chdr_width: 64                          # Bit width of the CHDR bus for this block
device: 'n310'
default_target: 'N310_AA'

# A list of all stream endpoints in design
# ----------------------------------------
stream_endpoints:
  ep0:                                  # Stream endpoint name
    ctrl: True                          # Endpoint passes control traffic
    data: True                          # Endpoint passes data traffic
    buff_size: 16384                    # Ingress buffer size for data
  ep1:
    ctrl: False
    data: True
    buff_size: 16384
  ep2:
    ctrl: False
    data: True
    buff_size: 16384
  ep3:
    ctrl: False
    data: True
    buff_size: 16384
  ep4:
    ctrl: False
    data: True
    buff_size: 16384
  ep5:
    ctrl: False
    data: True
    buff_size: 16384

# A list of all NoC blocks in design
# ----------------------------------
noc_blocks:
  radio0:                               # NoC block name
    block_desc: 'radio.yml'             # Block device descriptor file
    parameters:
      NUM_PORTS: 2
  radio1:
    block_desc: 'radio.yml'
    parameters:
      NUM_PORTS: 2
  fifo0:
    block_desc: 'axi_ram_fifo.yml'
    parameters:
      # These parameters match the memory interface on the N3XX
      NUM_PORTS: 4
      MEM_DATA_W: 64
      MEM_ADDR_W: 31
      # Create two non-overlapping 32 MB buffers by default
      FIFO_ADDR_BASE: "{31'h06000000, 31'h04000000, 31'h02000000, 31'h00000000}"
      FIFO_ADDR_MASK: "{31'h01FFFFFF, 31'h01FFFFFF, 31'h01FFFFFF, 31'h01FFFFFF}"
      MEM_CLK_RATE: "303819444" # 166.666666 MHz * 21.875 / 4 / 3 = 303.819444 MHz

# A list of all static connections in design
# ------------------------------------------
# Format: A list of connection maps (list of key-value pairs) with the following keys
#   - srcblk  = Source block to connect
#   - srcport = Port on the source block to connect
#   - dstblk  = Destination block to connect
#   - dstport = Port on the destination block to connect
connections:
  # RF 0 TX
  - { srcblk: ep0,    srcport: out0,  dstblk: radio0, dstport: in_0 }
  # RF 0 RX
  - { srcblk: radio0, srcport: out_0, dstblk: ep0,    dstport: in0  }
  # RF 1 TX
  - { srcblk: ep1,    srcport: out0,  dstblk: radio0, dstport: in_1 }
  # RF 1 RX
  - { srcblk: radio0, srcport: out_1, dstblk: ep1,    dstport: in0  }
  #
  # RF 2 TX
  - { srcblk: ep2,    srcport: out0,  dstblk: radio1, dstport: in_0 }
  # RF 2 RX
  - { srcblk: radio1, srcport: out_0, dstblk: ep2,    dstport: in0  }
  # RF 3 TX
  - { srcblk: ep3,    srcport: out0,  dstblk: radio1, dstport: in_1 }
  # RF 3 RX
  - { srcblk: radio1, srcport: out_1, dstblk: ep3,    dstport: in0  }
  #
  # DRAM FIFO Connections
  - { srcblk: ep4,   srcport: out0,  dstblk: fifo0, dstport: in_0 }
  - { srcblk: fifo0, srcport: out_0, dstblk: ep4,   dstport: in0  }
  - { srcblk: ep5,   srcport: out0,  dstblk: fifo0, dstport: in_1 }
  - { srcblk: fifo0, srcport: out_1, dstblk: ep5,   dstport: in0  }
  #
  # BSP Connections
  - { srcblk: radio0,   srcport: ctrlport, dstblk: _device_, dstport: ctrlport_radio0 }
  - { srcblk: radio1,   srcport: ctrlport, dstblk: _device_, dstport: ctrlport_radio1 }
  - { srcblk: _device_, srcport: radio0,   dstblk: radio0,   dstport: radio           }
  - { srcblk: _device_, srcport: radio1,   dstblk: radio1,   dstport: radio           }
  - { srcblk: _device_, srcport: time,     dstblk: radio0,   dstport: time            }
  - { srcblk: _device_, srcport: time,     dstblk: radio1,   dstport: time            }
  - { srcblk: fifo0,    srcport: axi_ram,  dstblk: _device_, dstport: dram            }

# A list of all clock domain connections in design
# ------------------------------------------------
# Format: A list of connection maps (list of key-value pairs) with the following keys
#   - srcblk  = Source block to connect (Always "_device"_)
#   - srcport = Clock domain on the source block to connect
#   - dstblk  = Destination block to connect
#   - dstport = Clock domain on the destination block to connect
clk_domains:
  - { srcblk: _device_, srcport: radio, dstblk: radio0, dstport: radio }
  - { srcblk: _device_, srcport: radio, dstblk: radio1, dstport: radio }
  - { srcblk: _device_, srcport: dram,  dstblk: fifo0,  dstport: mem   }