Added dummy function so that tcpip_output() always is defined, even if tcpip_set_outputfunc() never has been called. This fixes a bug with programs attempting to use the network when compiled for the native platform.

This commit is contained in:
adamdunkels 2008-11-09 12:29:24 +00:00
parent 312afede00
commit 3b283a5ff3

View file

@ -29,7 +29,7 @@
* This file is part of the Contiki operating system. * This file is part of the Contiki operating system.
* *
* *
* $Id: tcpip.c,v 1.15 2008/10/15 08:52:30 adamdunkels Exp $ * $Id: tcpip.c,v 1.16 2008/11/09 12:29:24 adamdunkels Exp $
*/ */
/** /**
* \file * \file
@ -109,7 +109,8 @@ enum {
#if UIP_CONF_IPV6 #if UIP_CONF_IPV6
u8_t (* tcpip_output)(uip_lladdr_t *); u8_t (* tcpip_output)(uip_lladdr_t *);
#else #else
u8_t (* tcpip_output)(void); static u8_t dummy_tcpip_output_function(void) {return 0;}
u8_t (* tcpip_output)(void) = dummy_tcpip_output_function;
#endif #endif
#if UIP_CONF_IP_FORWARD #if UIP_CONF_IP_FORWARD
@ -135,6 +136,7 @@ packet_input(void)
#if UIP_CONF_IPV6 #if UIP_CONF_IPV6
tcpip_ipv6_output(); tcpip_ipv6_output();
#else #else
PRINTF("tcpip packet_input forward output len %d\n", uip_len);
tcpip_output(); tcpip_output();
#endif #endif
#endif /* UIP_CONF_TCP_SPLIT */ #endif /* UIP_CONF_TCP_SPLIT */
@ -152,6 +154,7 @@ packet_input(void)
#if UIP_CONF_IPV6 #if UIP_CONF_IPV6
tcpip_ipv6_output(); tcpip_ipv6_output();
#else #else
PRINTF("tcpip packet_input output len %d\n", uip_len);
tcpip_output(); tcpip_output();
#endif #endif
#endif /* UIP_CONF_TCP_SPLIT */ #endif /* UIP_CONF_TCP_SPLIT */
@ -376,7 +379,9 @@ eventhandler(process_event_t ev, process_data_t data)
tcpip_ipv6_output(); tcpip_ipv6_output();
#else #else
if(uip_len > 0) { if(uip_len > 0) {
PRINTF("tcpip_output from periodic len %d\n", uip_len);
tcpip_output(); tcpip_output();
PRINTF("tcpip_output after periodic len %d\n", uip_len);
} }
#endif /* UIP_CONF_IPV6 */ #endif /* UIP_CONF_IPV6 */
} }
@ -436,6 +441,7 @@ eventhandler(process_event_t ev, process_data_t data)
tcpip_ipv6_output(); tcpip_ipv6_output();
#else #else
if(uip_len > 0) { if(uip_len > 0) {
PRINTF("tcpip_output from tcp poll len %d\n", uip_len);
tcpip_output(); tcpip_output();
} }
#endif /* UIP_CONF_IPV6 */ #endif /* UIP_CONF_IPV6 */
@ -664,7 +670,7 @@ tcpip_uipcall(void)
PROCESS_THREAD(tcpip_process, ev, data) PROCESS_THREAD(tcpip_process, ev, data)
{ {
PROCESS_BEGIN(); PROCESS_BEGIN();
#if UIP_TCP #if UIP_TCP
{ {
static unsigned char i; static unsigned char i;
@ -688,3 +694,4 @@ PROCESS_THREAD(tcpip_process, ev, data)
PROCESS_END(); PROCESS_END();
} }
/*---------------------------------------------------------------------------*/