> 04/10/2021 15:56, Konstantin Ananyev: > > Move rte_eth_dev, rte_eth_dev_data, rte_eth_rxtx_callback and related > > data into private header (ethdev_driver.h). > [...] > > +/** > > + * @internal > > + * Structure used to hold information about the callbacks to be called for > > a > > + * queue on RX and TX. > > + */ > > +struct rte_eth_rxtx_callback { > > + struct rte_eth_rxtx_callback *next; > > + union{ > > + rte_rx_callback_fn rx; > > + rte_tx_callback_fn tx; > > + } fn; > > + void *param; > > +}; > > + > > +/** > > + * @internal > > + * The generic data structure associated with each ethernet device. > > + * > > + * Pointers to burst-oriented packet receive and transmit functions are > > + * located at the beginning of the structure, along with the pointer to > > + * where all the data elements for the particular device are stored in > > shared > > + * memory. This split allows the function pointer and driver data to be > > per- > > + * process, while the actual configuration data for the device is shared. > > + */ > > +struct rte_eth_dev { > > + eth_rx_burst_t rx_pkt_burst; /**< Pointer to PMD receive function. */ > > + eth_tx_burst_t tx_pkt_burst; /**< Pointer to PMD transmit function. */ > > + eth_tx_prep_t tx_pkt_prepare; > > + /**< Pointer to PMD transmit prepare function. */ > > + eth_rx_queue_count_t rx_queue_count; > > + /**< Get the number of used RX descriptors. */ > > + eth_rx_descriptor_status_t rx_descriptor_status; > > + /**< Check the status of a Rx descriptor. */ > > + eth_tx_descriptor_status_t tx_descriptor_status; > > + /**< Check the status of a Tx descriptor. */ > > Why not using the new struct rte_eth_fp_ops? We don't want to change each and every driver for this change. The idea beyond it: 1. PMDs keep to setup fast-path function pointers and related data inside rte_eth_dev struct in the same way they did it before. 2. Inside rte_eth_dev_start() and inside rte_eth_dev_probing_finish() (for secondary process) we call eth_dev_fp_ops_setup, which copies these function and data pointers into rte_eth_fp_ops[port_id]. 3. Inside rte_eth_dev_stop() and inside rte_eth_dev_release_port() we call eth_dev_fp_ops_reset(), which resets rte_eth_fp_ops[port_id] into some dummy values. > > > + > > + /** > > + * Next two fields are per-device data but *data is shared between > > + * primary and secondary processes and *process_private is per-process > > + * private. The second one is managed by PMDs if necessary. > > + */ > > + struct rte_eth_dev_data *data; /**< Pointer to device data. */ > > We should mention that "data" is shared between processes. I think the comment above states exactly that. In fact, it is just cut and paste from lib/ethdev/rte_ethdev_core.h to lib/ethdev/ethdev_driver.h. > > > + void *process_private; /**< Pointer to per-process device data. */ > > + const struct eth_dev_ops *dev_ops; /**< Functions exported by PMD */ > > + struct rte_device *device; /**< Backing device */ > > + struct rte_intr_handle *intr_handle; /**< Device interrupt handle */ > > + /** User application callbacks for NIC interrupts */ > > + struct rte_eth_dev_cb_list link_intr_cbs; > > + /** > > + * User-supplied functions called from rx_burst to post-process > > + * received packets before passing them to the user > > + */ > > + struct rte_eth_rxtx_callback > > *post_rx_burst_cbs[RTE_MAX_QUEUES_PER_PORT]; > > + /** > > + * User-supplied functions called from tx_burst to pre-process > > + * received packets before passing them to the driver for transmission. > > + */ > > + struct rte_eth_rxtx_callback *pre_tx_burst_cbs[RTE_MAX_QUEUES_PER_PORT]; > > + enum rte_eth_dev_state state; /**< Flag indicating the port state */ > > + void *security_ctx; /**< Context for security ops */ > > + > > + uint64_t reserved_64s[4]; /**< Reserved for future fields */ > > + void *reserved_ptrs[4]; /**< Reserved for future fields */ > > +} __rte_cache_aligned; > > + > > +struct rte_eth_dev_sriov; > > +struct rte_eth_dev_owner; > > + > > +/** > > + * @internal > > + * The data part, with no function pointers, associated with each ethernet > > + * device. This structure is safe to place in shared memory to be common > > + * among different processes in a multi-process configuration. > > + */ > > +struct rte_eth_dev_data { > > + char name[RTE_ETH_NAME_MAX_LEN]; /**< Unique identifier name */ > > + > > + void **rx_queues; /**< Array of pointers to RX queues. */ > > + void **tx_queues; /**< Array of pointers to TX queues. */ > > + uint16_t nb_rx_queues; /**< Number of RX queues. */ > > + uint16_t nb_tx_queues; /**< Number of TX queues. */ > > + > > + struct rte_eth_dev_sriov sriov; /**< SRIOV data */ > > + > > + void *dev_private; > > + /**< PMD-specific private data. > > + * @see rte_eth_dev_release_port() > > + */ > > + > > + struct rte_eth_link dev_link; /**< Link-level information & status. */ > > + struct rte_eth_conf dev_conf; /**< Configuration applied to device. */ > > + uint16_t mtu; /**< Maximum Transmission Unit. */ > > + uint32_t min_rx_buf_size; > > + /**< Common RX buffer size handled by all queues. */ > > + > > + uint64_t rx_mbuf_alloc_failed; /**< RX ring mbuf allocation failures. */ > > + struct rte_ether_addr *mac_addrs; > > + /**< Device Ethernet link address. > > + * @see rte_eth_dev_release_port() > > + */ > > + uint64_t mac_pool_sel[ETH_NUM_RECEIVE_MAC_ADDR]; > > + /**< Bitmap associating MAC addresses to pools. */ > > + struct rte_ether_addr *hash_mac_addrs; > > + /**< Device Ethernet MAC addresses of hash filtering. > > + * @see rte_eth_dev_release_port() > > + */ > > + uint16_t port_id; /**< Device [external] port identifier. */ > > + > > + __extension__ > > + uint8_t promiscuous : 1, > > + /**< RX promiscuous mode ON(1) / OFF(0). */ > > + scattered_rx : 1, > > + /**< RX of scattered packets is ON(1) / OFF(0) */ > > + all_multicast : 1, > > + /**< RX all multicast mode ON(1) / OFF(0). */ > > + dev_started : 1, > > + /**< Device state: STARTED(1) / STOPPED(0). */ > > + lro : 1, > > + /**< RX LRO is ON(1) / OFF(0) */ > > + dev_configured : 1; > > + /**< Indicates whether the device is configured. > > + * CONFIGURED(1) / NOT CONFIGURED(0). > > + */ > > + uint8_t rx_queue_state[RTE_MAX_QUEUES_PER_PORT]; > > + /**< Queues state: HAIRPIN(2) / STARTED(1) / STOPPED(0). */ > > + uint8_t tx_queue_state[RTE_MAX_QUEUES_PER_PORT]; > > + /**< Queues state: HAIRPIN(2) / STARTED(1) / STOPPED(0). */ > > + uint32_t dev_flags; /**< Capabilities. */ > > + int numa_node; /**< NUMA node connection. */ > > + struct rte_vlan_filter_conf vlan_filter_conf; > > + /**< VLAN filter configuration. */ > > + struct rte_eth_dev_owner owner; /**< The port owner. */ > > + uint16_t representor_id; > > + /**< Switch-specific identifier. > > + * Valid if RTE_ETH_DEV_REPRESENTOR in dev_flags. > > + */ > > + > > + pthread_mutex_t flow_ops_mutex; /**< rte_flow ops mutex. */ > > + uint64_t reserved_64s[4]; /**< Reserved for future fields */ > > + void *reserved_ptrs[4]; /**< Reserved for future fields */ > > +} __rte_cache_aligned; > > + > > +/** > > + * @internal > > + * The pool of *rte_eth_dev* structures. The size of the pool > > + * is configured at compile-time in the <rte_ethdev.c> file. > > + */ > > +extern struct rte_eth_dev rte_eth_devices[]; > > Later we should add a function to configure the size of this array dynamically > in the early DPDK init stage. After we will hide rte_eth_devices[] and friends, we should be able to do with them whatever we want. But I suppose, that should be a subject of separate patch/discussion, Probably not in 21.11 timeframe.