!851 sync macros with kernel defined which use in recv and send
From: @yinbin6 Reviewed-by: @jiangheng12 Signed-off-by: @jiangheng12
This commit is contained in:
commit
6d4daacf20
26
0111-support-udp-pkglen-mtu-modify-IP_REASS_MAX_PBUFS.patch
Normal file
26
0111-support-udp-pkglen-mtu-modify-IP_REASS_MAX_PBUFS.patch
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
From b619f034c74d53bd6d8b572cb47fdb58fd90d7ae Mon Sep 17 00:00:00 2001
|
||||||
|
From: yangchen <yangchen145@huawei.com>
|
||||||
|
Date: Wed, 6 Mar 2024 11:00:56 +0800
|
||||||
|
Subject: [PATCH] support udp pkglen > mtu: modify IP_REASS_MAX_PBUFS
|
||||||
|
|
||||||
|
---
|
||||||
|
src/include/lwipopts.h | 3 +++
|
||||||
|
1 file changed, 3 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/include/lwipopts.h b/src/include/lwipopts.h
|
||||||
|
index 28b8aca..d067dea 100644
|
||||||
|
--- a/src/include/lwipopts.h
|
||||||
|
+++ b/src/include/lwipopts.h
|
||||||
|
@@ -171,6 +171,9 @@
|
||||||
|
|
||||||
|
#define IP_HLEN 20
|
||||||
|
|
||||||
|
+/* the max pbuf num of a udp pbuf chain is ((65535 + MBUF_MAX_DATA_LEN - 1) / MBUF_MAX_DATA_LEN) */
|
||||||
|
+#define IP_REASS_MAX_PBUFS 46
|
||||||
|
+
|
||||||
|
/*
|
||||||
|
-------------------------------------
|
||||||
|
----------- IPv6 options -----------
|
||||||
|
--
|
||||||
|
2.33.0
|
||||||
|
|
||||||
38
0112-support-udp-pkglen-mtu-modify-netbuf_alloc-size.patch
Normal file
38
0112-support-udp-pkglen-mtu-modify-netbuf_alloc-size.patch
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
From 1e4e2fe5d7239da26edf89f554f929c10e0d5573 Mon Sep 17 00:00:00 2001
|
||||||
|
From: yangchen <yangchen145@huawei.com>
|
||||||
|
Date: Wed, 6 Mar 2024 18:25:19 +0800
|
||||||
|
Subject: [PATCH] support udp pkglen > mtu: modify netbuf_alloc size
|
||||||
|
|
||||||
|
---
|
||||||
|
src/api/sockets.c | 7 +++++++
|
||||||
|
1 file changed, 7 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/api/sockets.c b/src/api/sockets.c
|
||||||
|
index 923518c..66f6e2c 100644
|
||||||
|
--- a/src/api/sockets.c
|
||||||
|
+++ b/src/api/sockets.c
|
||||||
|
@@ -1891,7 +1891,13 @@ lwip_sendto(int s, const void *data, size_t size, int flags,
|
||||||
|
/* make the buffer point to the data that should be sent */
|
||||||
|
#if LWIP_NETIF_TX_SINGLE_PBUF
|
||||||
|
/* Allocate a new netbuf and copy the data into it. */
|
||||||
|
+#if GAZELLE_ENABLE
|
||||||
|
+ /* In the gazelle scenario, only use buf.p->payload and buf.p->tot_len, and
|
||||||
|
+ buf.p->payload stores the sock pointer info. Don't need to alloc short_size */
|
||||||
|
+ if (netbuf_alloc(&buf, 0) == NULL) {
|
||||||
|
+#else
|
||||||
|
if (netbuf_alloc(&buf, short_size) == NULL) {
|
||||||
|
+#endif
|
||||||
|
err = ERR_MEM;
|
||||||
|
} else {
|
||||||
|
#if LWIP_CHECKSUM_ON_COPY
|
||||||
|
@@ -1905,6 +1911,7 @@ lwip_sendto(int s, const void *data, size_t size, int flags,
|
||||||
|
/* In the gazelle scenario, the payload is stored in send_ring,
|
||||||
|
and the payload stores the sock pointer information. */
|
||||||
|
buf.p->payload = (void *)sock;
|
||||||
|
+ buf.p->tot_len = short_size;
|
||||||
|
#else
|
||||||
|
MEMCPY(buf.p->payload, data, short_size);
|
||||||
|
#endif
|
||||||
|
--
|
||||||
|
2.33.0
|
||||||
|
|
||||||
24
0113-fix-duplicate-pbuf_free-in-udp_sendto.patch
Normal file
24
0113-fix-duplicate-pbuf_free-in-udp_sendto.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
From 3b0bca4b38276c95f1305247ebf8a3db02ff5d83 Mon Sep 17 00:00:00 2001
|
||||||
|
From: liyunqing <liyunqing@kylinos.cn>
|
||||||
|
Date: Thu, 7 Mar 2024 11:18:00 +0800
|
||||||
|
Subject: [PATCH] fix duplicate pbuf_free in udp_sendto
|
||||||
|
|
||||||
|
---
|
||||||
|
src/core/udp.c | 1 -
|
||||||
|
1 file changed, 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/core/udp.c b/src/core/udp.c
|
||||||
|
index 440f909..ff5c99b 100644
|
||||||
|
--- a/src/core/udp.c
|
||||||
|
+++ b/src/core/udp.c
|
||||||
|
@@ -680,7 +680,6 @@ udp_sendto_chksum(struct udp_pcb *pcb, struct pbuf *p, const ip_addr_t *dst_ip,
|
||||||
|
struct pbuf *udp_pbuf = do_lwip_get_from_sendring((struct lwip_sock *)(p->payload), p->tot_len, &apiflags);
|
||||||
|
do_lwip_get_from_sendring_over((struct lwip_sock *)(p->payload));
|
||||||
|
|
||||||
|
- pbuf_free(p);
|
||||||
|
p = udp_pbuf;
|
||||||
|
if (p == NULL) {
|
||||||
|
return ERR_MEM;
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
40
0114-sync-recv-flags-with-linux-kernel.patch
Normal file
40
0114-sync-recv-flags-with-linux-kernel.patch
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
From 931c9ff6d250685ce29cf10e3e03ecaae70419ea Mon Sep 17 00:00:00 2001
|
||||||
|
From: liyunqing <liyunqing@kylinos.cn>
|
||||||
|
Date: Tue, 27 Feb 2024 15:40:33 +0800
|
||||||
|
Subject: [PATCH] sync recv flags with linux kernel
|
||||||
|
|
||||||
|
---
|
||||||
|
src/include/lwip/sockets.h | 10 +++++++++-
|
||||||
|
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/include/lwip/sockets.h b/src/include/lwip/sockets.h
|
||||||
|
index 89b6eb5..4466f11 100644
|
||||||
|
--- a/src/include/lwip/sockets.h
|
||||||
|
+++ b/src/include/lwip/sockets.h
|
||||||
|
@@ -281,14 +281,22 @@ struct linger {
|
||||||
|
#define IPPROTO_UDPLITE 136
|
||||||
|
#define IPPROTO_RAW 255
|
||||||
|
|
||||||
|
+#if GAZELLE_ENABLE
|
||||||
|
/* Flags we can use with send and recv. */
|
||||||
|
+#define MSG_PEEK 0x02 /* Peeks at an incoming message */
|
||||||
|
+#define MSG_WAITALL 0x100 /* Unimplemented: Requests that the function block until the full amount of data requested can be returned */
|
||||||
|
+#define MSG_OOB 0x01 /* Unimplemented: Requests out-of-band data. The significance and semantics of out-of-band data are protocol-specific */
|
||||||
|
+#define MSG_DONTWAIT 0x40 /* Nonblocking i/o for this operation only */
|
||||||
|
+#define MSG_MORE 0x8000 /* Sender will send more */
|
||||||
|
+#define MSG_NOSIGNAL 0x4000 /* Uninmplemented: Requests not to send the SIGPIPE signal if an attempt to send is made on a stream-oriented socket that is no longer connected. */
|
||||||
|
+#else
|
||||||
|
#define MSG_PEEK 0x01 /* Peeks at an incoming message */
|
||||||
|
#define MSG_WAITALL 0x02 /* Unimplemented: Requests that the function block until the full amount of data requested can be returned */
|
||||||
|
#define MSG_OOB 0x04 /* Unimplemented: Requests out-of-band data. The significance and semantics of out-of-band data are protocol-specific */
|
||||||
|
#define MSG_DONTWAIT 0x08 /* Nonblocking i/o for this operation only */
|
||||||
|
#define MSG_MORE 0x10 /* Sender will send more */
|
||||||
|
#define MSG_NOSIGNAL 0x20 /* Uninmplemented: Requests not to send the SIGPIPE signal if an attempt to send is made on a stream-oriented socket that is no longer connected. */
|
||||||
|
-
|
||||||
|
+#endif /* GAZELLE_ENABLE */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Options for level IPPROTO_IP
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
18
lwip.spec
18
lwip.spec
@ -4,7 +4,7 @@
|
|||||||
Summary: lwip is a small independent implementation of the TCP/IP protocol suite
|
Summary: lwip is a small independent implementation of the TCP/IP protocol suite
|
||||||
Name: lwip
|
Name: lwip
|
||||||
Version: 2.2.0
|
Version: 2.2.0
|
||||||
Release: 3
|
Release: 7
|
||||||
License: BSD
|
License: BSD
|
||||||
URL: http://savannah.nongnu.org/projects/lwip/
|
URL: http://savannah.nongnu.org/projects/lwip/
|
||||||
Source0: http://download.savannah.nongnu.org/releases/lwip/%{name}-%{version}.zip
|
Source0: http://download.savannah.nongnu.org/releases/lwip/%{name}-%{version}.zip
|
||||||
@ -122,6 +122,10 @@ Patch9106: 0107-fix-move-lpcb-to-the-front-of-list-error.patch
|
|||||||
Patch9107: 0108-fix-receive-fin-packet-process-error.patch
|
Patch9107: 0108-fix-receive-fin-packet-process-error.patch
|
||||||
Patch9108: 0109-support-udp-recv-zero-packets.patch
|
Patch9108: 0109-support-udp-recv-zero-packets.patch
|
||||||
Patch9109: 0110-adapt-lwip-2.2.0.patch
|
Patch9109: 0110-adapt-lwip-2.2.0.patch
|
||||||
|
Patch9110: 0111-support-udp-pkglen-mtu-modify-IP_REASS_MAX_PBUFS.patch
|
||||||
|
Patch9111: 0112-support-udp-pkglen-mtu-modify-netbuf_alloc-size.patch
|
||||||
|
Patch9112: 0113-fix-duplicate-pbuf_free-in-udp_sendto.patch
|
||||||
|
Patch9113: 0114-sync-recv-flags-with-linux-kernel.patch
|
||||||
|
|
||||||
BuildRequires: gcc-c++ dos2unix dpdk-devel
|
BuildRequires: gcc-c++ dos2unix dpdk-devel
|
||||||
|
|
||||||
@ -151,6 +155,18 @@ cd %{_builddir}/%{name}-%{version}/src
|
|||||||
%{_libdir}/liblwip.a
|
%{_libdir}/liblwip.a
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Mar 11 2024 liyunqing <liyunqing@kylinos.cn> - 2.2.0-7
|
||||||
|
- sync macros with kernel defined which use in recv and send
|
||||||
|
|
||||||
|
* Thu Mar 7 2024 liyunqing <liyunqing@kylinos.cn> - 2.2.0-6
|
||||||
|
- fix duplicate pbuf_free in udp_sendto
|
||||||
|
|
||||||
|
* Wed Mar 6 2024 yangchen <yangchen145@huawei.com> - 2.2.0-5
|
||||||
|
- support udp pkglen > mtu: modify netbuf_alloc size
|
||||||
|
|
||||||
|
* Tue Mar 5 2024 yangchen <yangchen145@huawei.com> - 2.2.0-4
|
||||||
|
- support udp pkglen > mtu: modify IP_REASS_MAX_PBUFS
|
||||||
|
|
||||||
* Tue Mar 5 2024 jiangheng <jiangheng14@huawei.com> - 2.2.0-3
|
* Tue Mar 5 2024 jiangheng <jiangheng14@huawei.com> - 2.2.0-3
|
||||||
- remove backport patches
|
- remove backport patches
|
||||||
- sys_mbox_new return error when rte ring create failed
|
- sys_mbox_new return error when rte ring create failed
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user