* mlx5: is GTP encapsulation possible using the rte_flow api?
@ 2024-05-08 15:23 László Molnár
  2024-07-22  5:43 ` Maayan Kashani
  2024-07-22  9:02 ` Raslan Darawsheh
  0 siblings, 2 replies; 3+ messages in thread
From: László Molnár @ 2024-05-08 15:23 UTC (permalink / raw)
  To: users
Hi All,
I wonder whether it would be possible to implement HW accelerated GTP
encapsulation (as a first step) functionality using a Bluefield 2 NIC
and the rte_flow API?
The encapsulation would need to work between different ports using
hairpin queues.
Let's say I already have the rules in dpdk-testpmd that remove the
original ETH header using raw_decap, and add the new ETH/IP/UDP/GTP
using raw_encap.
Now I would need to update some header fields (payload length for
ipv4, udp, gtp). I would use "modify_field op add", but I found no way
I can access the payload length field for UDP and GTP.
For example, when I try to access the UDP payload length field by using
"dst_type udp_port_src dst_offset 32" in the "modify_field" action,
I get a "destination offset is too big: Invalid argument" error.
This seems to be caused by a check in the mlx5 driver, which is a bit
surprising as the documentation in rte_flow.rst (DPDK version 24.03)
says that:
   ``offset`` allows going past the specified packet field boundary to
   copy a field to an arbitrary place in a packet,
Is this just a driver limitation or an HW limitation? Or could a flex
item solve this?
Thanks, Laszlo
^ permalink raw reply	[flat|nested] 3+ messages in thread
* RE: mlx5: is GTP encapsulation possible using the rte_flow api?
  2024-05-08 15:23 mlx5: is GTP encapsulation possible using the rte_flow api? László Molnár
@ 2024-07-22  5:43 ` Maayan Kashani
  2024-07-22  9:02 ` Raslan Darawsheh
  1 sibling, 0 replies; 3+ messages in thread
From: Maayan Kashani @ 2024-07-22  5:43 UTC (permalink / raw)
  To: László Molnár, users, Gregory Etelson
++@Gregory Etelson
Regards,
Maayan Kashani
> -----Original Message-----
> From: László Molnár <laszlo.molnar@ericsson.com>
> Sent: Wednesday, 8 May 2024 18:24
> To: users@dpdk.org
> Subject: mlx5: is GTP encapsulation possible using the rte_flow api?
> 
> Hi All,
> 
> I wonder whether it would be possible to implement HW accelerated GTP
> encapsulation (as a first step) functionality using a Bluefield 2 NIC and the
> rte_flow API?
> 
> The encapsulation would need to work between different ports using hairpin
> queues.
> 
> Let's say I already have the rules in dpdk-testpmd that remove the original
> ETH header using raw_decap, and add the new ETH/IP/UDP/GTP using
> raw_encap.
> 
> Now I would need to update some header fields (payload length for ipv4,
> udp, gtp). I would use "modify_field op add", but I found no way I can access
> the payload length field for UDP and GTP.
> 
> For example, when I try to access the UDP payload length field by using
> "dst_type udp_port_src dst_offset 32" in the "modify_field" action, I get a
> "destination offset is too big: Invalid argument" error.
> 
> This seems to be caused by a check in the mlx5 driver, which is a bit surprising
> as the documentation in rte_flow.rst (DPDK version 24.03) says that:
> 
>    ``offset`` allows going past the specified packet field boundary to
>    copy a field to an arbitrary place in a packet,
> 
> Is this just a driver limitation or an HW limitation? Or could a flex item solve
> this?
> 
> Thanks, Laszlo
^ permalink raw reply	[flat|nested] 3+ messages in thread
* Re: mlx5: is GTP encapsulation possible using the rte_flow api?
  2024-05-08 15:23 mlx5: is GTP encapsulation possible using the rte_flow api? László Molnár
  2024-07-22  5:43 ` Maayan Kashani
@ 2024-07-22  9:02 ` Raslan Darawsheh
  1 sibling, 0 replies; 3+ messages in thread
From: Raslan Darawsheh @ 2024-07-22  9:02 UTC (permalink / raw)
  To: László Molnár, users
[-- Attachment #1: Type: text/plain, Size: 1504 bytes --]
Hello,
> Hi All,
>I wonder whether it would be possible to implement HW accelerated GTP
>encapsulation (as a first step) functionality using a Bluefield 2 NIC
>and the rte_flow API?
yes should be supported.
>The encapsulation would need to work between different ports using
>hairpin queues.
>Let's say I already have the rules in dpdk-testpmd that remove the
>original ETH header using raw_decap, and add the new ETH/IP/UDP/GTP
>using raw_encap.
>Now I would need to update some header fields (payload length for
>pv4, udp, gtp). I would use "modify_field op add", but I found no way
>I can access the payload length field for UDP and GTP.
These are usually calculated by the NIC on ecnap so you don't need to set these fields or modify them.
>For example, when I try to access the UDP payload length field by using
>"dst_type udp_port_src dst_offset 32" in the "modify_field" action,
>I get a "destination offset is too big: Invalid argument" error.
In general and in MLX5 we don’t support changing the length field of the packet
>This seems to be caused by a check in the mlx5 driver, which is a bit
>surprising as the documentation in rte_flow.rst (DPDK version 24.03)
>says that:
   >``offset`` allows going past the specified packet field boundary to
   >copy a field to an arbitrary place in a packet,
>Is this just a driver limitation or an HW limitation? Or could a flex
>item solve this?
>Thanks, Laszlo
Kindest regards
Raslan Darawsheh
[-- Attachment #2: Type: text/html, Size: 6273 bytes --]
^ permalink raw reply	[flat|nested] 3+ messages in thread
end of thread, other threads:[~2024-07-22  9:19 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-05-08 15:23 mlx5: is GTP encapsulation possible using the rte_flow api? László Molnár
2024-07-22  5:43 ` Maayan Kashani
2024-07-22  9:02 ` Raslan Darawsheh
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).