diff --git a/components/net/lwip/Kconfig b/components/net/lwip/Kconfig index 8299540493..2566870d6e 100644 --- a/components/net/lwip/Kconfig +++ b/components/net/lwip/Kconfig @@ -22,7 +22,13 @@ if RT_USING_LWIP endchoice - if (RT_USING_LWIP203 || RT_USING_LWIP212) + config RT_USING_LWIP_VER_NUM + hex + default 0x20102 if RT_USING_LWIP212 + default 0x20003 if RT_USING_LWIP203 + default 0x10401 if RT_USING_LWIP141 + + if (RT_USING_LWIP_VER_NUM >= 0x20000) config RT_USING_LWIP_IPV6 bool "IPV6 protocol" default n diff --git a/components/net/lwip/lwip-1.4.1/SConscript b/components/net/lwip/lwip-1.4.1/SConscript index 8525e89f2a..63aa0a36d1 100644 --- a/components/net/lwip/lwip-1.4.1/SConscript +++ b/components/net/lwip/lwip-1.4.1/SConscript @@ -63,8 +63,7 @@ src/netif/ppp/vj.c """) # The set of source files associated with this SConscript file. -path = [GetCurrentDir() + '/src', - GetCurrentDir() + '/src/include', +path = [GetCurrentDir() + '/src/include', GetCurrentDir() + '/src/include/ipv4', GetCurrentDir() + '/src/include/netif'] diff --git a/components/net/lwip/lwip-1.4.1/src/lwipopts.h b/components/net/lwip/lwip-1.4.1/src/lwipopts.h deleted file mode 100644 index 03930c8741..0000000000 --- a/components/net/lwip/lwip-1.4.1/src/lwipopts.h +++ /dev/null @@ -1,581 +0,0 @@ -#ifndef __LWIPOPTS_H__ -#define __LWIPOPTS_H__ - -#include - -#define ERRNO - -#define NO_SYS 0 -#define LWIP_SOCKET 1 -#define LWIP_NETCONN 1 - -#ifdef RT_LWIP_IGMP -#define LWIP_IGMP 1 -#else -#define LWIP_IGMP 0 -#endif - -#ifdef RT_LWIP_ICMP -#define LWIP_ICMP 1 -#else -#define LWIP_ICMP 0 -#endif - -#ifdef RT_LWIP_SNMP -#define LWIP_SNMP 1 -#else -#define LWIP_SNMP 0 -#endif - -#ifdef RT_LWIP_DNS -#define LWIP_DNS 1 -#else -#define LWIP_DNS 0 -#endif - -#define LWIP_HAVE_LOOPIF 0 - -#define LWIP_PLATFORM_BYTESWAP 0 - -/* #define RT_LWIP_DEBUG */ - -#ifdef RT_LWIP_DEBUG -#define LWIP_DEBUG -#endif - -/* ---------- Debug options ---------- */ -#ifdef LWIP_DEBUG -#ifdef RT_LWIP_SYS_DEBUG -#define SYS_DEBUG LWIP_DBG_ON -#else -#define SYS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_ETHARP_DEBUG -#define ETHARP_DEBUG LWIP_DBG_ON -#else -#define ETHARP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_PPP_DEBUG -#define PPP_DEBUG LWIP_DBG_ON -#else -#define PPP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_MEM_DEBUG -#define MEM_DEBUG LWIP_DBG_ON -#else -#define MEM_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_MEMP_DEBUG -#define MEMP_DEBUG LWIP_DBG_ON -#else -#define MEMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_PBUF_DEBUG -#define PBUF_DEBUG LWIP_DBG_ON -#else -#define PBUF_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_API_LIB_DEBUG -#define API_LIB_DEBUG LWIP_DBG_ON -#else -#define API_LIB_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_API_MSG_DEBUG -#define API_MSG_DEBUG LWIP_DBG_ON -#else -#define API_MSG_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCPIP_DEBUG -#define TCPIP_DEBUG LWIP_DBG_ON -#else -#define TCPIP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_NETIF_DEBUG -#define NETIF_DEBUG LWIP_DBG_ON -#else -#define NETIF_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_SOCKETS_DEBUG -#define SOCKETS_DEBUG LWIP_DBG_ON -#else -#define SOCKETS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_DNS_DEBUG -#define DNS_DEBUG LWIP_DBG_ON -#else -#define DNS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_AUTOIP_DEBUG -#define AUTOIP_DEBUG LWIP_DBG_ON -#else -#define AUTOIP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_DHCP_DEBUG -#define DHCP_DEBUG LWIP_DBG_ON -#else -#define DHCP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IP_DEBUG -#define IP_DEBUG LWIP_DBG_ON -#else -#define IP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IP_REASS_DEBUG -#define IP_REASS_DEBUG LWIP_DBG_ON -#else -#define IP_REASS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_ICMP_DEBUG -#define ICMP_DEBUG LWIP_DBG_ON -#else -#define ICMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IGMP_DEBUG -#define IGMP_DEBUG LWIP_DBG_ON -#else -#define IGMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_UDP_DEBUG -#define UDP_DEBUG LWIP_DBG_ON -#else -#define UDP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_DEBUG -#define TCP_DEBUG LWIP_DBG_ON -#else -#define TCP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_INPUT_DEBUG -#define TCP_INPUT_DEBUG LWIP_DBG_ON -#else -#define TCP_INPUT_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_OUTPUT_DEBUG -#define TCP_OUTPUT_DEBUG LWIP_DBG_ON -#else -#define TCP_OUTPUT_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_RTO_DEBUG -#define TCP_RTO_DEBUG LWIP_DBG_ON -#else -#define TCP_RTO_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_CWND_DEBUG -#define TCP_CWND_DEBUG LWIP_DBG_ON -#else -#define TCP_CWND_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_WND_DEBUG -#define TCP_WND_DEBUG LWIP_DBG_ON -#else -#define TCP_WND_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_FR_DEBUG -#define TCP_FR_DEBUG LWIP_DBG_ON -#else -#define TCP_FR_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_QLEN_DEBUG -#define TCP_QLEN_DEBUG LWIP_DBG_ON -#else -#define TCP_QLEN_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_RST_DEBUG -#define TCP_RST_DEBUG LWIP_DBG_ON -#else -#define TCP_RST_DEBUG LWIP_DBG_OFF -#endif - -#endif /* LWIP_DEBUG */ - -#define LWIP_DBG_TYPES_ON (LWIP_DBG_ON|LWIP_DBG_TRACE|LWIP_DBG_STATE|LWIP_DBG_FRESH|LWIP_DBG_HALT) - -/* ---------- Memory options ---------- */ -#define MEMCPY(dst,src,len) rt_memcpy(dst,src,len) -#define SMEMCPY(dst,src,len) MEMCPY(dst,src,len) - -#define MEM_ALIGNMENT 4 - -#define MEM_LIBC_MALLOC 1 -#define mem_malloc rt_malloc -#define mem_free rt_free -#define mem_calloc rt_calloc - -#define MEMP_MEM_MALLOC 0 - -/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application - sends a lot of data out of ROM (or other static memory), this - should be set high. */ -#define MEMP_NUM_PBUF 16 - -/* the number of struct netconns */ -#ifdef RT_MEMP_NUM_NETCONN -#define MEMP_NUM_NETCONN RT_MEMP_NUM_NETCONN -#endif - -/* the number of UDP protocol control blocks. One per active RAW "connection". */ -#ifdef RT_LWIP_RAW_PCB_NUM -#define MEMP_NUM_RAW_PCB RT_LWIP_RAW_PCB_NUM -#endif - -/* the number of UDP protocol control blocks. One per active UDP "connection". */ -#ifdef RT_LWIP_UDP_PCB_NUM -#define MEMP_NUM_UDP_PCB RT_LWIP_UDP_PCB_NUM -#endif - -/* the number of simulatenously active TCP connections. */ -#ifdef RT_LWIP_TCP_PCB_NUM -#define MEMP_NUM_TCP_PCB RT_LWIP_TCP_PCB_NUM -#endif - -/* the number of simultaneously queued TCP */ -#ifdef RT_LWIP_TCP_SEG_NUM -#define MEMP_NUM_TCP_SEG RT_LWIP_TCP_SEG_NUM -#else -#define MEMP_NUM_TCP_SEG TCP_SND_QUEUELEN -#endif - -/* - * You can re-define following setting in rtcofnig.h to overwrite the default - * setting in the lwip opts.h - */ -/* MEMP_NUM_NETBUF: the number of struct netbufs. */ -// #define MEMP_NUM_NETBUF 2 -/* MEMP_NUM_NETCONN: the number of struct netconns. */ -// #define MEMP_NUM_NETCONN 4 - -/* MEMP_NUM_TCPIP_MSG_*: the number of struct tcpip_msg, which is used - for sequential API communication and incoming packets. Used in - src/api/tcpip.c. */ -// #define MEMP_NUM_TCPIP_MSG_API 16 -// #define MEMP_NUM_TCPIP_MSG_INPKT 16 - -/* ---------- Pbuf options ---------- */ -/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */ -#ifdef RT_LWIP_PBUF_NUM -#define PBUF_POOL_SIZE RT_LWIP_PBUF_NUM -#endif - -/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */ -#ifdef RT_LWIP_PBUF_POOL_BUFSIZE -#define PBUF_POOL_BUFSIZE RT_LWIP_PBUF_POOL_BUFSIZE -#endif - -/* PBUF_LINK_HLEN: the number of bytes that should be allocated for a - link level header. */ -#define PBUF_LINK_HLEN 16 - -#ifdef RT_LWIP_ETH_PAD_SIZE -#define ETH_PAD_SIZE RT_LWIP_ETH_PAD_SIZE -#endif - -/** SYS_LIGHTWEIGHT_PROT - * define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection - * for certain critical regions during buffer allocation, deallocation and memory - * allocation and deallocation. - */ -#define SYS_LIGHTWEIGHT_PROT (NO_SYS==0) - -#ifdef LWIP_USING_NAT -#define IP_NAT 1 -#else -#define IP_NAT 0 -#endif - -/* ---------- TCP options ---------- */ -#ifdef RT_LWIP_TCP -#define LWIP_TCP 1 -#else -#define LWIP_TCP 0 -#endif - -#define TCP_TTL 255 - -/* Controls if TCP should queue segments that arrive out of - order. Define to 0 if your device is low on memory. */ -#define TCP_QUEUE_OOSEQ 1 - -/* TCP Maximum segment size. */ -#define TCP_MSS 1460 - -/* TCP sender buffer space (bytes). */ -#ifdef RT_LWIP_TCP_SND_BUF -#define TCP_SND_BUF RT_LWIP_TCP_SND_BUF -#else -#define TCP_SND_BUF (TCP_MSS * 2) -#endif - -/* TCP sender buffer space (pbufs). This must be at least = 2 * - TCP_SND_BUF/TCP_MSS for things to work. */ -#define TCP_SND_QUEUELEN (4 * TCP_SND_BUF/TCP_MSS) - -/* TCP writable space (bytes). This must be less than or equal - to TCP_SND_BUF. It is the amount of space which must be - available in the tcp snd_buf for select to return writable */ -#define TCP_SNDLOWAT (TCP_SND_BUF/2) -#define TCP_SNDQUEUELOWAT TCP_SND_QUEUELEN/2 - -/* TCP receive window. */ -#ifdef RT_LWIP_TCP_WND -#define TCP_WND RT_LWIP_TCP_WND -#else -#define TCP_WND (TCP_MSS * 2) -#endif - -/* Maximum number of retransmissions of data segments. */ -#define TCP_MAXRTX 12 - -/* Maximum number of retransmissions of SYN segments. */ -#define TCP_SYNMAXRTX 4 - -/* tcpip thread options */ -#ifdef RT_LWIP_TCPTHREAD_PRIORITY -#define TCPIP_MBOX_SIZE RT_LWIP_TCPTHREAD_MBOX_SIZE -#define TCPIP_THREAD_PRIO RT_LWIP_TCPTHREAD_PRIORITY -#define TCPIP_THREAD_STACKSIZE RT_LWIP_TCPTHREAD_STACKSIZE -#else -#define TCPIP_MBOX_SIZE 8 -#define TCPIP_THREAD_PRIO 128 -#define TCPIP_THREAD_STACKSIZE 4096 -#endif -#define TCPIP_THREAD_NAME "tcpip" -#define DEFAULT_TCP_RECVMBOX_SIZE 10 - -/* ---------- ARP options ---------- */ -#define LWIP_ARP 1 -#define ARP_TABLE_SIZE 10 -#define ARP_QUEUEING 1 - -/* ---------- Checksum options ---------- */ -#ifdef RT_LWIP_USING_HW_CHECKSUM -#define CHECKSUM_GEN_IP 0 -#define CHECKSUM_GEN_UDP 0 -#define CHECKSUM_GEN_TCP 0 -#define CHECKSUM_GEN_ICMP 0 -#define CHECKSUM_CHECK_IP 0 -#define CHECKSUM_CHECK_UDP 0 -#define CHECKSUM_CHECK_TCP 0 -#define CHECKSUM_CHECK_ICMP 0 -#endif - -/* ---------- IP options ---------- */ -/* Define IP_FORWARD to 1 if you wish to have the ability to forward - IP packets across network interfaces. If you are going to run lwIP - on a device with only one network interface, define this to 0. */ -#define IP_FORWARD 0 - -/* IP reassembly and segmentation.These are orthogonal even - * if they both deal with IP fragments */ -#ifdef RT_LWIP_REASSEMBLY_FRAG -#define IP_REASSEMBLY 1 -#define IP_FRAG 1 -#define IP_REASS_MAX_PBUFS 10 -#define MEMP_NUM_REASSDATA 10 -#else -#define IP_REASSEMBLY 0 -#define IP_FRAG 0 -#endif - -/* ---------- ICMP options ---------- */ -#define ICMP_TTL 255 - -/* ---------- DHCP options ---------- */ -/* Define LWIP_DHCP to 1 if you want DHCP configuration of - interfaces. */ -#ifdef RT_LWIP_DHCP -#define LWIP_DHCP 1 -#else -#define LWIP_DHCP 0 -#endif - -/* 1 if you want to do an ARP check on the offered address - (recommended). */ -#define DHCP_DOES_ARP_CHECK (LWIP_DHCP) - -/* ---------- AUTOIP options ------- */ -#define LWIP_AUTOIP 0 -#define LWIP_DHCP_AUTOIP_COOP (LWIP_DHCP && LWIP_AUTOIP) - -/* ---------- UDP options ---------- */ -#ifdef RT_LWIP_UDP -#define LWIP_UDP 1 -#else -#define LWIP_UDP 0 -#endif - -#define LWIP_UDPLITE 0 -#define UDP_TTL 255 -#define DEFAULT_UDP_RECVMBOX_SIZE 1 - -/* ---------- RAW options ---------- */ -#define DEFAULT_RAW_RECVMBOX_SIZE 1 -#define DEFAULT_ACCEPTMBOX_SIZE 10 - -/* ---------- Statistics options ---------- */ -#ifdef RT_LWIP_STATS -#define LWIP_STATS 1 -#define LWIP_STATS_DISPLAY 1 -#else -#define LWIP_STATS 0 -#endif - -#if LWIP_STATS -#define LINK_STATS 1 -#define IP_STATS 1 -#define ICMP_STATS 1 -#define IGMP_STATS 1 -#define IPFRAG_STATS 1 -#define UDP_STATS 1 -#define TCP_STATS 1 -#define MEM_STATS 1 -#define MEMP_STATS 1 -#define PBUF_STATS 1 -#define SYS_STATS 1 -#endif /* LWIP_STATS */ - -/* ---------- PPP options ---------- */ -#ifdef RT_LWIP_PPP -#define PPP_SUPPORT 1 /* Set > 0 for PPP */ -#else -#define PPP_SUPPORT 0 /* Set > 0 for PPP */ -#endif - -#if PPP_SUPPORT -#define NUM_PPP 1 /* Max PPP sessions. */ - -/* Select modules to enable. Ideally these would be set in the makefile but - * we're limited by the command line length so you need to modify the settings - * in this file. - */ -#ifdef RT_LWIP_PPPOE -#define PPPOE_SUPPORT 1 -#else -#define PPPOE_SUPPORT 0 -#endif - -#ifdef RT_LWIP_PPPOS -#define PPPOS_SUPPORT 1 -#else -#define PPPOS_SUPPORT 0 -#endif - -#define PAP_SUPPORT 1 /* Set > 0 for PAP. */ -#define CHAP_SUPPORT 1 /* Set > 0 for CHAP. */ -#define MSCHAP_SUPPORT 0 /* Set > 0 for MSCHAP (NOT FUNCTIONAL!) */ -#define CBCP_SUPPORT 0 /* Set > 0 for CBCP (NOT FUNCTIONAL!) */ -#define CCP_SUPPORT 0 /* Set > 0 for CCP (NOT FUNCTIONAL!) */ -#define VJ_SUPPORT 1 /* Set > 0 for VJ header compression. */ -#define MD5_SUPPORT 1 /* Set > 0 for MD5 (see also CHAP) */ - -#endif /* PPP_SUPPORT */ - -/* no read/write/close for socket */ -#define LWIP_POSIX_SOCKETS_IO_NAMES 0 - -/** - * LWIP_NETIF_HOSTNAME==1: Support netif hostname - */ -#ifndef LWIP_NETIF_HOSTNAME -#define LWIP_NETIF_HOSTNAME 1 -#endif - -#define LWIP_NETIF_API 1 - -/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active timeouts. */ -#define MEMP_NUM_SYS_TIMEOUT (LWIP_TCP + IP_REASSEMBLY + LWIP_ARP + (2*LWIP_DHCP) + LWIP_AUTOIP + LWIP_IGMP + LWIP_DNS + PPP_SUPPORT) -#ifdef LWIP_IGMP -#include -#define LWIP_RAND rand -#endif -/* - ------------------------------------ - ---------- Socket options ---------- - ------------------------------------ -*/ -/* - * LWIP_SOCKET==1: Enable Socket API (require to use sockets.c) - */ -#ifndef LWIP_SOCKET -#define LWIP_SOCKET 1 -#endif -#include -#include - -/* - * LWIP_COMPAT_SOCKETS==1: Enable BSD-style sockets functions names. - * (only used if you use sockets.c) - */ -#ifdef SAL_USING_POSIX -#define LWIP_COMPAT_SOCKETS 0 -#else -#ifndef LWIP_COMPAT_SOCKETS -#define LWIP_COMPAT_SOCKETS 1 -#endif -#endif - - -/** - * LWIP_SO_SNDTIMEO==1: Enable send timeout for sockets/netconns and - * SO_SNDTIMEO processing. - */ -#ifndef LWIP_SO_SNDTIMEO -#define LWIP_SO_SNDTIMEO 1 -#endif - -/** - * LWIP_SO_RCVTIMEO==1: Enable receive timeout for sockets/netconns and - * SO_RCVTIMEO processing. - */ -#ifndef LWIP_SO_RCVTIMEO -#define LWIP_SO_RCVTIMEO 1 -#endif - -/** - * LWIP_SO_RCVBUF==1: Enable SO_RCVBUF processing. - */ -#ifndef LWIP_SO_RCVBUF -#define LWIP_SO_RCVBUF 1 -#endif - -/** - * If LWIP_SO_RCVBUF is used, this is the default value for recv_bufsize. - */ -#ifndef RECV_BUFSIZE_DEFAULT -#define RECV_BUFSIZE_DEFAULT 8192 -#endif - -/** - * SO_REUSE==1: Enable SO_REUSEADDR option. - */ -#ifndef SO_REUSE -#define SO_REUSE 0 -#endif - -#endif /* __LWIPOPTS_H__ */ diff --git a/components/net/lwip/lwip-2.0.3/SConscript b/components/net/lwip/lwip-2.0.3/SConscript index 9f99cd6f1a..856194f655 100644 --- a/components/net/lwip/lwip-2.0.3/SConscript +++ b/components/net/lwip/lwip-2.0.3/SConscript @@ -59,8 +59,7 @@ ppp_src = Glob("src/netif/ppp/*.c") + Glob("src/netif/ppp/polarssl/*c") src = src + ipv4_src # The set of source files associated with this SConscript file. -path = [GetCurrentDir() + '/src', - GetCurrentDir() + '/src/include', +path = [GetCurrentDir() + '/src/include', GetCurrentDir() + '/src/include/ipv4', GetCurrentDir() + '/src/include/netif'] diff --git a/components/net/lwip/lwip-2.0.3/src/lwipopts.h b/components/net/lwip/lwip-2.0.3/src/lwipopts.h deleted file mode 100644 index 2de6aa1052..0000000000 --- a/components/net/lwip/lwip-2.0.3/src/lwipopts.h +++ /dev/null @@ -1,637 +0,0 @@ -#ifndef __LWIPOPTS_H__ -#define __LWIPOPTS_H__ - -#include - -#define LWIP_ERRNO_STDINCLUDE - -#define LWIP_IPV4 1 - -#ifdef RT_USING_LWIP_IPV6 -#define LWIP_IPV6 1 -#else -#define LWIP_IPV6 0 -#endif /* RT_USING_LWIP_IPV6 */ - -#define NO_SYS 0 -#define LWIP_SOCKET 1 -#define LWIP_NETCONN 1 - -#ifdef RT_LWIP_IGMP -#define LWIP_IGMP 1 -#else -#define LWIP_IGMP 0 -#endif - -#ifdef RT_LWIP_ICMP -#define LWIP_ICMP 1 -#else -#define LWIP_ICMP 0 -#endif - -#ifdef RT_LWIP_SNMP -#define LWIP_SNMP 1 -#else -#define LWIP_SNMP 0 -#endif - -#ifdef RT_LWIP_DNS -#define LWIP_DNS 1 -#else -#define LWIP_DNS 0 -#endif - -#define LWIP_HAVE_LOOPIF 0 - -#define LWIP_PLATFORM_BYTESWAP 0 - -/* #define RT_LWIP_DEBUG */ - -#ifdef RT_LWIP_DEBUG -#define LWIP_DEBUG -#endif - -/* ---------- Debug options ---------- */ -#ifdef LWIP_DEBUG -#ifdef RT_LWIP_SYS_DEBUG -#define SYS_DEBUG LWIP_DBG_ON -#else -#define SYS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_ETHARP_DEBUG -#define ETHARP_DEBUG LWIP_DBG_ON -#else -#define ETHARP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_PPP_DEBUG -#define PPP_DEBUG LWIP_DBG_ON -#else -#define PPP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_MEM_DEBUG -#define MEM_DEBUG LWIP_DBG_ON -#else -#define MEM_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_MEMP_DEBUG -#define MEMP_DEBUG LWIP_DBG_ON -#else -#define MEMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_PBUF_DEBUG -#define PBUF_DEBUG LWIP_DBG_ON -#else -#define PBUF_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_API_LIB_DEBUG -#define API_LIB_DEBUG LWIP_DBG_ON -#else -#define API_LIB_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_API_MSG_DEBUG -#define API_MSG_DEBUG LWIP_DBG_ON -#else -#define API_MSG_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCPIP_DEBUG -#define TCPIP_DEBUG LWIP_DBG_ON -#else -#define TCPIP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_NETIF_DEBUG -#define NETIF_DEBUG LWIP_DBG_ON -#else -#define NETIF_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_SOCKETS_DEBUG -#define SOCKETS_DEBUG LWIP_DBG_ON -#else -#define SOCKETS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_DNS_DEBUG -#define DNS_DEBUG LWIP_DBG_ON -#else -#define DNS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_AUTOIP_DEBUG -#define AUTOIP_DEBUG LWIP_DBG_ON -#else -#define AUTOIP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_DHCP_DEBUG -#define DHCP_DEBUG LWIP_DBG_ON -#else -#define DHCP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IP_DEBUG -#define IP_DEBUG LWIP_DBG_ON -#else -#define IP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IP_REASS_DEBUG -#define IP_REASS_DEBUG LWIP_DBG_ON -#else -#define IP_REASS_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_ICMP_DEBUG -#define ICMP_DEBUG LWIP_DBG_ON -#else -#define ICMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_IGMP_DEBUG -#define IGMP_DEBUG LWIP_DBG_ON -#else -#define IGMP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_UDP_DEBUG -#define UDP_DEBUG LWIP_DBG_ON -#else -#define UDP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_DEBUG -#define TCP_DEBUG LWIP_DBG_ON -#else -#define TCP_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_INPUT_DEBUG -#define TCP_INPUT_DEBUG LWIP_DBG_ON -#else -#define TCP_INPUT_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_OUTPUT_DEBUG -#define TCP_OUTPUT_DEBUG LWIP_DBG_ON -#else -#define TCP_OUTPUT_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_RTO_DEBUG -#define TCP_RTO_DEBUG LWIP_DBG_ON -#else -#define TCP_RTO_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_CWND_DEBUG -#define TCP_CWND_DEBUG LWIP_DBG_ON -#else -#define TCP_CWND_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_WND_DEBUG -#define TCP_WND_DEBUG LWIP_DBG_ON -#else -#define TCP_WND_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_FR_DEBUG -#define TCP_FR_DEBUG LWIP_DBG_ON -#else -#define TCP_FR_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_QLEN_DEBUG -#define TCP_QLEN_DEBUG LWIP_DBG_ON -#else -#define TCP_QLEN_DEBUG LWIP_DBG_OFF -#endif - -#ifdef RT_LWIP_TCP_RST_DEBUG -#define TCP_RST_DEBUG LWIP_DBG_ON -#else -#define TCP_RST_DEBUG LWIP_DBG_OFF -#endif - -#endif /* LWIP_DEBUG */ - -#define LWIP_DBG_TYPES_ON (LWIP_DBG_ON|LWIP_DBG_TRACE|LWIP_DBG_STATE|LWIP_DBG_FRESH|LWIP_DBG_HALT) - -/* ---------- Memory options ---------- */ -#define MEMCPY(dst,src,len) rt_memcpy(dst,src,len) -#define SMEMCPY(dst,src,len) MEMCPY(dst,src,len) - -#ifdef RT_LWIP_MEM_ALIGNMENT -#define MEM_ALIGNMENT RT_LWIP_MEM_ALIGNMENT -#else -#define MEM_ALIGNMENT 4 -#endif - -#define MEMP_OVERFLOW_CHECK 1 -#define LWIP_ALLOW_MEM_FREE_FROM_OTHER_CONTEXT 1 -//#define MEM_LIBC_MALLOC 1 -//#define MEM_USE_POOLS 1 -//#define MEMP_USE_CUSTOM_POOLS 1 -//#define MEM_SIZE (1024*64) - -#define MEMP_MEM_MALLOC 0 - -/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application - sends a lot of data out of ROM (or other static memory), this - should be set high. */ -#define MEMP_NUM_PBUF 32 //16 - -/* the number of struct netconns */ -#ifdef RT_MEMP_NUM_NETCONN -#define MEMP_NUM_NETCONN RT_MEMP_NUM_NETCONN -#endif - -/* the number of UDP protocol control blocks. One per active RAW "connection". */ -#ifdef RT_LWIP_RAW_PCB_NUM -#define MEMP_NUM_RAW_PCB RT_LWIP_RAW_PCB_NUM -#endif - -/* the number of UDP protocol control blocks. One per active UDP "connection". */ -#ifdef RT_LWIP_UDP_PCB_NUM -#define MEMP_NUM_UDP_PCB RT_LWIP_UDP_PCB_NUM -#endif - -/* the number of simulatenously active TCP connections. */ -#ifdef RT_LWIP_TCP_PCB_NUM -#define MEMP_NUM_TCP_PCB RT_LWIP_TCP_PCB_NUM -#endif - -/* the number of simultaneously queued TCP */ -#ifdef RT_LWIP_TCP_SEG_NUM -#define MEMP_NUM_TCP_SEG RT_LWIP_TCP_SEG_NUM -#else -#define MEMP_NUM_TCP_SEG TCP_SND_QUEUELEN -#endif - -/* - * You can re-define following setting in rtcofnig.h to overwrite the default - * setting in the lwip opts.h - */ -/* MEMP_NUM_NETBUF: the number of struct netbufs. */ -// #define MEMP_NUM_NETBUF 2 -/* MEMP_NUM_NETCONN: the number of struct netconns. */ -// #define MEMP_NUM_NETCONN 4 - -/* MEMP_NUM_TCPIP_MSG_*: the number of struct tcpip_msg, which is used - for sequential API communication and incoming packets. Used in - src/api/tcpip.c. */ -// #define MEMP_NUM_TCPIP_MSG_API 16 -// #define MEMP_NUM_TCPIP_MSG_INPKT 16 - -/* ---------- Pbuf options ---------- */ -/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */ -#ifdef RT_LWIP_PBUF_NUM -#define PBUF_POOL_SIZE RT_LWIP_PBUF_NUM -#endif - -/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */ -#ifdef RT_LWIP_PBUF_POOL_BUFSIZE -#define PBUF_POOL_BUFSIZE RT_LWIP_PBUF_POOL_BUFSIZE -#endif - -/* PBUF_LINK_HLEN: the number of bytes that should be allocated for a - link level header. */ -#define PBUF_LINK_HLEN 16 - -#ifdef RT_LWIP_ETH_PAD_SIZE -#define ETH_PAD_SIZE RT_LWIP_ETH_PAD_SIZE -#endif - -/** SYS_LIGHTWEIGHT_PROT - * define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection - * for certain critical regions during buffer allocation, deallocation and memory - * allocation and deallocation. - */ -#define SYS_LIGHTWEIGHT_PROT (NO_SYS==0) - -#ifdef LWIP_USING_NAT -#define IP_NAT 1 -#else -#define IP_NAT 0 -#endif - -/* ---------- TCP options ---------- */ -#ifdef RT_LWIP_TCP -#define LWIP_TCP 1 -#else -#define LWIP_TCP 0 -#endif - -#define TCP_TTL 255 - -/* Controls if TCP should queue segments that arrive out of - order. Define to 0 if your device is low on memory. */ -#define TCP_QUEUE_OOSEQ 1 - -/* TCP Maximum segment size. */ -#define TCP_MSS 1460 - -/* TCP sender buffer space (bytes). */ -#ifdef RT_LWIP_TCP_SND_BUF -#define TCP_SND_BUF RT_LWIP_TCP_SND_BUF -#else -#define TCP_SND_BUF (TCP_MSS * 2) -#endif - -/* TCP sender buffer space (pbufs). This must be at least = 2 * - TCP_SND_BUF/TCP_MSS for things to work. */ -#define TCP_SND_QUEUELEN (4 * TCP_SND_BUF/TCP_MSS) - -/* TCP writable space (bytes). This must be less than or equal - to TCP_SND_BUF. It is the amount of space which must be - available in the tcp snd_buf for select to return writable */ -#define TCP_SNDLOWAT (TCP_SND_BUF/2) -#define TCP_SNDQUEUELOWAT TCP_SND_QUEUELEN/2 - -/* TCP receive window. */ -#ifdef RT_LWIP_TCP_WND -#define TCP_WND RT_LWIP_TCP_WND -#else -#define TCP_WND (TCP_MSS * 2) -#endif - -/* Maximum number of retransmissions of data segments. */ -#define TCP_MAXRTX 12 - -/* Maximum number of retransmissions of SYN segments. */ -#define TCP_SYNMAXRTX 4 - -/* tcpip thread options */ -#ifdef RT_LWIP_TCPTHREAD_PRIORITY -#define TCPIP_MBOX_SIZE RT_LWIP_TCPTHREAD_MBOX_SIZE -#define TCPIP_THREAD_PRIO RT_LWIP_TCPTHREAD_PRIORITY -#define TCPIP_THREAD_STACKSIZE RT_LWIP_TCPTHREAD_STACKSIZE -#else -#define TCPIP_MBOX_SIZE 8 -#define TCPIP_THREAD_PRIO 128 -#define TCPIP_THREAD_STACKSIZE 4096 -#endif -#define TCPIP_THREAD_NAME "tcpip" -#define DEFAULT_TCP_RECVMBOX_SIZE 10 - -/* ---------- ARP options ---------- */ -#define LWIP_ARP 1 -#define ARP_TABLE_SIZE 10 -#define ARP_QUEUEING 1 - -/* ---------- Checksum options ---------- */ -#ifdef RT_LWIP_USING_HW_CHECKSUM -#define CHECKSUM_GEN_IP 0 -#define CHECKSUM_GEN_UDP 0 -#define CHECKSUM_GEN_TCP 0 -#define CHECKSUM_GEN_ICMP 0 -#define CHECKSUM_CHECK_IP 0 -#define CHECKSUM_CHECK_UDP 0 -#define CHECKSUM_CHECK_TCP 0 -#define CHECKSUM_CHECK_ICMP 0 -#endif - -/* ---------- IP options ---------- */ -/* Define IP_FORWARD to 1 if you wish to have the ability to forward - IP packets across network interfaces. If you are going to run lwIP - on a device with only one network interface, define this to 0. */ -#define IP_FORWARD 0 - -/* IP reassembly and segmentation.These are orthogonal even - * if they both deal with IP fragments */ -#ifdef RT_LWIP_REASSEMBLY_FRAG -#define IP_REASSEMBLY 1 -#define IP_FRAG 1 -#define IP_REASS_MAX_PBUFS 10 -#define MEMP_NUM_REASSDATA 10 -#else -#define IP_REASSEMBLY 0 -#define IP_FRAG 0 -#endif - -/* ---------- ICMP options ---------- */ -#define ICMP_TTL 255 - -/* ---------- DHCP options ---------- */ -/* Define LWIP_DHCP to 1 if you want DHCP configuration of - interfaces. */ -#ifdef RT_LWIP_DHCP -#define LWIP_DHCP 1 -#else -#define LWIP_DHCP 0 -#endif - -/* 1 if you want to do an ARP check on the offered address - (recommended). */ -#define DHCP_DOES_ARP_CHECK (LWIP_DHCP) - -/* ---------- AUTOIP options ------- */ -#define LWIP_AUTOIP 0 -#define LWIP_DHCP_AUTOIP_COOP (LWIP_DHCP && LWIP_AUTOIP) - -/* ---------- UDP options ---------- */ -#ifdef RT_LWIP_UDP -#define LWIP_UDP 1 -#else -#define LWIP_UDP 0 -#endif - -#define LWIP_UDPLITE 0 -#define UDP_TTL 255 -#define DEFAULT_UDP_RECVMBOX_SIZE 1 - -/* ---------- RAW options ---------- */ -#ifdef RT_LWIP_RAW -#define LWIP_RAW 1 -#else -#define LWIP_RAW 0 -#endif - -#define DEFAULT_RAW_RECVMBOX_SIZE 1 -#define DEFAULT_ACCEPTMBOX_SIZE 10 - -/* ---------- Statistics options ---------- */ -#ifdef RT_LWIP_STATS -#define LWIP_STATS 1 -#define LWIP_STATS_DISPLAY 1 -#else -#define LWIP_STATS 0 -#endif - -#if LWIP_STATS -#define LINK_STATS 1 -#define IP_STATS 1 -#define ICMP_STATS 1 -#define IGMP_STATS 1 -#define IPFRAG_STATS 1 -#define UDP_STATS 1 -#define TCP_STATS 1 -#define MEM_STATS 1 -#define MEMP_STATS 1 -#define PBUF_STATS 1 -#define SYS_STATS 1 -#define MIB2_STATS 1 -#endif /* LWIP_STATS */ - -/* ---------- PPP options ---------- */ -#ifdef RT_LWIP_PPP -#define PPP_SUPPORT 1 /* Set > 0 for PPP */ -#else -#define PPP_SUPPORT 0 /* Set > 0 for PPP */ -#endif - -#if PPP_SUPPORT -#define NUM_PPP 1 /* Max PPP sessions. */ - -/* Select modules to enable. Ideally these would be set in the makefile but - * we're limited by the command line length so you need to modify the settings - * in this file. - */ -#ifdef RT_LWIP_PPPOE -#define PPPOE_SUPPORT 1 -#else -#define PPPOE_SUPPORT 0 -#endif - -#ifdef RT_LWIP_PPPOS -#define PPPOS_SUPPORT 1 -#else -#define PPPOS_SUPPORT 0 -#endif - -#define PAP_SUPPORT 1 /* Set > 0 for PAP. */ -#define CHAP_SUPPORT 1 /* Set > 0 for CHAP. */ -#define MSCHAP_SUPPORT 0 /* Set > 0 for MSCHAP (NOT FUNCTIONAL!) */ -#define CBCP_SUPPORT 0 /* Set > 0 for CBCP (NOT FUNCTIONAL!) */ -#define CCP_SUPPORT 0 /* Set > 0 for CCP (NOT FUNCTIONAL!) */ -#define VJ_SUPPORT 1 /* Set > 0 for VJ header compression. */ -#define MD5_SUPPORT 1 /* Set > 0 for MD5 (see also CHAP) */ - -#endif /* PPP_SUPPORT */ - -/** - * LWIP_POSIX_SOCKETS_IO_NAMES==1: Enable POSIX-style sockets functions names. - * Disable this option if you use a POSIX operating system that uses the same - * names (read, write & close). (only used if you use sockets.c) - */ -#ifndef LWIP_POSIX_SOCKETS_IO_NAMES -#define LWIP_POSIX_SOCKETS_IO_NAMES 0 -#endif - -/** - * LWIP_TCP_KEEPALIVE==1: Enable TCP_KEEPIDLE, TCP_KEEPINTVL and TCP_KEEPCNT - * options processing. Note that TCP_KEEPIDLE and TCP_KEEPINTVL have to be set - * in seconds. (does not require sockets.c, and will affect tcp.c) - */ -#ifndef LWIP_TCP_KEEPALIVE -#define LWIP_TCP_KEEPALIVE 1 -#endif - -/** - * LWIP_NETIF_HOSTNAME==1: Support netif hostname - */ -#ifndef LWIP_NETIF_HOSTNAME -#define LWIP_NETIF_HOSTNAME 1 -#endif - -/** - * LWIP_NETIF_API==1: Support netif api (in netifapi.c) - */ -#ifndef LWIP_NETIF_API -#define LWIP_NETIF_API 1 -#endif - -#ifdef LWIP_IGMP -#include -#define LWIP_RAND rand -#endif -/* - ------------------------------------ - ---------- Socket options ---------- - ------------------------------------ -*/ -/* - * LWIP_SOCKET==1: Enable Socket API (require to use sockets.c) - */ -#ifndef LWIP_SOCKET -#define LWIP_SOCKET 1 -#endif -#include -#include - -/* - * LWIP_COMPAT_SOCKETS==1: Enable BSD-style sockets functions names. - * (only used if you use sockets.c) - */ -#ifdef SAL_USING_POSIX -#define LWIP_COMPAT_SOCKETS 0 -#else -#ifndef LWIP_COMPAT_SOCKETS -#define LWIP_COMPAT_SOCKETS 1 -#endif -#endif - -/** - * LWIP_SO_SNDTIMEO==1: Enable send timeout for sockets/netconns and - * SO_SNDTIMEO processing. - */ -#ifndef LWIP_SO_SNDTIMEO -#define LWIP_SO_SNDTIMEO 1 -#endif - -/** - * LWIP_SO_RCVTIMEO==1: Enable receive timeout for sockets/netconns and - * SO_RCVTIMEO processing. - */ -#ifndef LWIP_SO_RCVTIMEO -#define LWIP_SO_RCVTIMEO 1 -#endif - -/** - * LWIP_SO_RCVBUF==1: Enable SO_RCVBUF processing. - */ -#ifndef LWIP_SO_RCVBUF -#define LWIP_SO_RCVBUF 1 -#endif - -/** - * If LWIP_SO_RCVBUF is used, this is the default value for recv_bufsize. - */ -#ifndef RECV_BUFSIZE_DEFAULT -#define RECV_BUFSIZE_DEFAULT 8192 -#endif - -/** - * SO_REUSE==1: Enable SO_REUSEADDR option. - */ -#ifndef SO_REUSE -#define SO_REUSE 0 -#endif - -/* - ------------------------------------ - ------- Applications options ------- - ------------------------------------ -*/ - -/** - * Max. length of TFTP filename - */ -#ifdef RT_LWIP_TFTP_MAX_FILENAME_LEN -#define TFTP_MAX_FILENAME_LEN RT_LWIP_TFTP_MAX_FILENAME_LEN -#elif defined(RT_DFS_ELM_MAX_LFN) -#define TFTP_MAX_FILENAME_LEN RT_DFS_ELM_MAX_LFN -#else -#define TFTP_MAX_FILENAME_LEN 64 -#endif - - -#endif /* __LWIPOPTS_H__ */ diff --git a/components/net/lwip/lwip-2.1.2/SConscript b/components/net/lwip/lwip-2.1.2/SConscript index 4c5fba2054..7cce1451cf 100644 --- a/components/net/lwip/lwip-2.1.2/SConscript +++ b/components/net/lwip/lwip-2.1.2/SConscript @@ -234,8 +234,7 @@ src += lwipsixlowpan_SRCS src += lwipcore4_SRCS -path = [cwd + '/src', - cwd + '/src/include', +path = [cwd + '/src/include', cwd + '/src/include/netif'] if not GetDepend('RT_USING_SAL'): diff --git a/components/net/lwip/lwip-2.1.2/src/lwippools.h b/components/net/lwip/lwip-2.1.2/src/lwippools.h deleted file mode 100644 index 6583863de3..0000000000 --- a/components/net/lwip/lwip-2.1.2/src/lwippools.h +++ /dev/null @@ -1,10 +0,0 @@ -#if 1 - LWIP_MALLOC_MEMPOOL_START - LWIP_MALLOC_MEMPOOL((unsigned char)128, 256) - LWIP_MALLOC_MEMPOOL((unsigned char)128, 512) - LWIP_MALLOC_MEMPOOL((unsigned char)128, 1024) - LWIP_MALLOC_MEMPOOL((unsigned char)128, 1514) - LWIP_MALLOC_MEMPOOL((unsigned char)128, 1536) - LWIP_MALLOC_MEMPOOL((unsigned char)128, 4096) - LWIP_MALLOC_MEMPOOL_END -#endif diff --git a/components/net/lwip/port/arch/cc.h b/components/net/lwip/port/arch/cc.h index d62c97df54..e79ead4027 100644 --- a/components/net/lwip/port/arch/cc.h +++ b/components/net/lwip/port/arch/cc.h @@ -56,7 +56,7 @@ #endif /* ARCH_CPU_BIG_ENDIAN */ #endif /* BYTE_ORDER */ -#ifdef RT_USING_LWIP141 +#if RT_USING_LWIP_VER_NUM < 0x20000 #include typedef uint8_t u8_t; typedef int8_t s8_t; @@ -72,20 +72,7 @@ typedef uintptr_t mem_ptr_t; #define U32_F "lu" #define S32_F "ld" #define X32_F "lx" -#endif /* RT_USING_LWIP141 */ - -#include -/* some errno not defined in newlib */ -#ifndef ENSRNOTFOUND -#define ENSRNOTFOUND 163 /* Domain name not found */ -/* WARNING: ESHUTDOWN also not defined in newlib. We chose - 180 here because the number "108" which is used - in arch.h has been assigned to another error code. */ -#endif - -/* LWIP_TIMEVAL_PRIVATE: provided by */ -#include -#define LWIP_TIMEVAL_PRIVATE 0 +#endif /* RT_USING_LWIP_VER_NUM < 0x20000 */ #if defined(__CC_ARM) /* ARMCC compiler */ #define PACK_STRUCT_FIELD(x) x @@ -119,8 +106,4 @@ void sys_arch_assert(const char* file, int line); #define LWIP_PLATFORM_DIAG(x) do {rt_kprintf x;} while(0) #define LWIP_PLATFORM_ASSERT(x) do {rt_kprintf(x); sys_arch_assert(__FILE__, __LINE__);}while(0) -#define SYS_ARCH_DECL_PROTECT(level) register rt_base_t level -#define SYS_ARCH_PROTECT(level) do {level = rt_hw_interrupt_disable();} while(0) -#define SYS_ARCH_UNPROTECT(level) do {rt_hw_interrupt_enable(level);} while(0) - #endif /* __ARCH_CC_H__ */ diff --git a/components/net/lwip/lwip-2.1.2/src/lwipopts.h b/components/net/lwip/port/lwipopts.h similarity index 91% rename from components/net/lwip/lwip-2.1.2/src/lwipopts.h rename to components/net/lwip/port/lwipopts.h index 701449c108..8c6c9cfcc2 100644 --- a/components/net/lwip/lwip-2.1.2/src/lwipopts.h +++ b/components/net/lwip/port/lwipopts.h @@ -1,12 +1,50 @@ +/* + * Copyright (c) 2006-2022, RT-Thread Development Team + * + * SPDX-License-Identifier: Apache-2.0 + * + * Change Logs: + * Date Author Notes + * 2022-02-23 Meco Man integrate v1.4.1 v2.0.3 and v2.1.2 porting layer + * 2022-02-25 xiangxistu modify the default config through v1.4.1 + */ + #ifndef __LWIPOPTS_H__ #define __LWIPOPTS_H__ #include -#define LWIP_ERRNO_STDINCLUDE -#define LWIP_SOCKET_SELECT 1 -#define LWIP_SOCKET_POLL 1 +/* ---------- LIBC and standard header files ---------- */ +#include +#include +#include +#include +#include +#include +#define LWIP_ERRNO_INCLUDE "sys/errno.h" +#define LWIP_TIMEVAL_PRIVATE 0 +#define LWIP_NO_UNISTD_H 0 +#define LWIP_NO_STDDEF_H 0 +#define LWIP_NO_STDINT_H 0 +#define LWIP_NO_INTTYPES_H 0 +#define LWIP_NO_LIMITS_H 0 +#define LWIP_NO_CTYPE_H 0 +#define LWIP_SOCKET_SELECT 1 +#define LWIP_SOCKET_POLL 1 + +#define LWIP_RAND rand + +#ifndef SSIZE_MAX +#define SSIZE_MAX INT_MAX +#endif + +/* some errno not defined in newlib */ +#ifndef ENSRNOTFOUND +#define ENSRNOTFOUND 163 /* Domain name not found */ +#endif + +/* ---------- Basic Configuration ---------- */ #define LWIP_IPV4 1 #ifdef RT_USING_LWIP_IPV6 @@ -16,6 +54,7 @@ #endif /* RT_USING_LWIP_IPV6 */ #define NO_SYS 0 +#define SYS_LIGHTWEIGHT_PROT 1 #define LWIP_SOCKET 1 #define LWIP_NETCONN 1 @@ -227,19 +266,19 @@ #define LWIP_DBG_TYPES_ON (LWIP_DBG_ON|LWIP_DBG_TRACE|LWIP_DBG_STATE|LWIP_DBG_FRESH|LWIP_DBG_HALT) -# ifndef __STRICT_ANSI__ -# define SSIZE_MAX LONG_MAX -# endif - -#define LWIP_NO_UNISTD_H 0 - /* ---------- Memory options ---------- */ #define MEMCPY(dst,src,len) rt_memcpy(dst,src,len) #define SMEMCPY(dst,src,len) MEMCPY(dst,src,len) +#ifdef RT_LWIP_MEM_ALIGNMENT +#define MEM_ALIGNMENT RT_LWIP_MEM_ALIGNMENT +#else #define MEM_ALIGNMENT 4 +#endif + #define MEMP_OVERFLOW_CHECK 1 #define LWIP_ALLOW_MEM_FREE_FROM_OTHER_CONTEXT 1 + //#define MEM_LIBC_MALLOC 1 //#define MEM_USE_POOLS 1 //#define MEMP_USE_CUSTOM_POOLS 1 @@ -313,13 +352,6 @@ #define ETH_PAD_SIZE RT_LWIP_ETH_PAD_SIZE #endif -/** SYS_LIGHTWEIGHT_PROT - * define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection - * for certain critical regions during buffer allocation, deallocation and memory - * allocation and deallocation. - */ -#define SYS_LIGHTWEIGHT_PROT (NO_SYS==0) - #ifdef LWIP_USING_NAT #define IP_NAT 1 #else @@ -552,23 +584,8 @@ #define LWIP_NETIF_API 1 #endif -#ifdef LWIP_IGMP -#include -#define LWIP_RAND rand -#endif -/* - ------------------------------------ - ---------- Socket options ---------- - ------------------------------------ -*/ -/* - * LWIP_SOCKET==1: Enable Socket API (require to use sockets.c) - */ -#ifndef LWIP_SOCKET -#define LWIP_SOCKET 1 -#endif -#include -#include +/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active timeouts. */ +#define MEMP_NUM_SYS_TIMEOUT (LWIP_TCP + IP_REASSEMBLY + LWIP_ARP + (2*LWIP_DHCP) + LWIP_AUTOIP + LWIP_IGMP + LWIP_DNS + PPP_SUPPORT) /* * LWIP_COMPAT_SOCKETS==1: Enable BSD-style sockets functions names. @@ -619,26 +636,10 @@ #define SO_REUSE 0 #endif -/* - ------------------------------------ - ------- Applications options ------- - ------------------------------------ -*/ - -/** - * Max. length of TFTP filename - */ -#ifdef RT_LWIP_TFTP_MAX_FILENAME_LEN -#define TFTP_MAX_FILENAME_LEN RT_LWIP_TFTP_MAX_FILENAME_LEN -#elif defined(RT_DFS_ELM_MAX_LFN) -#define TFTP_MAX_FILENAME_LEN RT_DFS_ELM_MAX_LFN -#else -#define TFTP_MAX_FILENAME_LEN 64 -#endif - - +#if RT_USING_LWIP_VER_NUM >= 0x20000 /* >= v2.0.0 */ #define LWIP_HOOK_IP4_ROUTE_SRC(dest, src) lwip_ip4_route_src(dest, src) #include "lwip/ip_addr.h" struct netif *lwip_ip4_route_src(const ip4_addr_t *dest, const ip4_addr_t *src); +#endif /* RT_USING_LWIP_VER_NUM >= 0x20000 */ #endif /* __LWIPOPTS_H__ */ diff --git a/components/net/lwip/lwip-2.0.3/src/lwippools.h b/components/net/lwip/port/lwippools.h similarity index 100% rename from components/net/lwip/lwip-2.0.3/src/lwippools.h rename to components/net/lwip/port/lwippools.h diff --git a/components/net/lwip/port/netif/ethernetif.h b/components/net/lwip/port/netif/ethernetif.h index 53e34b6d25..64501de67c 100644 --- a/components/net/lwip/port/netif/ethernetif.h +++ b/components/net/lwip/port/netif/ethernetif.h @@ -5,7 +5,7 @@ * * Change Logs: * Date Author Notes - * 2022-02-22 liuxianliang integrate v1.4.1 v2.0.3 and v2.1.2 porting layer + * 2022-02-22 xiangxistu integrate v1.4.1 v2.0.3 and v2.1.2 porting layer */ #ifndef __NETIF_ETHERNETIF_H__ diff --git a/components/net/lwip/port/sys_arch.c b/components/net/lwip/port/sys_arch.c index 6cd23586c9..72d3663a68 100644 --- a/components/net/lwip/port/sys_arch.c +++ b/components/net/lwip/port/sys_arch.c @@ -527,7 +527,6 @@ u32_t sys_now(void) return rt_tick_get_millisecond(); } -#if LWIP_VERSION_MAJOR >= 2U /* >= v2.x */ RT_WEAK void mem_init(void) { } @@ -553,7 +552,6 @@ void mem_free(void *mem) { rt_free(mem); } -#endif /* LWIP_VERSION_MAJOR >= 2U */ #ifdef RT_LWIP_PPP u32_t sio_read(sio_fd_t fd, u8_t *buf, u32_t size) @@ -593,7 +591,7 @@ void ppp_trace(int level, const char *format, ...) } #endif /* RT_LWIP_PPP */ -#if (LWIP_VERSION_MAJOR * 100 + LWIP_VERSION_MINOR) >= 201 /* >= v2.1.0 */ +#if LWIP_VERSION_MAJOR >= 2 /* >= v2.x */ #if MEM_OVERFLOW_CHECK || MEMP_OVERFLOW_CHECK /** * Check if a mep element was victim of an overflow or underflow @@ -633,8 +631,8 @@ void mem_overflow_check_raw(void *p, size_t size, const char *descr1, const char #endif /* MEM_SANITY_REGION_BEFORE_ALIGNED > 0 */ #else LWIP_UNUSED_ARG(p); - LWIP_UNUSED_ARG(desc); - LWIP_UNUSED_ARG(descr); + LWIP_UNUSED_ARG(descr1); + LWIP_UNUSED_ARG(descr2); #endif /* MEM_SANITY_REGION_AFTER_ALIGNED || MEM_SANITY_REGION_BEFORE_ALIGNED */ } @@ -655,7 +653,7 @@ void mem_overflow_init_raw(void *p, size_t size) #endif #else /* MEM_SANITY_REGION_BEFORE_ALIGNED > 0 || MEM_SANITY_REGION_AFTER_ALIGNED > 0 */ LWIP_UNUSED_ARG(p); - LWIP_UNUSED_ARG(desc); + LWIP_UNUSED_ARG(size); #endif /* MEM_SANITY_REGION_BEFORE_ALIGNED > 0 || MEM_SANITY_REGION_AFTER_ALIGNED > 0 */ } #endif /* MEM_OVERFLOW_CHECK || MEMP_OVERFLOW_CHECK */ @@ -685,7 +683,7 @@ struct netif *lwip_ip4_route_src(const ip4_addr_t *dest, const ip4_addr_t *src) return netif; } #endif /* LWIP_HOOK_IP4_ROUTE_SRC */ -#endif /* (LWIP_VERSION_MAJOR * 100 + LWIP_VERSION_MINOR) >= 201 */ +#endif /*LWIP_VERSION_MAJOR >= 2 */ #if LWIP_SOCKET #include