Greg Steiert / pegasus_dev

Dependents:   blinky_max32630fthr

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers socket_api.h Source File

socket_api.h

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2014-2015 ARM Limited. All rights reserved.
00003  *
00004  * SPDX-License-Identifier: LicenseRef-PBL
00005  *
00006  * Licensed under the Permissive Binary License, Version 1.0 (the "License"); you may not use this file except in compliance with the License.
00007  * You may obtain a copy of the License at
00008  *
00009  * https://www.mbed.com/licenses/PBL-1.0
00010  *
00011  * See the License for the specific language governing permissions and limitations under the License.
00012  *
00013  */
00014 #ifndef _NS_SOCKET_API_H
00015 #define _NS_SOCKET_API_H
00016 
00017 #ifdef __cplusplus
00018 extern "C" {
00019 #endif
00020 /**
00021  * \file socket_api.h
00022  * \brief 6LoWPAN Library Socket API
00023  *
00024  * \section socket-com Common socket API
00025  *  - socket_open(), A function to open a socket.
00026  *  - socket_free(), A function to free a socket.
00027  *
00028  * \section socket-read Socket read API at callback
00029  *  - socket_read(), A function to read received data buffer from a socket.
00030  *  - socket_read_session_address(), A function to read session info for a TCP event.
00031  *
00032  * \section socket-tx Socket TX API
00033  * - socket_send(), A function to write data buffer to a socket.
00034  * - socket_sendto(), A function to write data to a specific destination in the socket.
00035  *
00036  * \section sock-connect TCP socket connection handle
00037  *  - socket_listen(), A function to set the socket to listening mode.
00038  *  - socket_connect(), A function to connect to a remote peer.
00039  *  - socket_close(), A function to close a connection.
00040  *
00041  * Sockets are a common abstraction model for network communication and are used in most operating systems.
00042  * 6LoWPAN Library API follows BSD socket API conventions closely with some extensions necessitated
00043  * by the event-based scheduling model.
00044  *
00045  * Library supports the following socket types:
00046  * | Socket name    |   Socket description           |
00047  * | :------------: | :----------------------------: |
00048  * | SOCKET_UDP     |   UDP socket type              |
00049  * | SOCKET_TCP     |   TCP socket type              |
00050  * | SOCKET_ICMP    |   ICMP raw socket type         |
00051  *
00052  * \section socket-raw ICMP RAW socket instruction
00053  * An ICMP raw socket can be created with the function socket_open() and the
00054  * identifier 0xffff. When using ICMP sockets, the minimum packet length is 4
00055  * bytes which is the 4 bytes of ICMP header. The first byte is for type, second
00056  * for code and last two are for the checksum that must always be set to zero.
00057  * The stack will calculate the checksum automatically before transmitting the packet.
00058  * THe header is followed by the payload if there is any.
00059  * NOTE: While it is perfectly legal to send an ICMP packet without payload,
00060  * some packet sniffing softwares might regard such packets as malformed.
00061  * In such a case, a dummy payload can be attached by providing a socket_sendto()
00062  * function with a pointer to your desired data buffer.
00063  * Moreover, the current implementation of the stack allows only certain ICMP types, for example
00064  * ICMP echo, reply, destination unreachable, router advertisement, router solicitation.
00065  * It will drop any other unimplemented types. For example, Private experimentation type (200) will
00066  * be dropped by default.
00067 
00068  * | ICMP Type |    ICMP Code | Checksum  | Payload    | Notes           |
00069  * | :-------: | :----------: | :-------: | :--------: | :--------------:|
00070  * | 1         | 1            | 2         | n bytes    | Length in bytes |
00071  * | 0xXX      | 0xXX         | 0x00 0x00 | n bytes    | Transmit        |
00072  * | 0xXX      | 0xXX         | 0xXX 0xXX | n bytes    | Receive         |
00073  *
00074  * ICMP echo request with 4 bytes of payload (ping6).
00075  *
00076  * | ICMP Type |    ICMP Code | Checksum  | Payload             |
00077  * | :-------: | :----------: | :-------: | :-----------------: |
00078  * | 0x80      | 0x00         | 0x00 0x00 | 0x00 0x01 0x02 0x03 |
00079  *
00080  * ICMP echo response for the message above.
00081  *
00082  * | ICMP Type |    ICMP Code | Checksum  | Payload             |
00083  * | :-------: | :----------: | :-------: | :-----------------: |
00084  * | 0x81      | 0x00         | 0xXX 0xXX | 0x00 0x01 0x02 0x03 |
00085  *
00086  * \section socket-receive Socket receiving
00087  * When there is data to read from the socket, a receive callback function is called with the event type parameter set to SOCKET_DATA.
00088  * The application must read the received data with socket_read() during the callback because the stack will release the data
00089  * when returning from the receive callback.
00090  *
00091  * Socket event has event_type and socket_id fields. The receive callback function must be defined when socket is opened using socket_open() API.
00092  *
00093  * All supported socket event types are listed here:
00094  *
00095  * | Event Type                 | Value | Description                                                         |
00096  * | :------------------------: | :---: | :-----------------------------------------------------------------: |
00097  * | SOCKET_EVENT_MASK          | 0xF0  | NC Socket event mask.                                               |
00098  * | SOCKET_DATA                | 0x00  | Data received, read data length available in d_len field.           |
00099  * | SOCKET_BIND_DONE           | 0x10  | TCP connection ready.                                               |
00100  * | SOCKET_TX_FAIL             | 0x50  | Socket data send failed.                                            |
00101  * | SOCKET_CONNECT_CLOSED      | 0x60  | TCP connection closed.                                              |
00102  * | SOCKET_CONNECT_FAIL_CLOSED | 0x70  | TCP connection closed no ACK received.                              |
00103  * | SOCKET_NO_ROUTER           | 0x80  | No route available to destination.                                  |
00104  * | SOCKET_TX_DONE             | 0x90  | Last socket TX process done, in TCP, whole TCP process is ready.    |
00105  * | SOCKET_NO_RAM              | 0xA0  | No RAM available.                                                   |
00106  *
00107  *
00108  * \section socket-tcp How to use TCP sockets:
00109  *
00110  * | API                           | Socket Type   | Description                                                      |
00111  * | :---------------------------: | :-----------: | :------------------------------------------------------------:   |
00112  * | socket_open()                 | Server/Client | Open socket to specific or dynamic port number.                  |
00113  * | socket_close()                | Server/Client | Close opened TCP connection.                                     |
00114  * | socket_listen()               | Server        | Set server port to listen state.                                 |
00115  * | socket_connect()              | Client        | Connect client socket to specific destination.                   |
00116  * | socket_send()                 | Client        | Send data to session based destination.                          |
00117  * | socket_sendto()               | Server/Client | Send data to specific destination.                               |
00118  * | socket_read_session_address() | Server/Client | Read socket TCP session address and port information.            |
00119  *
00120  * When the TCP socket is opened it is in closed state. It must be set either to listen or to connect state before it can be used to receive or transmit data.
00121  *
00122  * A socket can be set to listen mode with the socket_listen() function. After the call, the socket can accept an incoming connection from a remote host.
00123  * The listen mode closes the connection automatically after server timeout or when the client or application closes the connection manually by socket_close() function.
00124  *
00125  * A TCP socket can be connected to a remote host with socket_connect() with correct arguments. After the function call, a (non-blocking) application must wait for the socket event to confirm the successful state change of the socket.
00126  * After the successful state change, data can be sent using socket_send() by client and socket_send() by server.
00127  * The connection can be closed with socket_close() function or by server timeout.
00128  *
00129  * \section socket-udpicmp How to use UDP and RAW socket:
00130  *
00131  * A UDP socket is ready to receive and send data immediately after a successful call of socket_open() and a NET_READY event is received.
00132  * Data can be transmitted with the socket_sendto() function. An ICMP socket works with same function call.
00133  *
00134  */
00135 
00136 #include "ns_address.h"
00137 
00138 /** \name Protocol IDs used with sockets. */
00139 ///@{
00140 /** UDP socket type. */
00141 #define SOCKET_UDP      17
00142 /** Normal TCP socket type. */
00143 #define SOCKET_TCP      6
00144 /** ICMPv6 raw socket type */
00145 #define SOCKET_ICMP     32
00146 /** Raw IPv6 socket type (socket_open identifier is IPv6 protocol number) */
00147 #define SOCKET_RAW      2
00148 /** REMOVED Feature in this release socket open return error Local Sockets for Tun interface functionality to APP-APP trough any BUS */
00149 #define SOCKET_LOCAL    1
00150 ///@}
00151 
00152 /** ICMP socket instruction
00153  *
00154  * ICMP header is comprised of 4 bytes. The first byte is for type, second for code and
00155  * the last two are for checksum that must always be zero.
00156  * The stack will calculate the checksum automatically when sending the packet.
00157  * The payload comes after the header and it can be of any length. It can also be set to 0.
00158  *
00159  * This applies for reading and sending.
00160  *
00161  *      ICMP TYPE   ICMP Code   ICMP Checksum (2 bytes)     Payload n bytes
00162  *      --------    --------    -------- --------           -------- -------- ....... -------
00163  *      0xXX        0xXX        0x00    0x00                0xXX    0xXX    ......  0xXX
00164  *
00165  * Example data flow for ping:
00166  *
00167  * ICMP echo request with 4-bytes payload (Ping6).
00168  *      0x80, 0x00, 0x00, 0x00, 0x00, 0x01, 0x02, 0x03
00169  *
00170  * ICMP echo response for the message above.
00171  *      0x81, 0x00, 0xXX, 0xXX, 0x00, 0x01, 0x02, 0x03
00172  */
00173 
00174 /*!
00175  * \struct socket_callback_t
00176  * \brief Socket Callback function structure type.
00177  */
00178 
00179 typedef struct socket_callback_t {
00180     uint8_t event_type;     /**< Socket Callback Event check list below*/
00181     int8_t socket_id;       /**< Socket id queue which socket cause call back */
00182     int8_t interface_id;    /**< Network Interface ID where Packet came */
00183     uint16_t  d_len;        /**< Data length if event type is SOCKET_DATA */
00184     uint8_t LINK_LQI;       /**< LINK LQI info if interface cuold give */
00185 } socket_callback_t;
00186 
00187 /** IPv6 wildcard address IN_ANY */
00188 extern const uint8_t ns_in6addr_any[16];
00189 
00190 /**
00191  * \brief Create and initialize a socket for communication.
00192  *
00193  * \param protocol Defines the protocol to use.
00194  * \param identifier The socket port. 0 indicates that port is not specified and it will be selected automatically when using the socket.
00195  * \param passed_fptr A function pointer to a function that is called whenever a data frame is received to this socket.
00196  *
00197  * \return 0 or greater on success; Return value is the socket ID.
00198  * \return -1 on failure.
00199  * \return -2 on port reserved.
00200  */
00201 extern int8_t socket_open(uint8_t protocol, uint16_t identifier, void (*passed_fptr)(void *));
00202 
00203 /**
00204  * \brief A function to free a socket.
00205  *
00206  * \param socket ID of the socket to be released.
00207  *
00208  * \return 0 socket released.
00209  * \return -1 socket not released.
00210  */
00211 extern int8_t socket_free(int8_t socket);
00212 
00213 /**
00214  * \brief A function to set the socket to listening mode.
00215  *
00216  * \param socket Socket ID to bind.
00217  * \return 0 on success.
00218  * \return -1 on failure.
00219  */
00220 extern int8_t socket_listen(int8_t socket);
00221 
00222 /**
00223  * \brief A function to connect to remote peer (TCP).
00224  *
00225  * \param socket The socket ID.
00226  * \param address The address of a remote peer.
00227  * \param randomly_take_src_number 1 enables find next free random port number for the current one.
00228  *
00229  * \return 0 on success.
00230  * \return -1 in case of an invalid socket ID or parameter.
00231  * \return -2 if memory allocation fails.
00232  * \return -3 if the socket is in listening state.
00233  * \return -4 if the socket is already connected.
00234  * \return -5 connect is not supported on this type of socket.
00235  * \return -6 if the TCP session state is wrong.
00236  * \return -7 if the source address selection fails.
00237  */
00238 extern int8_t socket_connect(int8_t socket, ns_address_t *address, uint8_t randomly_take_src_number);
00239 
00240 /**
00241  * \brief Bind socket to address.
00242  *
00243  * Used by the application to bind a socket to a port and/or an address. Binding can
00244  * be done only once. The port or address cannot be changed after binding.
00245  *
00246  * \param socket Socket ID of the socket to bind.
00247  * \param address Address structure containing the port and address to bind.
00248  *
00249  * \return 0 on success.
00250  * \return -1 if the given address is NULL.
00251  * \return -2 if the port is already bound to another socket.
00252  * \return -4 if the socket is already bound.
00253  * \return -5 bind is not supported on this type of socket
00254  */
00255 extern int8_t socket_bind(int8_t socket, const ns_address_t *address);
00256 
00257 /**
00258  * \brief Bind a local address to a socket based on the destination address and
00259  *  the address selection preferences.
00260  *  Binding happens to the same address that socket_connect() would bind to.
00261  *  Reference: RFC5014 IPv6 Socket API for Source Address Selection.
00262  *
00263  * \param socket The socket ID.
00264  * \param dst_address The destination address to which the socket wants to communicate.
00265  *
00266  * \return 0 on success.
00267  * \return -1 if the given address is NULL or socket ID is invalid.
00268  * \return -2 if the memory allocation failed.
00269  * \return -3 if the socket is already bound to address.
00270  * \return -4 if the interface cannot be found.
00271  * \return -5 if the source address selection fails.
00272  * \return -6 bind2addrsel is not supported on this type of socket.
00273  */
00274 extern int8_t socket_bind2addrsel(int8_t socket, const ns_address_t *dst_address);
00275 
00276 /**
00277  * \brief A function to close a connection.
00278  *
00279  * \param socket The ID of the socket to be closed.
00280  * \param address The address of the destination client. When using as a client, a null pointer shall be passed.
00281  *
00282  * \return 0 on success.
00283  * \return -1 if the given socket ID is not found, if the socket type is wrong or tcp_close() returns a failure.
00284  * \return -2 if no active TCP session was found.
00285  * \return -3 if the referred socket ID port is declared as a zero.
00286  *
00287  * Note: It is highly recommended to always use randomly_take_src_number. The stack generates a new source port between 49152-65534.
00288  */
00289 extern int8_t socket_close(int8_t socket, ns_address_t *address);
00290 
00291 /**
00292  * \brief Send data via a connected TCP socket by client.
00293  *
00294  * Note: The socket connection must be ready before using this function.
00295  * The stack uses automatically the address of the remote connected host as the destination address for the packet.
00296  *
00297  * \param socket The socket ID.
00298  * \param buffer A pointer to data.
00299  * \param length Data length.
00300  *
00301  * \return 0 done
00302  * \return -1 Invalid socket ID.
00303  * \return -2 Socket memory allocation fail.
00304  * \return -3 TCP state not established.
00305  * \return -4 Socket TX process busy.
00306  * \return -5 Socket is not connected.
00307  * \return -6 Packet too short.
00308  */
00309 extern int8_t socket_send(int8_t socket, uint8_t *buffer, uint16_t length);
00310 
00311 /**
00312  * \brief A function to read received data buffer from a socket.
00313  *
00314  * Used by the application to get data from a socket. This method must be called once
00315  * from a socket callback when handling event SOCKET_DATA. If the received data does not fit
00316  * in the buffer provided the excess data bytes are discarded.
00317  *
00318  * \param socket The socket ID.
00319  * \param src_addr A pointer to a structure where the sender's address is stored.
00320  * \param buffer A pointer to an array where the read data is written to.
00321  * \param length The maximum length of the allocated buffer.
00322  *
00323  * \return greater than 0 indicates the length of the data copied to buffer.
00324  * \return 0 if no data is available to read.
00325  * \return -1 invalid input parameters.
00326  */
00327 extern int16_t socket_read(int8_t socket, ns_address_t *src_addr, uint8_t *buffer, uint16_t length);
00328 
00329 /**
00330  * \brief A function to send UDP, TCP or raw ICMP data via the socket.
00331  *
00332  * Used by the application to send data.
00333  *
00334  * \param socket The socket ID.
00335  * \param address A pointer to the destination address information.
00336  * \param buffer A pointer to data to be sent.
00337  * \param length Length of the data to be sent.
00338  * \return 0 on success.
00339  * \return -1 Invalid socket ID.
00340  * \return -2 Socket memory allocation fail.
00341  * \return -3 TCP state not established.
00342  * \return -4 Socket TX process busy.
00343  * \return -6 Packet too short.
00344  */
00345 extern int8_t socket_sendto(int8_t socket, ns_address_t *address, uint8_t *buffer, uint16_t length);
00346 
00347 /**
00348  * \brief A function to read session info for TCP event.
00349  *
00350  *
00351  * \param socket The socket ID.
00352  * \param address A pointer to the address structure where the session address information is read to.
00353  *
00354  * \return 0 on success.
00355  * \return -1 if no socket is found or TCP is not compiled into this project.
00356  * \return -2 if no session information is found.
00357  *
00358  * Note: This function should be called only at socket callback when the socket event is SOCKET_BIND_DONE or SOCKET_TX_DONE.
00359  * The following sections introduce those functions.
00360  */
00361 extern int8_t socket_read_session_address(int8_t socket, ns_address_t *address);
00362 
00363 
00364 /** \name Flags for SOCKET_IPV6_ADDR_PREFERENCES - opposites 16 bits apart. */
00365 ///@{
00366 #define SOCKET_IPV6_PREFER_SRC_TMP              0x00000001 /**< Prefer temporary address (RFC 4941); default. */
00367 #define SOCKET_IPV6_PREFER_SRC_PUBLIC           0x00010000 /**< Prefer public address (RFC 4941). */
00368 #define SOCKET_IPV6_PREFER_SRC_6LOWPAN_SHORT    0x00000100 /**< Prefer 6LoWPAN short address. */
00369 #define SOCKET_IPV6_PREFER_SRC_6LOWPAN_LONG     0x01000000 /**< Prefer 6LoWPAN long address. */
00370 ///@}
00371 
00372 /** \name Options for SOCKET_IPV6_ADDRESS_SELECT. */
00373 ///@{
00374 #define SOCKET_SRC_ADDRESS_MODE_PRIMARY     0 /**< Default value always. */
00375 #define SOCKET_SRC_ADDRESS_MODE_SECONDARY   1 /**< This mode typically selects the secondary address. */
00376 ///@}
00377 
00378 /** \name Protocol levels used for socket_setsockopt. */
00379 ///@{
00380 #define SOCKET_IPPROTO_IPV6         41  /**< IPv6. */
00381 ///@}
00382 
00383 /** \name Option names for protocol level SOCKET_IPPROTO_IPV6.
00384  * \anchor OPTNAMES_IPV6
00385  */
00386 ///@{
00387 /** Specify traffic class for outgoing packets, as int16_t (RFC 3542 S6.5 says int); valid values 0-255, or -1 for system default. */
00388 #define SOCKET_IPV6_TCLASS                  1
00389 /** Specify hop limit for outgoing unicast packets, as int16_t (RFC 3493 S5.1 says int); valid values 0-255, or -1 for system default. */
00390 #define SOCKET_IPV6_UNICAST_HOPS            2
00391 /** Specify hop limit for outgoing multicast packets, as int16_t (RFC 3493 S5.2 says int); valid values 0-255, or -1 for system default. */
00392 #define SOCKET_IPV6_MULTICAST_HOPS          3
00393 /** Specify source address preferences, as uint32_t - see RFC 5014; valid values combinations of SOCKET_IPV6_PREFER_xxx flags. */
00394 #define SOCKET_IPV6_ADDR_PREFERENCES        4
00395 /** Specify PMTU preference, as int8_t (RFC 3542 S11.1 says int); valid values -1 (PMTUD for unicast, default), 0 (PMTUD always), 1 (PMTUD off). */
00396 #define SOCKET_IPV6_USE_MIN_MTU             5
00397 /** Specify not to fragment datagrams, as int8_t (RFC 3542 S11.2 says int); valid values 0 (fragment to path MTU, default), 1 (no fragmentation, TX fails if bigger than outgoing interface MTU). */
00398 #define SOCKET_IPV6_DONTFRAG                6
00399 /** Specify flow label for outgoing packets, as int32_t; valid values 0-0xfffff, or -1 for system default, or -2 to always autogenerate */
00400 #define SOCKET_IPV6_FLOW_LABEL              7
00401 
00402 #define SOCKET_BROADCAST_PAN                0xfc /**< Internal use - transmit with IEEE 802.15.4 broadcast PAN ID */
00403 #define SOCKET_LINK_LAYER_SECURITY          0xfd /**< Not standard enable or disable socket security at link layer (For 802.15.4). */
00404 #define SOCKET_INTERFACE_SELECT             0xfe /**< Not standard socket interface ID. */
00405 #define SOCKET_IPV6_ADDRESS_SELECT          0xff /**< Deprecated - use SOCKET_IPV6_ADDR_PREFERENCES instead. */
00406 ///@}
00407 
00408 /**
00409  * \brief Set an option for a socket
00410  *
00411  * Used to specify miscellaneous options for a socket. Supported levels and
00412  * names defined above.
00413  *
00414  * \param socket The socket ID.
00415  * \param level The protocol level.
00416  * \param opt_name The option name (interpretation depends on level). See \ref OPTNAMES_IPV6.
00417  * \param opt_value A pointer to value for the specified option.
00418  * \param opt_len Size of the data pointed to by the value.
00419  *
00420  * \return 0 on success.
00421  * \return -1 invalid socket ID.
00422  * \return -2 invalid/unsupported option.
00423  * \return -3 invalid option value.
00424  */
00425 extern int8_t socket_setsockopt(int8_t socket, uint8_t level, uint8_t opt_name, const void *opt_value, uint16_t opt_len);
00426 
00427 /**
00428  * \brief Get an option for a socket.
00429  *
00430  * Used to read miscellaneous options for a socket. Supported levels and
00431  * names defined above. If the buffer is smaller than the option, the output
00432  * is silently truncated; otherwise opt_len is modified to indicate the actual
00433  * length.
00434  *
00435  * \param socket The socket ID.
00436  * \param level The protocol level.
00437  * \param opt_name The option name (interpretation depends on level). See \ref OPTNAMES_IPV6.
00438  * \param opt_value A pointer to output buffer.
00439  * \param opt_len A pointer to length of output buffer; updated on exit.
00440  *
00441  * \return 0 on success.
00442  * \return -1 invalid socket ID.
00443  * \return -2 invalid/unsupported option.
00444  */
00445 extern int8_t socket_getsockopt(int8_t socket, uint8_t level, uint8_t opt_name, void *opt_value, uint16_t *opt_len);
00446 
00447 #ifdef __cplusplus
00448 }
00449 #endif
00450 #endif /*_NS_SOCKET_H*/