/* SPDX-License-Identifier: BSD-3-Clause * Copyright (c) 2015-2018 Atomic Rules LLC */ #ifndef _ARK_UDM_H_ #define _ARK_UDM_H_ #include #include /* The UDM or Upstream Data Mover is an internal Arkville hardware * module for moving packet from the RX packet streams to host memory. * This module is *not* intended for end-user manipulation, hence * there is minimal documentation. */ /* Meta data structure passed from FPGA, must match layout in FPGA * -- 32 bytes */ struct ark_rx_meta { uint32_t user_meta[5]; /* user defined based on fpga code */ uint8_t reserved[10]; uint16_t pkt_len; } __rte_packed; /* * UDM hardware structures * These are overlay structures to a memory mapped FPGA device. These * structs will never be instantiated in ram memory */ #define ARK_RX_WRITE_TIME_NS 2500 #define ARK_UDM_SETUP 0 #define ARK_UDM_MODID 0x4d445500 #define ARK_UDM_MODVER 0x37313232 struct ark_udm_setup_t { union { char id[4]; uint32_t idnum; }; union { char ver[4]; uint32_t vernum; }; uint32_t r0; uint32_t const0; }; #define ARK_UDM_CFG 0x010 struct ark_udm_cfg_t { uint32_t write_interval; /* 4ns cycles */ volatile uint32_t command; uint32_t dataroom; uint32_t headroom; }; typedef enum { ARK_UDM_START = 0x1, ARK_UDM_STOP = 0x2, ARK_UDM_RESET = 0x3 } ark_udm_commands; #define ARK_UDM_STATS 0x020 struct ark_udm_stats_t { volatile uint64_t rx_byte_count; volatile uint64_t rx_packet_count; volatile uint64_t rx_mbuf_count; volatile uint64_t rx_sent_packets; }; #define ARK_UDM_PQ 0x040 struct ark_udm_queue_stats_t { volatile uint64_t q_byte_count; volatile uint64_t q_packet_count; /* includes drops */ volatile uint64_t q_mbuf_count; volatile uint64_t q_ff_packet_count; volatile uint64_t q_pkt_drop; uint32_t q_enable; }; #define ARK_UDM_RT_CFG 0x00e0 struct ark_udm_rt_cfg_t { rte_iova_t hw_prod_addr; uint32_t reserved; volatile uint32_t prod_idx; /* Updated by HW */ }; /* Consolidated structure */ #define ARK_UDM_EXPECT_SIZE (0x00fc + 4) #define ARK_UDM_QOFFSET ARK_UDM_EXPECT_SIZE struct ark_udm_t { struct ark_udm_setup_t setup; struct ark_udm_cfg_t cfg; struct ark_udm_stats_t stats; struct ark_udm_queue_stats_t qstats; uint8_t reserved1[(ARK_UDM_RT_CFG - ARK_UDM_PQ) - sizeof(struct ark_udm_queue_stats_t)]; struct ark_udm_rt_cfg_t rt_cfg; int8_t reserved3[(ARK_UDM_EXPECT_SIZE - ARK_UDM_RT_CFG) - sizeof(struct ark_udm_rt_cfg_t)]; }; int ark_udm_verify(struct ark_udm_t *udm); void ark_udm_configure(struct ark_udm_t *udm, uint32_t headroom, uint32_t dataroom); void ark_udm_write_addr(struct ark_udm_t *udm, rte_iova_t addr); void ark_udm_dump_stats(struct ark_udm_t *udm, const char *msg); void ark_udm_dump_queue_stats(struct ark_udm_t *udm, const char *msg, uint16_t qid); void ark_udm_dump_setup(struct ark_udm_t *udm, uint16_t q_id); /* Per queue data */ uint64_t ark_udm_dropped(struct ark_udm_t *udm); uint64_t ark_udm_bytes(struct ark_udm_t *udm); uint64_t ark_udm_packets(struct ark_udm_t *udm); void ark_udm_queue_stats_reset(struct ark_udm_t *udm); void ark_udm_queue_enable(struct ark_udm_t *udm, int enable); #endif