> General rewording and cleanup on the rte_event_dev_config structure. > Improved the wording of some sentences and created linked > cross-references out of the existing references to the dev_info > structure. > > As part of the rework, fix issue with how single-link port-queue pairs > were counted in the rte_event_dev_config structure. This did not match > the actual implementation and, if following the documentation, certain > valid port/queue configurations would have been impossible to configure. > Fix this by changing the documentation to match the implementation > > Bugzilla ID: 1368 > Fixes: 75d113136f38 ("eventdev: express DLB/DLB2 PMD constraints") > > Signed-off-by: Bruce Richardson <bruce.richard...@intel.com>
Acked-by: Pavan Nikhilesh <pbhagavat...@marvell.com> > > --- > V3: > - minor tweaks following review > - merged in doc fix for bugzilla 1368 into this patch, since it fit with > other clarifications to the config struct. > --- > lib/eventdev/rte_eventdev.h | 61 ++++++++++++++++++++++--------------- > 1 file changed, 37 insertions(+), 24 deletions(-) > > diff --git a/lib/eventdev/rte_eventdev.h b/lib/eventdev/rte_eventdev.h > index 9d286168b1..73cc6b6688 100644 > --- a/lib/eventdev/rte_eventdev.h > +++ b/lib/eventdev/rte_eventdev.h > @@ -684,9 +684,9 @@ rte_event_dev_attr_get(uint8_t dev_id, uint32_t > attr_id, > struct rte_event_dev_config { > uint32_t dequeue_timeout_ns; > /**< rte_event_dequeue_burst() timeout on this device. > - * This value should be in the range of *min_dequeue_timeout_ns* > and > - * *max_dequeue_timeout_ns* which previously provided in > - * rte_event_dev_info_get() > + * This value should be in the range of @ref > rte_event_dev_info.min_dequeue_timeout_ns and > + * @ref rte_event_dev_info.max_dequeue_timeout_ns returned by > + * @ref rte_event_dev_info_get() > * The value 0 is allowed, in which case, default dequeue timeout used. > * @see RTE_EVENT_DEV_CFG_PER_DEQUEUE_TIMEOUT > */ > @@ -694,40 +694,53 @@ struct rte_event_dev_config { > /**< In a *closed system* this field is the limit on maximum number of > * events that can be inflight in the eventdev at a given time. The > * limit is required to ensure that the finite space in a closed system > - * is not overwhelmed. The value cannot exceed the > *max_num_events* > - * as provided by rte_event_dev_info_get(). > - * This value should be set to -1 for *open system*. > + * is not exhausted. > + * The value cannot exceed @ref > rte_event_dev_info.max_num_events > + * returned by rte_event_dev_info_get(). > + * > + * This value should be set to -1 for *open systems*, that is, > + * those systems returning -1 in @ref > rte_event_dev_info.max_num_events. > + * > + * @see rte_event_port_conf.new_event_threshold > */ > uint8_t nb_event_queues; > /**< Number of event queues to configure on this device. > - * This value cannot exceed the *max_event_queues* which previously > - * provided in rte_event_dev_info_get() > + * This value *includes* any single-link queue-port pairs to be used. > + * This value cannot exceed @ref > rte_event_dev_info.max_event_queues + > + * @ref rte_event_dev_info.max_single_link_event_port_queue_pairs > + * returned by rte_event_dev_info_get(). > + * The number of non-single-link queues i.e. this value less > + * *nb_single_link_event_port_queues* in this struct, cannot exceed > + * @ref rte_event_dev_info.max_event_queues > */ > uint8_t nb_event_ports; > /**< Number of event ports to configure on this device. > - * This value cannot exceed the *max_event_ports* which previously > - * provided in rte_event_dev_info_get() > + * This value *includes* any single-link queue-port pairs to be used. > + * This value cannot exceed @ref > rte_event_dev_info.max_event_ports + > + * @ref rte_event_dev_info.max_single_link_event_port_queue_pairs > + * returned by rte_event_dev_info_get(). > + * The number of non-single-link ports i.e. this value less > + * *nb_single_link_event_port_queues* in this struct, cannot exceed > + * @ref rte_event_dev_info.max_event_ports > */ > uint32_t nb_event_queue_flows; > - /**< Number of flows for any event queue on this device. > - * This value cannot exceed the *max_event_queue_flows* which > previously > - * provided in rte_event_dev_info_get() > + /**< Max number of flows needed for a single event queue on this > device. > + * This value cannot exceed @ref > rte_event_dev_info.max_event_queue_flows > + * returned by rte_event_dev_info_get() > */ > uint32_t nb_event_port_dequeue_depth; > - /**< Maximum number of events can be dequeued at a time from an > - * event port by this device. > - * This value cannot exceed the *max_event_port_dequeue_depth* > - * which previously provided in rte_event_dev_info_get(). > + /**< Max number of events that can be dequeued at a time from an > event port on this device. > + * This value cannot exceed @ref > rte_event_dev_info.max_event_port_dequeue_depth > + * returned by rte_event_dev_info_get(). > * Ignored when device is not RTE_EVENT_DEV_CAP_BURST_MODE > capable. > - * @see rte_event_port_setup() > + * @see rte_event_port_setup() rte_event_dequeue_burst() > */ > uint32_t nb_event_port_enqueue_depth; > - /**< Maximum number of events can be enqueued at a time from an > - * event port by this device. > - * This value cannot exceed the *max_event_port_enqueue_depth* > - * which previously provided in rte_event_dev_info_get(). > + /**< Maximum number of events can be enqueued at a time to an > event port on this device. > + * This value cannot exceed @ref > rte_event_dev_info.max_event_port_enqueue_depth > + * returned by rte_event_dev_info_get(). > * Ignored when device is not RTE_EVENT_DEV_CAP_BURST_MODE > capable. > - * @see rte_event_port_setup() > + * @see rte_event_port_setup() rte_event_enqueue_burst() > */ > uint32_t event_dev_cfg; > /**< Event device config flags(RTE_EVENT_DEV_CFG_)*/ > @@ -737,7 +750,7 @@ struct rte_event_dev_config { > * queues; this value cannot exceed *nb_event_ports* or > * *nb_event_queues*. If the device has ports and queues that are > * optimized for single-link usage, this field is a hint for how many > - * to allocate; otherwise, regular event ports and queues can be used. > + * to allocate; otherwise, regular event ports and queues will be used. > */ > }; > > -- > 2.40.1