1d30ea906Sjfb8856606 /* SPDX-License-Identifier: BSD-3-Clause 2d30ea906Sjfb8856606 * Copyright(c) 2016-2017 Intel Corporation 32bfe3f2eSlogwang */ 42bfe3f2eSlogwang 52bfe3f2eSlogwang #ifndef _COMMON_H_ 62bfe3f2eSlogwang #define _COMMON_H_ 72bfe3f2eSlogwang 82bfe3f2eSlogwang #include <rte_hash_crc.h> 92bfe3f2eSlogwang #include <rte_hash.h> 102bfe3f2eSlogwang 112bfe3f2eSlogwang #define MAX_NODES 16 122bfe3f2eSlogwang /* 132bfe3f2eSlogwang * Shared port info, including statistics information for display by server. 142bfe3f2eSlogwang * Structure will be put in a memzone. 152bfe3f2eSlogwang * - All port id values share one cache line as this data will be read-only 162bfe3f2eSlogwang * during operation. 172bfe3f2eSlogwang * - All rx statistic values share cache lines, as this data is written only 182bfe3f2eSlogwang * by the server process. (rare reads by stats display) 192bfe3f2eSlogwang * - The tx statistics have values for all ports per cache line, but the stats 202bfe3f2eSlogwang * themselves are written by the nodes, so we have a distinct set, on different 212bfe3f2eSlogwang * cache lines for each node to use. 222bfe3f2eSlogwang */ 232bfe3f2eSlogwang struct rx_stats { 242bfe3f2eSlogwang uint64_t rx[RTE_MAX_ETHPORTS]; 252bfe3f2eSlogwang } __rte_cache_aligned; 262bfe3f2eSlogwang 272bfe3f2eSlogwang struct tx_stats { 282bfe3f2eSlogwang uint64_t tx[RTE_MAX_ETHPORTS]; 292bfe3f2eSlogwang uint64_t tx_drop[RTE_MAX_ETHPORTS]; 302bfe3f2eSlogwang } __rte_cache_aligned; 312bfe3f2eSlogwang 322bfe3f2eSlogwang struct filter_stats { 332bfe3f2eSlogwang uint64_t drop; 342bfe3f2eSlogwang uint64_t passed; 352bfe3f2eSlogwang } __rte_cache_aligned; 362bfe3f2eSlogwang 372bfe3f2eSlogwang struct shared_info { 382bfe3f2eSlogwang uint8_t num_nodes; 392bfe3f2eSlogwang uint16_t num_ports; 402bfe3f2eSlogwang uint32_t num_flows; 412bfe3f2eSlogwang uint16_t id[RTE_MAX_ETHPORTS]; 422bfe3f2eSlogwang struct rx_stats rx_stats; 432bfe3f2eSlogwang struct tx_stats tx_stats[MAX_NODES]; 442bfe3f2eSlogwang struct filter_stats filter_stats[MAX_NODES]; 452bfe3f2eSlogwang }; 462bfe3f2eSlogwang 472bfe3f2eSlogwang /* define common names for structures shared between server and node */ 482bfe3f2eSlogwang #define MP_NODE_RXQ_NAME "MProc_Node_%u_RX" 492bfe3f2eSlogwang #define PKTMBUF_POOL_NAME "MProc_pktmbuf_pool" 502bfe3f2eSlogwang #define MZ_SHARED_INFO "MProc_shared_info" 512bfe3f2eSlogwang 522bfe3f2eSlogwang /* 532bfe3f2eSlogwang * Given the rx queue name template above, get the queue name 542bfe3f2eSlogwang */ 552bfe3f2eSlogwang static inline const char * get_rx_queue_name(unsigned int id)562bfe3f2eSlogwangget_rx_queue_name(unsigned int id) 572bfe3f2eSlogwang { 582bfe3f2eSlogwang /* 592bfe3f2eSlogwang * Buffer for return value. Size calculated by %u being replaced 602bfe3f2eSlogwang * by maximum 3 digits (plus an extra byte for safety) 612bfe3f2eSlogwang */ 622bfe3f2eSlogwang static char buffer[sizeof(MP_NODE_RXQ_NAME) + 2]; 632bfe3f2eSlogwang 64*4b05018fSfengbojiang snprintf(buffer, sizeof(buffer), MP_NODE_RXQ_NAME, id); 652bfe3f2eSlogwang return buffer; 662bfe3f2eSlogwang } 672bfe3f2eSlogwang 682bfe3f2eSlogwang #define RTE_LOGTYPE_APP RTE_LOGTYPE_USER1 692bfe3f2eSlogwang 702bfe3f2eSlogwang #endif 71