As seen with Matan, there's really a bug preventing to schedule a later
age event(with /rte_flow_get_aged_flows()/) from the user's callback itself.
I could suggest the following patch:
--- dpdk-21.02/drivers/net/mlx5/mlx5.c 2021-02-14 10:58:34.000000000
+0100
+++ dpdk-21.02/drivers/net/mlx5/mlx5.c.new 2021-04-08
18:35:44.124965176 +0200
@@ -554,7 +554,7 @@
rte_eth_dev_callback_process
(&rte_eth_devices[sh->port[i].devx_ih_port_id],
RTE_ETH_EVENT_FLOW_AGED, NULL);
- age_info->flags = 0;
+ age_info->flags &= ~MLX5_AGE_EVENT_NEW;
}
}
Thanks.
On 4/8/21 11:52 AM, Matan Azrad wrote:
Yes, you right for the meaning of MLX5_AGE_TRIGGER.
But why you said it is erased when the callback return?
It is erased when a new aged-out flow is detected by the driver….
Do you have an issue with option 1?
Matan
*From:*David Bouyeure <david.bouye...@fraudbuster.mobi>
*Sent:* Thursday, April 8, 2021 10:50 AM
*To:* Matan Azrad <ma...@nvidia.com>; Asaf Penso <as...@nvidia.com>;
dev@dpdk.org
*Cc:* Jack Min <jack...@nvidia.com>
*Subject:* Re: [dpdk-dev] rte_flow ageing
*External email: Use caution opening links or attachments*
Hi Matan,
below are my comments.
Thank you.
On 4/7/21 8:09 PM, Matan Azrad wrote:
Yes you can call it from the event callback.
Sure, but it won't trigger the event callback as it would for the next
aged-out flow(s) if called from outside the callback.
Yes, MLX5_AGE_TRIGGER probably means that event was sent and no
need to send it again in the next aged-out flow.
I don't think so. MLX5_AGE_TRIGGER means 'Do call the callback for
next aged-out flow(s)'.
Erasing it cause new event to be sent in the next aged-out flow...
No, I think it's the reverse.
I don't understand what is the issue for you in option 1...
השג את Outlookעבור Android
<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Faka.ms%2FAAb9ysg&data=04%7C01%7Cmatan%40nvidia.com%7C5f8447e5e9a0419d028408d8fa62f35c%7C43083d15727340c1b7db39efd9ccc17a%7C0%7C0%7C637534650206068346%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=vfiLHcxWtpQEh9jqE7wIsGhs%2FZlMN5r4aJtSrvE7OgY%3D&reserved=0>
------------------------------------------------------------------------
*From:*David Bouyeure <david.bouye...@fraudbuster.mobi>
<mailto:david.bouye...@fraudbuster.mobi>
*Sent:* Wednesday, April 7, 2021 7:19:34 PM
*To:* Matan Azrad <ma...@nvidia.com> <mailto:ma...@nvidia.com>;
Asaf Penso <as...@nvidia.com> <mailto:as...@nvidia.com>;
dev@dpdk.org <mailto:dev@dpdk.org> <dev@dpdk.org>
<mailto:dev@dpdk.org>
*Cc:* Jack Min <jack...@nvidia.com> <mailto:jack...@nvidia.com>
*Subject:* Re: [dpdk-dev] rte_flow ageing
*External email: Use caution opening links or attachments*
Hi Matan, and thanks a lot,
regarding the mode *1*, I still have a doubt:
1. Register the AGE event -> in event time to query the
aged-out flows by the rte_flow_get_aged_flows API, this
call will trigger a new event when new aged-out flow will
be detected for the port.(if you don’t call
rte_flow_get_aged_flows the event will not be retriggered.)
You meant calling rte_flow_get_aged_flows() from the event
callback I guess...?
I think this is not working because MLX5_AGE_TRIGGER is erased
when the callback returns.
Anyway, the polling mode is enough to me so far.
Thanks again.
Regards.
On 4/5/21 12:23 PM, Matan Azrad wrote:
-->