04/10/2021 15:55, Konstantin Ananyev: > Copy public function pointers (rx_pkt_burst(), etc.) and related > pointers to internal data from rte_eth_dev structure into a > separate flat array. That array will remain in a public header. > The intention here is to make rte_eth_dev and related structures internal. > That should allow future possible changes to core eth_dev structures > to be transparent to the user and help to avoid ABI/API breakages. > The plan is to keep minimal part of data from rte_eth_dev public, > so we still can use inline functions for 'fast' calls > (like rte_eth_rx_burst(), etc.) to avoid/minimize slowdown.
I don't understand why 'fast' is quoted. It looks strange. > +/* reset eth 'fast' API to dummy values */ > +void eth_dev_fp_ops_reset(struct rte_eth_fp_ops *fpo); > + > +/* setup eth 'fast' API to ethdev values */ > +void eth_dev_fp_ops_setup(struct rte_eth_fp_ops *fpo, > + const struct rte_eth_dev *dev); I assume "fp" stands for fast path. Please write "fast path" completely in the comments. > + /* expose selection of PMD rx/tx function */ > + eth_dev_fp_ops_setup(rte_eth_fp_ops + port_id, dev); [...] > + /* point rx/tx functions to dummy ones */ > + eth_dev_fp_ops_reset(rte_eth_fp_ops + port_id); Nit: Rx/Tx or could be "fast path", to be consistent. > + /* > + * for secondary process, at that point we expect device > + * to be already 'usable', so shared data and all function pointers > + * for 'fast' devops have to be setup properly inside rte_eth_dev. > + */ > + if (rte_eal_process_type() == RTE_PROC_SECONDARY) > + eth_dev_fp_ops_setup(rte_eth_fp_ops + dev->data->port_id, dev); > + > rte_eth_dev_callback_process(dev, RTE_ETH_EVENT_NEW, NULL); > > dev->state = RTE_ETH_DEV_ATTACHED; > diff --git a/lib/ethdev/rte_ethdev_core.h b/lib/ethdev/rte_ethdev_core.h > index 948c0b71c1..fe47a660c7 100644 > --- a/lib/ethdev/rte_ethdev_core.h > +++ b/lib/ethdev/rte_ethdev_core.h > @@ -53,6 +53,51 @@ typedef int (*eth_rx_descriptor_status_t)(void *rxq, > uint16_t offset); > typedef int (*eth_tx_descriptor_status_t)(void *txq, uint16_t offset); > /**< @internal Check the status of a Tx descriptor */ > > +/** > + * @internal > + * Structure used to hold opaque pointernals to internal ethdev RX/TXi typos in above line > + * queues data. > + * The main purpose to expose these pointers at all - allow compiler > + * to fetch this data for 'fast' ethdev inline functions in advance. > + */ > +struct rte_ethdev_qdata { > + void **data; > + /**< points to array of internal queue data pointers */ > + void **clbk; > + /**< points to array of queue callback data pointers */ > +}; > + > +/** > + * @internal > + * 'fast' ethdev funcions and related data are hold in a flat array. > + * one entry per ethdev. > + */ > +struct rte_eth_fp_ops { > + > + /** first 64B line */ > + eth_rx_burst_t rx_pkt_burst; > + /**< PMD receive function. */ > + eth_tx_burst_t tx_pkt_burst; > + /**< PMD transmit function. */ > + eth_tx_prep_t tx_pkt_prepare; > + /**< 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. */ > + uintptr_t reserved[2]; uintptr_t size is not fix. I think you mean uint64_t. > + > + /** second 64B line */ > + struct rte_ethdev_qdata rxq; > + struct rte_ethdev_qdata txq; > + uintptr_t reserved2[4]; > + > +} __rte_cache_aligned; > + > +extern struct rte_eth_fp_ops rte_eth_fp_ops[RTE_MAX_ETHPORTS];