<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div class="elementToProof"><span style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0); background-color: rgb(255, 255, 255);">Hi Jerin,</span></div>
<div class="elementToProof"><span style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0); background-color: rgb(255, 255, 255);"> Can you please provide your input/feedback for this patch set?</span></div>
<div id="appendonsend"></div>
<div style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)" class="elementToProof">
<br>
</div>
<div style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:12pt; color:rgb(0,0,0)" class="elementToProof">
-Harish</div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> Naga Harish K S V <s.v.naga.harish.k@intel.com><br>
<b>Sent:</b> Tuesday, December 20, 2022 2:41 PM<br>
<b>To:</b> jerinj@marvell.com <jerinj@marvell.com>; Carrillo, Erik G <Erik.G.Carrillo@intel.com>; Gujjar, Abhinandan S <abhinandan.gujjar@intel.com><br>
<b>Cc:</b> dev@dpdk.org <dev@dpdk.org>; Jayatheerthan, Jay <jay.jayatheerthan@intel.com><br>
<b>Subject:</b> [PATCH v5 1/4] eventdev/eth_rx: change eventdev reconfig logic</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt">
<div class="PlainText">When rte_event_eth_rx_adapter_create() or<br>
rte_event_eth_rx_adapter_create_with_params() is used for creating<br>
adapter instance, eventdev is reconfigured with additional<br>
``rte_event_dev_config::nb_event_ports`` parameter.<br>
<br>
This eventdev reconfig logic is enhanced to increment the<br>
``rte_event_dev_config::nb_single_link_event_port_queues``<br>
parameter if the adapter event port config is of type<br>
``RTE_EVENT_PORT_CFG_SINGLE_LINK``.<br>
<br>
With this change the application no longer need to configure the<br>
eventdev with ``rte_event_dev_config::nb_single_link_event_port_queues``<br>
parameter required for eth_rx adapter when the adapter is created<br>
using above mentioned apis.<br>
<br>
Signed-off-by: Naga Harish K S V <s.v.naga.harish.k@intel.com><br>
Acked-by: Abhinandan Gujjar <abhinandan.gujjar@intel.com><br>
---<br>
v2:<br>
* Fix build error<br>
v3:<br>
* update doxygen<br>
v5:<br>
* update doxygen as per review comments<br>
---<br>
---<br>
.../prog_guide/event_ethernet_rx_adapter.rst | 19 +++++++++++++++++++<br>
lib/eventdev/rte_event_eth_rx_adapter.c | 3 +++<br>
lib/eventdev/rte_event_eth_rx_adapter.h | 14 ++++++++++++++<br>
3 files changed, 36 insertions(+)<br>
<br>
diff --git a/doc/guides/prog_guide/event_ethernet_rx_adapter.rst b/doc/guides/prog_guide/event_ethernet_rx_adapter.rst<br>
index 116c0a27c6..bbe278f7db 100644<br>
--- a/doc/guides/prog_guide/event_ethernet_rx_adapter.rst<br>
+++ b/doc/guides/prog_guide/event_ethernet_rx_adapter.rst<br>
@@ -71,6 +71,25 @@ set to true. The function is passed the event device to be associated with<br>
the adapter and port configuration for the adapter to setup an event port<br>
if the adapter needs to use a service function.<br>
<br>
+Event device configuration for service based adapter<br>
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~<br>
+<br>
+When rte_event_eth_rx_adapter_create() or<br>
+rte_event_eth_rx_adapter_create_with_params() is used for creating<br>
+adapter instance, ``rte_event_dev_config::nb_event_ports`` is<br>
+automatically incremented and the event device is reconfigured with<br>
+the additional event port during service initialization. This event<br>
+device reconfigure logic also increments the<br>
+``rte_event_dev_config::nb_single_link_event_port_queues``<br>
+parameter if the adapter event port config is of type<br>
+``RTE_EVENT_PORT_CFG_SINGLE_LINK``.<br>
+<br>
+Application no longer needs to account for the<br>
+``rte_event_dev_config::nb_event_ports`` and<br>
+``rte_event_dev_config::nb_single_link_event_port_queues``<br>
+parameters required for eth Rx adapter in the event device configuration,<br>
+when the adapter is created using the above-mentioned APIs.<br>
+<br>
Adding Rx Queues to the Adapter Instance<br>
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~<br>
<br>
diff --git a/lib/eventdev/rte_event_eth_rx_adapter.c b/lib/eventdev/rte_event_eth_rx_adapter.c<br>
index cf7bbd4d69..34aa87379e 100644<br>
--- a/lib/eventdev/rte_event_eth_rx_adapter.c<br>
+++ b/lib/eventdev/rte_event_eth_rx_adapter.c<br>
@@ -1532,6 +1532,9 @@ rxa_default_conf_cb(uint8_t id, uint8_t dev_id,<br>
rte_event_dev_stop(dev_id);<br>
port_id = dev_conf.nb_event_ports;<br>
dev_conf.nb_event_ports += 1;<br>
+ if (port_conf->event_port_cfg & RTE_EVENT_PORT_CFG_SINGLE_LINK)<br>
+ dev_conf.nb_single_link_event_port_queues += 1;<br>
+<br>
ret = rte_event_dev_configure(dev_id, &dev_conf);<br>
if (ret) {<br>
RTE_EDEV_LOG_ERR("failed to configure event dev %u\n",<br>
diff --git a/lib/eventdev/rte_event_eth_rx_adapter.h b/lib/eventdev/rte_event_eth_rx_adapter.h<br>
index d0e7d0092c..f4652f40e8 100644<br>
--- a/lib/eventdev/rte_event_eth_rx_adapter.h<br>
+++ b/lib/eventdev/rte_event_eth_rx_adapter.h<br>
@@ -382,6 +382,20 @@ int rte_event_eth_rx_adapter_create_ext(uint8_t id, uint8_t dev_id,<br>
* control in configuration of the service, it should use the<br>
* rte_event_eth_rx_adapter_create_ext() version.<br>
*<br>
+ * When this API is used for creating adapter instance,<br>
+ * ``rte_event_dev_config::nb_event_ports`` is automatically incremented,<br>
+ * and event device is reconfigured with additional event port during service<br>
+ * initialization. This event device reconfigure logic also increments the<br>
+ * ``rte_event_dev_config::nb_single_link_event_port_queues``<br>
+ * parameter if the adapter event port config is of type<br>
+ * ``RTE_EVENT_PORT_CFG_SINGLE_LINK``.<br>
+ *<br>
+ * Application no longer needs to account for<br>
+ * ``rte_event_dev_config::nb_event_ports`` and<br>
+ * ``rte_event_dev_config::nb_single_link_event_port_queues``<br>
+ * parameters required for eth Rx adapter in the event device configuration<br>
+ * when the adapter is created with this API.<br>
+ *<br>
* @param id<br>
* The identifier of the ethernet Rx event adapter.<br>
*<br>
-- <br>
2.25.1<br>
<br>
</div>
</span></font></div>
</body>
</html>