forked from eastzone/cs344-sw
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathreg_defines.h
547 lines (473 loc) · 26.6 KB
/
reg_defines.h
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
/********************************************************
*
* C register defines file for reference_router
*
********************************************************/
#ifndef _REG_DEFINES_
#define _REG_DEFINES_
/* ========= Constants ========= */
// ===== File: lib/verilog/common/xml/global.xml =====
// Maximum number of phy ports
#define MAX_PHY_PORTS 4
// PCI address bus width
#define PCI_ADDR_WIDTH 32
// PCI data bus width
#define PCI_DATA_WIDTH 32
// PCI byte enable bus width
#define PCI_BE_WIDTH 4
// CPCI--CNET address bus width. This is byte addresses even though bottom bits are zero.
#define CPCI_CNET_ADDR_WIDTH 27
// CPCI--CNET data bus width
#define CPCI_CNET_DATA_WIDTH 32
// CPCI--NF2 address bus width. This is byte addresses even though bottom bits are zero.
#define CPCI_NF2_ADDR_WIDTH 27
// CPCI--NF2 data bus width
#define CPCI_NF2_DATA_WIDTH 32
// DMA data bus width
#define DMA_DATA_WIDTH 32
// DMA control bus width
#define DMA_CTRL_WIDTH 4
// CPCI debug bus width
#define CPCI_DEBUG_DATA_WIDTH 29
// SRAM address width
#define SRAM_ADDR_WIDTH 19
// SRAM data width
#define SRAM_DATA_WIDTH 36
// DRAM address width
#define DRAM_ADDR_WIDTH 24
// ===== File: lib/verilog/common/xml/nf_defines.xml =====
// Clock period of 125 MHz clock in ns
#define FAST_CLK_PERIOD 8
// Clock period of 62.5 MHz clock in ns
#define SLOW_CLK_PERIOD 16
// Header value used by the IO queues
#define IO_QUEUE_STAGE_NUM 0xff
// Data path data width
#define DATA_WIDTH 64
// Data path control width
#define CTRL_WIDTH 8
// ===== File: lib/verilog/output_queues/sram_rr_output_queues/xml/sram_rr_output_queues.xml =====
#define NUM_OUTPUT_QUEUES 8
#define OQ_DEFAULT_MAX_PKTS 0x7ffff
#define OQ_SRAM_PKT_CNT_WIDTH 19
#define OQ_SRAM_WORD_CNT_WIDTH 19
#define OQ_SRAM_BYTE_CNT_WIDTH 19
#define OQ_ENABLE_SEND_BIT_NUM 0
#define OQ_INITIALIZE_OQ_BIT_NUM 1
// ===== File: lib/verilog/output_port_lookup/cam_router/xml/cam_router.xml =====
// Number of entrties in the ARP table
#define ROUTER_OP_LUT_ARP_TABLE_DEPTH 32
// Number of entrties in the routing table table
#define ROUTER_OP_LUT_ROUTE_TABLE_DEPTH 32
// Number of entrties in the destination IP filter table
#define ROUTER_OP_LUT_DST_IP_FILTER_TABLE_DEPTH 32
// Default MAC address for port 0
#define ROUTER_OP_LUT_DEFAULT_MAC_0 0xcafef00d0001
#define ROUTER_OP_LUT_DEFAULT_MAC_0_HI 0x0000cafe
#define ROUTER_OP_LUT_DEFAULT_MAC_0_LO 0xf00d0001
// Default MAC address for port 1
#define ROUTER_OP_LUT_DEFAULT_MAC_1 0xcafef00d0002
#define ROUTER_OP_LUT_DEFAULT_MAC_1_HI 0x0000cafe
#define ROUTER_OP_LUT_DEFAULT_MAC_1_LO 0xf00d0002
// Default MAC address for port 2
#define ROUTER_OP_LUT_DEFAULT_MAC_2 0xcafef00d0003
#define ROUTER_OP_LUT_DEFAULT_MAC_2_HI 0x0000cafe
#define ROUTER_OP_LUT_DEFAULT_MAC_2_LO 0xf00d0003
// Default MAC address for port 3
#define ROUTER_OP_LUT_DEFAULT_MAC_3 0xcafef00d0004
#define ROUTER_OP_LUT_DEFAULT_MAC_3_HI 0x0000cafe
#define ROUTER_OP_LUT_DEFAULT_MAC_3_LO 0xf00d0004
// ===== File: lib/verilog/utils/xml/device_id_reg.xml =====
// Total number of registers
#define DEV_ID_NUM_REGS 32
// Number of non string registers
#define DEV_ID_NON_DEV_STR_REGS 7
// Device description length (in words, not chars)
#define DEV_ID_DEV_STR_WORD_LEN 25
// Device description length (in bytes/chars)
#define DEV_ID_DEV_STR_BYTE_LEN 100
// Device description length (in bits)
#define DEV_ID_DEV_STR_BIT_LEN 800
// Length of MD5 sum (bits)
#define DEV_ID_MD5SUM_LENGTH 128
// MD5 sum of the string "device_id.v"
#define DEV_ID_MD5_VALUE 0x4071736d8a603d2b4d55f62989a73c95
#define DEV_ID_MD5_VALUE_0 0x4071736d
#define DEV_ID_MD5_VALUE_1 0x8a603d2b
#define DEV_ID_MD5_VALUE_2 0x4d55f629
#define DEV_ID_MD5_VALUE_3 0x89a73c95
/* ========== Registers ========== */
// Name: device_id (DEV_ID)
// Description: Device identification
// File: lib/verilog/utils/xml/device_id_reg.xml
#define DEV_ID_MD5_0 0x0400000
#define DEV_ID_MD5_1 0x0400004
#define DEV_ID_MD5_2 0x0400008
#define DEV_ID_MD5_3 0x040000c
#define DEV_ID_DEVICE_ID 0x0400010
#define DEV_ID_REVISION 0x0400014
#define DEV_ID_CPCI_ID 0x0400018
#define DEV_ID_DEV_STR_0 0x040001c
#define DEV_ID_DEV_STR_1 0x0400020
#define DEV_ID_DEV_STR_2 0x0400024
#define DEV_ID_DEV_STR_3 0x0400028
#define DEV_ID_DEV_STR_4 0x040002c
#define DEV_ID_DEV_STR_5 0x0400030
#define DEV_ID_DEV_STR_6 0x0400034
#define DEV_ID_DEV_STR_7 0x0400038
#define DEV_ID_DEV_STR_8 0x040003c
#define DEV_ID_DEV_STR_9 0x0400040
#define DEV_ID_DEV_STR_10 0x0400044
#define DEV_ID_DEV_STR_11 0x0400048
#define DEV_ID_DEV_STR_12 0x040004c
#define DEV_ID_DEV_STR_13 0x0400050
#define DEV_ID_DEV_STR_14 0x0400054
#define DEV_ID_DEV_STR_15 0x0400058
#define DEV_ID_DEV_STR_16 0x040005c
#define DEV_ID_DEV_STR_17 0x0400060
#define DEV_ID_DEV_STR_18 0x0400064
#define DEV_ID_DEV_STR_19 0x0400068
#define DEV_ID_DEV_STR_20 0x040006c
#define DEV_ID_DEV_STR_21 0x0400070
#define DEV_ID_DEV_STR_22 0x0400074
#define DEV_ID_DEV_STR_23 0x0400078
#define DEV_ID_DEV_STR_24 0x040007c
// Name: mdio (MDIO)
// Description: MDIO interface
// File: lib/verilog/io/mdio/xml/mdio.xml
#define MDIO_PHY_0_PHY_CONTROL 0x0440000
#define MDIO_PHY_0_PHY_STATUS 0x0440004
#define MDIO_PHY_0_PHY_PHY_ID_0 0x0440008
#define MDIO_PHY_0_PHY_PHY_ID_1 0x044000c
#define MDIO_PHY_0_PHY_AUTONEGOTIATION_ADVERT 0x0440010
#define MDIO_PHY_0_PHY_AUTONEG_LINK_PARTNER_BASE_PAGE_ABILITY 0x0440014
#define MDIO_PHY_0_PHY_AUTONEG_EXPANSION 0x0440018
#define MDIO_PHY_0_PHY_AUTONEG_NEXT_PAGE_TX 0x044001c
#define MDIO_PHY_0_PHY_AUTONEG_LINK_PARTNER_RCVD_NEXT_PAGE 0x0440020
#define MDIO_PHY_0_PHY_MASTER_SLAVE_CTRL 0x0440024
#define MDIO_PHY_0_PHY_MASTER_SLAVE_STATUS 0x0440028
#define MDIO_PHY_0_PHY_PSE_CTRL 0x044002c
#define MDIO_PHY_0_PHY_PSE_STATUS 0x0440030
#define MDIO_PHY_0_PHY_MMD_ACCESS_CTRL 0x0440034
#define MDIO_PHY_0_PHY_MMD_ACCESS_STATUS 0x0440038
#define MDIO_PHY_0_PHY_EXTENDED_STATUS 0x044003c
#define MDIO_PHY_1_PHY_CONTROL 0x0440020
#define MDIO_PHY_1_PHY_STATUS 0x0440024
#define MDIO_PHY_1_PHY_PHY_ID_0 0x0440028
#define MDIO_PHY_1_PHY_PHY_ID_1 0x044002c
#define MDIO_PHY_1_PHY_AUTONEGOTIATION_ADVERT 0x0440030
#define MDIO_PHY_1_PHY_AUTONEG_LINK_PARTNER_BASE_PAGE_ABILITY 0x0440034
#define MDIO_PHY_1_PHY_AUTONEG_EXPANSION 0x0440038
#define MDIO_PHY_1_PHY_AUTONEG_NEXT_PAGE_TX 0x044003c
#define MDIO_PHY_1_PHY_AUTONEG_LINK_PARTNER_RCVD_NEXT_PAGE 0x0440040
#define MDIO_PHY_1_PHY_MASTER_SLAVE_CTRL 0x0440044
#define MDIO_PHY_1_PHY_MASTER_SLAVE_STATUS 0x0440048
#define MDIO_PHY_1_PHY_PSE_CTRL 0x044004c
#define MDIO_PHY_1_PHY_PSE_STATUS 0x0440050
#define MDIO_PHY_1_PHY_MMD_ACCESS_CTRL 0x0440054
#define MDIO_PHY_1_PHY_MMD_ACCESS_STATUS 0x0440058
#define MDIO_PHY_1_PHY_EXTENDED_STATUS 0x044005c
#define MDIO_PHY_2_PHY_CONTROL 0x0440040
#define MDIO_PHY_2_PHY_STATUS 0x0440044
#define MDIO_PHY_2_PHY_PHY_ID_0 0x0440048
#define MDIO_PHY_2_PHY_PHY_ID_1 0x044004c
#define MDIO_PHY_2_PHY_AUTONEGOTIATION_ADVERT 0x0440050
#define MDIO_PHY_2_PHY_AUTONEG_LINK_PARTNER_BASE_PAGE_ABILITY 0x0440054
#define MDIO_PHY_2_PHY_AUTONEG_EXPANSION 0x0440058
#define MDIO_PHY_2_PHY_AUTONEG_NEXT_PAGE_TX 0x044005c
#define MDIO_PHY_2_PHY_AUTONEG_LINK_PARTNER_RCVD_NEXT_PAGE 0x0440060
#define MDIO_PHY_2_PHY_MASTER_SLAVE_CTRL 0x0440064
#define MDIO_PHY_2_PHY_MASTER_SLAVE_STATUS 0x0440068
#define MDIO_PHY_2_PHY_PSE_CTRL 0x044006c
#define MDIO_PHY_2_PHY_PSE_STATUS 0x0440070
#define MDIO_PHY_2_PHY_MMD_ACCESS_CTRL 0x0440074
#define MDIO_PHY_2_PHY_MMD_ACCESS_STATUS 0x0440078
#define MDIO_PHY_2_PHY_EXTENDED_STATUS 0x044007c
#define MDIO_PHY_3_PHY_CONTROL 0x0440060
#define MDIO_PHY_3_PHY_STATUS 0x0440064
#define MDIO_PHY_3_PHY_PHY_ID_0 0x0440068
#define MDIO_PHY_3_PHY_PHY_ID_1 0x044006c
#define MDIO_PHY_3_PHY_AUTONEGOTIATION_ADVERT 0x0440070
#define MDIO_PHY_3_PHY_AUTONEG_LINK_PARTNER_BASE_PAGE_ABILITY 0x0440074
#define MDIO_PHY_3_PHY_AUTONEG_EXPANSION 0x0440078
#define MDIO_PHY_3_PHY_AUTONEG_NEXT_PAGE_TX 0x044007c
#define MDIO_PHY_3_PHY_AUTONEG_LINK_PARTNER_RCVD_NEXT_PAGE 0x0440080
#define MDIO_PHY_3_PHY_MASTER_SLAVE_CTRL 0x0440084
#define MDIO_PHY_3_PHY_MASTER_SLAVE_STATUS 0x0440088
#define MDIO_PHY_3_PHY_PSE_CTRL 0x044008c
#define MDIO_PHY_3_PHY_PSE_STATUS 0x0440090
#define MDIO_PHY_3_PHY_MMD_ACCESS_CTRL 0x0440094
#define MDIO_PHY_3_PHY_MMD_ACCESS_STATUS 0x0440098
#define MDIO_PHY_3_PHY_EXTENDED_STATUS 0x044009c
// Name: dma (DMA)
// Description: DMA transfer module
// File: lib/verilog/dma/xml/dma.xml
// Name: nf2_mac_grp (MAC_GRP_0)
// Description: Ethernet MAC group
// File: lib/verilog/io_queues/ethernet_mac/xml/ethernet_mac.xml
#define MAC_GRP_0_CONTROL 0x0600000
#define MAC_GRP_0_RX_QUEUE_NUM_PKTS_IN_QUEUE 0x0600004
#define MAC_GRP_0_RX_QUEUE_NUM_PKTS_STORED 0x0600008
#define MAC_GRP_0_RX_QUEUE_NUM_PKTS_DROPPED_FULL 0x060000c
#define MAC_GRP_0_RX_QUEUE_NUM_PKTS_DROPPED_BAD 0x0600010
#define MAC_GRP_0_RX_QUEUE_NUM_PKTS_DEQUEUED 0x0600014
#define MAC_GRP_0_RX_QUEUE_NUM_WORDS_PUSHED 0x0600018
#define MAC_GRP_0_RX_QUEUE_NUM_BYTES_PUSHED 0x060001c
#define MAC_GRP_0_TX_QUEUE_NUM_PKTS_IN_QUEUE 0x0600020
#define MAC_GRP_0_TX_QUEUE_NUM_PKTS_ENQUEUED 0x0600024
#define MAC_GRP_0_TX_QUEUE_NUM_PKTS_SENT 0x0600028
#define MAC_GRP_0_TX_QUEUE_NUM_WORDS_PUSHED 0x060002c
#define MAC_GRP_0_TX_QUEUE_NUM_BYTES_PUSHED 0x0600030
// Name: nf2_mac_grp (MAC_GRP_1)
// Description: Ethernet MAC group
// File: lib/verilog/io_queues/ethernet_mac/xml/ethernet_mac.xml
#define MAC_GRP_1_CONTROL 0x0640000
#define MAC_GRP_1_RX_QUEUE_NUM_PKTS_IN_QUEUE 0x0640004
#define MAC_GRP_1_RX_QUEUE_NUM_PKTS_STORED 0x0640008
#define MAC_GRP_1_RX_QUEUE_NUM_PKTS_DROPPED_FULL 0x064000c
#define MAC_GRP_1_RX_QUEUE_NUM_PKTS_DROPPED_BAD 0x0640010
#define MAC_GRP_1_RX_QUEUE_NUM_PKTS_DEQUEUED 0x0640014
#define MAC_GRP_1_RX_QUEUE_NUM_WORDS_PUSHED 0x0640018
#define MAC_GRP_1_RX_QUEUE_NUM_BYTES_PUSHED 0x064001c
#define MAC_GRP_1_TX_QUEUE_NUM_PKTS_IN_QUEUE 0x0640020
#define MAC_GRP_1_TX_QUEUE_NUM_PKTS_ENQUEUED 0x0640024
#define MAC_GRP_1_TX_QUEUE_NUM_PKTS_SENT 0x0640028
#define MAC_GRP_1_TX_QUEUE_NUM_WORDS_PUSHED 0x064002c
#define MAC_GRP_1_TX_QUEUE_NUM_BYTES_PUSHED 0x0640030
// Name: nf2_mac_grp (MAC_GRP_2)
// Description: Ethernet MAC group
// File: lib/verilog/io_queues/ethernet_mac/xml/ethernet_mac.xml
#define MAC_GRP_2_CONTROL 0x0680000
#define MAC_GRP_2_RX_QUEUE_NUM_PKTS_IN_QUEUE 0x0680004
#define MAC_GRP_2_RX_QUEUE_NUM_PKTS_STORED 0x0680008
#define MAC_GRP_2_RX_QUEUE_NUM_PKTS_DROPPED_FULL 0x068000c
#define MAC_GRP_2_RX_QUEUE_NUM_PKTS_DROPPED_BAD 0x0680010
#define MAC_GRP_2_RX_QUEUE_NUM_PKTS_DEQUEUED 0x0680014
#define MAC_GRP_2_RX_QUEUE_NUM_WORDS_PUSHED 0x0680018
#define MAC_GRP_2_RX_QUEUE_NUM_BYTES_PUSHED 0x068001c
#define MAC_GRP_2_TX_QUEUE_NUM_PKTS_IN_QUEUE 0x0680020
#define MAC_GRP_2_TX_QUEUE_NUM_PKTS_ENQUEUED 0x0680024
#define MAC_GRP_2_TX_QUEUE_NUM_PKTS_SENT 0x0680028
#define MAC_GRP_2_TX_QUEUE_NUM_WORDS_PUSHED 0x068002c
#define MAC_GRP_2_TX_QUEUE_NUM_BYTES_PUSHED 0x0680030
// Name: nf2_mac_grp (MAC_GRP_3)
// Description: Ethernet MAC group
// File: lib/verilog/io_queues/ethernet_mac/xml/ethernet_mac.xml
#define MAC_GRP_3_CONTROL 0x06c0000
#define MAC_GRP_3_RX_QUEUE_NUM_PKTS_IN_QUEUE 0x06c0004
#define MAC_GRP_3_RX_QUEUE_NUM_PKTS_STORED 0x06c0008
#define MAC_GRP_3_RX_QUEUE_NUM_PKTS_DROPPED_FULL 0x06c000c
#define MAC_GRP_3_RX_QUEUE_NUM_PKTS_DROPPED_BAD 0x06c0010
#define MAC_GRP_3_RX_QUEUE_NUM_PKTS_DEQUEUED 0x06c0014
#define MAC_GRP_3_RX_QUEUE_NUM_WORDS_PUSHED 0x06c0018
#define MAC_GRP_3_RX_QUEUE_NUM_BYTES_PUSHED 0x06c001c
#define MAC_GRP_3_TX_QUEUE_NUM_PKTS_IN_QUEUE 0x06c0020
#define MAC_GRP_3_TX_QUEUE_NUM_PKTS_ENQUEUED 0x06c0024
#define MAC_GRP_3_TX_QUEUE_NUM_PKTS_SENT 0x06c0028
#define MAC_GRP_3_TX_QUEUE_NUM_WORDS_PUSHED 0x06c002c
#define MAC_GRP_3_TX_QUEUE_NUM_BYTES_PUSHED 0x06c0030
// Name: cpu_dma_queue (CPU_QUEUE_0)
// Description: CPU DMA queue
// File: lib/verilog/io_queues/cpu_dma_queue/xml/cpu_dma_queue.xml
// Name: cpu_dma_queue (CPU_QUEUE_1)
// Description: CPU DMA queue
// File: lib/verilog/io_queues/cpu_dma_queue/xml/cpu_dma_queue.xml
// Name: cpu_dma_queue (CPU_QUEUE_2)
// Description: CPU DMA queue
// File: lib/verilog/io_queues/cpu_dma_queue/xml/cpu_dma_queue.xml
// Name: cpu_dma_queue (CPU_QUEUE_3)
// Description: CPU DMA queue
// File: lib/verilog/io_queues/cpu_dma_queue/xml/cpu_dma_queue.xml
// Name: SRAM (SRAM)
// Description: SRAM
// Name: router_op_lut (ROUTER_OP_LUT)
// Description: Output port lookup for IPv4 router (CAM based)
// File: lib/verilog/output_port_lookup/cam_router/xml/cam_router.xml
#define ROUTER_OP_LUT_ARP_NUM_MISSES 0x2000000
#define ROUTER_OP_LUT_LPM_NUM_MISSES 0x2000004
#define ROUTER_OP_LUT_NUM_CPU_PKTS_SENT 0x2000008
#define ROUTER_OP_LUT_NUM_BAD_OPTS_VER 0x200000c
#define ROUTER_OP_LUT_NUM_BAD_CHKSUMS 0x2000010
#define ROUTER_OP_LUT_NUM_BAD_TTLS 0x2000014
#define ROUTER_OP_LUT_NUM_NON_IP_RCVD 0x2000018
#define ROUTER_OP_LUT_NUM_PKTS_FORWARDED 0x200001c
#define ROUTER_OP_LUT_NUM_WRONG_DEST 0x2000020
#define ROUTER_OP_LUT_NUM_FILTERED_PKTS 0x2000024
#define ROUTER_OP_LUT_MAC_0_HI 0x2000028
#define ROUTER_OP_LUT_MAC_0_LO 0x200002c
#define ROUTER_OP_LUT_MAC_1_HI 0x2000030
#define ROUTER_OP_LUT_MAC_1_LO 0x2000034
#define ROUTER_OP_LUT_MAC_2_HI 0x2000038
#define ROUTER_OP_LUT_MAC_2_LO 0x200003c
#define ROUTER_OP_LUT_MAC_3_HI 0x2000040
#define ROUTER_OP_LUT_MAC_3_LO 0x2000044
#define ROUTER_OP_LUT_ROUTE_TABLE_ENTRY_IP 0x2000048
#define ROUTER_OP_LUT_ROUTE_TABLE_ENTRY_MASK 0x200004c
#define ROUTER_OP_LUT_ROUTE_TABLE_ENTRY_NEXT_HOP_IP 0x2000050
#define ROUTER_OP_LUT_ROUTE_TABLE_ENTRY_OUTPUT_PORT 0x2000054
#define ROUTER_OP_LUT_ROUTE_TABLE_RD_ADDR 0x2000058
#define ROUTER_OP_LUT_ROUTE_TABLE_WR_ADDR 0x200005c
#define ROUTER_OP_LUT_ARP_TABLE_ENTRY_MAC_HI 0x2000060
#define ROUTER_OP_LUT_ARP_TABLE_ENTRY_MAC_LO 0x2000064
#define ROUTER_OP_LUT_ARP_TABLE_ENTRY_NEXT_HOP_IP 0x2000068
#define ROUTER_OP_LUT_ARP_TABLE_RD_ADDR 0x200006c
#define ROUTER_OP_LUT_ARP_TABLE_WR_ADDR 0x2000070
#define ROUTER_OP_LUT_DST_IP_FILTER_TABLE_ENTRY_IP 0x2000074
#define ROUTER_OP_LUT_DST_IP_FILTER_TABLE_RD_ADDR 0x2000078
#define ROUTER_OP_LUT_DST_IP_FILTER_TABLE_WR_ADDR 0x200007c
// Name: strip_headers (STRIP_HEADERS)
// Description: Strip headers from data
// File: lib/verilog/strip_headers/keep_length/xml/strip_headers.xml
// Name: in_arb (IN_ARB)
// Description: Round-robin input arbiter
// File: lib/verilog/input_arbiter/rr_input_arbiter/xml/rr_input_arbiter.xml
#define IN_ARB_NUM_PKTS_SENT 0x2000200
#define IN_ARB_LAST_PKT_WORD_0_HI 0x2000204
#define IN_ARB_LAST_PKT_WORD_0_LO 0x2000208
#define IN_ARB_LAST_PKT_CTRL_0 0x200020c
#define IN_ARB_LAST_PKT_WORD_1_HI 0x2000210
#define IN_ARB_LAST_PKT_WORD_1_LO 0x2000214
#define IN_ARB_LAST_PKT_CTRL_1 0x2000218
#define IN_ARB_STATE 0x200021c
// Name: output_queues (OQ)
// Description: SRAM-based output queue using round-robin removal
// File: lib/verilog/output_queues/sram_rr_output_queues/xml/sram_rr_output_queues.xml
#define OQ_QUEUE_0_QUEUE_CTRL 0x2001000
#define OQ_QUEUE_0_QUEUE_NUM_PKT_BYTES_STORED 0x2001004
#define OQ_QUEUE_0_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001008
#define OQ_QUEUE_0_QUEUE_NUM_PKT_BYTES_REMOVED 0x200100c
#define OQ_QUEUE_0_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001010
#define OQ_QUEUE_0_QUEUE_NUM_PKTS_STORED 0x2001014
#define OQ_QUEUE_0_QUEUE_NUM_PKTS_DROPPED 0x2001018
#define OQ_QUEUE_0_QUEUE_NUM_PKTS_REMOVED 0x200101c
#define OQ_QUEUE_0_QUEUE_ADDR_LO 0x2001020
#define OQ_QUEUE_0_QUEUE_ADDR_HI 0x2001024
#define OQ_QUEUE_0_QUEUE_RD_ADDR 0x2001028
#define OQ_QUEUE_0_QUEUE_WR_ADDR 0x200102c
#define OQ_QUEUE_0_QUEUE_NUM_PKTS_IN_Q 0x2001030
#define OQ_QUEUE_0_QUEUE_MAX_PKTS_IN_Q 0x2001034
#define OQ_QUEUE_0_QUEUE_NUM_WORDS_IN_Q 0x2001038
#define OQ_QUEUE_0_QUEUE_NUM_WORDS_LEFT 0x200103c
#define OQ_QUEUE_0_QUEUE_FULL_THRESH 0x2001040
#define OQ_QUEUE_1_QUEUE_CTRL 0x2001200
#define OQ_QUEUE_1_QUEUE_NUM_PKT_BYTES_STORED 0x2001204
#define OQ_QUEUE_1_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001208
#define OQ_QUEUE_1_QUEUE_NUM_PKT_BYTES_REMOVED 0x200120c
#define OQ_QUEUE_1_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001210
#define OQ_QUEUE_1_QUEUE_NUM_PKTS_STORED 0x2001214
#define OQ_QUEUE_1_QUEUE_NUM_PKTS_DROPPED 0x2001218
#define OQ_QUEUE_1_QUEUE_NUM_PKTS_REMOVED 0x200121c
#define OQ_QUEUE_1_QUEUE_ADDR_LO 0x2001220
#define OQ_QUEUE_1_QUEUE_ADDR_HI 0x2001224
#define OQ_QUEUE_1_QUEUE_RD_ADDR 0x2001228
#define OQ_QUEUE_1_QUEUE_WR_ADDR 0x200122c
#define OQ_QUEUE_1_QUEUE_NUM_PKTS_IN_Q 0x2001230
#define OQ_QUEUE_1_QUEUE_MAX_PKTS_IN_Q 0x2001234
#define OQ_QUEUE_1_QUEUE_NUM_WORDS_IN_Q 0x2001238
#define OQ_QUEUE_1_QUEUE_NUM_WORDS_LEFT 0x200123c
#define OQ_QUEUE_1_QUEUE_FULL_THRESH 0x2001240
#define OQ_QUEUE_2_QUEUE_CTRL 0x2001400
#define OQ_QUEUE_2_QUEUE_NUM_PKT_BYTES_STORED 0x2001404
#define OQ_QUEUE_2_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001408
#define OQ_QUEUE_2_QUEUE_NUM_PKT_BYTES_REMOVED 0x200140c
#define OQ_QUEUE_2_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001410
#define OQ_QUEUE_2_QUEUE_NUM_PKTS_STORED 0x2001414
#define OQ_QUEUE_2_QUEUE_NUM_PKTS_DROPPED 0x2001418
#define OQ_QUEUE_2_QUEUE_NUM_PKTS_REMOVED 0x200141c
#define OQ_QUEUE_2_QUEUE_ADDR_LO 0x2001420
#define OQ_QUEUE_2_QUEUE_ADDR_HI 0x2001424
#define OQ_QUEUE_2_QUEUE_RD_ADDR 0x2001428
#define OQ_QUEUE_2_QUEUE_WR_ADDR 0x200142c
#define OQ_QUEUE_2_QUEUE_NUM_PKTS_IN_Q 0x2001430
#define OQ_QUEUE_2_QUEUE_MAX_PKTS_IN_Q 0x2001434
#define OQ_QUEUE_2_QUEUE_NUM_WORDS_IN_Q 0x2001438
#define OQ_QUEUE_2_QUEUE_NUM_WORDS_LEFT 0x200143c
#define OQ_QUEUE_2_QUEUE_FULL_THRESH 0x2001440
#define OQ_QUEUE_3_QUEUE_CTRL 0x2001600
#define OQ_QUEUE_3_QUEUE_NUM_PKT_BYTES_STORED 0x2001604
#define OQ_QUEUE_3_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001608
#define OQ_QUEUE_3_QUEUE_NUM_PKT_BYTES_REMOVED 0x200160c
#define OQ_QUEUE_3_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001610
#define OQ_QUEUE_3_QUEUE_NUM_PKTS_STORED 0x2001614
#define OQ_QUEUE_3_QUEUE_NUM_PKTS_DROPPED 0x2001618
#define OQ_QUEUE_3_QUEUE_NUM_PKTS_REMOVED 0x200161c
#define OQ_QUEUE_3_QUEUE_ADDR_LO 0x2001620
#define OQ_QUEUE_3_QUEUE_ADDR_HI 0x2001624
#define OQ_QUEUE_3_QUEUE_RD_ADDR 0x2001628
#define OQ_QUEUE_3_QUEUE_WR_ADDR 0x200162c
#define OQ_QUEUE_3_QUEUE_NUM_PKTS_IN_Q 0x2001630
#define OQ_QUEUE_3_QUEUE_MAX_PKTS_IN_Q 0x2001634
#define OQ_QUEUE_3_QUEUE_NUM_WORDS_IN_Q 0x2001638
#define OQ_QUEUE_3_QUEUE_NUM_WORDS_LEFT 0x200163c
#define OQ_QUEUE_3_QUEUE_FULL_THRESH 0x2001640
#define OQ_QUEUE_4_QUEUE_CTRL 0x2001800
#define OQ_QUEUE_4_QUEUE_NUM_PKT_BYTES_STORED 0x2001804
#define OQ_QUEUE_4_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001808
#define OQ_QUEUE_4_QUEUE_NUM_PKT_BYTES_REMOVED 0x200180c
#define OQ_QUEUE_4_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001810
#define OQ_QUEUE_4_QUEUE_NUM_PKTS_STORED 0x2001814
#define OQ_QUEUE_4_QUEUE_NUM_PKTS_DROPPED 0x2001818
#define OQ_QUEUE_4_QUEUE_NUM_PKTS_REMOVED 0x200181c
#define OQ_QUEUE_4_QUEUE_ADDR_LO 0x2001820
#define OQ_QUEUE_4_QUEUE_ADDR_HI 0x2001824
#define OQ_QUEUE_4_QUEUE_RD_ADDR 0x2001828
#define OQ_QUEUE_4_QUEUE_WR_ADDR 0x200182c
#define OQ_QUEUE_4_QUEUE_NUM_PKTS_IN_Q 0x2001830
#define OQ_QUEUE_4_QUEUE_MAX_PKTS_IN_Q 0x2001834
#define OQ_QUEUE_4_QUEUE_NUM_WORDS_IN_Q 0x2001838
#define OQ_QUEUE_4_QUEUE_NUM_WORDS_LEFT 0x200183c
#define OQ_QUEUE_4_QUEUE_FULL_THRESH 0x2001840
#define OQ_QUEUE_5_QUEUE_CTRL 0x2001a00
#define OQ_QUEUE_5_QUEUE_NUM_PKT_BYTES_STORED 0x2001a04
#define OQ_QUEUE_5_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001a08
#define OQ_QUEUE_5_QUEUE_NUM_PKT_BYTES_REMOVED 0x2001a0c
#define OQ_QUEUE_5_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001a10
#define OQ_QUEUE_5_QUEUE_NUM_PKTS_STORED 0x2001a14
#define OQ_QUEUE_5_QUEUE_NUM_PKTS_DROPPED 0x2001a18
#define OQ_QUEUE_5_QUEUE_NUM_PKTS_REMOVED 0x2001a1c
#define OQ_QUEUE_5_QUEUE_ADDR_LO 0x2001a20
#define OQ_QUEUE_5_QUEUE_ADDR_HI 0x2001a24
#define OQ_QUEUE_5_QUEUE_RD_ADDR 0x2001a28
#define OQ_QUEUE_5_QUEUE_WR_ADDR 0x2001a2c
#define OQ_QUEUE_5_QUEUE_NUM_PKTS_IN_Q 0x2001a30
#define OQ_QUEUE_5_QUEUE_MAX_PKTS_IN_Q 0x2001a34
#define OQ_QUEUE_5_QUEUE_NUM_WORDS_IN_Q 0x2001a38
#define OQ_QUEUE_5_QUEUE_NUM_WORDS_LEFT 0x2001a3c
#define OQ_QUEUE_5_QUEUE_FULL_THRESH 0x2001a40
#define OQ_QUEUE_6_QUEUE_CTRL 0x2001c00
#define OQ_QUEUE_6_QUEUE_NUM_PKT_BYTES_STORED 0x2001c04
#define OQ_QUEUE_6_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001c08
#define OQ_QUEUE_6_QUEUE_NUM_PKT_BYTES_REMOVED 0x2001c0c
#define OQ_QUEUE_6_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001c10
#define OQ_QUEUE_6_QUEUE_NUM_PKTS_STORED 0x2001c14
#define OQ_QUEUE_6_QUEUE_NUM_PKTS_DROPPED 0x2001c18
#define OQ_QUEUE_6_QUEUE_NUM_PKTS_REMOVED 0x2001c1c
#define OQ_QUEUE_6_QUEUE_ADDR_LO 0x2001c20
#define OQ_QUEUE_6_QUEUE_ADDR_HI 0x2001c24
#define OQ_QUEUE_6_QUEUE_RD_ADDR 0x2001c28
#define OQ_QUEUE_6_QUEUE_WR_ADDR 0x2001c2c
#define OQ_QUEUE_6_QUEUE_NUM_PKTS_IN_Q 0x2001c30
#define OQ_QUEUE_6_QUEUE_MAX_PKTS_IN_Q 0x2001c34
#define OQ_QUEUE_6_QUEUE_NUM_WORDS_IN_Q 0x2001c38
#define OQ_QUEUE_6_QUEUE_NUM_WORDS_LEFT 0x2001c3c
#define OQ_QUEUE_6_QUEUE_FULL_THRESH 0x2001c40
#define OQ_QUEUE_7_QUEUE_CTRL 0x2001e00
#define OQ_QUEUE_7_QUEUE_NUM_PKT_BYTES_STORED 0x2001e04
#define OQ_QUEUE_7_QUEUE_NUM_OVERHEAD_BYTES_STORED 0x2001e08
#define OQ_QUEUE_7_QUEUE_NUM_PKT_BYTES_REMOVED 0x2001e0c
#define OQ_QUEUE_7_QUEUE_NUM_OVERHEAD_BYTES_REMOVED 0x2001e10
#define OQ_QUEUE_7_QUEUE_NUM_PKTS_STORED 0x2001e14
#define OQ_QUEUE_7_QUEUE_NUM_PKTS_DROPPED 0x2001e18
#define OQ_QUEUE_7_QUEUE_NUM_PKTS_REMOVED 0x2001e1c
#define OQ_QUEUE_7_QUEUE_ADDR_LO 0x2001e20
#define OQ_QUEUE_7_QUEUE_ADDR_HI 0x2001e24
#define OQ_QUEUE_7_QUEUE_RD_ADDR 0x2001e28
#define OQ_QUEUE_7_QUEUE_WR_ADDR 0x2001e2c
#define OQ_QUEUE_7_QUEUE_NUM_PKTS_IN_Q 0x2001e30
#define OQ_QUEUE_7_QUEUE_MAX_PKTS_IN_Q 0x2001e34
#define OQ_QUEUE_7_QUEUE_NUM_WORDS_IN_Q 0x2001e38
#define OQ_QUEUE_7_QUEUE_NUM_WORDS_LEFT 0x2001e3c
#define OQ_QUEUE_7_QUEUE_FULL_THRESH 0x2001e40
// Name: DRAM (DRAM)
// Description: DRAM
#endif