1*10465441SEvalZero /* 2*10465441SEvalZero * Copyright (c) 2001-2004 Swedish Institute of Computer Science. 3*10465441SEvalZero * All rights reserved. 4*10465441SEvalZero * 5*10465441SEvalZero * Redistribution and use in source and binary forms, with or without modification, 6*10465441SEvalZero * are permitted provided that the following conditions are met: 7*10465441SEvalZero * 8*10465441SEvalZero * 1. Redistributions of source code must retain the above copyright notice, 9*10465441SEvalZero * this list of conditions and the following disclaimer. 10*10465441SEvalZero * 2. Redistributions in binary form must reproduce the above copyright notice, 11*10465441SEvalZero * this list of conditions and the following disclaimer in the documentation 12*10465441SEvalZero * and/or other materials provided with the distribution. 13*10465441SEvalZero * 3. The name of the author may not be used to endorse or promote products 14*10465441SEvalZero * derived from this software without specific prior written permission. 15*10465441SEvalZero * 16*10465441SEvalZero * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 17*10465441SEvalZero * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 18*10465441SEvalZero * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 19*10465441SEvalZero * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 20*10465441SEvalZero * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 21*10465441SEvalZero * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22*10465441SEvalZero * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23*10465441SEvalZero * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 24*10465441SEvalZero * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 25*10465441SEvalZero * OF SUCH DAMAGE. 26*10465441SEvalZero * 27*10465441SEvalZero * This file is part of the lwIP TCP/IP stack. 28*10465441SEvalZero * 29*10465441SEvalZero * Author: Adam Dunkels <[email protected]> 30*10465441SEvalZero * 31*10465441SEvalZero */ 32*10465441SEvalZero #ifndef __LWIP_TCPIP_H__ 33*10465441SEvalZero #define __LWIP_TCPIP_H__ 34*10465441SEvalZero 35*10465441SEvalZero #include "lwip/opt.h" 36*10465441SEvalZero 37*10465441SEvalZero #if !NO_SYS /* don't build if not configured for use in lwipopts.h */ 38*10465441SEvalZero 39*10465441SEvalZero #include "lwip/api_msg.h" 40*10465441SEvalZero #include "lwip/netifapi.h" 41*10465441SEvalZero #include "lwip/pbuf.h" 42*10465441SEvalZero #include "lwip/api.h" 43*10465441SEvalZero #include "lwip/sys.h" 44*10465441SEvalZero #include "lwip/timers.h" 45*10465441SEvalZero #include "lwip/netif.h" 46*10465441SEvalZero 47*10465441SEvalZero #ifdef __cplusplus 48*10465441SEvalZero extern "C" { 49*10465441SEvalZero #endif 50*10465441SEvalZero 51*10465441SEvalZero /** Define this to something that triggers a watchdog. This is called from 52*10465441SEvalZero * tcpip_thread after processing a message. */ 53*10465441SEvalZero #ifndef LWIP_TCPIP_THREAD_ALIVE 54*10465441SEvalZero #define LWIP_TCPIP_THREAD_ALIVE() 55*10465441SEvalZero #endif 56*10465441SEvalZero 57*10465441SEvalZero #if LWIP_TCPIP_CORE_LOCKING 58*10465441SEvalZero /** The global semaphore to lock the stack. */ 59*10465441SEvalZero extern sys_mutex_t lock_tcpip_core; 60*10465441SEvalZero #define LOCK_TCPIP_CORE() sys_mutex_lock(&lock_tcpip_core) 61*10465441SEvalZero #define UNLOCK_TCPIP_CORE() sys_mutex_unlock(&lock_tcpip_core) 62*10465441SEvalZero #define TCPIP_APIMSG(m) tcpip_apimsg_lock(m) 63*10465441SEvalZero #define TCPIP_APIMSG_ACK(m) 64*10465441SEvalZero #define TCPIP_NETIFAPI(m) tcpip_netifapi_lock(m) 65*10465441SEvalZero #define TCPIP_NETIFAPI_ACK(m) 66*10465441SEvalZero #else /* LWIP_TCPIP_CORE_LOCKING */ 67*10465441SEvalZero #define LOCK_TCPIP_CORE() 68*10465441SEvalZero #define UNLOCK_TCPIP_CORE() 69*10465441SEvalZero #define TCPIP_APIMSG(m) tcpip_apimsg(m) 70*10465441SEvalZero #define TCPIP_APIMSG_ACK(m) sys_sem_signal(&m->conn->op_completed) 71*10465441SEvalZero #define TCPIP_NETIFAPI(m) tcpip_netifapi(m) 72*10465441SEvalZero #define TCPIP_NETIFAPI_ACK(m) sys_sem_signal(&m->sem) 73*10465441SEvalZero #endif /* LWIP_TCPIP_CORE_LOCKING */ 74*10465441SEvalZero 75*10465441SEvalZero /** Function prototype for the init_done function passed to tcpip_init */ 76*10465441SEvalZero typedef void (*tcpip_init_done_fn)(void *arg); 77*10465441SEvalZero /** Function prototype for functions passed to tcpip_callback() */ 78*10465441SEvalZero typedef void (*tcpip_callback_fn)(void *ctx); 79*10465441SEvalZero 80*10465441SEvalZero /* Forward declarations */ 81*10465441SEvalZero struct tcpip_callback_msg; 82*10465441SEvalZero 83*10465441SEvalZero void tcpip_init(tcpip_init_done_fn tcpip_init_done, void *arg); 84*10465441SEvalZero 85*10465441SEvalZero #if LWIP_NETCONN 86*10465441SEvalZero err_t tcpip_apimsg(struct api_msg *apimsg); 87*10465441SEvalZero #if LWIP_TCPIP_CORE_LOCKING 88*10465441SEvalZero err_t tcpip_apimsg_lock(struct api_msg *apimsg); 89*10465441SEvalZero #endif /* LWIP_TCPIP_CORE_LOCKING */ 90*10465441SEvalZero #endif /* LWIP_NETCONN */ 91*10465441SEvalZero 92*10465441SEvalZero err_t tcpip_input(struct pbuf *p, struct netif *inp); 93*10465441SEvalZero 94*10465441SEvalZero #if LWIP_NETIF_API 95*10465441SEvalZero err_t tcpip_netifapi(struct netifapi_msg *netifapimsg); 96*10465441SEvalZero #if LWIP_TCPIP_CORE_LOCKING 97*10465441SEvalZero err_t tcpip_netifapi_lock(struct netifapi_msg *netifapimsg); 98*10465441SEvalZero #endif /* LWIP_TCPIP_CORE_LOCKING */ 99*10465441SEvalZero #endif /* LWIP_NETIF_API */ 100*10465441SEvalZero 101*10465441SEvalZero err_t tcpip_callback_with_block(tcpip_callback_fn function, void *ctx, u8_t block); 102*10465441SEvalZero #define tcpip_callback(f, ctx) tcpip_callback_with_block(f, ctx, 1) 103*10465441SEvalZero 104*10465441SEvalZero struct tcpip_callback_msg* tcpip_callbackmsg_new(tcpip_callback_fn function, void *ctx); 105*10465441SEvalZero void tcpip_callbackmsg_delete(struct tcpip_callback_msg* msg); 106*10465441SEvalZero err_t tcpip_trycallback(struct tcpip_callback_msg* msg); 107*10465441SEvalZero 108*10465441SEvalZero /* free pbufs or heap memory from another context without blocking */ 109*10465441SEvalZero err_t pbuf_free_callback(struct pbuf *p); 110*10465441SEvalZero err_t mem_free_callback(void *m); 111*10465441SEvalZero 112*10465441SEvalZero #if LWIP_TCPIP_TIMEOUT 113*10465441SEvalZero err_t tcpip_timeout(u32_t msecs, sys_timeout_handler h, void *arg); 114*10465441SEvalZero err_t tcpip_untimeout(sys_timeout_handler h, void *arg); 115*10465441SEvalZero #endif /* LWIP_TCPIP_TIMEOUT */ 116*10465441SEvalZero 117*10465441SEvalZero enum tcpip_msg_type { 118*10465441SEvalZero #if LWIP_NETCONN 119*10465441SEvalZero TCPIP_MSG_API, 120*10465441SEvalZero #endif /* LWIP_NETCONN */ 121*10465441SEvalZero TCPIP_MSG_INPKT, 122*10465441SEvalZero #if LWIP_NETIF_API 123*10465441SEvalZero TCPIP_MSG_NETIFAPI, 124*10465441SEvalZero #endif /* LWIP_NETIF_API */ 125*10465441SEvalZero #if LWIP_TCPIP_TIMEOUT 126*10465441SEvalZero TCPIP_MSG_TIMEOUT, 127*10465441SEvalZero TCPIP_MSG_UNTIMEOUT, 128*10465441SEvalZero #endif /* LWIP_TCPIP_TIMEOUT */ 129*10465441SEvalZero TCPIP_MSG_CALLBACK, 130*10465441SEvalZero TCPIP_MSG_CALLBACK_STATIC 131*10465441SEvalZero }; 132*10465441SEvalZero 133*10465441SEvalZero struct tcpip_msg { 134*10465441SEvalZero enum tcpip_msg_type type; 135*10465441SEvalZero sys_sem_t *sem; 136*10465441SEvalZero union { 137*10465441SEvalZero #if LWIP_NETCONN 138*10465441SEvalZero struct api_msg *apimsg; 139*10465441SEvalZero #endif /* LWIP_NETCONN */ 140*10465441SEvalZero #if LWIP_NETIF_API 141*10465441SEvalZero struct netifapi_msg *netifapimsg; 142*10465441SEvalZero #endif /* LWIP_NETIF_API */ 143*10465441SEvalZero struct { 144*10465441SEvalZero struct pbuf *p; 145*10465441SEvalZero struct netif *netif; 146*10465441SEvalZero } inp; 147*10465441SEvalZero struct { 148*10465441SEvalZero tcpip_callback_fn function; 149*10465441SEvalZero void *ctx; 150*10465441SEvalZero } cb; 151*10465441SEvalZero #if LWIP_TCPIP_TIMEOUT 152*10465441SEvalZero struct { 153*10465441SEvalZero u32_t msecs; 154*10465441SEvalZero sys_timeout_handler h; 155*10465441SEvalZero void *arg; 156*10465441SEvalZero } tmo; 157*10465441SEvalZero #endif /* LWIP_TCPIP_TIMEOUT */ 158*10465441SEvalZero } msg; 159*10465441SEvalZero }; 160*10465441SEvalZero 161*10465441SEvalZero #ifdef __cplusplus 162*10465441SEvalZero } 163*10465441SEvalZero #endif 164*10465441SEvalZero 165*10465441SEvalZero #endif /* !NO_SYS */ 166*10465441SEvalZero 167*10465441SEvalZero #endif /* __LWIP_TCPIP_H__ */ 168