summaryrefslogtreecommitdiff
path: root/nuttx/include/netinet/in.h
diff options
context:
space:
mode:
authorpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2007-09-02 21:58:35 +0000
committerpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2007-09-02 21:58:35 +0000
commit9a272c38fb40781171f7b4d054430f2c0be730c0 (patch)
tree892d21bc1008301a5f07a8634cf5cb227f563dc6 /nuttx/include/netinet/in.h
parent8e6fadad87d3220628d412fee845ad0b0cfb697f (diff)
downloadpx4-nuttx-9a272c38fb40781171f7b4d054430f2c0be730c0.tar.gz
px4-nuttx-9a272c38fb40781171f7b4d054430f2c0be730c0.tar.bz2
px4-nuttx-9a272c38fb40781171f7b4d054430f2c0be730c0.zip
Implements basic TCP connection logic
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@326 42af7a65-404d-4744-a932-0658087f49c3
Diffstat (limited to 'nuttx/include/netinet/in.h')
-rw-r--r--nuttx/include/netinet/in.h58
1 files changed, 46 insertions, 12 deletions
diff --git a/nuttx/include/netinet/in.h b/nuttx/include/netinet/in.h
index e2ed78363..dd518388a 100644
--- a/nuttx/include/netinet/in.h
+++ b/nuttx/include/netinet/in.h
@@ -43,34 +43,68 @@
#include <sys/types.h>
/****************************************************************************
- * Public Type Definitions
+ * Public Macro Definitions
****************************************************************************/
-/* Address to accept any incoming messages. */
-#define INADDR_ANY ((in_addr_t)0x00000000)
+/* Values for protocol argument to socket() */
+
+#define IPPROTO_TCP 1
+#define IPPROTO_UDP 2
+
+/* Special values of in_addr_t */
+
+#define INADDR_ANY ((in_addr_t)0x00000000) /* Address to accept any incoming messages */
+#define INADDR_BROADCAST ((in_addr_t)0xffffffff) /* Address to send to all hosts */
+#define INADDR_NONE ((in_addr_t)0xffffffff) /* Address indicating an error return */
+
+#define IN6ADDR_ANY_INIT {{{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}}}
-/* Address to send to all hosts. */
-#define INADDR_BROADCAST ((in_addr_t)0xffffffff)
+/* struct in6_addr union selectors */
-/* Address indicating an error return. */
-#define INADDR_NONE ((in_addr_t)0xffffffff)
+#define s6_addr in6_u.u6_addr8
+#define s6_addr16 in6_u.u6_addr16
+#define s6_addr32 in6_u.u6_addr32
+
+/****************************************************************************
+ * Public Type Definitions
+ ****************************************************************************/
/****************************************************************************
* Public Type Definitions
****************************************************************************/
-/* Internet address. */
+/* IPv4 Internet address */
+
typedef uint32 in_addr_t;
struct in_addr
{
- in_addr_t s_addr; /* address in network byte order */
+ in_addr_t s_addr; /* Address (network byte order) */
};
struct sockaddr_in
{
- sa_family_t sin_family; /* address family: AF_INET */
- uint16 sin_port; /* port in network byte order */
- struct in_addr sin_addr; /* internet address */
+ sa_family_t sin_family; /* address family: AF_INET */
+ uint16 sin_port; /* port in network byte order */
+ struct in_addr sin_addr; /* internet address */
+};
+
+/* IPv6 Internet address */
+
+struct in6_addr
+{
+ union
+ {
+ uint8 u6_addr8[16];
+ uint16 u6_addr16[8];
+ uint32 u6_addr32[4];
+ } in6_u;
+};
+
+struct sockaddr_in6
+{
+ sa_family_t sin_family; /* Address family: AF_INET */
+ uint16 sin_port; /* Port in network byte order */
+ struct in6_addr sin6_addr; /* IPv6 internet address */
};
/****************************************************************************