258 lines
9.1 KiB
C
258 lines
9.1 KiB
C
/**
|
|
******************************************************************************
|
|
* @file lwipopts.h
|
|
* This file is based on \src\include\lwip\opt.h
|
|
******************************************************************************
|
|
* Copyright (c) 2013 - 2014, Freescale Semiconductor, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
* are permitted provided that the following conditions are met:
|
|
*
|
|
* o Redistributions of source code must retain the above copyright notice, this list
|
|
* of conditions and the following disclaimer.
|
|
*
|
|
* o Redistributions in binary form must reproduce the above copyright notice, this
|
|
* list of conditions and the following disclaimer in the documentation and/or
|
|
* other materials provided with the distribution.
|
|
*
|
|
* o Neither the name of Freescale Semiconductor, Inc. nor the names of its
|
|
* contributors may be used to endorse or promote products derived from this
|
|
* software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
|
|
#ifndef __LWIPOPTS_H__
|
|
#define __LWIPOPTS_H__
|
|
/*include fsl os abstraction header file to judge whether OS is used*/
|
|
|
|
/**
|
|
* SYS_LIGHTWEIGHT_PROT==1: if you want inter-task protection for certain
|
|
* critical regions during buffer allocation, deallocation and memory
|
|
* allocation and deallocation.
|
|
*/
|
|
#define SYS_LIGHTWEIGHT_PROT 0
|
|
#if USE_RTOS
|
|
|
|
/**
|
|
* NO_SYS==0: Use RTOS
|
|
*/
|
|
#define NO_SYS 0
|
|
/**
|
|
* LWIP_NETCONN==1: Enable Netconn API (require to use api_lib.c)
|
|
*/
|
|
#define LWIP_NETCONN 1
|
|
/**
|
|
* LWIP_SOCKET==1: Enable Socket API (require to use sockets.c)
|
|
*/
|
|
#define LWIP_SOCKET 1
|
|
#define LWIP_COMPAT_MUTEX 1
|
|
#define LWIP_SO_RCVTIMEO 1
|
|
|
|
#else
|
|
/**
|
|
* NO_SYS==1: Bare metal lwIP
|
|
*/
|
|
#define NO_SYS 1
|
|
/**
|
|
* LWIP_NETCONN==0: Disable Netconn API (require to use api_lib.c)
|
|
*/
|
|
#define LWIP_NETCONN 0
|
|
/**
|
|
* LWIP_SOCKET==0: Disable Socket API (require to use sockets.c)
|
|
*/
|
|
#define LWIP_SOCKET 0
|
|
|
|
#endif
|
|
/* ---------- Memory options ---------- */
|
|
/**
|
|
* MEM_ALIGNMENT: should be set to the alignment of the CPU
|
|
* 4 byte alignment -> #define MEM_ALIGNMENT 4
|
|
* 2 byte alignment -> #define MEM_ALIGNMENT 2
|
|
*/
|
|
|
|
#define MEM_ALIGNMENT 4
|
|
|
|
/**
|
|
* MEM_SIZE: the size of the heap memory. If the application will send
|
|
* a lot of data that needs to be copied, this should be set high.
|
|
*/
|
|
|
|
#define MEM_SIZE (1*1024)
|
|
|
|
/* 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 10
|
|
//#define MEMP_NUM_PBUF 25//gkl
|
|
|
|
|
|
/* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
|
|
per active UDP "connection". */
|
|
#define MEMP_NUM_UDP_PCB 6
|
|
/* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP
|
|
connections. */
|
|
#define MEMP_NUM_TCP_PCB 10
|
|
/* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
|
|
connections. */
|
|
#define MEMP_NUM_TCP_PCB_LISTEN 6
|
|
/* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
|
|
segments. */
|
|
#define MEMP_NUM_TCP_SEG 16
|
|
/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active
|
|
timeouts. */
|
|
#define MEMP_NUM_SYS_TIMEOUT 10
|
|
|
|
/* ---------- Pbuf options ---------- */
|
|
/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
|
|
#define PBUF_POOL_SIZE 10
|
|
//#define PBUF_POOL_SIZE 25//gkl
|
|
|
|
|
|
|
|
/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
|
|
#define PBUF_POOL_BUFSIZE 1518
|
|
|
|
|
|
/* ---------- TCP options ---------- */
|
|
#define LWIP_TCP 1
|
|
#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 0
|
|
|
|
/* TCP Maximum segment size. */
|
|
#define TCP_MSS (1500 - 40) /* TCP_MSS = (Ethernet MTU - IP header size - TCP header size) */
|
|
|
|
/* TCP sender buffer space (bytes). */
|
|
#define TCP_SND_BUF (2*TCP_MSS)
|
|
|
|
/* TCP sender buffer space (pbufs). This must be at least = 2 *
|
|
TCP_SND_BUF/TCP_MSS for things to work. */
|
|
#define TCP_SND_QUEUELEN (6 * TCP_SND_BUF)/TCP_MSS
|
|
|
|
/* TCP receive window. */
|
|
#define TCP_WND (2*TCP_MSS)
|
|
|
|
|
|
/* ---------- ICMP options ---------- */
|
|
#define LWIP_ICMP 1
|
|
|
|
|
|
/* ---------- DHCP options ---------- */
|
|
/* Define LWIP_DHCP to 1 if you want DHCP configuration of
|
|
interfaces. DHCP is not implemented in lwIP 0.5.1, however, so
|
|
turning this on does currently not work. */
|
|
#define LWIP_DHCP 0
|
|
|
|
|
|
/* ---------- UDP options ---------- */
|
|
#define LWIP_UDP 1
|
|
#define UDP_TTL 255
|
|
|
|
|
|
/* ---------- Statistics options ---------- */
|
|
#define LWIP_STATS 0
|
|
#define LWIP_PROVIDE_ERRNO 1
|
|
|
|
|
|
/*
|
|
--------------------------------------
|
|
---------- Checksum options ----------
|
|
--------------------------------------
|
|
*/
|
|
|
|
/*
|
|
Some MCU allow computing and verifying the IP, UDP, TCP and ICMP checksums by hardware:
|
|
- To use this feature let the following define uncommented.
|
|
- To disable it and process by CPU comment the the checksum.
|
|
*/
|
|
//#define CHECKSUM_BY_HARDWARE
|
|
|
|
|
|
#ifdef CHECKSUM_BY_HARDWARE
|
|
/* CHECKSUM_GEN_IP==0: Generate checksums by hardware for outgoing IP packets.*/
|
|
#define CHECKSUM_GEN_IP 0
|
|
/* CHECKSUM_GEN_UDP==0: Generate checksums by hardware for outgoing UDP packets.*/
|
|
#define CHECKSUM_GEN_UDP 0
|
|
/* CHECKSUM_GEN_TCP==0: Generate checksums by hardware for outgoing TCP packets.*/
|
|
#define CHECKSUM_GEN_TCP 0
|
|
/* CHECKSUM_CHECK_IP==0: Check checksums by hardware for incoming IP packets.*/
|
|
#define CHECKSUM_CHECK_IP 0
|
|
/* CHECKSUM_CHECK_UDP==0: Check checksums by hardware for incoming UDP packets.*/
|
|
#define CHECKSUM_CHECK_UDP 0
|
|
/* CHECKSUM_CHECK_TCP==0: Check checksums by hardware for incoming TCP packets.*/
|
|
#define CHECKSUM_CHECK_TCP 0
|
|
#else
|
|
/* CHECKSUM_GEN_IP==1: Generate checksums in software for outgoing IP packets.*/
|
|
#define CHECKSUM_GEN_IP 1
|
|
/* CHECKSUM_GEN_UDP==1: Generate checksums in software for outgoing UDP packets.*/
|
|
#define CHECKSUM_GEN_UDP 1
|
|
/* CHECKSUM_GEN_TCP==1: Generate checksums in software for outgoing TCP packets.*/
|
|
#define CHECKSUM_GEN_TCP 1
|
|
/* CHECKSUM_CHECK_IP==1: Check checksums in software for incoming IP packets.*/
|
|
#define CHECKSUM_CHECK_IP 1
|
|
/* CHECKSUM_CHECK_UDP==1: Check checksums in software for incoming UDP packets.*/
|
|
#define CHECKSUM_CHECK_UDP 1
|
|
/* CHECKSUM_CHECK_TCP==1: Check checksums in software for incoming TCP packets.*/
|
|
#define CHECKSUM_CHECK_TCP 1
|
|
#endif
|
|
|
|
/*
|
|
------------------------------------
|
|
---------- Debugging options ----------
|
|
------------------------------------
|
|
*/
|
|
|
|
#define LWIP_DEBUG
|
|
//#define ICMP_DEBUG LWIP_DBG_ON
|
|
//#define UDP_DEBUG LWIP_DBG_ON
|
|
|
|
#define TCPIP_MBOX_SIZE 32
|
|
//#define TCPIP_THREAD_STACKSIZE 1024
|
|
//#define TCPIP_THREAD_PRIO 1
|
|
|
|
/**
|
|
* DEFAULT_RAW_RECVMBOX_SIZE: The mailbox size for the incoming packets on a
|
|
* NETCONN_RAW. The queue size value itself is platform-dependent, but is passed
|
|
* to sys_mbox_new() when the recvmbox is created.
|
|
*/
|
|
#define DEFAULT_RAW_RECVMBOX_SIZE 12
|
|
|
|
/**
|
|
* DEFAULT_UDP_RECVMBOX_SIZE: The mailbox size for the incoming packets on a
|
|
* NETCONN_UDP. The queue size value itself is platform-dependent, but is passed
|
|
* to sys_mbox_new() when the recvmbox is created.
|
|
*/
|
|
#define DEFAULT_UDP_RECVMBOX_SIZE 12
|
|
|
|
/**
|
|
* DEFAULT_TCP_RECVMBOX_SIZE: The mailbox size for the incoming packets on a
|
|
* NETCONN_TCP. The queue size value itself is platform-dependent, but is passed
|
|
* to sys_mbox_new() when the recvmbox is created.
|
|
*/
|
|
#define DEFAULT_TCP_RECVMBOX_SIZE 12
|
|
|
|
/**
|
|
* DEFAULT_ACCEPTMBOX_SIZE: The mailbox size for the incoming connections.
|
|
* The queue size value itself is platform-dependent, but is passed to
|
|
* sys_mbox_new() when the acceptmbox is created.
|
|
*/
|
|
#define DEFAULT_ACCEPTMBOX_SIZE 12
|
|
|
|
#endif /* __LWIPOPTS_H__ */
|
|
|
|
/******************* (C) COPYRIGHT 2009 STMicroelectronics *****END OF FILE****/
|