summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--nuttx/net/Makefile5
-rw-r--r--nuttx/net/net_initialize.c149
-rw-r--r--nuttx/net/net_sockets.c34
-rw-r--r--nuttx/net/uip/uip_initialize.c42
4 files changed, 154 insertions, 76 deletions
diff --git a/nuttx/net/Makefile b/nuttx/net/Makefile
index adaaf1c22..3d9bfebda 100644
--- a/nuttx/net/Makefile
+++ b/nuttx/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/nuttx/net/net_initialize.c b/nuttx/net/net_initialize.c
new file mode 100644
index 000000000..db39e90b0
--- /dev/null
+++ b/nuttx/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 <gnutt@nuttx.org>
+ *
+ * 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 <nuttx/config.h>
+#ifdef CONFIG_NET
+
+#include <debug.h>
+
+#include <nuttx/net/iob.h>
+#include <nuttx/net/net.h>
+#include <nuttx/net/arp.h>
+
+#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/nuttx/net/net_sockets.c b/nuttx/net/net_sockets.c
index 63120b913..1b237e3ce 100644
--- a/nuttx/net/net_sockets.c
+++ b/nuttx/net/net_sockets.c
@@ -47,14 +47,11 @@
#include <errno.h>
#include <debug.h>
-#include <nuttx/net/iob.h>
-#include <nuttx/net/arp.h>
#include <nuttx/net/uip.h>
#include <nuttx/net/net.h>
#include <nuttx/kmalloc.h>
#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/nuttx/net/uip/uip_initialize.c b/nuttx/net/uip/uip_initialize.c
index e7e303f27..e6863d585 100644
--- a/nuttx/net/uip/uip_initialize.c
+++ b/nuttx/net/uip/uip_initialize.c
@@ -49,10 +49,6 @@
#include <nuttx/net/netstats.h>
#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 */