On Tue, Jan 23, 2024 at 11:00:50AM +0100, Mattias Rönnblom wrote:
> On 2024-01-19 18:43, Bruce Richardson wrote:
> > Improve the documentation text for the configuration functions and
> > structures for configuring an eventdev, as well as ports and queues.
> > Clarify text where possible, and ensure references come through as links
> > in the html output.
> > 
> > Signed-off-by: Bruce Richardson <bruce.richard...@intel.com>
> > ---
> >   lib/eventdev/rte_eventdev.h | 196 ++++++++++++++++++++++++------------
> >   1 file changed, 130 insertions(+), 66 deletions(-)
> > 
> > diff --git a/lib/eventdev/rte_eventdev.h b/lib/eventdev/rte_eventdev.h
> > index 3b8f5b8101..1fda8a5a13 100644
> > --- a/lib/eventdev/rte_eventdev.h
> > +++ b/lib/eventdev/rte_eventdev.h
> > @@ -676,12 +676,14 @@ struct rte_event_dev_config {
> >   /**
> >    * Configure an event device.
> >    *
> > - * This function must be invoked first before any other function in the
> > - * API. This function can also be re-invoked when a device is in the
> > - * stopped state.
> > + * This function must be invoked before any other configuration function 
> > in the
> > + * API, when preparing an event device for application use.
> > + * This function can also be re-invoked when a device is in the stopped 
> > state.
> >    *
> > - * The caller may use rte_event_dev_info_get() to get the capability of 
> > each
> > - * resources available for this event device.
> > + * The caller should use rte_event_dev_info_get() to get the capabilities 
> > and
> > + * resource limits for this event device before calling this API.
> 
> "should" -> "may". If you know the limitations by other means, that's fine
> too.
> 

I think I'll keep it as "should", since it's strongly recommended. "Must"
would be incorrect, since it's not mandatory, but I think "may" is too
week.

> > + * Many values in the dev_conf input parameter are subject to limits given
> > + * in the device information returned from rte_event_dev_info_get().
> >    *
> >    * @param dev_id
> >    *   The identifier of the device to configure.
> > @@ -691,6 +693,9 @@ struct rte_event_dev_config {
> >    * @return
> >    *   - 0: Success, device configured.
> >    *   - <0: Error code returned by the driver configuration function.
> > + *     - -ENOTSUP - device does not support configuration
> > + *     - -EINVAL  - invalid input parameter
> > + *     - -EBUSY   - device has already been started
> >    */
> >   int
> >   rte_event_dev_configure(uint8_t dev_id,
> > @@ -700,14 +705,33 @@ rte_event_dev_configure(uint8_t dev_id,
> >   /* Event queue configuration bitmap flags */
> >   #define RTE_EVENT_QUEUE_CFG_ALL_TYPES          (1ULL << 0)
> > -/**< Allow ATOMIC,ORDERED,PARALLEL schedule type enqueue
> > +/**< Allow events with schedule types ATOMIC, ORDERED, and PARALLEL to be 
> > enqueued to this queue.
> > + * The scheduling type to be used is that specified in each individual 
> > event.
> > + * This flag can only be set when configuring queues on devices reporting 
> > the
> > + * @ref RTE_EVENT_DEV_CAP_QUEUE_ALL_TYPES capability.
> >    *
> > + * Without this flag, only events with the specific scheduling type 
> > configured at queue setup
> > + * can be sent to the queue.
> > + *
> > + * @see RTE_EVENT_DEV_CAP_QUEUE_ALL_TYPES
> >    * @see RTE_SCHED_TYPE_ORDERED, RTE_SCHED_TYPE_ATOMIC, 
> > RTE_SCHED_TYPE_PARALLEL
> >    * @see rte_event_enqueue_burst()
> >    */
> >   #define RTE_EVENT_QUEUE_CFG_SINGLE_LINK        (1ULL << 1)
> >   /**< This event queue links only to a single event port.
> > - *
> > + * No load-balancing of events is performed, as all events
> > + * sent to this queue end up at the same event port.
> > + * The number of queues on which this flag is to be set must be
> > + * configured at device configuration time, by setting
> > + * @ref rte_event_dev_config.nb_single_link_event_port_queues
> > + * parameter appropriately.
> > + *
> > + * This flag serves as a hint only, any devices without specific
> > + * support for single-link queues can fall-back automatically to
> > + * using regular queues with a single destination port.
> > + *
> > + *  @see rte_event_dev_info.max_single_link_event_port_queue_pairs
> > + *  @see rte_event_dev_config.nb_single_link_event_port_queues
> >    *  @see rte_event_port_setup(), rte_event_port_link()
> >    */
> > @@ -715,56 +739,75 @@ rte_event_dev_configure(uint8_t dev_id,
> >   struct rte_event_queue_conf {
> >     uint32_t nb_atomic_flows;
> >     /**< The maximum number of active flows this queue can track at any
> > -    * given time. If the queue is configured for atomic scheduling (by
> > -    * applying the RTE_EVENT_QUEUE_CFG_ALL_TYPES flag to event_queue_cfg
> > -    * or RTE_SCHED_TYPE_ATOMIC flag to schedule_type), then the
> > -    * value must be in the range of [1, nb_event_queue_flows], which was
> > -    * previously provided in rte_event_dev_configure().
> > +    * given time.
> > +    *
> > +    * If the queue is configured for atomic scheduling (by
> > +    * applying the @ref RTE_EVENT_QUEUE_CFG_ALL_TYPES flag to
> > +    * @ref rte_event_queue_conf.event_queue_cfg
> > +    * or @ref RTE_SCHED_TYPE_ATOMIC flag to @ref 
> > rte_event_queue_conf.schedule_type), then the
> > +    * value must be in the range of [1, @ref 
> > rte_event_dev_config.nb_event_queue_flows],
> > +    * which was previously provided in rte_event_dev_configure().
> > +    *
> > +    * If the queue is not configured for atomic scheduling this value is 
> > ignored.
> >      */
> >     uint32_t nb_atomic_order_sequences;
> >     /**< The maximum number of outstanding events waiting to be
> >      * reordered by this queue. In other words, the number of entries in
> >      * this queue’s reorder buffer.When the number of events in the
> >      * reorder buffer reaches to *nb_atomic_order_sequences* then the
> > -    * scheduler cannot schedule the events from this queue and invalid
> > -    * event will be returned from dequeue until one or more entries are
> > +    * scheduler cannot schedule the events from this queue and no
> > +    * events will be returned from dequeue until one or more entries are
> >      * freed up/released.
> > +    *
> >      * If the queue is configured for ordered scheduling (by applying the
> > -    * RTE_EVENT_QUEUE_CFG_ALL_TYPES flag to event_queue_cfg or
> > -    * RTE_SCHED_TYPE_ORDERED flag to schedule_type), then the value must
> > -    * be in the range of [1, nb_event_queue_flows], which was
> > +    * @ref RTE_EVENT_QUEUE_CFG_ALL_TYPES flag to @ref 
> > rte_event_queue_conf.event_queue_cfg or
> > +    * @ref RTE_SCHED_TYPE_ORDERED flag to @ref 
> > rte_event_queue_conf.schedule_type),
> > +    * then the value must be in the range of
> > +    * [1, @ref rte_event_dev_config.nb_event_queue_flows], which was
> >      * previously supplied to rte_event_dev_configure().
> > +    *
> > +    * If the queue is not configured for ordered scheduling, then this 
> > value is ignored
> >      */
> >     uint32_t event_queue_cfg;
> >     /**< Queue cfg flags(EVENT_QUEUE_CFG_) */
> >     uint8_t schedule_type;
> >     /**< Queue schedule type(RTE_SCHED_TYPE_*).
> > -    * Valid when RTE_EVENT_QUEUE_CFG_ALL_TYPES bit is not set in
> > -    * event_queue_cfg.
> > +    * Valid when @ref RTE_EVENT_QUEUE_CFG_ALL_TYPES flag is not set in
> > +    * @ref rte_event_queue_conf.event_queue_cfg.
> > +    *
> > +    * If the @ref RTE_EVENT_QUEUE_CFG_ALL_TYPES flag is set, then this 
> > field is ignored.
> > +    *
> > +    * @see RTE_SCHED_TYPE_ORDERED, RTE_SCHED_TYPE_ATOMIC, 
> > RTE_SCHED_TYPE_PARALLEL
> >      */
> >     uint8_t priority;
> >     /**< Priority for this event queue relative to other event queues.
> >      * The requested priority should in the range of
> > -    * [RTE_EVENT_DEV_PRIORITY_HIGHEST, RTE_EVENT_DEV_PRIORITY_LOWEST].
> > +    * [@ref RTE_EVENT_DEV_PRIORITY_HIGHEST, @ref 
> > RTE_EVENT_DEV_PRIORITY_LOWEST].
> >      * The implementation shall normalize the requested priority to
> >      * event device supported priority value.
> > -    * Valid when the device has RTE_EVENT_DEV_CAP_QUEUE_QOS capability
> > +    *
> > +    * Valid when the device has @ref RTE_EVENT_DEV_CAP_QUEUE_QOS 
> > capability,
> > +    * ignored otherwise
> >      */
> >     uint8_t weight;
> >     /**< Weight of the event queue relative to other event queues.
> >      * The requested weight should be in the range of
> > -    * [RTE_EVENT_DEV_WEIGHT_HIGHEST, RTE_EVENT_DEV_WEIGHT_LOWEST].
> > +    * [@ref RTE_EVENT_QUEUE_WEIGHT_HIGHEST, @ref 
> > RTE_EVENT_QUEUE_WEIGHT_LOWEST].
> >      * The implementation shall normalize the requested weight to event
> >      * device supported weight value.
> > -    * Valid when the device has RTE_EVENT_DEV_CAP_QUEUE_QOS capability.
> > +    *
> > +    * Valid when the device has @ref RTE_EVENT_DEV_CAP_QUEUE_QOS 
> > capability,
> > +    * ignored otherwise.
> >      */
> >     uint8_t affinity;
> >     /**< Affinity of the event queue relative to other event queues.
> >      * The requested affinity should be in the range of
> > -    * [RTE_EVENT_DEV_AFFINITY_HIGHEST, RTE_EVENT_DEV_AFFINITY_LOWEST].
> > +    * [@ref RTE_EVENT_QUEUE_AFFINITY_HIGHEST, @ref 
> > RTE_EVENT_QUEUE_AFFINITY_LOWEST].
> >      * The implementation shall normalize the requested affinity to event
> >      * device supported affinity value.
> > -    * Valid when the device has RTE_EVENT_DEV_CAP_QUEUE_QOS capability.
> > +    *
> > +    * Valid when the device has @ref RTE_EVENT_DEV_CAP_QUEUE_QOS 
> > capability,
> > +    * ignored otherwise.
> >      */
> >   };
> > @@ -779,7 +822,7 @@ struct rte_event_queue_conf {
> >    *   The identifier of the device.
> >    * @param queue_id
> >    *   The index of the event queue to get the configuration information.
> > - *   The value must be in the range [0, nb_event_queues - 1]
> > + *   The value must be in the range [0, @ref 
> > rte_event_dev_config.nb_event_queues - 1]
> 
> The value must be < @ref rte_event_dev_config.nb_event_queues.
> 
> It's an unsigned type, so no need to specify a lower bound.
> 

Ok. This probably applies in many places throughout the whole header file.

> >    *   previously supplied to rte_event_dev_configure().
> >    * @param[out] queue_conf
> >    *   The pointer to the default event queue configuration data.
> > @@ -800,7 +843,8 @@ rte_event_queue_default_conf_get(uint8_t dev_id, 
> > uint8_t queue_id,
> >    *   The identifier of the device.
> >    * @param queue_id
> >    *   The index of the event queue to setup. The value must be in the range
> > - *   [0, nb_event_queues - 1] previously supplied to 
> > rte_event_dev_configure().
> > + *   [0, @ref rte_event_dev_config.nb_event_queues - 1] previously 
> > supplied to
> > + *   rte_event_dev_configure().
> >    * @param queue_conf
> >    *   The pointer to the configuration data to be used for the event queue.
> >    *   NULL value is allowed, in which case default configuration   used.
> > @@ -816,43 +860,44 @@ rte_event_queue_setup(uint8_t dev_id, uint8_t 
> > queue_id,
> >                   const struct rte_event_queue_conf *queue_conf);
> >   /**
> > - * The priority of the queue.
> > + * Queue attribute id for the priority of the queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_PRIORITY 0
> >   /**
> > - * The number of atomic flows configured for the queue.
> > + * Queue attribute id for the number of atomic flows configured for the 
> > queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_FLOWS 1
> >   /**
> > - * The number of atomic order sequences configured for the queue.
> > + * Queue attribute id for the number of atomic order sequences configured 
> > for the queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_ORDER_SEQUENCES 2
> >   /**
> > - * The cfg flags for the queue.
> > + * Queue attribute id for the cfg flags for the queue.
> 
> "cfg" -> "configuration"?
> 
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_EVENT_QUEUE_CFG 3
> >   /**
> > - * The schedule type of the queue.
> > + * Queue attribute id for the schedule type of the queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE 4
> >   /**
> > - * The weight of the queue.
> > + * Queue attribute id for the weight of the queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_WEIGHT 5
> >   /**
> > - * Affinity of the queue.
> > + * Queue attribute id for the affinity of the queue.
> >    */
> >   #define RTE_EVENT_QUEUE_ATTR_AFFINITY 6
> >   /**
> > - * Get an attribute from a queue.
> > + * Get an attribute or property of an event queue.
> 
> What is the difference between property and attribute here?
> 

Good question. Not sure what I had in mind here. I'll revert in v3, I
think.

> >    *
> >    * @param dev_id
> > - *   Eventdev id
> > + *   The identifier of the device.
> >    * @param queue_id
> > - *   Eventdev queue id
> > + *   The index of the event queue to query. The value must be in the range
> > + *   [0, nb_event_queues - 1] previously supplied to 
> > rte_event_dev_configure().
> >    * @param attr_id
> > - *   The attribute ID to retrieve
> > + *   The attribute ID to retrieve (RTE_EVENT_QUEUE_ATTR_*)
> >    * @param[out] attr_value
> >    *   A pointer that will be filled in with the attribute value if 
> > successful
> >    *
> > @@ -861,8 +906,8 @@ rte_event_queue_setup(uint8_t dev_id, uint8_t queue_id,
> >    *   - -EINVAL: invalid device, queue or attr_id provided, or attr_value 
> > was
> >    *                NULL
> >    *   - -EOVERFLOW: returned when attr_id is set to
> > - *   RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE and event_queue_cfg is set to
> > - *   RTE_EVENT_QUEUE_CFG_ALL_TYPES
> > + *   @ref RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE and @ref 
> > RTE_EVENT_QUEUE_CFG_ALL_TYPES is
> > + *   set in the queue configuration flags.
> >    */
> >   int
> >   rte_event_queue_attr_get(uint8_t dev_id, uint8_t queue_id, uint32_t 
> > attr_id,
> > @@ -872,11 +917,13 @@ rte_event_queue_attr_get(uint8_t dev_id, uint8_t 
> > queue_id, uint32_t attr_id,
> >    * Set an event queue attribute.
> >    *
> >    * @param dev_id
> > - *   Eventdev id
> > + *   The identifier of the device.
> >    * @param queue_id
> > - *   Eventdev queue id
> > + *   The index of the event queue to configure. The value must be in the 
> > range
> > + *   [0, @ref rte_event_dev_config.nb_event_queues - 1] previously
> > + *   supplied to rte_event_dev_configure().
> >    * @param attr_id
> > - *   The attribute ID to set
> > + *   The attribute ID to set (RTE_EVENT_QUEUE_ATTR_*)
> >    * @param attr_value
> >    *   The attribute value to set
> >    *
> > @@ -902,7 +949,10 @@ rte_event_queue_attr_set(uint8_t dev_id, uint8_t 
> > queue_id, uint32_t attr_id,
> >    */
> >   #define RTE_EVENT_PORT_CFG_SINGLE_LINK         (1ULL << 1)
> >   /**< This event port links only to a single event queue.
> > + * The queue it links with should be similarly configured with the
> > + * @ref RTE_EVENT_QUEUE_CFG_SINGLE_LINK flag.
> >    *
> > + *  @see RTE_EVENT_QUEUE_CFG_SINGLE_LINK
> >    *  @see rte_event_port_setup(), rte_event_port_link()
> >    */
> >   #define RTE_EVENT_PORT_CFG_HINT_PRODUCER       (1ULL << 2)
> > @@ -918,7 +968,7 @@ rte_event_queue_attr_set(uint8_t dev_id, uint8_t 
> > queue_id, uint32_t attr_id,
> >   #define RTE_EVENT_PORT_CFG_HINT_CONSUMER       (1ULL << 3)
> >   /**< Hint that this event port will primarily dequeue events from the 
> > system.
> >    * A PMD can optimize its internal workings by assuming that this port is
> > - * primarily going to consume events, and not enqueue FORWARD or RELEASE
> > + * primarily going to consume events, and not enqueue NEW or FORWARD
> >    * events.
> >    *
> >    * Note that this flag is only a hint, so PMDs must operate under the
> > @@ -944,48 +994,55 @@ struct rte_event_port_conf {
> >     /**< A backpressure threshold for new event enqueues on this port.
> >      * Use for *closed system* event dev where event capacity is limited,
> >      * and cannot exceed the capacity of the event dev.
> > +    *
> >      * Configuring ports with different thresholds can make higher priority
> >      * traffic less likely to  be backpressured.
> >      * For example, a port used to inject NIC Rx packets into the event dev
> >      * can have a lower threshold so as not to overwhelm the device,
> >      * while ports used for worker pools can have a higher threshold.
> > -    * This value cannot exceed the *nb_events_limit*
> > +    * This value cannot exceed the @ref 
> > rte_event_dev_config.nb_events_limit value
> >      * which was previously supplied to rte_event_dev_configure().
> > -    * This should be set to '-1' for *open system*.
> > +    *
> > +    * This should be set to '-1' for *open system*, i.e when
> > +    * @ref rte_event_dev_info.max_num_events == -1.
> >      */
> >     uint16_t dequeue_depth;
> > -   /**< Configure number of bulk dequeues for this event port.
> > -    * This value cannot exceed the *nb_event_port_dequeue_depth*
> > -    * which previously supplied to rte_event_dev_configure().
> > -    * Ignored when device is not RTE_EVENT_DEV_CAP_BURST_MODE capable.
> > +   /**< Configure the maximum size of burst dequeues for this event port.
> > +    * This value cannot exceed the @ref 
> > rte_event_dev_config.nb_event_port_dequeue_depth value
> > +    * which was previously supplied to rte_event_dev_configure().
> > +    *
> > +    * Ignored when device does not support the @ref 
> > RTE_EVENT_DEV_CAP_BURST_MODE capability.
> >      */
> >     uint16_t enqueue_depth;
> > -   /**< Configure number of bulk enqueues for this event port.
> > -    * This value cannot exceed the *nb_event_port_enqueue_depth*
> > -    * which previously supplied to rte_event_dev_configure().
> > -    * Ignored when device is not RTE_EVENT_DEV_CAP_BURST_MODE capable.
> > +   /**< Configure the maximum size of burst enqueues to this event port.
> > +    * This value cannot exceed the @ref 
> > rte_event_dev_config.nb_event_port_enqueue_depth value
> > +    * which was previously supplied to rte_event_dev_configure().
> > +    *
> > +    * Ignored when device does not support the @ref 
> > RTE_EVENT_DEV_CAP_BURST_MODE capability.
> >      */
> > -   uint32_t event_port_cfg; /**< Port cfg flags(EVENT_PORT_CFG_) */
> > +   uint32_t event_port_cfg; /**< Port configuration flags(EVENT_PORT_CFG_) 
> > */
> >   };
> >   /**
> >    * Retrieve the default configuration information of an event port 
> > designated
> >    * by its *port_id* from the event driver for an event device.
> >    *
> > - * This function intended to be used in conjunction with 
> > rte_event_port_setup()
> > - * where caller needs to set up the port by overriding few default values.
> > + * This function is intended to be used in conjunction with 
> > rte_event_port_setup()
> > + * where the caller can set up the port by just overriding few default 
> > values.
> >    *
> >    * @param dev_id
> >    *   The identifier of the device.
> >    * @param port_id
> >    *   The index of the event port to get the configuration information.
> > - *   The value must be in the range [0, nb_event_ports - 1]
> > + *   The value must be in the range [0, @ref 
> > rte_event_dev_config.nb_event_ports - 1]
> >    *   previously supplied to rte_event_dev_configure().
> >    * @param[out] port_conf
> > - *   The pointer to the default event port configuration data
> > + *   The pointer to a structure to store the default event port 
> > configuration data.
> >    * @return
> >    *   - 0: Success, driver updates the default event port configuration 
> > data.
> >    *   - <0: Error code returned by the driver info get function.
> > + *      - -EINVAL - invalid input parameter
> > + *      - -ENOTSUP - function is not supported for this device
> >    *
> >    * @see rte_event_port_setup()
> >    */
> > @@ -1000,18 +1057,24 @@ rte_event_port_default_conf_get(uint8_t dev_id, 
> > uint8_t port_id,
> >    *   The identifier of the device.
> >    * @param port_id
> >    *   The index of the event port to setup. The value must be in the range
> > - *   [0, nb_event_ports - 1] previously supplied to 
> > rte_event_dev_configure().
> > + *   [0, @ref rte_event_dev_config.nb_event_ports - 1] previously supplied 
> > to
> > + *   rte_event_dev_configure().
> >    * @param port_conf
> > - *   The pointer to the configuration data to be used for the queue.
> > - *   NULL value is allowed, in which case default configuration    used.
> > + *   The pointer to the configuration data to be used for the port.
> > + *   NULL value is allowed, in which case the default configuration is 
> > used.
> >    *
> >    * @see rte_event_port_default_conf_get()
> >    *
> >    * @return
> >    *   - 0: Success, event port correctly set up.
> >    *   - <0: Port configuration failed
> > - *   - (-EDQUOT) Quota exceeded(Application tried to link the queue 
> > configured
> > - *   with RTE_EVENT_QUEUE_CFG_SINGLE_LINK to more than one event ports)
> > + *     - -EINVAL - Invalid input parameter
> > + *     - -EBUSY - Port already started
> > + *     - -ENOTSUP - Function not supported on this device, or a NULL 
> > pointer passed
> > + *        as the port_conf parameter, and no default configuration 
> > function available
> > + *        for this device.
> > + *     - -EDQUOT - Application tried to link a queue configured
> 
> "." for each bullet?
> 
Ideally, yes. I'll try and keep this consistent as I make changes, but it's
not going to be top of my worry-about list!

thanks again for the reviews.

/Bruce

Reply via email to