hattori&ide

Dependencies:   mbed

Committer:
hattori_atsushi
Date:
Sun Dec 18 08:16:01 2022 +0000
Revision:
0:f77369cabd75
hattori

Who changed what in which revision?

UserRevisionLine numberNew contents of line
hattori_atsushi 0:f77369cabd75 1 /*
hattori_atsushi 0:f77369cabd75 2 * Copyright (c) 2001-2003 Swedish Institute of Computer Science.
hattori_atsushi 0:f77369cabd75 3 * All rights reserved.
hattori_atsushi 0:f77369cabd75 4 *
hattori_atsushi 0:f77369cabd75 5 * Redistribution and use in source and binary forms, with or without modification,
hattori_atsushi 0:f77369cabd75 6 * are permitted provided that the following conditions are met:
hattori_atsushi 0:f77369cabd75 7 *
hattori_atsushi 0:f77369cabd75 8 * 1. Redistributions of source code must retain the above copyright notice,
hattori_atsushi 0:f77369cabd75 9 * this list of conditions and the following disclaimer.
hattori_atsushi 0:f77369cabd75 10 * 2. Redistributions in binary form must reproduce the above copyright notice,
hattori_atsushi 0:f77369cabd75 11 * this list of conditions and the following disclaimer in the documentation
hattori_atsushi 0:f77369cabd75 12 * and/or other materials provided with the distribution.
hattori_atsushi 0:f77369cabd75 13 * 3. The name of the author may not be used to endorse or promote products
hattori_atsushi 0:f77369cabd75 14 * derived from this software without specific prior written permission.
hattori_atsushi 0:f77369cabd75 15 *
hattori_atsushi 0:f77369cabd75 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
hattori_atsushi 0:f77369cabd75 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
hattori_atsushi 0:f77369cabd75 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
hattori_atsushi 0:f77369cabd75 19 * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
hattori_atsushi 0:f77369cabd75 20 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
hattori_atsushi 0:f77369cabd75 21 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
hattori_atsushi 0:f77369cabd75 22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
hattori_atsushi 0:f77369cabd75 23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
hattori_atsushi 0:f77369cabd75 24 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
hattori_atsushi 0:f77369cabd75 25 * OF SUCH DAMAGE.
hattori_atsushi 0:f77369cabd75 26 *
hattori_atsushi 0:f77369cabd75 27 * This file is part of the lwIP TCP/IP stack.
hattori_atsushi 0:f77369cabd75 28 *
hattori_atsushi 0:f77369cabd75 29 * Author: Adam Dunkels <adam@sics.se>
hattori_atsushi 0:f77369cabd75 30 *
hattori_atsushi 0:f77369cabd75 31 */
hattori_atsushi 0:f77369cabd75 32 #ifndef __LWIPOPTS_H__
hattori_atsushi 0:f77369cabd75 33 #define __LWIPOPTS_H__
hattori_atsushi 0:f77369cabd75 34
hattori_atsushi 0:f77369cabd75 35 #include "netCfg.h"
hattori_atsushi 0:f77369cabd75 36 #if NET_LWIP_STACK
hattori_atsushi 0:f77369cabd75 37
hattori_atsushi 0:f77369cabd75 38 //#include "arch/sys_arch.h"
hattori_atsushi 0:f77369cabd75 39
hattori_atsushi 0:f77369cabd75 40 /* <sys/time.h> is included in cc.h! */
hattori_atsushi 0:f77369cabd75 41 #define LWIP_TIMEVAL_PRIVATE 0
hattori_atsushi 0:f77369cabd75 42
hattori_atsushi 0:f77369cabd75 43 //#define __LWIP_DEBUG
hattori_atsushi 0:f77369cabd75 44 #include "dbg/dbg.h"
hattori_atsushi 0:f77369cabd75 45
hattori_atsushi 0:f77369cabd75 46 #ifdef __LWIP_DEBUG
hattori_atsushi 0:f77369cabd75 47
hattori_atsushi 0:f77369cabd75 48 #define LWIP_DEBUG 1
hattori_atsushi 0:f77369cabd75 49
hattori_atsushi 0:f77369cabd75 50 #define LWIP_DBG_MIN_LEVEL 0
hattori_atsushi 0:f77369cabd75 51 //#define LWIP_COMPAT_SOCKETS 1
hattori_atsushi 0:f77369cabd75 52 #define TAPIF_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 53 #define TUNIF_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 54 #define UNIXIF_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 55 #define DELIF_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 56 #define SIO_FIFO_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 57 #define TCPDUMP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 58
hattori_atsushi 0:f77369cabd75 59 #define PPP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 60 #define MEM_DEBUG LWIP_DBG_ON
hattori_atsushi 0:f77369cabd75 61 #define MEMP_DEBUG LWIP_DBG_ON
hattori_atsushi 0:f77369cabd75 62 #define PBUF_DEBUG LWIP_DBG_ON
hattori_atsushi 0:f77369cabd75 63 #define API_LIB_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 64 #define API_MSG_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 65 #define TCPIP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 66 #define NETIF_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 67 #define SOCKETS_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 68 #define DEMO_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 69 #define IP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 70 #define IP_REASS_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 71 #define RAW_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 72 #define ICMP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 73 #define UDP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 74 #define TCP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 75 #define TCP_INPUT_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 76 #define TCP_OUTPUT_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 77 #define TCP_RTO_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 78 #define TCP_CWND_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 79 #define TCP_WND_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 80 #define TCP_FR_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 81 #define TCP_QLEN_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 82 #define TCP_RST_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 83 #define ETHARP_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 84 #define DNS_DEBUG LWIP_DBG_OFF
hattori_atsushi 0:f77369cabd75 85
hattori_atsushi 0:f77369cabd75 86 #endif
hattori_atsushi 0:f77369cabd75 87
hattori_atsushi 0:f77369cabd75 88 /*
hattori_atsushi 0:f77369cabd75 89 extern unsigned char debug_flags;
hattori_atsushi 0:f77369cabd75 90 #define LWIP_DBG_TYPES_ON debug_flags
hattori_atsushi 0:f77369cabd75 91 */
hattori_atsushi 0:f77369cabd75 92 #define NO_SYS 1
hattori_atsushi 0:f77369cabd75 93 #define LWIP_SOCKET (NO_SYS==0)
hattori_atsushi 0:f77369cabd75 94 #define LWIP_NETCONN (NO_SYS==0)
hattori_atsushi 0:f77369cabd75 95
hattori_atsushi 0:f77369cabd75 96
hattori_atsushi 0:f77369cabd75 97 #define IP_FRAG_USES_STATIC_BUF 0
hattori_atsushi 0:f77369cabd75 98
hattori_atsushi 0:f77369cabd75 99
hattori_atsushi 0:f77369cabd75 100
hattori_atsushi 0:f77369cabd75 101 /* ---------- Memory options ---------- */
hattori_atsushi 0:f77369cabd75 102 /* MEM_ALIGNMENT: should be set to the alignment of the CPU for which
hattori_atsushi 0:f77369cabd75 103 lwIP is compiled. 4 byte alignment -> define MEM_ALIGNMENT to 4, 2
hattori_atsushi 0:f77369cabd75 104 byte alignment -> define MEM_ALIGNMENT to 2. */
hattori_atsushi 0:f77369cabd75 105 /* MSVC port: intel processors don't need 4-byte alignment,
hattori_atsushi 0:f77369cabd75 106 but are faster that way! */
hattori_atsushi 0:f77369cabd75 107 #define MEM_ALIGNMENT 4
hattori_atsushi 0:f77369cabd75 108
hattori_atsushi 0:f77369cabd75 109 /* MEM_SIZE: the size of the heap memory. If the application will send
hattori_atsushi 0:f77369cabd75 110 a lot of data that needs to be copied, this should be set high. */
hattori_atsushi 0:f77369cabd75 111 //#define MEM_SIZE 10240
hattori_atsushi 0:f77369cabd75 112
hattori_atsushi 0:f77369cabd75 113 #if TARGET_LPC1768
hattori_atsushi 0:f77369cabd75 114
hattori_atsushi 0:f77369cabd75 115
hattori_atsushi 0:f77369cabd75 116 #define MEM_SIZE 4000
hattori_atsushi 0:f77369cabd75 117
hattori_atsushi 0:f77369cabd75 118 ///
hattori_atsushi 0:f77369cabd75 119
hattori_atsushi 0:f77369cabd75 120 #define MEM_POSITION __attribute((section("AHBSRAM0")))
hattori_atsushi 0:f77369cabd75 121
hattori_atsushi 0:f77369cabd75 122 /* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application
hattori_atsushi 0:f77369cabd75 123 sends a lot of data out of ROM (or other static memory), this
hattori_atsushi 0:f77369cabd75 124 should be set high. */
hattori_atsushi 0:f77369cabd75 125 #define MEMP_NUM_PBUF 16
hattori_atsushi 0:f77369cabd75 126 /* MEMP_NUM_RAW_PCB: the number of UDP protocol control blocks. One
hattori_atsushi 0:f77369cabd75 127 per active RAW "connection". */
hattori_atsushi 0:f77369cabd75 128 //#define MEMP_NUM_RAW_PCB 3
hattori_atsushi 0:f77369cabd75 129 /* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
hattori_atsushi 0:f77369cabd75 130 per active UDP "connection". */
hattori_atsushi 0:f77369cabd75 131 #define MEMP_NUM_UDP_PCB 2
hattori_atsushi 0:f77369cabd75 132 /* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP
hattori_atsushi 0:f77369cabd75 133 connections. */
hattori_atsushi 0:f77369cabd75 134 #define MEMP_NUM_TCP_PCB 2
hattori_atsushi 0:f77369cabd75 135 /* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
hattori_atsushi 0:f77369cabd75 136 connections. */
hattori_atsushi 0:f77369cabd75 137 #define MEMP_NUM_TCP_PCB_LISTEN 2//4
hattori_atsushi 0:f77369cabd75 138 /* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
hattori_atsushi 0:f77369cabd75 139 segments. */
hattori_atsushi 0:f77369cabd75 140 #define MEMP_NUM_TCP_SEG 16
hattori_atsushi 0:f77369cabd75 141 /* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active
hattori_atsushi 0:f77369cabd75 142 timeouts. */
hattori_atsushi 0:f77369cabd75 143 #define MEMP_NUM_SYS_TIMEOUT 12
hattori_atsushi 0:f77369cabd75 144
hattori_atsushi 0:f77369cabd75 145 /* The following four are used only with the sequential API and can be
hattori_atsushi 0:f77369cabd75 146 set to 0 if the application only will use the raw API. */
hattori_atsushi 0:f77369cabd75 147 /* MEMP_NUM_NETBUF: the number of struct netbufs. */
hattori_atsushi 0:f77369cabd75 148 #define MEMP_NUM_NETBUF 0
hattori_atsushi 0:f77369cabd75 149 /* MEMP_NUM_NETCONN: the number of struct netconns. */
hattori_atsushi 0:f77369cabd75 150 #define MEMP_NUM_NETCONN 0
hattori_atsushi 0:f77369cabd75 151 /* MEMP_NUM_TCPIP_MSG_*: the number of struct tcpip_msg, which is used
hattori_atsushi 0:f77369cabd75 152 for sequential API communication and incoming packets. Used in
hattori_atsushi 0:f77369cabd75 153 src/api/tcpip.c. */
hattori_atsushi 0:f77369cabd75 154 #define MEMP_NUM_TCPIP_MSG_API 0
hattori_atsushi 0:f77369cabd75 155 #define MEMP_NUM_TCPIP_MSG_INPKT 0
hattori_atsushi 0:f77369cabd75 156
hattori_atsushi 0:f77369cabd75 157 /* ---------- Pbuf options ---------- */
hattori_atsushi 0:f77369cabd75 158 /* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
hattori_atsushi 0:f77369cabd75 159 #define PBUF_POOL_SIZE 8//100
hattori_atsushi 0:f77369cabd75 160
hattori_atsushi 0:f77369cabd75 161 /* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
hattori_atsushi 0:f77369cabd75 162 #define PBUF_POOL_BUFSIZE 128
hattori_atsushi 0:f77369cabd75 163
hattori_atsushi 0:f77369cabd75 164 /* PBUF_LINK_HLEN: the number of bytes that should be allocated for a
hattori_atsushi 0:f77369cabd75 165 link level header. */
hattori_atsushi 0:f77369cabd75 166 //#define PBUF_LINK_HLEN 16
hattori_atsushi 0:f77369cabd75 167
hattori_atsushi 0:f77369cabd75 168 /** SYS_LIGHTWEIGHT_PROT
hattori_atsushi 0:f77369cabd75 169 * define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection
hattori_atsushi 0:f77369cabd75 170 * for certain critical regions during buffer allocation, deallocation and memory
hattori_atsushi 0:f77369cabd75 171 * allocation and deallocation.
hattori_atsushi 0:f77369cabd75 172 */
hattori_atsushi 0:f77369cabd75 173 #define SYS_LIGHTWEIGHT_PROT 0 //No sys here
hattori_atsushi 0:f77369cabd75 174
hattori_atsushi 0:f77369cabd75 175 /* ---------- TCP options ---------- */
hattori_atsushi 0:f77369cabd75 176 #define LWIP_TCP 1
hattori_atsushi 0:f77369cabd75 177 #define TCP_TTL 255
hattori_atsushi 0:f77369cabd75 178
hattori_atsushi 0:f77369cabd75 179 /* Controls if TCP should queue segments that arrive out of
hattori_atsushi 0:f77369cabd75 180 order. Define to 0 if your device is low on memory. */
hattori_atsushi 0:f77369cabd75 181 #define TCP_QUEUE_OOSEQ 0
hattori_atsushi 0:f77369cabd75 182
hattori_atsushi 0:f77369cabd75 183 /* TCP Maximum segment size. */
hattori_atsushi 0:f77369cabd75 184 //#define TCP_MSS 1024
hattori_atsushi 0:f77369cabd75 185 #define TCP_MSS 0x276//536//0x276
hattori_atsushi 0:f77369cabd75 186
hattori_atsushi 0:f77369cabd75 187 /* TCP sender buffer space (bytes). */
hattori_atsushi 0:f77369cabd75 188 #define TCP_SND_BUF 2048
hattori_atsushi 0:f77369cabd75 189
hattori_atsushi 0:f77369cabd75 190 /* TCP sender buffer space (pbufs). This must be at least = 2 *
hattori_atsushi 0:f77369cabd75 191 TCP_SND_BUF/TCP_MSS for things to work. */
hattori_atsushi 0:f77369cabd75 192 #define TCP_SND_QUEUELEN (2 * TCP_SND_BUF/TCP_MSS)
hattori_atsushi 0:f77369cabd75 193
hattori_atsushi 0:f77369cabd75 194 /* TCP writable space (bytes). This must be less than or equal
hattori_atsushi 0:f77369cabd75 195 to TCP_SND_BUF. It is the amount of space which must be
hattori_atsushi 0:f77369cabd75 196 available in the tcp snd_buf for select to return writable */
hattori_atsushi 0:f77369cabd75 197 #define TCP_SNDLOWAT (TCP_SND_BUF/2)
hattori_atsushi 0:f77369cabd75 198
hattori_atsushi 0:f77369cabd75 199 /* TCP receive window. */
hattori_atsushi 0:f77369cabd75 200 #define TCP_WND 2048 //8096
hattori_atsushi 0:f77369cabd75 201
hattori_atsushi 0:f77369cabd75 202 /* Maximum number of retransmissions of data segments. */
hattori_atsushi 0:f77369cabd75 203 //#define TCP_MAXRTX 12
hattori_atsushi 0:f77369cabd75 204
hattori_atsushi 0:f77369cabd75 205 /* Maximum number of retransmissions of SYN segments. */
hattori_atsushi 0:f77369cabd75 206 //#define TCP_SYNMAXRTX 4
hattori_atsushi 0:f77369cabd75 207
hattori_atsushi 0:f77369cabd75 208 #elif TARGET_LPC2368
hattori_atsushi 0:f77369cabd75 209
hattori_atsushi 0:f77369cabd75 210 #define MEM_POSITION __attribute((section("AHBSRAM1")))
hattori_atsushi 0:f77369cabd75 211
hattori_atsushi 0:f77369cabd75 212 /* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application
hattori_atsushi 0:f77369cabd75 213 sends a lot of data out of ROM (or other static memory), this
hattori_atsushi 0:f77369cabd75 214 should be set high. */
hattori_atsushi 0:f77369cabd75 215 #define MEMP_NUM_PBUF 8
hattori_atsushi 0:f77369cabd75 216 /* MEMP_NUM_RAW_PCB: the number of UDP protocol control blocks. One
hattori_atsushi 0:f77369cabd75 217 per active RAW "connection". */
hattori_atsushi 0:f77369cabd75 218 //#define MEMP_NUM_RAW_PCB 3
hattori_atsushi 0:f77369cabd75 219 /* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
hattori_atsushi 0:f77369cabd75 220 per active UDP "connection". */
hattori_atsushi 0:f77369cabd75 221 #define MEMP_NUM_UDP_PCB 2
hattori_atsushi 0:f77369cabd75 222 /* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP
hattori_atsushi 0:f77369cabd75 223 connections. */
hattori_atsushi 0:f77369cabd75 224 #define MEMP_NUM_TCP_PCB 2
hattori_atsushi 0:f77369cabd75 225 /* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
hattori_atsushi 0:f77369cabd75 226 connections. */
hattori_atsushi 0:f77369cabd75 227 #define MEMP_NUM_TCP_PCB_LISTEN 2//4
hattori_atsushi 0:f77369cabd75 228 /* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
hattori_atsushi 0:f77369cabd75 229 segments. */
hattori_atsushi 0:f77369cabd75 230 #define MEMP_NUM_TCP_SEG 8
hattori_atsushi 0:f77369cabd75 231 /* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active
hattori_atsushi 0:f77369cabd75 232 timeouts. */
hattori_atsushi 0:f77369cabd75 233 #define MEMP_NUM_SYS_TIMEOUT 12
hattori_atsushi 0:f77369cabd75 234
hattori_atsushi 0:f77369cabd75 235 /* The following four are used only with the sequential API and can be
hattori_atsushi 0:f77369cabd75 236 set to 0 if the application only will use the raw API. */
hattori_atsushi 0:f77369cabd75 237 /* MEMP_NUM_NETBUF: the number of struct netbufs. */
hattori_atsushi 0:f77369cabd75 238 #define MEMP_NUM_NETBUF 0
hattori_atsushi 0:f77369cabd75 239 /* MEMP_NUM_NETCONN: the number of struct netconns. */
hattori_atsushi 0:f77369cabd75 240 #define MEMP_NUM_NETCONN 0
hattori_atsushi 0:f77369cabd75 241 /* MEMP_NUM_TCPIP_MSG_*: the number of struct tcpip_msg, which is used
hattori_atsushi 0:f77369cabd75 242 for sequential API communication and incoming packets. Used in
hattori_atsushi 0:f77369cabd75 243 src/api/tcpip.c. */
hattori_atsushi 0:f77369cabd75 244 #define MEMP_NUM_TCPIP_MSG_API 0
hattori_atsushi 0:f77369cabd75 245 #define MEMP_NUM_TCPIP_MSG_INPKT 0
hattori_atsushi 0:f77369cabd75 246
hattori_atsushi 0:f77369cabd75 247 /* ---------- Pbuf options ---------- */
hattori_atsushi 0:f77369cabd75 248 /* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
hattori_atsushi 0:f77369cabd75 249 #define PBUF_POOL_SIZE 8//16//100
hattori_atsushi 0:f77369cabd75 250
hattori_atsushi 0:f77369cabd75 251 /* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
hattori_atsushi 0:f77369cabd75 252 //#define PBUF_POOL_BUFSIZE 128
hattori_atsushi 0:f77369cabd75 253
hattori_atsushi 0:f77369cabd75 254 /* PBUF_LINK_HLEN: the number of bytes that should be allocated for a
hattori_atsushi 0:f77369cabd75 255 link level header. */
hattori_atsushi 0:f77369cabd75 256 //#define PBUF_LINK_HLEN 16
hattori_atsushi 0:f77369cabd75 257
hattori_atsushi 0:f77369cabd75 258 /** SYS_LIGHTWEIGHT_PROT
hattori_atsushi 0:f77369cabd75 259 * define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection
hattori_atsushi 0:f77369cabd75 260 * for certain critical regions during buffer allocation, deallocation and memory
hattori_atsushi 0:f77369cabd75 261 * allocation and deallocation.
hattori_atsushi 0:f77369cabd75 262 */
hattori_atsushi 0:f77369cabd75 263 #define SYS_LIGHTWEIGHT_PROT 0 //No sys here
hattori_atsushi 0:f77369cabd75 264
hattori_atsushi 0:f77369cabd75 265 /* ---------- TCP options ---------- */
hattori_atsushi 0:f77369cabd75 266 #define LWIP_TCP 1
hattori_atsushi 0:f77369cabd75 267 #define TCP_TTL 255
hattori_atsushi 0:f77369cabd75 268
hattori_atsushi 0:f77369cabd75 269 /* Controls if TCP should queue segments that arrive out of
hattori_atsushi 0:f77369cabd75 270 order. Define to 0 if your device is low on memory. */
hattori_atsushi 0:f77369cabd75 271 #define TCP_QUEUE_OOSEQ 0
hattori_atsushi 0:f77369cabd75 272
hattori_atsushi 0:f77369cabd75 273 /* TCP Maximum segment size. */
hattori_atsushi 0:f77369cabd75 274 //#define TCP_MSS 1024
hattori_atsushi 0:f77369cabd75 275 #define TCP_MSS 512//0x276//536//0x276
hattori_atsushi 0:f77369cabd75 276
hattori_atsushi 0:f77369cabd75 277 /* TCP sender buffer space (bytes). */
hattori_atsushi 0:f77369cabd75 278 #define TCP_SND_BUF 1024//2048
hattori_atsushi 0:f77369cabd75 279
hattori_atsushi 0:f77369cabd75 280 /* TCP sender buffer space (pbufs). This must be at least = 2 *
hattori_atsushi 0:f77369cabd75 281 TCP_SND_BUF/TCP_MSS for things to work. */
hattori_atsushi 0:f77369cabd75 282 #define TCP_SND_QUEUELEN (4 * TCP_SND_BUF/TCP_MSS)//(4 * TCP_SND_BUF/TCP_MSS)
hattori_atsushi 0:f77369cabd75 283
hattori_atsushi 0:f77369cabd75 284 /* TCP writable space (bytes). This must be less than or equal
hattori_atsushi 0:f77369cabd75 285 to TCP_SND_BUF. It is the amount of space which must be
hattori_atsushi 0:f77369cabd75 286 available in the tcp snd_buf for select to return writable */
hattori_atsushi 0:f77369cabd75 287 #define TCP_SNDLOWAT (TCP_SND_BUF/2)
hattori_atsushi 0:f77369cabd75 288
hattori_atsushi 0:f77369cabd75 289 /* TCP receive window. */
hattori_atsushi 0:f77369cabd75 290 #define TCP_WND 512 //8096
hattori_atsushi 0:f77369cabd75 291
hattori_atsushi 0:f77369cabd75 292 /* Maximum number of retransmissions of data segments. */
hattori_atsushi 0:f77369cabd75 293 //#define TCP_MAXRTX 12
hattori_atsushi 0:f77369cabd75 294
hattori_atsushi 0:f77369cabd75 295 /* Maximum number of retransmissions of SYN segments. */
hattori_atsushi 0:f77369cabd75 296 //#define TCP_SYNMAXRTX 4
hattori_atsushi 0:f77369cabd75 297
hattori_atsushi 0:f77369cabd75 298 #endif
hattori_atsushi 0:f77369cabd75 299
hattori_atsushi 0:f77369cabd75 300 /* ---------- ARP options ---------- */
hattori_atsushi 0:f77369cabd75 301 #define LWIP_ARP (NET_ETH | NET_ZG2100)
hattori_atsushi 0:f77369cabd75 302 #define ARP_TABLE_SIZE 2//4//10
hattori_atsushi 0:f77369cabd75 303 #define ARP_QUEUEING 0//1
hattori_atsushi 0:f77369cabd75 304 #define ETHARP_TRUST_IP_MAC 1
hattori_atsushi 0:f77369cabd75 305
hattori_atsushi 0:f77369cabd75 306 /* ---------- IP options ---------- */
hattori_atsushi 0:f77369cabd75 307 /* Define IP_FORWARD to 1 if you wish to have the ability to forward
hattori_atsushi 0:f77369cabd75 308 IP packets across network interfaces. If you are going to run lwIP
hattori_atsushi 0:f77369cabd75 309 on a device with only one network interface, define this to 0. */
hattori_atsushi 0:f77369cabd75 310 #define IP_FORWARD 0
hattori_atsushi 0:f77369cabd75 311
hattori_atsushi 0:f77369cabd75 312
hattori_atsushi 0:f77369cabd75 313 /* IP reassembly and segmentation.These are orthogonal even
hattori_atsushi 0:f77369cabd75 314 * if they both deal with IP fragments */
hattori_atsushi 0:f77369cabd75 315 /*
hattori_atsushi 0:f77369cabd75 316 #define IP_REASSEMBLY 1
hattori_atsushi 0:f77369cabd75 317 #define IP_REASS_MAX_PBUFS 10
hattori_atsushi 0:f77369cabd75 318 #define MEMP_NUM_REASSDATA 10
hattori_atsushi 0:f77369cabd75 319 #define IP_FRAG 1
hattori_atsushi 0:f77369cabd75 320 */
hattori_atsushi 0:f77369cabd75 321 /* ---------- ICMP options ---------- */
hattori_atsushi 0:f77369cabd75 322 #define ICMP_TTL 255
hattori_atsushi 0:f77369cabd75 323
hattori_atsushi 0:f77369cabd75 324 /* ---------- DHCP options ---------- */
hattori_atsushi 0:f77369cabd75 325 /* Define LWIP_DHCP to 1 if you want DHCP configuration of
hattori_atsushi 0:f77369cabd75 326 interfaces. */
hattori_atsushi 0:f77369cabd75 327 #define LWIP_DHCP (NET_ETH | NET_ZG2100)
hattori_atsushi 0:f77369cabd75 328
hattori_atsushi 0:f77369cabd75 329 /* 1 if you want to do an ARP check on the offered address
hattori_atsushi 0:f77369cabd75 330 (recommended if using DHCP). */
hattori_atsushi 0:f77369cabd75 331 #define DHCP_DOES_ARP_CHECK (LWIP_DHCP)
hattori_atsushi 0:f77369cabd75 332
hattori_atsushi 0:f77369cabd75 333 /* ---------- AUTOIP options ------- */
hattori_atsushi 0:f77369cabd75 334 #define LWIP_AUTOIP 0
hattori_atsushi 0:f77369cabd75 335
hattori_atsushi 0:f77369cabd75 336 /* ---------- SNMP options ---------- */
hattori_atsushi 0:f77369cabd75 337 /** @todo SNMP is experimental for now
hattori_atsushi 0:f77369cabd75 338 @note UDP must be available for SNMP transport */
hattori_atsushi 0:f77369cabd75 339 #ifndef LWIP_SNMP
hattori_atsushi 0:f77369cabd75 340 #define LWIP_SNMP 0
hattori_atsushi 0:f77369cabd75 341 #endif
hattori_atsushi 0:f77369cabd75 342
hattori_atsushi 0:f77369cabd75 343
hattori_atsushi 0:f77369cabd75 344 #ifndef SNMP_PRIVATE_MIB
hattori_atsushi 0:f77369cabd75 345 #define SNMP_PRIVATE_MIB 0
hattori_atsushi 0:f77369cabd75 346 #endif
hattori_atsushi 0:f77369cabd75 347
hattori_atsushi 0:f77369cabd75 348
hattori_atsushi 0:f77369cabd75 349 /* ---------- UDP options ---------- */
hattori_atsushi 0:f77369cabd75 350 #define LWIP_UDP 1
hattori_atsushi 0:f77369cabd75 351 #define UDP_TTL 255
hattori_atsushi 0:f77369cabd75 352
hattori_atsushi 0:f77369cabd75 353 /* ---------- DNS options ---------- */
hattori_atsushi 0:f77369cabd75 354 #define LWIP_DNS 1
hattori_atsushi 0:f77369cabd75 355
hattori_atsushi 0:f77369cabd75 356 /* ---------- RAW options ---------- */
hattori_atsushi 0:f77369cabd75 357 #define LWIP_RAW 0
hattori_atsushi 0:f77369cabd75 358 #define RAW_TTL 255
hattori_atsushi 0:f77369cabd75 359
hattori_atsushi 0:f77369cabd75 360 /* ---------- Statistics options ---------- */
hattori_atsushi 0:f77369cabd75 361 /* individual STATS options can be turned off by defining them to 0
hattori_atsushi 0:f77369cabd75 362 * (e.g #define TCP_STATS 0). All of them are turned off if LWIP_STATS
hattori_atsushi 0:f77369cabd75 363 * is 0
hattori_atsushi 0:f77369cabd75 364 * */
hattori_atsushi 0:f77369cabd75 365
hattori_atsushi 0:f77369cabd75 366 #define LWIP_STATS 0
hattori_atsushi 0:f77369cabd75 367
hattori_atsushi 0:f77369cabd75 368 /* ---------- PPP options ---------- */
hattori_atsushi 0:f77369cabd75 369
hattori_atsushi 0:f77369cabd75 370 #define PPP_SUPPORT NET_PPP /* Set > 0 for PPP */
hattori_atsushi 0:f77369cabd75 371
hattori_atsushi 0:f77369cabd75 372 #if PPP_SUPPORT > 0
hattori_atsushi 0:f77369cabd75 373
hattori_atsushi 0:f77369cabd75 374 #define NUM_PPP 1 /* Max PPP sessions. */
hattori_atsushi 0:f77369cabd75 375
hattori_atsushi 0:f77369cabd75 376
hattori_atsushi 0:f77369cabd75 377 /* Select modules to enable. Ideally these would be set in the makefile but
hattori_atsushi 0:f77369cabd75 378 * we're limited by the command line length so you need to modify the settings
hattori_atsushi 0:f77369cabd75 379 * in this file.
hattori_atsushi 0:f77369cabd75 380 */
hattori_atsushi 0:f77369cabd75 381 #define PAP_SUPPORT 1 /* Set > 0 for PAP. */
hattori_atsushi 0:f77369cabd75 382 #define CHAP_SUPPORT 1 /* Set > 0 for CHAP. */
hattori_atsushi 0:f77369cabd75 383 #define MSCHAP_SUPPORT 0 /* Set > 0 for MSCHAP (NOT FUNCTIONAL!) */
hattori_atsushi 0:f77369cabd75 384 #define CBCP_SUPPORT 0 /* Set > 0 for CBCP (NOT FUNCTIONAL!) */
hattori_atsushi 0:f77369cabd75 385 #define CCP_SUPPORT 0 /* Set > 0 for CCP (NOT FUNCTIONAL!) */
hattori_atsushi 0:f77369cabd75 386 #define VJ_SUPPORT 1 /* Set > 0 for VJ header compression. */
hattori_atsushi 0:f77369cabd75 387 #define MD5_SUPPORT 1 /* Set > 0 for MD5 (see also CHAP) */
hattori_atsushi 0:f77369cabd75 388
hattori_atsushi 0:f77369cabd75 389
hattori_atsushi 0:f77369cabd75 390 /*
hattori_atsushi 0:f77369cabd75 391 * Timeouts.
hattori_atsushi 0:f77369cabd75 392 */
hattori_atsushi 0:f77369cabd75 393 #define FSM_DEFTIMEOUT 6 /* Timeout time in seconds */
hattori_atsushi 0:f77369cabd75 394 #define FSM_DEFMAXTERMREQS 2 /* Maximum Terminate-Request transmissions */
hattori_atsushi 0:f77369cabd75 395 #define FSM_DEFMAXCONFREQS 10 /* Maximum Configure-Request transmissions */
hattori_atsushi 0:f77369cabd75 396 #define FSM_DEFMAXNAKLOOPS 5 /* Maximum number of nak loops */
hattori_atsushi 0:f77369cabd75 397
hattori_atsushi 0:f77369cabd75 398 #define UPAP_DEFTIMEOUT 6 /* Timeout (seconds) for retransmitting req */
hattori_atsushi 0:f77369cabd75 399 #define UPAP_DEFREQTIME 30 /* Time to wait for auth-req from peer */
hattori_atsushi 0:f77369cabd75 400
hattori_atsushi 0:f77369cabd75 401 #define CHAP_DEFTIMEOUT 6 /* Timeout time in seconds */
hattori_atsushi 0:f77369cabd75 402 #define CHAP_DEFTRANSMITS 10 /* max # times to send challenge */
hattori_atsushi 0:f77369cabd75 403
hattori_atsushi 0:f77369cabd75 404
hattori_atsushi 0:f77369cabd75 405 /* Interval in seconds between keepalive echo requests, 0 to disable. */
hattori_atsushi 0:f77369cabd75 406 #if 1
hattori_atsushi 0:f77369cabd75 407 #define LCP_ECHOINTERVAL 0
hattori_atsushi 0:f77369cabd75 408 #else
hattori_atsushi 0:f77369cabd75 409
hattori_atsushi 0:f77369cabd75 410 #define LCP_ECHOINTERVAL 10
hattori_atsushi 0:f77369cabd75 411 #endif
hattori_atsushi 0:f77369cabd75 412
hattori_atsushi 0:f77369cabd75 413
hattori_atsushi 0:f77369cabd75 414 /* Number of unanswered echo requests before failure. */
hattori_atsushi 0:f77369cabd75 415 #define LCP_MAXECHOFAILS 3
hattori_atsushi 0:f77369cabd75 416
hattori_atsushi 0:f77369cabd75 417 /* Max Xmit idle time (in jiffies) before resend flag char. */
hattori_atsushi 0:f77369cabd75 418 #define PPP_MAXIDLEFLAG 0//Send it every time//100
hattori_atsushi 0:f77369cabd75 419
hattori_atsushi 0:f77369cabd75 420 /*
hattori_atsushi 0:f77369cabd75 421 * Packet sizes
hattori_atsushi 0:f77369cabd75 422 *
hattori_atsushi 0:f77369cabd75 423 * Note - lcp shouldn't be allowed to negotiate stuff outside these
hattori_atsushi 0:f77369cabd75 424 * limits. See lcp.h in the pppd directory.
hattori_atsushi 0:f77369cabd75 425 * (XXX - these constants should simply be shared by lcp.c instead
hattori_atsushi 0:f77369cabd75 426 * of living in lcp.h)
hattori_atsushi 0:f77369cabd75 427 */
hattori_atsushi 0:f77369cabd75 428 #define PPP_MTU 1500 /* Default MTU (size of Info field) */
hattori_atsushi 0:f77369cabd75 429 #if 0
hattori_atsushi 0:f77369cabd75 430 #define PPP_MAXMTU 65535 - (PPP_HDRLEN + PPP_FCSLEN)
hattori_atsushi 0:f77369cabd75 431 #else
hattori_atsushi 0:f77369cabd75 432
hattori_atsushi 0:f77369cabd75 433 #define PPP_MAXMTU 1500 /* Largest MTU we allow */
hattori_atsushi 0:f77369cabd75 434 #endif
hattori_atsushi 0:f77369cabd75 435
hattori_atsushi 0:f77369cabd75 436 #define PPP_MINMTU 64
hattori_atsushi 0:f77369cabd75 437 #define PPP_MRU 1500 /* default MRU = max length of info field */
hattori_atsushi 0:f77369cabd75 438 #define PPP_MAXMRU 1500 /* Largest MRU we allow */
hattori_atsushi 0:f77369cabd75 439 #define PPP_DEFMRU 296 /* Try for this */
hattori_atsushi 0:f77369cabd75 440 #define PPP_MINMRU 128 /* No MRUs below this */
hattori_atsushi 0:f77369cabd75 441
hattori_atsushi 0:f77369cabd75 442
hattori_atsushi 0:f77369cabd75 443 #define MAXNAMELEN 64 /* max length of hostname or name for auth */
hattori_atsushi 0:f77369cabd75 444 #define MAXSECRETLEN 64 /* max length of password or secret */
hattori_atsushi 0:f77369cabd75 445
hattori_atsushi 0:f77369cabd75 446 #endif /* PPP_SUPPORT > 0 */
hattori_atsushi 0:f77369cabd75 447
hattori_atsushi 0:f77369cabd75 448 //C++ Compat
hattori_atsushi 0:f77369cabd75 449 #define try vTry
hattori_atsushi 0:f77369cabd75 450
hattori_atsushi 0:f77369cabd75 451 #endif
hattori_atsushi 0:f77369cabd75 452
hattori_atsushi 0:f77369cabd75 453
hattori_atsushi 0:f77369cabd75 454 #endif /* __LWIPOPTS_H__ */