diff --git a/net/Makefile b/net/Makefile index adaaf1c22d..3d9bfebda3 100644 --- a/net/Makefile +++ b/net/Makefile @@ -39,6 +39,11 @@ ifeq ($(CONFIG_NET),y) # Basic networking support +NET_ASRCS = +NET_CSRCS = net_initialize.c + +# Socket support + SOCK_ASRCS = SOCK_CSRCS = bind.c connect.c getsockname.c recv.c recvfrom.c socket.c SOCK_CSRCS += sendto.c net_sockets.c net_close.c net_dup.c net_dup2.c diff --git a/net/net_initialize.c b/net/net_initialize.c new file mode 100644 index 0000000000..db39e90b06 --- /dev/null +++ b/net/net_initialize.c @@ -0,0 +1,149 @@ +/**************************************************************************** + * net/net_sockets.c + * + * Copyright (C) 2007-2009, 2011-2014 Gregory Nutt. All rights reserved. + * Author: Gregory Nutt + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. 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. + * 3. Neither the name NuttX 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 OWNER 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. + * + ****************************************************************************/ + +/**************************************************************************** + * Included Files + ****************************************************************************/ + +#include +#ifdef CONFIG_NET + +#include + +#include +#include +#include + +#include "net.h" +#include "tcp/tcp.h" +#include "udp/udp.h" +#include "pkt/pkt.h" +#include "igmp/igmp.h" +#include "route/route.h" + +/**************************************************************************** + * Pre-processor Definitions + ****************************************************************************/ + +/**************************************************************************** + * Public Types + ****************************************************************************/ + +/**************************************************************************** + * Private Variables + ****************************************************************************/ + +/**************************************************************************** + * Private Variables + ****************************************************************************/ + +/**************************************************************************** + * Private Functions + ****************************************************************************/ + +/**************************************************************************** + * Public Functions + ****************************************************************************/ + +/* This is called from the initialization logic to configure the socket layer */ + +void net_initialize(void) +{ + /* Initialize the locking facility */ + + net_lockinitialize(); + + /* Initialize I/O buffering */ + +#ifdef CONFIG_NET_IOB + iob_initialize(); +#endif + + /* Initialize the device interface layer */ + + uip_initialize(); + +#ifdef CONFIG_NET_PKT + /* Initialize packet socket support */ + + pkt_initialize(); +#endif + +#ifdef CONFIG_NET_TCP + /* Initialize the listening port structures */ + + tcp_listeninit(); + + /* Initialize the TCP/IP connection structures */ + + tcp_initialize(); + + /* Initialize the TCP/IP write buffering */ + +#ifdef CONFIG_NET_TCP_WRITE_BUFFERS + tcp_wrbuffer_initialize(); +#endif +#endif /* CONFIG_NET_TCP */ + +#ifdef CONFIG_NET_UDP + /* Initialize the UDP connection structures */ + + udp_initialize(); +#endif + +#ifdef CONFIG_NET_IGMP + /* Initialize IGMP support */ + + igmp_initialize(); +#endif + +#ifdef CONFIG_NET_ROUTE + /* Initialize the routing table */ + + net_initroute(); +#endif + +#if CONFIG_NSOCKET_DESCRIPTORS > 0 + /* Initialize the socket layer */ + + netdev_seminit(); +#endif + + /* Initialize the periodic ARP timer */ + + arp_timer_init(); +} + +#endif /* CONFIG_NET */ diff --git a/net/net_sockets.c b/net/net_sockets.c index 63120b9132..1b237e3ce7 100644 --- a/net/net_sockets.c +++ b/net/net_sockets.c @@ -47,14 +47,11 @@ #include #include -#include -#include #include #include #include #include "net.h" -#include "route/route.h" /**************************************************************************** * Pre-processor Definitions @@ -98,37 +95,6 @@ static void _net_semtake(FAR struct socketlist *list) * Public Functions ****************************************************************************/ -/* This is called from the initialization logic to configure the socket layer */ - -void net_initialize(void) -{ - /* Initialize the uIP layer */ - - uip_initialize(); - - /* Initialize I/O buffering */ - -#ifdef CONFIG_NET_IOB - iob_initialize(); -#endif - -#ifdef CONFIG_NET_ROUTE - /* Initialize the routing table */ - - net_initroute(); -#endif - -#if CONFIG_NSOCKET_DESCRIPTORS > 0 - /* Initialize the socket layer */ - - netdev_seminit(); -#endif - - /* Initialize the periodic ARP timer */ - - arp_timer_init(); -} - #if CONFIG_NSOCKET_DESCRIPTORS > 0 /* Initialize a list of sockets for a new task */ diff --git a/net/uip/uip_initialize.c b/net/uip/uip_initialize.c index e7e303f27c..e6863d585e 100644 --- a/net/uip/uip_initialize.c +++ b/net/uip/uip_initialize.c @@ -49,10 +49,6 @@ #include #include "uip/uip.h" -#include "tcp/tcp.h" -#include "udp/udp.h" -#include "pkt/pkt.h" -#include "igmp/igmp.h" /**************************************************************************** * Pre-processor Definitions @@ -120,46 +116,8 @@ uint8_t uip_reasstmr; void uip_initialize(void) { - /* Initialize the locking facility */ - - net_lockinitialize(); - /* Initialize callback support */ uip_callbackinit(); - - /* Initialize packet socket support */ - -#ifdef CONFIG_NET_PKT - pkt_initialize(); -#endif - - /* Initialize the listening port structures */ - -#ifdef CONFIG_NET_TCP - tcp_listeninit(); - - /* Initialize the TCP/IP connection structures */ - - tcp_initialize(); - - /* Initialize the TCP/IP write buffering */ - -#ifdef CONFIG_NET_TCP_WRITE_BUFFERS - tcp_wrbuffer_initialize(); -#endif -#endif /* CONFIG_NET_TCP */ - - /* Initialize the UDP connection structures */ - -#ifdef CONFIG_NET_UDP - udp_initialize(); -#endif - - /* Initialize IGMP support */ - -#ifdef CONFIG_NET_IGMP - igmp_initialize(); -#endif } #endif /* CONFIG_NET */