From mboxrd@z Thu Jan 1 00:00:00 1970
Return-Path:
Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124])
by inbox.dpdk.org (Postfix) with ESMTP id 5ADC9423AE;
Wed, 11 Jan 2023 15:22:45 +0100 (CET)
Received: from mails.dpdk.org (localhost [127.0.0.1])
by mails.dpdk.org (Postfix) with ESMTP id 1573840E25;
Wed, 11 Jan 2023 15:22:45 +0100 (CET)
Received: from inbox.dpdk.org (inbox.dpdk.org [95.142.172.178])
by mails.dpdk.org (Postfix) with ESMTP id C5FB340A7D
for ; Wed, 11 Jan 2023 15:22:43 +0100 (CET)
Received: by inbox.dpdk.org (Postfix, from userid 33)
id B25F6423AF; Wed, 11 Jan 2023 15:22:43 +0100 (CET)
From: bugzilla@dpdk.org
To: dev@dpdk.org
Subject: [Bug 1156] dpdk_flow_ops_fn api returns error for RSS queue action
Date: Wed, 11 Jan 2023 14:22:43 +0000
X-Bugzilla-Reason: AssignedTo
X-Bugzilla-Type: new
X-Bugzilla-Watch-Reason: None
X-Bugzilla-Product: DPDK
X-Bugzilla-Component: other
X-Bugzilla-Version: 22.03
X-Bugzilla-Keywords:
X-Bugzilla-Severity: critical
X-Bugzilla-Who: lthammin@usc.edu
X-Bugzilla-Status: UNCONFIRMED
X-Bugzilla-Resolution:
X-Bugzilla-Priority: Normal
X-Bugzilla-Assigned-To: dev@dpdk.org
X-Bugzilla-Target-Milestone: ---
X-Bugzilla-Flags:
X-Bugzilla-Changed-Fields: bug_id short_desc product version rep_platform
op_sys bug_status bug_severity priority component assigned_to reporter
target_milestone attachments.created
Message-ID:
Content-Type: multipart/alternative; boundary=16734469630.0e34339.577686
Content-Transfer-Encoding: 7bit
X-Bugzilla-URL: http://bugs.dpdk.org/
Auto-Submitted: auto-generated
X-Auto-Response-Suppress: All
MIME-Version: 1.0
X-BeenThere: dev@dpdk.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: DPDK patches and discussions
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
Errors-To: dev-bounces@dpdk.org
--16734469630.0e34339.577686
Date: Wed, 11 Jan 2023 15:22:43 +0100
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: quoted-printable
X-Bugzilla-URL: http://bugs.dpdk.org/
Auto-Submitted: auto-generated
X-Auto-Response-Suppress: All
https://bugs.dpdk.org/show_bug.cgi?id=3D1156
Bug ID: 1156
Summary: dpdk_flow_ops_fn api returns error for RSS queue
action
Product: DPDK
Version: 22.03
Hardware: All
OS: All
Status: UNCONFIRMED
Severity: critical
Priority: Normal
Component: other
Assignee: dev@dpdk.org
Reporter: lthammin@usc.edu
Target Milestone: ---
Created attachment 238
--> https://bugs.dpdk.org/attachment.cgi?id=3D238&action=3Dedit
A temporary patch that solves the issue
Hi,
I would like to enable RSS on a set of queues of port through RTE flow.=20
For this I am calling dpdk_flow_ops_fn() by setting
vnet_flow_t flow;
flow.queue_index =3D start_queue_id;
flow.queue_num =3D end_queue_id - start_queue_id + 1;
flow.actions |=3D VNET_FLOW_ACTION_RSS;
But, dpdk_flow_ops_fn() returns VNET_FLOW_ERROR_NOT_SUPPORTED because it fa=
ils
the below condition:
switch (flow->type)
{
case VNET_FLOW_TYPE_ETHERNET:
case VNET_FLOW_TYPE_IP4:
case VNET_FLOW_TYPE_IP6:
case VNET_FLOW_TYPE_IP4_N_TUPLE:
case VNET_FLOW_TYPE_IP6_N_TUPLE:
case VNET_FLOW_TYPE_IP4_VXLAN:
case VNET_FLOW_TYPE_IP4_GTPC:
case VNET_FLOW_TYPE_IP4_GTPU:
case VNET_FLOW_TYPE_IP4_L2TPV3OIP:
case VNET_FLOW_TYPE_IP4_IPSEC_ESP:
case VNET_FLOW_TYPE_IP4_IPSEC_AH:
case VNET_FLOW_TYPE_GENERIC:
if ((rv =3D dpdk_flow_add (xd, flow, fe)))
goto done;
break;
default:
rv =3D VNET_FLOW_ERROR_NOT_SUPPORTED;
goto done;
}
It fails because flow->type is not one of above. The flow->type is set only=
if
a valid RTE flow pattern is required for the flow. For, RTE flows with RSS
Queue action, the pattern is not accepted. So, flow->type in this case shou=
ld
be invalid (VNET_FLOW_TYPE_UNKNOWN).
If we try to program a RTE flow with some pattern and RSS Queue action, we =
get
below error.
DBGvpp# sh flow int TenGigabitEthernetb5/0/3
supported flow actions : count mark buffer-advance redirect-to-node
redirect-to-queue rss drop
last DPDK error type : 15
last DPDK error message : RSS Queues not supported when pattern specified
DBGvpp#
dpdk_flow_ops_fn() calls dpdk_flow_add(). Note that, even if dpdk_flow_ops_=
fn()
is bypassed, dpdk_flow_add() still fails because of the below conditions.
if (FLOW_IS_ETHERNET_CLASS (f))
flow_class =3D FLOW_ETHERNET_CLASS;
else if (FLOW_IS_IPV4_CLASS (f))
flow_class =3D FLOW_IPV4_CLASS;
else if (FLOW_IS_IPV6_CLASS (f))
flow_class =3D FLOW_IPV6_CLASS;
else
return VNET_FLOW_ERROR_NOT_SUPPORTED;
I have attached a patch that I have been using temporarily. Please check it=
out
and provide an official patch.
Thanks,
Nikhil
--=20
You are receiving this mail because:
You are the assignee for the bug.=
--16734469630.0e34339.577686
Date: Wed, 11 Jan 2023 15:22:43 +0100
MIME-Version: 1.0
Content-Type: text/html; charset=UTF-8
Content-Transfer-Encoding: quoted-printable
X-Bugzilla-URL: http://bugs.dpdk.org/
Auto-Submitted: auto-generated
X-Auto-Response-Suppress: All
dpdk_flow_ops_fn api returns error for RSS queue action
Product
DPDK
Version
22.03
Hardware
All
OS
All
Status
UNCONFIRMED
Severity
critical
Priority
Normal
Component
other
Assignee
dev@dpdk.org
Reporter
lthammin@usc.edu
Target Milestone
---
Created attachment 238[details]
A temporary patch that solves the issue
Hi,
I would like to enable RSS on a set of queues of port through RTE flow.=20
For this I am calling dpdk_flow_ops_fn() by setting
vnet_flow_t flow;
flow.queue_index =3D start_queue_id;
flow.queue_num =3D end_queue_id - start_queue_id + 1;
flow.actions |=3D VNET_FLOW_ACTION_RSS;
But, dpdk_flow_ops_fn() returns VNET_FLOW_ERROR_NOT_SUPPORTED because it fa=
ils
the below condition:
switch (flow->type)
{
case VNET_FLOW_TYPE_ETHERNET:
case VNET_FLOW_TYPE_IP4:
case VNET_FLOW_TYPE_IP6:
case VNET_FLOW_TYPE_IP4_N_TUPLE:
case VNET_FLOW_TYPE_IP6_N_TUPLE:
case VNET_FLOW_TYPE_IP4_VXLAN:
case VNET_FLOW_TYPE_IP4_GTPC:
case VNET_FLOW_TYPE_IP4_GTPU:
case VNET_FLOW_TYPE_IP4_L2TPV3OIP:
case VNET_FLOW_TYPE_IP4_IPSEC_ESP:
case VNET_FLOW_TYPE_IP4_IPSEC_AH:
case VNET_FLOW_TYPE_GENERIC:
if ((rv =3D dpdk_flow_add (xd, flow, fe)))
goto done;
break;
default:
rv =3D VNET_FLOW_ERROR_NOT_SUPPORTED;
goto done;
}
It fails because flow->type is not one of above. The flow->type is se=
t only if
a valid RTE flow pattern is required for the flow. For, RTE flows with RSS
Queue action, the pattern is not accepted. So, flow->type in this case s=
hould
be invalid (VNET_FLOW_TYPE_UNKNOWN).
If we try to program a RTE flow with some pattern and RSS Queue action, we =
get
below error.
DBGvpp# sh flow int TenGigabitEthernetb5/0/3
supported flow actions : count mark buffer-advance redirect-to-node
redirect-to-queue rss drop
last DPDK error type : 15
last DPDK error message : RSS Queues not supported when pattern specified
DBGvpp#
dpdk_flow_ops_fn() calls dpdk_flow_add(). Note that, even if dpdk_flow_ops_=
fn()
is bypassed, dpdk_flow_add() still fails because of the below conditions.
if (FLOW_IS_ETHERNET_CLASS (f))
flow_class =3D FLOW_ETHERNET_CLASS;
else if (FLOW_IS_IPV4_CLASS (f))
flow_class =3D FLOW_IPV4_CLASS;
else if (FLOW_IS_IPV6_CLASS (f))
flow_class =3D FLOW_IPV6_CLASS;
else
return VNET_FLOW_ERROR_NOT_SUPPORTED;
I have attached a patch that I have been using temporarily. Please check it=
out
and provide an official patch.
Thanks,
Nikhil
Created attachment 238 [details] A temporary patch that solves the issue Hi, I would like to enable RSS on a set of queues of port through RTE flow.=20 For this I am calling dpdk_flow_ops_fn() by setting vnet_flow_t flow; flow.queue_index =3D start_queue_id; flow.queue_num =3D end_queue_id - start_queue_id + 1; flow.actions |=3D VNET_FLOW_ACTION_RSS; But, dpdk_flow_ops_fn() returns VNET_FLOW_ERROR_NOT_SUPPORTED because it fa= ils the below condition: switch (flow->type) { case VNET_FLOW_TYPE_ETHERNET: case VNET_FLOW_TYPE_IP4: case VNET_FLOW_TYPE_IP6: case VNET_FLOW_TYPE_IP4_N_TUPLE: case VNET_FLOW_TYPE_IP6_N_TUPLE: case VNET_FLOW_TYPE_IP4_VXLAN: case VNET_FLOW_TYPE_IP4_GTPC: case VNET_FLOW_TYPE_IP4_GTPU: case VNET_FLOW_TYPE_IP4_L2TPV3OIP: case VNET_FLOW_TYPE_IP4_IPSEC_ESP: case VNET_FLOW_TYPE_IP4_IPSEC_AH: case VNET_FLOW_TYPE_GENERIC: if ((rv =3D dpdk_flow_add (xd, flow, fe))) goto done; break; default: rv =3D VNET_FLOW_ERROR_NOT_SUPPORTED; goto done; } It fails because flow->type is not one of above. The flow->type is se= t only if a valid RTE flow pattern is required for the flow. For, RTE flows with RSS Queue action, the pattern is not accepted. So, flow->type in this case s= hould be invalid (VNET_FLOW_TYPE_UNKNOWN). If we try to program a RTE flow with some pattern and RSS Queue action, we = get below error. DBGvpp# sh flow int TenGigabitEthernetb5/0/3 supported flow actions : count mark buffer-advance redirect-to-node redirect-to-queue rss drop last DPDK error type : 15 last DPDK error message : RSS Queues not supported when pattern specified DBGvpp# dpdk_flow_ops_fn() calls dpdk_flow_add(). Note that, even if dpdk_flow_ops_= fn() is bypassed, dpdk_flow_add() still fails because of the below conditions. if (FLOW_IS_ETHERNET_CLASS (f)) flow_class =3D FLOW_ETHERNET_CLASS; else if (FLOW_IS_IPV4_CLASS (f)) flow_class =3D FLOW_IPV4_CLASS; else if (FLOW_IS_IPV6_CLASS (f)) flow_class =3D FLOW_IPV6_CLASS; else return VNET_FLOW_ERROR_NOT_SUPPORTED; I have attached a patch that I have been using temporarily. Please check it= out and provide an official patch. Thanks, Nikhil