13998e2a0SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause 23998e2a0SBruce Richardson * Copyright(c) 2016-2017 Intel Corporation 3ed2a80fdSPablo de Lara */ 4ed2a80fdSPablo de Lara 5ed2a80fdSPablo de Lara #ifndef _COMMON_H_ 6ed2a80fdSPablo de Lara #define _COMMON_H_ 7ed2a80fdSPablo de Lara 8ed2a80fdSPablo de Lara #include <rte_hash_crc.h> 9ed2a80fdSPablo de Lara #include <rte_hash.h> 10ed2a80fdSPablo de Lara 11ed2a80fdSPablo de Lara #define MAX_NODES 16 12ed2a80fdSPablo de Lara /* 13ed2a80fdSPablo de Lara * Shared port info, including statistics information for display by server. 14ed2a80fdSPablo de Lara * Structure will be put in a memzone. 15ed2a80fdSPablo de Lara * - All port id values share one cache line as this data will be read-only 16ed2a80fdSPablo de Lara * during operation. 17ed2a80fdSPablo de Lara * - All rx statistic values share cache lines, as this data is written only 18ed2a80fdSPablo de Lara * by the server process. (rare reads by stats display) 19ed2a80fdSPablo de Lara * - The tx statistics have values for all ports per cache line, but the stats 20ed2a80fdSPablo de Lara * themselves are written by the nodes, so we have a distinct set, on different 21ed2a80fdSPablo de Lara * cache lines for each node to use. 22ed2a80fdSPablo de Lara */ 23*7e06c0deSTyler Retzlaff struct __rte_cache_aligned rx_stats { 24ed2a80fdSPablo de Lara uint64_t rx[RTE_MAX_ETHPORTS]; 25*7e06c0deSTyler Retzlaff }; 26ed2a80fdSPablo de Lara 27*7e06c0deSTyler Retzlaff struct __rte_cache_aligned tx_stats { 28ed2a80fdSPablo de Lara uint64_t tx[RTE_MAX_ETHPORTS]; 29ed2a80fdSPablo de Lara uint64_t tx_drop[RTE_MAX_ETHPORTS]; 30*7e06c0deSTyler Retzlaff }; 31ed2a80fdSPablo de Lara 32*7e06c0deSTyler Retzlaff struct __rte_cache_aligned filter_stats { 33ed2a80fdSPablo de Lara uint64_t drop; 34ed2a80fdSPablo de Lara uint64_t passed; 35*7e06c0deSTyler Retzlaff }; 36ed2a80fdSPablo de Lara 37ed2a80fdSPablo de Lara struct shared_info { 38ed2a80fdSPablo de Lara uint8_t num_nodes; 39f8244c63SZhiyong Yang uint16_t num_ports; 40ed2a80fdSPablo de Lara uint32_t num_flows; 41f8244c63SZhiyong Yang uint16_t id[RTE_MAX_ETHPORTS]; 42ed2a80fdSPablo de Lara struct rx_stats rx_stats; 43ed2a80fdSPablo de Lara struct tx_stats tx_stats[MAX_NODES]; 44ed2a80fdSPablo de Lara struct filter_stats filter_stats[MAX_NODES]; 45ed2a80fdSPablo de Lara }; 46ed2a80fdSPablo de Lara 47ed2a80fdSPablo de Lara /* define common names for structures shared between server and node */ 48ed2a80fdSPablo de Lara #define MP_NODE_RXQ_NAME "MProc_Node_%u_RX" 49ed2a80fdSPablo de Lara #define PKTMBUF_POOL_NAME "MProc_pktmbuf_pool" 50ed2a80fdSPablo de Lara #define MZ_SHARED_INFO "MProc_shared_info" 51ed2a80fdSPablo de Lara 52ed2a80fdSPablo de Lara /* 53ed2a80fdSPablo de Lara * Given the rx queue name template above, get the queue name 54ed2a80fdSPablo de Lara */ 55ed2a80fdSPablo de Lara static inline const char * get_rx_queue_name(unsigned int id)56ed2a80fdSPablo de Laraget_rx_queue_name(unsigned int id) 57ed2a80fdSPablo de Lara { 58ed2a80fdSPablo de Lara /* 59ed2a80fdSPablo de Lara * Buffer for return value. Size calculated by %u being replaced 60ed2a80fdSPablo de Lara * by maximum 3 digits (plus an extra byte for safety) 61ed2a80fdSPablo de Lara */ 62ed2a80fdSPablo de Lara static char buffer[sizeof(MP_NODE_RXQ_NAME) + 2]; 63ed2a80fdSPablo de Lara 64f4be6a9aSMichael Santana snprintf(buffer, sizeof(buffer), MP_NODE_RXQ_NAME, id); 65ed2a80fdSPablo de Lara return buffer; 66ed2a80fdSPablo de Lara } 67ed2a80fdSPablo de Lara 68ed2a80fdSPablo de Lara #define RTE_LOGTYPE_APP RTE_LOGTYPE_USER1 69ed2a80fdSPablo de Lara 70ed2a80fdSPablo de Lara #endif 71