* [PATCH 1/1] examples/ipsec-secgw: resolve segfault for IPsec packets
@ 2025-04-07 7:21 Rakesh Kudurumalla
2025-05-21 14:13 ` Akhil Goyal
0 siblings, 1 reply; 2+ messages in thread
From: Rakesh Kudurumalla @ 2025-04-07 7:21 UTC (permalink / raw)
To: Radu Nicolau, Akhil Goyal; +Cc: dev, jerinj, ndabilpuram, Rakesh Kudurumalla
launching ipsec-segw application in event vector mode
after traffic has started results in segfault because
we are receiving few IPSEC packet and application is trying
to decrypt IPSEC packets using lookaside protocol.
This contradicts inline event mode.This patch fixes the same
by freeing IPSEC packets and processing only plain packets.
Signed-off-by: Rakesh Kudurumalla <rkudurumalla@marvell.com>
---
examples/ipsec-secgw/ipsec_worker.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/examples/ipsec-secgw/ipsec_worker.c b/examples/ipsec-secgw/ipsec_worker.c
index e0690fc8d9..04609964cd 100644
--- a/examples/ipsec-secgw/ipsec_worker.c
+++ b/examples/ipsec-secgw/ipsec_worker.c
@@ -700,6 +700,9 @@ ipsec_ev_inbound_route_pkts(struct rte_event_vector *vec,
struct rte_ipsec_session *sess;
struct rte_mbuf *pkt;
struct ipsec_sa *sa;
+ uint8_t mask = (1UL << RTE_SECURITY_ACTION_TYPE_INLINE_CRYPTO) |
+ (1UL << RTE_SECURITY_ACTION_TYPE_INLINE_PROTOCOL);
+
j = ipsec_ev_route_ip_pkts(vec, rt, t);
@@ -707,7 +710,7 @@ ipsec_ev_inbound_route_pkts(struct rte_event_vector *vec,
for (i = 0; i < t->ipsec.num; i++) {
pkt = t->ipsec.pkts[i];
sa = ipsec_mask_saptr(t->ipsec.saptr[i]);
- if (unlikely(sa == NULL)) {
+ if (unlikely(sa == NULL) || ((1UL << sa->sessions[0].type) & mask)) {
free_pkts(&pkt, 1);
continue;
}
--
2.25.1
^ permalink raw reply [flat|nested] 2+ messages in thread
* RE: [PATCH 1/1] examples/ipsec-secgw: resolve segfault for IPsec packets
2025-04-07 7:21 [PATCH 1/1] examples/ipsec-secgw: resolve segfault for IPsec packets Rakesh Kudurumalla
@ 2025-05-21 14:13 ` Akhil Goyal
0 siblings, 0 replies; 2+ messages in thread
From: Akhil Goyal @ 2025-05-21 14:13 UTC (permalink / raw)
To: Rakesh Kudurumalla, Radu Nicolau
Cc: dev, Jerin Jacob, Nithin Kumar Dabilpuram, Rakesh Kudurumalla
> Subject: [PATCH 1/1] examples/ipsec-secgw: resolve segfault for IPsec packets
>
> launching ipsec-segw application in event vector mode
> after traffic has started results in segfault because
> we are receiving few IPSEC packet and application is trying
> to decrypt IPSEC packets using lookaside protocol.
> This contradicts inline event mode.This patch fixes the same
> by freeing IPSEC packets and processing only plain packets.
Please add a Fixme tag and cc stable@dpdk.org
>
> Signed-off-by: Rakesh Kudurumalla <rkudurumalla@marvell.com>
> ---
> examples/ipsec-secgw/ipsec_worker.c | 5 ++++-
> 1 file changed, 4 insertions(+), 1 deletion(-)
>
> diff --git a/examples/ipsec-secgw/ipsec_worker.c b/examples/ipsec-
> secgw/ipsec_worker.c
> index e0690fc8d9..04609964cd 100644
> --- a/examples/ipsec-secgw/ipsec_worker.c
> +++ b/examples/ipsec-secgw/ipsec_worker.c
> @@ -700,6 +700,9 @@ ipsec_ev_inbound_route_pkts(struct rte_event_vector
> *vec,
> struct rte_ipsec_session *sess;
> struct rte_mbuf *pkt;
> struct ipsec_sa *sa;
> + uint8_t mask = (1UL << RTE_SECURITY_ACTION_TYPE_INLINE_CRYPTO)
> |
> + (1UL << RTE_SECURITY_ACTION_TYPE_INLINE_PROTOCOL);
> +
>
> j = ipsec_ev_route_ip_pkts(vec, rt, t);
>
> @@ -707,7 +710,7 @@ ipsec_ev_inbound_route_pkts(struct rte_event_vector
> *vec,
> for (i = 0; i < t->ipsec.num; i++) {
> pkt = t->ipsec.pkts[i];
> sa = ipsec_mask_saptr(t->ipsec.saptr[i]);
> - if (unlikely(sa == NULL)) {
> + if (unlikely(sa == NULL) || ((1UL << sa->sessions[0].type) &
> mask)) {
> free_pkts(&pkt, 1);
> continue;
> }
> --
> 2.25.1
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-05-21 14:13 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-04-07 7:21 [PATCH 1/1] examples/ipsec-secgw: resolve segfault for IPsec packets Rakesh Kudurumalla
2025-05-21 14:13 ` Akhil Goyal
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).