2015-02-06 15:35:48 +01:00
/*
* socket . h - CC31xx / CC32xx Host Driver Implementation
*
* Copyright ( C ) 2014 Texas Instruments Incorporated - http : //www.ti.com/
*
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
*
* Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
*
* 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 .
*
* Neither the name of Texas Instruments Incorporated 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 .
*
*/
/*****************************************************************************/
/* Include files */
/*****************************************************************************/
# include "simplelink.h"
2015-03-15 11:45:01 +01:00
# ifndef __SL_SOCKET_H__
# define __SL_SOCKET_H__
2015-02-06 15:35:48 +01:00
# ifdef __cplusplus
extern " C " {
# endif
/*!
\ addtogroup socket
@ {
*/
/*****************************************************************************/
/* Macro declarations */
/*****************************************************************************/
# define SL_FD_SETSIZE SL_MAX_SOCKETS /* Number of sockets to select on - same is max sockets! */
# define BSD_SOCKET_ID_MASK (0x0F) /* Index using the LBS 4 bits for socket id 0-7 */
/* Define some BSD protocol constants. */
# define SL_SOCK_STREAM (1) /* TCP Socket */
# define SL_SOCK_DGRAM (2) /* UDP Socket */
# define SL_SOCK_RAW (3) /* Raw socket */
# define SL_IPPROTO_TCP (6) /* TCP Raw Socket */
# define SL_IPPROTO_UDP (17) /* UDP Raw Socket */
# define SL_IPPROTO_RAW (255) /* Raw Socket */
# define SL_SEC_SOCKET (100) /* Secured Socket Layer (SSL,TLS) */
/* Address families. */
# define SL_AF_INET (2) /* IPv4 socket (UDP, TCP, etc) */
# define SL_AF_INET6 (3) /* IPv6 socket (UDP, TCP, etc) */
# define SL_AF_INET6_EUI_48 (9)
# define SL_AF_RF (6) /* data include RF parameter, All layer by user (Wifi could be disconnected) */
# define SL_AF_PACKET (17)
/* Protocol families, same as address families. */
# define SL_PF_INET AF_INET
# define SL_PF_INET6 AF_INET6
# define SL_INADDR_ANY (0) /* bind any address */
/* error codes */
# define SL_SOC_ERROR (-1) /* Failure. */
# define SL_SOC_OK ( 0) /* Success. */
# define SL_INEXE (-8) /* socket command in execution */
# define SL_EBADF (-9) /* Bad file number */
# define SL_ENSOCK (-10) /* The system limit on the total number of open socket, has been reached */
# define SL_EAGAIN (-11) /* Try again */
# define SL_EWOULDBLOCK SL_EAGAIN
# define SL_ENOMEM (-12) /* Out of memory */
# define SL_EACCES (-13) /* Permission denied */
# define SL_EFAULT (-14) /* Bad address */
# define SL_ECLOSE (-15) /* close socket operation failed to transmit all queued packets */
# define SL_EALREADY_ENABLED (-21) /* Transceiver - Transceiver already ON. there could be only one */
# define SL_EINVAL (-22) /* Invalid argument */
# define SL_EAUTO_CONNECT_OR_CONNECTING (-69) /* Transceiver - During connection, connected or auto mode started */
# define SL_CONNECTION_PENDING (-72) /* Transceiver - Device is connected, disconnect first to open transceiver */
# define SL_EUNSUPPORTED_ROLE (-86) /* Transceiver - Trying to start when WLAN role is AP or P2P GO */
# define SL_EDESTADDRREQ (-89) /* Destination address required */
# define SL_EPROTOTYPE (-91) /* Protocol wrong type for socket */
# define SL_ENOPROTOOPT (-92) /* Protocol not available */
# define SL_EPROTONOSUPPORT (-93) /* Protocol not supported */
# define SL_ESOCKTNOSUPPORT (-94) /* Socket type not supported */
# define SL_EOPNOTSUPP (-95) /* Operation not supported on transport endpoint */
# define SL_EAFNOSUPPORT (-97) /* Address family not supported by protocol */
# define SL_EADDRINUSE (-98) /* Address already in use */
# define SL_EADDRNOTAVAIL (-99) /* Cannot assign requested address */
# define SL_ENETUNREACH (-101) /* Network is unreachable */
# define SL_ENOBUFS (-105) /* No buffer space available */
# define SL_EOBUFF SL_ENOBUFS
# define SL_EISCONN (-106) /* Transport endpoint is already connected */
# define SL_ENOTCONN (-107) /* Transport endpoint is not connected */
# define SL_ETIMEDOUT (-110) /* Connection timed out */
# define SL_ECONNREFUSED (-111) /* Connection refused */
# define SL_EALREADY (-114) /* Non blocking connect in progress, try again */
# define SL_ESEC_RSA_WRONG_TYPE_E (-130) /* RSA wrong block type for RSA function */
# define SL_ESEC_RSA_BUFFER_E (-131) /* RSA buffer error, output too small or */
# define SL_ESEC_BUFFER_E (-132) /* output buffer too small or input too large */
# define SL_ESEC_ALGO_ID_E (-133) /* setting algo id error */
# define SL_ESEC_PUBLIC_KEY_E (-134) /* setting public key error */
# define SL_ESEC_DATE_E (-135) /* setting date validity error */
# define SL_ESEC_SUBJECT_E (-136) /* setting subject name error */
# define SL_ESEC_ISSUER_E (-137) /* setting issuer name error */
# define SL_ESEC_CA_TRUE_E (-138) /* setting CA basic constraint true error */
# define SL_ESEC_EXTENSIONS_E (-139) /* setting extensions error */
# define SL_ESEC_ASN_PARSE_E (-140) /* ASN parsing error, invalid input */
# define SL_ESEC_ASN_VERSION_E (-141) /* ASN version error, invalid number */
# define SL_ESEC_ASN_GETINT_E (-142) /* ASN get big _i16 error, invalid data */
# define SL_ESEC_ASN_RSA_KEY_E (-143) /* ASN key init error, invalid input */
# define SL_ESEC_ASN_OBJECT_ID_E (-144) /* ASN object id error, invalid id */
# define SL_ESEC_ASN_TAG_NULL_E (-145) /* ASN tag error, not null */
# define SL_ESEC_ASN_EXPECT_0_E (-146) /* ASN expect error, not zero */
# define SL_ESEC_ASN_BITSTR_E (-147) /* ASN bit string error, wrong id */
# define SL_ESEC_ASN_UNKNOWN_OID_E (-148) /* ASN oid error, unknown sum id */
# define SL_ESEC_ASN_DATE_SZ_E (-149) /* ASN date error, bad size */
# define SL_ESEC_ASN_BEFORE_DATE_E (-150) /* ASN date error, current date before */
# define SL_ESEC_ASN_AFTER_DATE_E (-151) /* ASN date error, current date after */
# define SL_ESEC_ASN_SIG_OID_E (-152) /* ASN signature error, mismatched oid */
# define SL_ESEC_ASN_TIME_E (-153) /* ASN time error, unknown time type */
# define SL_ESEC_ASN_INPUT_E (-154) /* ASN input error, not enough data */
# define SL_ESEC_ASN_SIG_CONFIRM_E (-155) /* ASN sig error, confirm failure */
# define SL_ESEC_ASN_SIG_HASH_E (-156) /* ASN sig error, unsupported hash type */
# define SL_ESEC_ASN_SIG_KEY_E (-157) /* ASN sig error, unsupported key type */
# define SL_ESEC_ASN_DH_KEY_E (-158) /* ASN key init error, invalid input */
# define SL_ESEC_ASN_NTRU_KEY_E (-159) /* ASN ntru key decode error, invalid input */
# define SL_ESEC_ECC_BAD_ARG_E (-170) /* ECC input argument of wrong type */
# define SL_ESEC_ASN_ECC_KEY_E (-171) /* ASN ECC bad input */
# define SL_ESEC_ECC_CURVE_OID_E (-172) /* Unsupported ECC OID curve type */
# define SL_ESEC_BAD_FUNC_ARG (-173) /* Bad function argument provided */
# define SL_ESEC_NOT_COMPILED_IN (-174) /* Feature not compiled in */
# define SL_ESEC_UNICODE_SIZE_E (-175) /* Unicode password too big */
# define SL_ESEC_NO_PASSWORD (-176) /* no password provided by user */
# define SL_ESEC_ALT_NAME_E (-177) /* alt name size problem, too big */
# define SL_ESEC_AES_GCM_AUTH_E (-180) /* AES-GCM Authentication check failure */
# define SL_ESEC_AES_CCM_AUTH_E (-181) /* AES-CCM Authentication check failure */
2015-03-15 11:45:01 +01:00
# define SL_SOCKET_ERROR_E (-208) /* Error state on socket */
# define SL_ESEC_MEMORY_ERROR (-203) /* out of memory */
# define SL_ESEC_VERIFY_FINISHED_ERROR (-204) /* verify problem on finished */
# define SL_ESEC_VERIFY_MAC_ERROR (-205) /* verify mac problem */
# define SL_ESEC_UNKNOWN_HANDSHAKE_TYPE (-207) /* weird handshake type */
# define SL_ESEC_SOCKET_ERROR_E (-208) /* error state on socket */
# define SL_ESEC_SOCKET_NODATA (-209) /* expected data, not there */
# define SL_ESEC_INCOMPLETE_DATA (-210) /* don't have enough data to complete task */
# define SL_ESEC_UNKNOWN_RECORD_TYPE (-211) /* unknown type in record hdr */
# define SL_ESEC_FATAL_ERROR (-213) /* recvd alert fatal error */
# define SL_ESEC_ENCRYPT_ERROR (-214) /* error during encryption */
# define SL_ESEC_NO_PEER_KEY (-216) /* need peer's key */
# define SL_ESEC_NO_PRIVATE_KEY (-217) /* need the private key */
# define SL_ESEC_RSA_PRIVATE_ERROR (-218) /* error during rsa priv op */
# define SL_ESEC_NO_DH_PARAMS (-219) /* server missing DH params */
# define SL_ESEC_BUILD_MSG_ERROR (-220) /* build message failure */
# define SL_ESEC_BAD_HELLO (-221) /* client hello malformed */
# define SL_ESEC_DOMAIN_NAME_MISMATCH (-222) /* peer subject name mismatch */
# define SL_ESEC_WANT_READ (-223) /* want read, call again */
# define SL_ESEC_NOT_READY_ERROR (-224) /* handshake layer not ready */
# define SL_ESEC_PMS_VERSION_ERROR (-225) /* pre m secret version error */
# define SL_ESEC_VERSION_ERROR (-226) /* record layer version error */
# define SL_ESEC_WANT_WRITE (-227) /* want write, call again */
# define SL_ESEC_BUFFER_ERROR (-228) /* malformed buffer input */
# define SL_ESEC_VERIFY_CERT_ERROR (-229) /* verify cert error */
# define SL_ESEC_VERIFY_SIGN_ERROR (-230) /* verify sign error */
# define SL_ESEC_LENGTH_ERROR (-241) /* record layer length error */
# define SL_ESEC_PEER_KEY_ERROR (-242) /* can't decode peer key */
# define SL_ESEC_ZERO_RETURN (-243) /* peer sent close notify */
# define SL_ESEC_SIDE_ERROR (-244) /* wrong client/server type */
# define SL_ESEC_NO_PEER_CERT (-245) /* peer didn't send key */
# define SL_ESEC_ECC_CURVETYPE_ERROR (-250) /* Bad ECC Curve Type */
# define SL_ESEC_ECC_CURVE_ERROR (-251) /* Bad ECC Curve */
# define SL_ESEC_ECC_PEERKEY_ERROR (-252) /* Bad Peer ECC Key */
# define SL_ESEC_ECC_MAKEKEY_ERROR (-253) /* Bad Make ECC Key */
# define SL_ESEC_ECC_EXPORT_ERROR (-254) /* Bad ECC Export Key */
# define SL_ESEC_ECC_SHARED_ERROR (-255) /* Bad ECC Shared Secret */
# define SL_ESEC_NOT_CA_ERROR (-257) /* Not a CA cert error */
# define SL_ESEC_BAD_PATH_ERROR (-258) /* Bad path for opendir */
# define SL_ESEC_BAD_CERT_MANAGER_ERROR (-259) /* Bad Cert Manager */
# define SL_ESEC_MAX_CHAIN_ERROR (-268) /* max chain depth exceeded */
# define SL_ESEC_SUITES_ERROR (-271) /* suites pointer error */
# define SL_ESEC_SSL_NO_PEM_HEADER (-272) /* no PEM header found */
# define SL_ESEC_OUT_OF_ORDER_E (-273) /* out of order message */
# define SL_ESEC_SANITY_CIPHER_E (-275) /* sanity check on cipher error */
# define SL_ESEC_GEN_COOKIE_E (-277) /* Generate Cookie Error */
# define SL_ESEC_NO_PEER_VERIFY (-278) /* Need peer cert verify Error */
# define SL_ESEC_UNKNOWN_SNI_HOST_NAME_E (-281) /* Unrecognized host name Error */
/* begin negotiation parameter errors */
# define SL_ESEC_UNSUPPORTED_SUITE (-290) /* unsupported cipher suite */
# define SL_ESEC_MATCH_SUITE_ERROR (-291 ) /* can't match cipher suite */
2015-02-06 15:35:48 +01:00
/* ssl tls security start with -300 offset */
# define SL_ESEC_CLOSE_NOTIFY (-300) /* ssl/tls alerts */
# define SL_ESEC_UNEXPECTED_MESSAGE (-310) /* ssl/tls alerts */
# define SL_ESEC_BAD_RECORD_MAC (-320) /* ssl/tls alerts */
# define SL_ESEC_DECRYPTION_FAILED (-321) /* ssl/tls alerts */
# define SL_ESEC_RECORD_OVERFLOW (-322) /* ssl/tls alerts */
# define SL_ESEC_DECOMPRESSION_FAILURE (-330) /* ssl/tls alerts */
# define SL_ESEC_HANDSHAKE_FAILURE (-340) /* ssl/tls alerts */
# define SL_ESEC_NO_CERTIFICATE (-341) /* ssl/tls alerts */
# define SL_ESEC_BAD_CERTIFICATE (-342) /* ssl/tls alerts */
# define SL_ESEC_UNSUPPORTED_CERTIFICATE (-343) /* ssl/tls alerts */
# define SL_ESEC_CERTIFICATE_REVOKED (-344) /* ssl/tls alerts */
# define SL_ESEC_CERTIFICATE_EXPIRED (-345) /* ssl/tls alerts */
# define SL_ESEC_CERTIFICATE_UNKNOWN (-346) /* ssl/tls alerts */
# define SL_ESEC_ILLEGAL_PARAMETER (-347) /* ssl/tls alerts */
# define SL_ESEC_UNKNOWN_CA (-348) /* ssl/tls alerts */
# define SL_ESEC_ACCESS_DENIED (-349) /* ssl/tls alerts */
# define SL_ESEC_DECODE_ERROR (-350) /* ssl/tls alerts */
# define SL_ESEC_DECRYPT_ERROR (-351) /* ssl/tls alerts */
# define SL_ESEC_EXPORT_RESTRICTION (-360) /* ssl/tls alerts */
# define SL_ESEC_PROTOCOL_VERSION (-370) /* ssl/tls alerts */
# define SL_ESEC_INSUFFICIENT_SECURITY (-371) /* ssl/tls alerts */
# define SL_ESEC_INTERNAL_ERROR (-380) /* ssl/tls alerts */
# define SL_ESEC_USER_CANCELLED (-390) /* ssl/tls alerts */
# define SL_ESEC_NO_RENEGOTIATION (-400) /* ssl/tls alerts */
# define SL_ESEC_UNSUPPORTED_EXTENSION (-410) /* ssl/tls alerts */
# define SL_ESEC_CERTIFICATE_UNOBTAINABLE (-411) /* ssl/tls alerts */
# define SL_ESEC_UNRECOGNIZED_NAME (-412) /* ssl/tls alerts */
# define SL_ESEC_BAD_CERTIFICATE_STATUS_RESPONSE (-413) /* ssl/tls alerts */
# define SL_ESEC_BAD_CERTIFICATE_HASH_VALUE (-414) /* ssl/tls alerts */
/* propierty secure */
# define SL_ESECGENERAL (-450) /* error secure level general error */
# define SL_ESECDECRYPT (-451) /* error secure level, decrypt recv packet fail */
# define SL_ESECCLOSED (-452) /* secure layrer is closed by other size , tcp is still connected */
# define SL_ESECSNOVERIFY (-453) /* Connected without server verification */
# define SL_ESECNOCAFILE (-454) /* error secure level CA file not found*/
# define SL_ESECMEMORY (-455) /* error secure level No memory space available */
# define SL_ESECBADCAFILE (-456) /* error secure level bad CA file */
# define SL_ESECBADCERTFILE (-457) /* error secure level bad Certificate file */
# define SL_ESECBADPRIVATEFILE (-458) /* error secure level bad private file */
# define SL_ESECBADDHFILE (-459) /* error secure level bad DH file */
# define SL_ESECT00MANYSSLOPENED (-460) /* MAX SSL Sockets are opened */
# define SL_ESECDATEERROR (-461) /* connected with certificate date verification error */
# define SL_ESECHANDSHAKETIMEDOUT (-462) /* connection timed out due to handshake time */
/* end error codes */
/* Max payload size by protocol */
# define SL_SOCKET_PAYLOAD_TYPE_MASK (0xF0) /*4 bits type, 4 bits sockets id */
# define SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4 (0x00) /* 1472 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4 (0x10) /* 1460 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6 (0x20) /* 1452 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6 (0x30) /* 1440 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4_SECURE (0x40) /* */
# define SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4_SECURE (0x50) /* */
# define SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6_SECURE (0x60) /* */
# define SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6_SECURE (0x70) /* */
# define SL_SOCKET_PAYLOAD_TYPE_RAW_TRANCEIVER (0x80) /* 1536 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_RAW_PACKET (0x90) /* 1536 bytes */
# define SL_SOCKET_PAYLOAD_TYPE_RAW_IP4 (0xa0)
# define SL_SOCKET_PAYLOAD_TYPE_RAW_IP6 (SL_SOCKET_PAYLOAD_TYPE_RAW_IP4 )
# define SL_SOL_SOCKET (1) /* Define the socket option category. */
# define SL_IPPROTO_IP (2) /* Define the IP option category. */
# define SL_SOL_PHY_OPT (3) /* Define the PHY option category. */
# define SL_SO_RCVBUF (8) /* Setting TCP receive buffer size */
# define SL_SO_KEEPALIVE (9) /* Connections are kept alive with periodic messages */
# define SL_SO_RCVTIMEO (20) /* Enable receive timeout */
# define SL_SO_NONBLOCKING (24) /* Enable . disable nonblocking mode */
# define SL_SO_SECMETHOD (25) /* security metohd */
# define SL_SO_SECURE_MASK (26) /* security mask */
# define SL_SO_SECURE_FILES (27) /* security files */
# define SL_SO_CHANGE_CHANNEL (28) /* This option is available only when transceiver started */
# define SL_SO_SECURE_FILES_PRIVATE_KEY_FILE_NAME (30) /* This option used to configue secure file */
# define SL_SO_SECURE_FILES_CERTIFICATE_FILE_NAME (31) /* This option used to configue secure file */
# define SL_SO_SECURE_FILES_CA_FILE_NAME (32) /* This option used to configue secure file */
# define SL_SO_SECURE_FILES_DH_KEY_FILE_NAME (33) /* This option used to configue secure file */
# define SL_IP_MULTICAST_IF (60) /* Specify outgoing multicast interface */
# define SL_IP_MULTICAST_TTL (61) /* Specify the TTL value to use for outgoing multicast packet. */
# define SL_IP_ADD_MEMBERSHIP (65) /* Join IPv4 multicast membership */
# define SL_IP_DROP_MEMBERSHIP (66) /* Leave IPv4 multicast membership */
# define SL_IP_HDRINCL (67) /* Raw socket IPv4 header included. */
# define SL_IP_RAW_RX_NO_HEADER (68) /* Proprietary socket option that does not includeIPv4/IPv6 header (and extension headers) on received raw sockets*/
# define SL_IP_RAW_IPV6_HDRINCL (69) /* Transmitted buffer over IPv6 socket contains IPv6 header. */
# define SL_SO_PHY_RATE (100) /* WLAN Transmit rate */
# define SL_SO_PHY_TX_POWER (101) /* TX Power level */
# define SL_SO_PHY_NUM_FRAMES_TO_TX (102) /* Number of frames to transmit */
# define SL_SO_PHY_PREAMBLE (103) /* Preamble for transmission */
# define SL_SO_SEC_METHOD_SSLV3 (0) /* security metohd SSL v3*/
# define SL_SO_SEC_METHOD_TLSV1 (1) /* security metohd TLS v1*/
# define SL_SO_SEC_METHOD_TLSV1_1 (2) /* security metohd TLS v1_1*/
# define SL_SO_SEC_METHOD_TLSV1_2 (3) /* security metohd TLS v1_2*/
# define SL_SO_SEC_METHOD_SSLv3_TLSV1_2 (4) /* use highest possible version from SSLv3 - TLS 1.2*/
# define SL_SO_SEC_METHOD_DLSV1 (5) /* security metohd DTL v1 */
# define SL_SEC_MASK_SSL_RSA_WITH_RC4_128_SHA (1 << 0)
# define SL_SEC_MASK_SSL_RSA_WITH_RC4_128_MD5 (1 << 1)
# define SL_SEC_MASK_TLS_RSA_WITH_AES_256_CBC_SHA (1 << 2)
# define SL_SEC_MASK_TLS_DHE_RSA_WITH_AES_256_CBC_SHA (1 << 3)
# define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA (1 << 4)
# define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_RC4_128_SHA (1 << 5)
2015-03-15 11:45:01 +01:00
# define SL_SEC_MASK_TLS_RSA_WITH_AES_128_CBC_SHA256 (1 << 6)
# define SL_SEC_MASK_TLS_RSA_WITH_AES_256_CBC_SHA256 (1 << 7)
# define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 (1 << 8)
# define SL_SEC_MASK_TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 (1 << 9)
# define SL_SEC_MASK_SECURE_DEFAULT ((SL_SEC_MASK_TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 << 1) - 1)
2015-02-06 15:35:48 +01:00
# define SL_MSG_DONTWAIT (0x00000008) /* Nonblocking IO */
/* AP DHCP Server - IP Release reason code */
# define SL_IP_LEASE_PEER_RELEASE (0)
# define SL_IP_LEASE_PEER_DECLINE (1)
# define SL_IP_LEASE_EXPIRED (2)
/* possible types when receiving SL_SOCKET_ASYNC_EVENT*/
# define SSL_ACCEPT (1) /* accept failed due to ssl issue ( tcp pass) */
# define RX_FRAGMENTATION_TOO_BIG (2) /* connection less mode, rx packet fragmentation > 16K, packet is being released */
# define OTHER_SIDE_CLOSE_SSL_DATA_NOT_ENCRYPTED (3) /* remote side down from secure to unsecure */
# ifdef SL_INC_STD_BSD_API_NAMING
# define FD_SETSIZE SL_FD_SETSIZE
# define SOCK_STREAM SL_SOCK_STREAM
# define SOCK_DGRAM SL_SOCK_DGRAM
# define SOCK_RAW SL_SOCK_RAW
# define IPPROTO_TCP SL_IPPROTO_TCP
# define IPPROTO_UDP SL_IPPROTO_UDP
# define IPPROTO_RAW SL_IPPROTO_RAW
# define AF_INET SL_AF_INET
# define AF_INET6 SL_AF_INET6
# define AF_INET6_EUI_48 SL_AF_INET6_EUI_48
# define AF_RF SL_AF_RF
# define AF_PACKET SL_AF_PACKET
# define PF_INET SL_PF_INET
# define PF_INET6 SL_PF_INET6
# define INADDR_ANY SL_INADDR_ANY
# define ERROR SL_SOC_ERROR
# define INEXE SL_INEXE
# define EBADF SL_EBADF
# define ENSOCK SL_ENSOCK
# define EAGAIN SL_EAGAIN
# define EWOULDBLOCK SL_EWOULDBLOCK
# define ENOMEM SL_ENOMEM
# define EACCES SL_EACCES
# define EFAULT SL_EFAULT
# define EINVAL SL_EINVAL
# define EDESTADDRREQ SL_EDESTADDRREQ
# define EPROTOTYPE SL_EPROTOTYPE
# define ENOPROTOOPT SL_ENOPROTOOPT
# define EPROTONOSUPPORT SL_EPROTONOSUPPORT
# define ESOCKTNOSUPPORT SL_ESOCKTNOSUPPORT
# define EOPNOTSUPP SL_EOPNOTSUPP
# define EAFNOSUPPORT SL_EAFNOSUPPORT
# define EADDRINUSE SL_EADDRINUSE
# define EADDRNOTAVAIL SL_EADDRNOTAVAIL
# define ENETUNREACH SL_ENETUNREACH
# define ENOBUFS SL_ENOBUFS
# define EOBUFF SL_EOBUFF
# define EISCONN SL_EISCONN
# define ENOTCONN SL_ENOTCONN
# define ETIMEDOUT SL_ETIMEDOUT
# define ECONNREFUSED SL_ECONNREFUSED
# define SOL_SOCKET SL_SOL_SOCKET
# define IPPROTO_IP SL_IPPROTO_IP
# define SO_KEEPALIVE SL_SO_KEEPALIVE
# define SO_RCVTIMEO SL_SO_RCVTIMEO
# define SO_NONBLOCKING SL_SO_NONBLOCKING
# define IP_MULTICAST_IF SL_IP_MULTICAST_IF
# define IP_MULTICAST_TTL SL_IP_MULTICAST_TTL
# define IP_ADD_MEMBERSHIP SL_IP_ADD_MEMBERSHIP
# define IP_DROP_MEMBERSHIP SL_IP_DROP_MEMBERSHIP
# define socklen_t SlSocklen_t
# define timeval SlTimeval_t
# define sockaddr SlSockAddr_t
# define in6_addr SlIn6Addr_t
# define sockaddr_in6 SlSockAddrIn6_t
# define in_addr SlInAddr_t
# define sockaddr_in SlSockAddrIn_t
# define MSG_DONTWAIT SL_MSG_DONTWAIT
# define FD_SET SL_FD_SET
# define FD_CLR SL_FD_CLR
# define FD_ISSET SL_FD_ISSET
# define FD_ZERO SL_FD_ZERO
# define fd_set SlFdSet_t
# define socket sl_Socket
# define close sl_Close
# define accept sl_Accept
# define bind sl_Bind
# define listen sl_Listen
# define connect sl_Connect
# define select sl_Select
# define setsockopt sl_SetSockOpt
# define getsockopt sl_GetSockOpt
# define recv sl_Recv
# define recvfrom sl_RecvFrom
# define write sl_Write
# define send sl_Send
# define sendto sl_SendTo
# define gethostbyname sl_NetAppDnsGetHostByName
# define htonl sl_Htonl
# define ntohl sl_Ntohl
# define htons sl_Htons
# define ntohs sl_Ntohs
# endif
/*****************************************************************************/
/* Structure/Enum declarations */
/*****************************************************************************/
/* Internet address */
typedef struct SlInAddr_t
{
# ifndef s_addr
_u32 s_addr ; /* Internet address 32 bits */
# else
union S_un {
struct { _u8 s_b1 , s_b2 , s_b3 , s_b4 ; } S_un_b ;
struct { _u8 s_w1 , s_w2 ; } S_un_w ;
_u32 S_addr ;
} S_un ;
# endif
} SlInAddr_t ;
/* sockopt */
typedef struct
{
_u32 KeepaliveEnabled ; /* 0 = disabled;1 = enabled; default = 1*/
} SlSockKeepalive_t ;
typedef struct
{
_u32 ReuseaddrEnabled ; /* 0 = disabled; 1 = enabled; default = 1*/
} SlSockReuseaddr_t ;
typedef struct
{
_u32 Winsize ; /* receive window size for tcp sockets */
} SlSockWinsize_t ;
typedef struct
{
_u32 NonblockingEnabled ; /* 0 = disabled;1 = enabled;default = 1*/
} SlSockNonblocking_t ;
2015-03-15 11:45:01 +01:00
2015-02-06 15:35:48 +01:00
typedef struct
{
2015-03-15 11:45:01 +01:00
_u8 sd ;
_u8 type ;
_i16 val ;
_u8 * pExtraInfo ;
2015-02-06 15:35:48 +01:00
} SlSocketAsyncEvent_t ;
typedef struct
{
2015-03-15 11:45:01 +01:00
_i16 status ;
_u8 sd ;
_u8 padding ;
} SlSockTxFailEventData_t ;
typedef union
{
SlSockTxFailEventData_t SockTxFailData ;
SlSocketAsyncEvent_t SockAsyncData ;
} SlSockEventData_u ;
2015-02-06 15:35:48 +01:00
typedef struct
{
_u32 Event ;
2015-03-15 11:45:01 +01:00
SlSockEventData_u socketAsyncEvent ;
2015-02-06 15:35:48 +01:00
} SlSockEvent_t ;
2015-03-15 11:45:01 +01:00
2015-02-06 15:35:48 +01:00
typedef struct
{
_u32 secureMask ;
} SlSockSecureMask ;
typedef struct
{
_u8 secureMethod ;
} SlSockSecureMethod ;
typedef enum
{
SL_BSD_SECURED_PRIVATE_KEY_IDX = 0 ,
SL_BSD_SECURED_CERTIFICATE_IDX ,
SL_BSD_SECURED_CA_IDX ,
SL_BSD_SECURED_DH_IDX
} slBsd_secureSocketFilesIndex_e ;
typedef struct
{
SlInAddr_t imr_multiaddr ; /* The IPv4 multicast address to join */
SlInAddr_t imr_interface ; /* The interface to use for this group */
} SlSockIpMreq ;
/* sockopt */
typedef _u32 SlTime_t ;
typedef _u32 SlSuseconds_t ;
typedef struct SlTimeval_t
{
SlTime_t tv_sec ; /* Seconds */
SlSuseconds_t tv_usec ; /* Microseconds */
} SlTimeval_t ;
typedef _u16 SlSocklen_t ;
/* IpV4 socket address */
typedef struct SlSockAddr_t
{
_u16 sa_family ; /* Address family (e.g. , AF_INET) */
_u8 sa_data [ 14 ] ; /* Protocol- specific address information*/
} SlSockAddr_t ;
/* IpV6 or Ipv6 EUI64 */
typedef struct SlIn6Addr_t
{
union
{
_u8 _S6_u8 [ 16 ] ;
_u32 _S6_u32 [ 4 ] ;
} _S6_un ;
} SlIn6Addr_t ;
typedef struct SlSockAddrIn6_t
{
_u16 sin6_family ; /* AF_INET6 || AF_INET6_EUI_48*/
_u16 sin6_port ; /* Transport layer port. */
_u32 sin6_flowinfo ; /* IPv6 flow information. */
SlIn6Addr_t sin6_addr ; /* IPv6 address. */
_u32 sin6_scope_id ; /* set of interfaces for a scope. */
} SlSockAddrIn6_t ;
/* Socket address, Internet style. */
typedef struct SlSockAddrIn_t
{
_u16 sin_family ; /* Internet Protocol (AF_INET). */
_u16 sin_port ; /* Address port (16 bits). */
SlInAddr_t sin_addr ; /* Internet address (32 bits). */
_i8 sin_zero [ 8 ] ; /* Not used. */
} SlSockAddrIn_t ;
typedef struct
{
_u32 ip ;
_u32 gateway ;
_u32 dns ;
} SlIpV4AcquiredAsync_t ;
typedef struct
{
_u32 type ;
_u32 ip [ 4 ] ;
_u32 gateway [ 4 ] ;
_u32 dns [ 4 ] ;
} SlIpV6AcquiredAsync_t ;
typedef struct
{
_u32 ip_address ;
_u32 lease_time ;
_u8 mac [ 6 ] ;
_u16 padding ;
} SlIpLeasedAsync_t ;
typedef struct
{
_u32 ip_address ;
_u8 mac [ 6 ] ;
_u16 reason ;
} SlIpReleasedAsync_t ;
typedef union
{
SlIpV4AcquiredAsync_t ipAcquiredV4 ; /*SL_NETAPP_IPV4_IPACQUIRED_EVENT*/
SlIpV6AcquiredAsync_t ipAcquiredV6 ; /*SL_NETAPP_IPV6_IPACQUIRED_EVENT*/
_u32 sd ; /*SL_SOCKET_TX_FAILED_EVENT*/
SlIpLeasedAsync_t ipLeased ; /* SL_NETAPP_IP_LEASED_EVENT */
SlIpReleasedAsync_t ipReleased ; /* SL_NETAPP_IP_RELEASED_EVENT */
} SlNetAppEventData_u ;
typedef struct
{
_u32 Event ;
SlNetAppEventData_u EventData ;
} SlNetAppEvent_t ;
typedef struct sock_secureFiles
{
_u8 secureFiles [ 4 ] ;
} SlSockSecureFiles_t ;
typedef struct SlFdSet_t /* The select socket array manager */
{
_u32 fd_array [ ( SL_FD_SETSIZE + 31 ) / 32 ] ; /* Bit map of SOCKET Descriptors */
} SlFdSet_t ;
typedef struct
{
_u8 rate ; /* Recevied Rate */
_u8 channel ; /* The received channel*/
_i8 rssi ; /* The computed RSSI value in db of current frame */
_u8 padding ; /* pad to align to 32 bits */
_u32 timestamp ; /* Timestamp in microseconds, */
} SlTransceiverRxOverHead_t ;
/*****************************************************************************/
/* Function prototypes */
/*****************************************************************************/
/*!
\ brief create an endpoint for communication
The socket function creates a new socket of a certain socket type , identified
by an integer number , and allocates system resources to it .
This function is called by the application layer to obtain a socket handle .
\ param [ in ] domain specifies the protocol family of the created socket .
For example :
AF_INET for network protocol IPv4
AF_RF for starting transceiver mode . Notes :
- sending and receiving any packet overriding 802.11 header
- for optimized power consumption the socket will be started in TX
only mode until receive command is activated
AF_INET6 for IPv6
\ param [ in ] type specifies the communication semantic , one of :
SOCK_STREAM ( reliable stream - oriented service or Stream Sockets )
SOCK_DGRAM ( datagram service or Datagram Sockets )
SOCK_RAW ( raw protocols atop the network layer )
when used with AF_RF :
SOCK_DGRAM - L2 socket
SOCK_RAW - L1 socket - bypass WLAN CCA ( Clear Channel Assessment )
\ param [ in ] protocol specifies a particular transport to be used with
the socket .
The most common are IPPROTO_TCP , IPPROTO_SCTP , IPPROTO_UDP ,
IPPROTO_DCCP .
The value 0 may be used to select a default
protocol from the selected domain and type
\ return On success , socket handle that is used for consequent socket operations .
A successful return code should be a positive number ( int16 )
On error , a negative ( int16 ) value will be returned specifying the error code .
SL_EAFNOSUPPORT - illegal domain parameter
SL_EPROTOTYPE - illegal type parameter
SL_EACCES - permission denied
SL_ENSOCK - exceeded maximal number of socket
SL_ENOMEM - memory allocation error
SL_EINVAL - error in socket configuration
SL_EPROTONOSUPPORT - illegal protocol parameter
SL_EOPNOTSUPP - illegal combination of protocol and type parameters
\ sa sl_Close
\ note belongs to \ ref basic_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Socket)
_i16 sl_Socket ( _i16 Domain , _i16 Type , _i16 Protocol ) ;
# endif
/*!
\ brief gracefully close socket
This function causes the system to release resources allocated to a socket . \ n
In case of TCP , the connection is terminated .
\ param [ in ] sd socket handle ( received in sl_Socket )
\ return On success , zero is returned .
On error , a negative number is returned .
\ sa sl_Socket
\ note belongs to \ ref ext_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Close)
_i16 sl_Close ( _i16 sd ) ;
# endif
/*!
\ brief Accept a connection on a socket
This function is used with connection - based socket types ( SOCK_STREAM ) .
It extracts the first connection request on the queue of pending
connections , creates a new connected socket , and returns a new file
descriptor referring to that socket .
The newly created socket is not in the listening state . The
original socket sd is unaffected by this call .
The argument sd is a socket that has been created with
sl_Socket ( ) , bound to a local address with sl_Bind ( ) , and is
listening for connections after a sl_Listen ( ) . The argument \ b
\ e addr is a pointer to a sockaddr structure . This structure
is filled in with the address of the peer socket , as known to
the communications layer . The exact format of the address
returned addr is determined by the socket ' s address family .
The \ b \ e addrlen argument is a value - result argument : it
should initially contain the size of the structure pointed to
by addr , on return it will contain the actual length ( in
bytes ) of the address returned .
\ param [ in ] sd socket descriptor ( handle )
\ param [ out ] addr the argument addr is a pointer
to a sockaddr structure . This
structure is filled in with the
address of the peer socket , as
known to the communications
layer . The exact format of the
address returned addr is
determined by the socket ' s
address \ n
sockaddr : \ n - code for the
address format . On this version
only AF_INET is supported . \ n -
socket address , the length
depends on the code format
\ param [ out ] addrlen the addrlen argument is a value - result
argument : it should initially contain the
size of the structure pointed to by addr
\ return On success , a socket handle .
On a non - blocking accept a possible negative value is SL_EAGAIN .
On failure , negative value .
SL_POOL_IS_EMPTY may be return in case there are no resources in the system
In this case try again later or increase MAX_CONCURRENT_ACTIONS
\ sa sl_Socket sl_Bind sl_Listen
\ note belongs to \ ref server_side
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Accept)
_i16 sl_Accept ( _i16 sd , SlSockAddr_t * addr , SlSocklen_t * addrlen ) ;
# endif
/*!
\ brief assign a name to a socket
This function gives the socket the local address addr .
addr is addrlen bytes long . Traditionally , this is called
When a socket is created with socket , it exists in a name
space ( address family ) but has no name assigned .
It is necessary to assign a local address before a SOCK_STREAM
socket may receive connections .
\ param [ in ] sd socket descriptor ( handle )
\ param [ in ] addr specifies the destination
addrs \ n sockaddr : \ n - code for
the address format . On this
version only AF_INET is
supported . \ n - socket address ,
the length depends on the code
format
\ param [ in ] addrlen contains the size of the structure pointed to by addr
\ return On success , zero is returned . On error , a negative error code is returned .
\ sa sl_Socket sl_Accept sl_Listen
\ note belongs to \ ref basic_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Bind)
_i16 sl_Bind ( _i16 sd , const SlSockAddr_t * addr , _i16 addrlen ) ;
# endif
/*!
\ brief listen for connections on a socket
The willingness to accept incoming connections and a queue
limit for incoming connections are specified with listen ( ) ,
and then the connections are accepted with accept .
The listen ( ) call applies only to sockets of type SOCK_STREAM
The backlog parameter defines the maximum length the queue of
pending connections may grow to .
\ param [ in ] sd socket descriptor ( handle )
\ param [ in ] backlog specifies the listen queue depth .
\ return On success , zero is returned . On error , a negative error code is returned .
\ sa sl_Socket sl_Accept sl_Bind
\ note belongs to \ ref server_side
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Listen)
_i16 sl_Listen ( _i16 sd , _i16 backlog ) ;
# endif
/*!
\ brief Initiate a connection on a socket
Function connects the socket referred to by the socket
descriptor sd , to the address specified by addr . The addrlen
argument specifies the size of addr . The format of the
address in addr is determined by the address space of the
socket . If it is of type SOCK_DGRAM , this call specifies the
peer with which the socket is to be associated ; this address
is that to which datagrams are to be sent , and the only
address from which datagrams are to be received . If the
socket is of type SOCK_STREAM , this call attempts to make a
connection to another socket . The other socket is specified
by address , which is an address in the communications space
of the socket .
\ param [ in ] sd socket descriptor ( handle )
\ param [ in ] addr specifies the destination addr \ n
sockaddr : \ n - code for the
address format . On this version
only AF_INET is supported . \ n -
socket address , the length
depends on the code format
\ param [ in ] addrlen contains the size of the structure pointed
to by addr
\ return On success , a socket handle .
On a non - blocking connect a possible negative value is SL_EALREADY .
On failure , negative value .
SL_POOL_IS_EMPTY may be return in case there are no resources in the system
In this case try again later or increase MAX_CONCURRENT_ACTIONS
\ sa sl_Socket
\ note belongs to \ ref client_side
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Connect)
_i16 sl_Connect ( _i16 sd , const SlSockAddr_t * addr , _i16 addrlen ) ;
# endif
/*!
\ brief Monitor socket activity
Select allow a program to monitor multiple file descriptors ,
waiting until one or more of the file descriptors become
" ready " for some class of I / O operation
\ param [ in ] nfds the highest - numbered file descriptor in any of the
three sets , plus 1.
\ param [ out ] readsds socket descriptors list for read monitoring and accept monitoring
2015-03-15 11:45:01 +01:00
\ param [ out ] writesds socket descriptors list for connect monitoring only , write monitoring is not supported , non blocking connect is supported
2015-02-06 15:35:48 +01:00
\ param [ out ] exceptsds socket descriptors list for exception monitoring , not supported .
\ param [ in ] timeout is an upper bound on the amount of time elapsed
before select ( ) returns . Null or above 0xffff seconds means
infinity timeout . The minimum timeout is 10 milliseconds ,
less than 10 milliseconds will be set automatically to 10 milliseconds .
Max microseconds supported is 0xfffc00 .
\ return On success , select ( ) returns the number of
file descriptors contained in the three returned
descriptor sets ( that is , the total number of bits that
are set in readfds , writefds , exceptfds ) which may be
zero if the timeout expires before anything interesting
happens . On error , a negative value is returned .
readsds - return the sockets on which Read request will
return without delay with valid data .
writesds - return the sockets on which Write request
will return without delay .
exceptsds - return the sockets closed recently .
SL_POOL_IS_EMPTY may be return in case there are no resources in the system
In this case try again later or increase MAX_CONCURRENT_ACTIONS
\ sa sl_Socket
\ note If the timeout value set to less than 5 ms it will automatically set
to 5 ms to prevent overload of the system
belongs to \ ref basic_api
Only one sl_Select can be handled at a time .
Calling this API while the same command is called from another thread , may result
in one of the two scenarios :
1. The command will wait ( internal ) until the previous command finish , and then be executed .
2. There are not enough resources and SL_POOL_IS_EMPTY error will return .
In this case , MAX_CONCURRENT_ACTIONS can be increased ( result in memory increase ) or try
again later to issue the command .
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Select)
_i16 sl_Select ( _i16 nfds , SlFdSet_t * readsds , SlFdSet_t * writesds , SlFdSet_t * exceptsds , struct SlTimeval_t * timeout ) ;
/*!
\ brief Select ' s SlFdSet_t SET function
Sets current socket descriptor on SlFdSet_t container
*/
void SL_FD_SET ( _i16 fd , SlFdSet_t * fdset ) ;
/*!
\ brief Select ' s SlFdSet_t CLR function
Clears current socket descriptor on SlFdSet_t container
*/
void SL_FD_CLR ( _i16 fd , SlFdSet_t * fdset ) ;
/*!
\ brief Select ' s SlFdSet_t ISSET function
Checks if current socket descriptor is set ( TRUE / FALSE )
\ return Returns TRUE if set , FALSE if unset
*/
_i16 SL_FD_ISSET ( _i16 fd , SlFdSet_t * fdset ) ;
/*!
\ brief Select ' s SlFdSet_t ZERO function
Clears all socket descriptors from SlFdSet_t
*/
void SL_FD_ZERO ( SlFdSet_t * fdset ) ;
# endif
/*!
\ brief set socket options
This function manipulate the options associated with a socket .
Options may exist at multiple protocol levels ; they are always
present at the uppermost socket level .
When manipulating socket options the level at which the option resides
and the name of the option must be specified . To manipulate options at
the socket level , level is specified as SOL_SOCKET . To manipulate
options at any other level the protocol number of the appropriate proto -
col controlling the option is supplied . For example , to indicate that an
option is to be interpreted by the TCP protocol , level should be set to
the protocol number of TCP ;
The parameters optval and optlen are used to access optval -
ues for setsockopt ( ) . For getsockopt ( ) they identify a
buffer in which the value for the requested option ( s ) are to
be returned . For getsockopt ( ) , optlen is a value - result
parameter , initially containing the size of the buffer
pointed to by option_value , and modified on return to
indicate the actual size of the value returned . If no option
value is to be supplied or returned , option_value may be
NULL .
\ param [ in ] sd socket handle
\ param [ in ] level defines the protocol level for this option
- < b > SL_SOL_SOCKET < / b > Socket level configurations ( L4 , transport layer )
- < b > SL_IPPROTO_IP < / b > IP level configurations ( L3 , network layer )
- < b > SL_SOL_PHY_OPT < / b > Link level configurations ( L2 , link layer )
\ param [ in ] optname defines the option name to interrogate
- < b > SL_SOL_SOCKET < / b >
- < b > SL_SO_KEEPALIVE < / b > \ n
Enable / Disable periodic keep alive .
Keeps TCP connections active by enabling the periodic transmission of messages \ n
Timeout is 5 minutes . \ n
Default : Enabled \ n
This options takes SlSockKeepalive_t struct as parameter
- < b > SL_SO_RCVTIMEO < / b > \ n
Sets the timeout value that specifies the maximum amount of time an input function waits until it completes . \ n
Default : No timeout \ n
This options takes SlTimeval_t struct as parameter
- < b > SL_SO_RCVBUF < / b > \ n
Sets tcp max recv window size . \ n
This options takes SlSockWinsize_t struct as parameter
- < b > SL_SO_NONBLOCKING < / b > \ n
Sets socket to non - blocking operation Impacts : connect , accept , send , sendto , recv and recvfrom . \ n
Default : Blocking .
This options takes SlSockNonblocking_t struct as parameter
- < b > SL_SO_SECMETHOD < / b > \ n
Sets method to tcp secured socket ( SL_SEC_SOCKET ) \ n
Default : SL_SO_SEC_METHOD_SSLv3_TLSV1_2 \ n
This options takes SlSockSecureMethod struct as parameter
- < b > SL_SO_SEC_MASK < / b > \ n
Sets specific cipher to tcp secured socket ( SL_SEC_SOCKET ) \ n
Default : " Best " cipher suitable to method \ n
This options takes SlSockSecureMask struct as parameter
- < b > SL_SO_SECURE_FILES_CA_FILE_NAME < / b > \ n
Map secured socket to CA file by name \ n
This options takes < b > _u8 < / b > buffer as parameter
- < b > SL_SO_SECURE_FILES_PRIVATE_KEY_FILE_NAME < / b > \ n
Map secured socket to private key by name \ n
This options takes < b > _u8 < / b > buffer as parameter
- < b > SL_SO_SECURE_FILES_CERTIFICATE_FILE_NAME < / b > \ n
Map secured socket to certificate file by name \ n
This options takes < b > _u8 < / b > buffer as parameter
- < b > SL_SO_SECURE_FILES_DH_KEY_FILE_NAME < / b > \ n
Map secured socket to Diffie Hellman file by name \ n
This options takes < b > _u8 < / b > buffer as parameter
- < b > SL_SO_CHANGE_CHANNEL < / b > \ n
Sets channel in transceiver mode .
This options takes < b > _u32 < / b > as channel number parameter
- < b > SL_IPPROTO_IP < / b >
- < b > SL_IP_MULTICAST_TTL < / b > \ n
Set the time - to - live value of outgoing multicast packets for this socket . \ n
This options takes < b > _u8 < / b > as parameter
- < b > SL_IP_ADD_MEMBERSHIP < / b > \ n
UDP socket , Join a multicast group . \ n
This options takes SlSockIpMreq struct as parameter
- < b > SL_IP_DROP_MEMBERSHIP < / b > \ n
UDP socket , Leave a multicast group \ n
This options takes SlSockIpMreq struct as parameter
- < b > SL_IP_RAW_RX_NO_HEADER < / b > \ n
Raw socket remove IP header from received data . \ n
Default : data includes ip header \ n
This options takes < b > _u32 < / b > as parameter
- < b > SL_IP_HDRINCL < / b > \ n
RAW socket only , the IPv4 layer generates an IP header when sending a packet unless \ n
the IP_HDRINCL socket option is enabled on the socket . \ n
When it is enabled , the packet must contain an IP header . \ n
Default : disabled , IPv4 header generated by Network Stack \ n
This options takes < b > _u32 < / b > as parameter
- < b > SL_IP_RAW_IPV6_HDRINCL < / b > ( inactive ) \ n
RAW socket only , the IPv6 layer generates an IP header when sending a packet unless \ n
the IP_HDRINCL socket option is enabled on the socket . When it is enabled , the packet must contain an IP header \ n
Default : disabled , IPv4 header generated by Network Stack \ n
This options takes < b > _u32 < / b > as parameter
- < b > SL_SOL_PHY_OPT < / b >
- < b > SL_SO_PHY_RATE < / b > \ n
RAW socket , set WLAN PHY transmit rate \ n
The values are based on RateIndex_e \ n
This options takes < b > _u32 < / b > as parameter
- < b > SL_SO_PHY_TX_POWER < / b > \ n
RAW socket , set WLAN PHY TX power \ n
Valid rage is 1 - 15 \ n
This options takes < b > _u32 < / b > as parameter
- < b > SL_SO_PHY_NUM_FRAMES_TO_TX < / b > \ n
RAW socket , set number of frames to transmit in transceiver mode .
Default : 1 packet
This options takes < b > _u32 < / b > as parameter
- < b > SL_SO_PHY_PREAMBLE < / b > \ n
RAW socket , set WLAN PHY preamble for Long / Short \ n
This options takes < b > _u32 < / b > as parameter
\ param [ in ] optval specifies a value for the option
\ param [ in ] optlen specifies the length of the
option value
\ return On success , zero is returned .
On error , a negative value is returned .
\ sa sl_getsockopt
\ note belongs to \ ref basic_api
\ warning
\ par Examples :
\ par
< b > SL_SO_KEEPALIVE : < / b > ( disable Keepalive )
\ code
SlSockKeepalive_t enableOption ;
enableOption . KeepaliveEnabled = 0 ;
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_KEEPALIVE , ( _u8 * ) & enableOption , sizeof ( enableOption ) ) ;
\ endcode
\ par
< b > SL_SO_RCVTIMEO : < / b >
\ code
struct SlTimeval_t timeVal ;
timeVal . tv_sec = 1 ; // Seconds
timeVal . tv_usec = 0 ; // Microseconds. 10000 microseconds resolution
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_RCVTIMEO , ( _u8 * ) & timeVal , sizeof ( timeVal ) ) ; // Enable receive timeout
\ endcode
\ par
< b > SL_SO_RCVBUF : < / b >
\ code
SlSockWinsize_t size ;
size . Winsize = 3000 ; // bytes
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_RCVBUF , ( _u8 * ) & size , sizeof ( size ) ) ;
\ endcode
\ par
< b > SL_SO_NONBLOCKING : < / b >
\ code
SlSockNonblocking_t enableOption ;
enableOption . NonblockingEnabled = 1 ;
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_NONBLOCKING , ( _u8 * ) & enableOption , sizeof ( enableOption ) ) ; // Enable/disable nonblocking mode
\ endcode
\ par
< b > SL_SO_SECMETHOD : < / b >
\ code
SlSockSecureMethod method ;
method . secureMethod = SL_SO_SEC_METHOD_SSLV3 ; // security method we want to use
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_STREAM , SL_SEC_SOCKET ) ;
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SECMETHOD , ( _u8 * ) & method , sizeof ( method ) ) ;
\ endcode
\ par
< b > SL_SO_SECURE_MASK : < / b >
\ code
SlSockSecureMask cipher ;
cipher . secureMask = SL_SEC_MASK_SSL_RSA_WITH_RC4_128_SHA ; // cipher type
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_STREAM , SL_SEC_SOCKET ) ;
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SEC_MASK , ( _u8 * ) & cipher , sizeof ( cipher ) ) ;
\ endcode
\ par
< b > SL_SO_SECURE_FILES_CA_FILE_NAME : < / b >
\ code
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SECURE_FILES_CA_FILE_NAME , " exuifaxCaCert.der " , strlen ( " exuifaxCaCert.der " ) ) ;
\ endcode
\ par
< b > SL_SO_SECURE_FILES_PRIVATE_KEY_FILE_NAME : < / b >
\ code
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SECURE_FILES_PRIVATE_KEY_FILE_NAME , " myPrivateKey.der " , strlen ( " myPrivateKey.der " ) ) ;
\ endcode
\ par
< b > SL_SO_SECURE_FILES_CERTIFICATE_FILE_NAME : < / b >
\ code
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SECURE_FILES_CERTIFICATE_FILE_NAME , " myCertificate.der " , strlen ( " myCertificate.der " ) ) ;
\ endcode
\ par
< b > SL_SO_SECURE_FILES_DH_KEY_FILE_NAME : < / b >
\ code
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_SECURE_FILES_DH_KEY_FILE_NAME , " myDHinServerMode.der " , strlen ( " myDHinServerMode.der " ) ) ;
\ endcode
\ par
< b > SL_IP_MULTICAST_TTL : < / b >
\ code
_u8 ttl = 20 ;
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_MULTICAST_TTL , & ttl , sizeof ( ttl ) ) ;
\ endcode
\ par
< b > SL_IP_ADD_MEMBERSHIP : < / b >
\ code
SlSockIpMreq mreq ;
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_ADD_MEMBERSHIP , & mreq , sizeof ( mreq ) ) ;
\ endcode
\ par
< b > SL_IP_DROP_MEMBERSHIP : < / b >
\ code
SlSockIpMreq mreq ;
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_DROP_MEMBERSHIP , & mreq , sizeof ( mreq ) ) ;
\ endcode
\ par
< b > SL_SO_CHANGE_CHANNEL : < / b >
\ code
_u32 newChannel = 6 ; // range is 1-13
sl_SetSockOpt ( SockID , SL_SOL_SOCKET , SL_SO_CHANGE_CHANNEL , & newChannel , sizeof ( newChannel ) ) ;
\ endcode
\ par
< b > SL_IP_RAW_RX_NO_HEADER : < / b >
\ code
_u32 header = 1 ; // remove ip header
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_RAW_RX_NO_HEADER , & header , sizeof ( header ) ) ;
\ endcode
\ par
< b > SL_IP_HDRINCL : < / b >
\ code
_u32 header = 1 ;
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_HDRINCL , & header , sizeof ( header ) ) ;
\ endcode
\ par
< b > SL_IP_RAW_IPV6_HDRINCL : < / b >
\ code
_u32 header = 1 ;
sl_SetSockOpt ( SockID , SL_IPPROTO_IP , SL_IP_RAW_IPV6_HDRINCL , & header , sizeof ( header ) ) ;
\ endcode
\ par
< b > SL_SO_PHY_RATE : < / b >
\ code
_u32 rate = 6 ; // see wlan.h RateIndex_e for values
sl_SetSockOpt ( SockID , SL_SOL_PHY_OPT , SL_SO_PHY_RATE , & rate , sizeof ( rate ) ) ;
\ endcode
\ par
< b > SL_SO_PHY_TX_POWER : < / b >
\ code
_u32 txpower = 1 ; // valid range is 1-15
sl_SetSockOpt ( SockID , SL_SOL_PHY_OPT , SL_SO_PHY_TX_POWER , & txpower , sizeof ( txpower ) ) ;
\ endcode
\ par
< b > SL_SO_PHY_NUM_FRAMES_TO_TX : < / b >
\ code
_u32 numframes = 1 ;
sl_SetSockOpt ( SockID , SL_SOL_PHY_OPT , SL_SO_PHY_NUM_FRAMES_TO_TX , & numframes , sizeof ( numframes ) ) ;
\ endcode
\ par
< b > SL_SO_PHY_PREAMBLE : < / b >
\ code
_u32 preamble = 1 ;
sl_SetSockOpt ( SockID , SL_SOL_PHY_OPT , SL_SO_PHY_PREAMBLE , & preamble , sizeof ( preamble ) ) ;
\ endcode
*/
# if _SL_INCLUDE_FUNC(sl_SetSockOpt)
_i16 sl_SetSockOpt ( _i16 sd , _i16 level , _i16 optname , const void * optval , SlSocklen_t optlen ) ;
# endif
/*!
\ brief Get socket options
This function manipulate the options associated with a socket .
Options may exist at multiple protocol levels ; they are always
present at the uppermost socket level .
When manipulating socket options the level at which the option resides
and the name of the option must be specified . To manipulate options at
the socket level , level is specified as SOL_SOCKET . To manipulate
options at any other level the protocol number of the appropriate proto -
col controlling the option is supplied . For example , to indicate that an
option is to be interpreted by the TCP protocol , level should be set to
the protocol number of TCP ;
The parameters optval and optlen are used to access optval -
ues for setsockopt ( ) . For getsockopt ( ) they identify a
buffer in which the value for the requested option ( s ) are to
be returned . For getsockopt ( ) , optlen is a value - result
parameter , initially containing the size of the buffer
pointed to by option_value , and modified on return to
indicate the actual size of the value returned . If no option
value is to be supplied or returned , option_value may be
NULL .
\ param [ in ] sd socket handle
\ param [ in ] level defines the protocol level for this option
\ param [ in ] optname defines the option name to interrogate
\ param [ out ] optval specifies a value for the option
\ param [ out ] optlen specifies the length of the
option value
\ return On success , zero is returned .
On error , a negative value is returned .
\ sa sl_SetSockOpt
\ note See sl_SetSockOpt
belongs to \ ref ext_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_GetSockOpt)
_i16 sl_GetSockOpt ( _i16 sd , _i16 level , _i16 optname , void * optval , SlSocklen_t * optlen ) ;
# endif
/*!
\ brief read data from TCP socket
function receives a message from a connection - mode socket
\ param [ in ] sd socket handle
\ param [ out ] buf Points to the buffer where the
message should be stored .
\ param [ in ] Len Specifies the length in bytes of
the buffer pointed to by the buffer argument .
Range : 1 - 16000 bytes
\ param [ in ] flags Specifies the type of message
reception . On this version , this parameter is not
supported .
\ return return the number of bytes received ,
or a negative value if an error occurred .
using a non - blocking recv a possible negative value is SL_EAGAIN .
SL_POOL_IS_EMPTY may be return in case there are no resources in the system
In this case try again later or increase MAX_CONCURRENT_ACTIONS
\ sa sl_RecvFrom
\ note belongs to \ ref recv_api
\ warning
\ par Examples :
\ code An example of receiving data using TCP socket :
SlSockAddrIn_t Addr ;
SlSockAddrIn_t LocalAddr ;
_i16 AddrSize = sizeof ( SlSockAddrIn_t ) ;
_i16 SockID , newSockID ;
_i16 Status ;
_i8 Buf [ RECV_BUF_LEN ] ;
LocalAddr . sin_family = SL_AF_INET ;
LocalAddr . sin_port = sl_Htons ( 5001 ) ;
LocalAddr . sin_addr . s_addr = 0 ;
Addr . sin_family = SL_AF_INET ;
Addr . sin_port = sl_Htons ( 5001 ) ;
Addr . sin_addr . s_addr = sl_Htonl ( SL_IPV4_VAL ( 10 , 1 , 1 , 200 ) ) ;
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_STREAM , 0 ) ;
Status = sl_Bind ( SockID , ( SlSockAddr_t * ) & LocalAddr , AddrSize ) ;
Status = sl_Listen ( SockID , 0 ) ;
newSockID = sl_Accept ( SockID , ( SlSockAddr_t * ) & Addr , ( SlSocklen_t * ) & AddrSize ) ;
Status = sl_Recv ( newSockID , Buf , 1460 , 0 ) ;
\ endcode
\ code Example code for Rx transceiver mode using a raw socket
_i8 buffer [ 1536 ] ;
_i16 sd ;
_u16 size ;
SlTransceiverRxOverHead_t * transHeader ;
sd = sl_Socket ( SL_AF_RF , SL_SOCK_RAW , 11 ) ; // channel 11
while ( 1 )
{
size = sl_Recv ( sd , buffer , 1536 , 0 ) ;
transHeader = ( SlTransceiverRxOverHead_t * ) buffer ;
printf ( " RSSI is %d frame type is 0x%x size %d \n " , transHeader - > rssi , buffer [ sizeof ( SlTransceiverRxOverHead_t ) ] , size ) ;
}
\ endcode
*/
# if _SL_INCLUDE_FUNC(sl_Recv)
_i16 sl_Recv ( _i16 sd , void * buf , _i16 Len , _i16 flags ) ;
# endif
/*!
\ brief read data from socket
function receives a message from a connection - mode or
connectionless - mode socket
\ param [ in ] sd socket handle
\ param [ out ] buf Points to the buffer where the message should be stored .
\ param [ in ] Len Specifies the length in bytes of the buffer pointed to by the buffer argument .
Range : 1 - 16000 bytes
\ param [ in ] flags Specifies the type of message
reception . On this version , this parameter is not
supported .
\ param [ in ] from pointer to an address structure
indicating the source
address . \ n sockaddr : \ n - code
for the address format . On this
version only AF_INET is
supported . \ n - socket address ,
the length depends on the code
format
\ param [ in ] fromlen source address structure
size . This parameter MUST be set to the size of the structure pointed to by addr .
\ return return the number of bytes received ,
or a negative value if an error occurred .
using a non - blocking recv a possible negative value is SL_EAGAIN .
SL_RET_CODE_INVALID_INPUT ( - 2 ) will be returned if fromlen has incorrect length .
SL_POOL_IS_EMPTY may be return in case there are no resources in the system
In this case try again later or increase MAX_CONCURRENT_ACTIONS
\ sa sl_Recv
\ note belongs to \ ref recv_api
\ warning
\ par Example :
\ code An example of receiving data :
SlSockAddrIn_t Addr ;
SlSockAddrIn_t LocalAddr ;
_i16 AddrSize = sizeof ( SlSockAddrIn_t ) ;
_i16 SockID ;
_i16 Status ;
_i8 Buf [ RECV_BUF_LEN ] ;
LocalAddr . sin_family = SL_AF_INET ;
LocalAddr . sin_port = sl_Htons ( 5001 ) ;
LocalAddr . sin_addr . s_addr = 0 ;
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_DGRAM , 0 ) ;
Status = sl_Bind ( SockID , ( SlSockAddr_t * ) & LocalAddr , AddrSize ) ;
Status = sl_RecvFrom ( SockID , Buf , 1472 , 0 , ( SlSockAddr_t * ) & Addr , ( SlSocklen_t * ) & AddrSize ) ;
\ endcode
*/
# if _SL_INCLUDE_FUNC(sl_RecvFrom)
_i16 sl_RecvFrom ( _i16 sd , void * buf , _i16 Len , _i16 flags , SlSockAddr_t * from , SlSocklen_t * fromlen ) ;
# endif
/*!
\ brief write data to TCP socket
This function is used to transmit a message to another socket .
Returns immediately after sending data to device .
In case of TCP failure an async event SL_SOCKET_TX_FAILED_EVENT is going to
be received .
In case of a RAW socket ( transceiver mode ) , extra 4 bytes should be reserved at the end of the
frame data buffer for WLAN FCS
\ param [ in ] sd socket handle
\ param [ in ] buf Points to a buffer containing
the message to be sent
\ param [ in ] Len message size in bytes . Range : 1 - 1460 bytes
\ param [ in ] flags Specifies the type of message
transmission . On this version , this parameter is not
supported for TCP .
For transceiver mode , the SL_RAW_RF_TX_PARAMS macro can be used to determine
transmission parameters ( channel , rate , tx_power , preamble )
\ return Return the number of bytes transmitted ,
or - 1 if an error occurred
\ sa sl_SendTo
\ note belongs to \ ref send_api
\ warning
\ par Example :
\ code An example of sending data :
SlSockAddrIn_t Addr ;
_i16 AddrSize = sizeof ( SlSockAddrIn_t ) ;
_i16 SockID ;
_i16 Status ;
_i8 Buf [ SEND_BUF_LEN ] ;
Addr . sin_family = SL_AF_INET ;
Addr . sin_port = sl_Htons ( 5001 ) ;
Addr . sin_addr . s_addr = sl_Htonl ( SL_IPV4_VAL ( 10 , 1 , 1 , 200 ) ) ;
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_STREAM , 0 ) ;
Status = sl_Connect ( SockID , ( SlSockAddr_t * ) & Addr , AddrSize ) ;
Status = sl_Send ( SockID , Buf , 1460 , 0 ) ;
\ endcode
*/
# if _SL_INCLUDE_FUNC(sl_Send )
_i16 sl_Send ( _i16 sd , const void * buf , _i16 Len , _i16 flags ) ;
# endif
/*!
\ brief write data to socket
This function is used to transmit a message to another socket
( connection less socket SOCK_DGRAM , SOCK_RAW ) .
Returns immediately after sending data to device .
In case of transmission failure an async event SL_SOCKET_TX_FAILED_EVENT is going to
be received .
\ param [ in ] sd socket handle
\ param [ in ] buf Points to a buffer containing
the message to be sent
\ param [ in ] Len message size in bytes . Range : 1 - 1460 bytes
\ param [ in ] flags Specifies the type of message
transmission . On this version , this parameter is not
supported
\ param [ in ] to pointer to an address structure
indicating the destination
address . \ n sockaddr : \ n - code
for the address format . On this
version only AF_INET is
supported . \ n - socket address ,
the length depends on the code
format
\ param [ in ] tolen destination address structure size
\ return Return the number of transmitted bytes ,
or - 1 if an error occurred
\ sa sl_Send
\ note belongs to \ ref send_api
\ warning
\ par Example :
\ code An example of sending data :
SlSockAddrIn_t Addr ;
_i16 AddrSize = sizeof ( SlSockAddrIn_t ) ;
_i16 SockID ;
_i16 Status ;
_i8 Buf [ SEND_BUF_LEN ] ;
Addr . sin_family = SL_AF_INET ;
Addr . sin_port = sl_Htons ( 5001 ) ;
Addr . sin_addr . s_addr = sl_Htonl ( SL_IPV4_VAL ( 10 , 1 , 1 , 200 ) ) ;
SockID = sl_Socket ( SL_AF_INET , SL_SOCK_DGRAM , 0 ) ;
Status = sl_SendTo ( SockID , Buf , 1472 , 0 , ( SlSockAddr_t * ) & Addr , AddrSize ) ;
\ endcode
*/
# if _SL_INCLUDE_FUNC(sl_SendTo)
_i16 sl_SendTo ( _i16 sd , const void * buf , _i16 Len , _i16 flags , const SlSockAddr_t * to , SlSocklen_t tolen ) ;
# endif
/*!
\ brief Reorder the bytes of a 32 - bit unsigned value
This function is used to Reorder the bytes of a 32 - bit unsigned value from processor order to network order .
\ param [ in ] var variable to reorder
\ return Return the reorder variable ,
\ sa sl_SendTo sl_Bind sl_Connect sl_RecvFrom sl_Accept
\ note belongs to \ ref send_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Htonl )
_u32 sl_Htonl ( _u32 val ) ;
# define sl_Ntohl sl_Htonl /* Reorder the bytes of a 16-bit unsigned value from network order to processor orde. */
# endif
/*!
\ brief Reorder the bytes of a 16 - bit unsigned value
This function is used to Reorder the bytes of a 16 - bit unsigned value from processor order to network order .
\ param [ in ] var variable to reorder
\ return Return the reorder variable ,
\ sa sl_SendTo sl_Bind sl_Connect sl_RecvFrom sl_Accept
\ note belongs to \ ref send_api
\ warning
*/
# if _SL_INCLUDE_FUNC(sl_Htons )
_u16 sl_Htons ( _u16 val ) ;
# define sl_Ntohs sl_Htons /* Reorder the bytes of a 16-bit unsigned value from network order to processor orde. */
# endif
/*!
Close the Doxygen group .
@ }
*/
# ifdef __cplusplus
}
# endif /* __cplusplus */
# endif /* __SOCKET_H__ */