| /*! \file socket.h |
| * Osmocom socket convenience functions. */ |
| |
| #pragma once |
| #if (!EMBEDDED) |
| |
| /*! \defgroup socket Socket convenience functions |
| * @{ |
| * \file socket.h */ |
| |
| #include <stdint.h> |
| #include <stdbool.h> |
| #include <stddef.h> |
| |
| #include <arpa/inet.h> |
| |
| /*! maximum length of a socket name ("r=1.2.3.4:123<->l=5.6.7.8:987") */ |
| #define OSMO_SOCK_NAME_MAXLEN (2 + INET6_ADDRSTRLEN + 1 + 5 + 3 + 2 + INET6_ADDRSTRLEN + 1 + 5 + 1) |
| |
| struct sockaddr_in; |
| struct sockaddr; |
| struct osmo_fd; |
| |
| struct osmo_sockaddr { |
| union { |
| struct sockaddr sa; |
| struct sockaddr_storage sas; |
| struct sockaddr_in sin; |
| struct sockaddr_in6 sin6; |
| } u; |
| }; |
| |
| /* flags for osmo_sock_init. */ |
| /*! connect the socket to a remote peer */ |
| #define OSMO_SOCK_F_CONNECT (1 << 0) |
| /*! bind the socket to a local address/port */ |
| #define OSMO_SOCK_F_BIND (1 << 1) |
| /*! switch socket to non-blocking mode */ |
| #define OSMO_SOCK_F_NONBLOCK (1 << 2) |
| /*! disable multiast loop (IP_MULTICAST_LOOP) */ |
| #define OSMO_SOCK_F_NO_MCAST_LOOP (1 << 3) |
| /*! disable receiving all multiast even for non-subscribed groups */ |
| #define OSMO_SOCK_F_NO_MCAST_ALL (1 << 4) |
| /*! use SO_REUSEADDR on UDP ports (required for multicast) */ |
| #define OSMO_SOCK_F_UDP_REUSEADDR (1 << 5) |
| |
| /*! use OSMO_SOCK_F_DSCP(x) to set IP DSCP 'x' for packets transmitted on the socket */ |
| #define OSMO_SOCK_F_DSCP(x) (((x)&0x3f) << 24) |
| #define GET_OSMO_SOCK_F_DSCP(f) (((f) >> 24) & 0x3f) |
| |
| /*! use OSMO_SOCK_F_PRIO(x) to set priority 'x' for packets transmitted on the socket */ |
| #define OSMO_SOCK_F_PRIO(x) (((x)&0xff) << 16) |
| #define GET_OSMO_SOCK_F_PRIO(f) (((f) >> 16) & 0xff) |
| |
| |
| /*! maximum number of local or remote addresses supported by an osmo_sock instance */ |
| #define OSMO_SOCK_MAX_ADDRS 32 |
| |
| int osmo_sock_init(uint16_t family, uint16_t type, uint8_t proto, |
| const char *host, uint16_t port, unsigned int flags); |
| |
| int osmo_sock_init2(uint16_t family, uint16_t type, uint8_t proto, |
| const char *local_host, uint16_t local_port, |
| const char *remote_host, uint16_t remote_port, unsigned int flags); |
| |
| int osmo_sock_init2_multiaddr(uint16_t family, uint16_t type, uint8_t proto, |
| const char **local_hosts, size_t local_hosts_cnt, uint16_t local_port, |
| const char **remote_hosts, size_t remote_hosts_cnt, uint16_t remote_port, unsigned int flags); |
| |
| int osmo_sock_init_osa(uint16_t type, uint8_t proto, |
| const struct osmo_sockaddr *local, |
| const struct osmo_sockaddr *remote, |
| unsigned int flags); |
| |
| int osmo_sock_init_ofd(struct osmo_fd *ofd, int family, int type, int proto, |
| const char *host, uint16_t port, unsigned int flags); |
| |
| int osmo_sock_init2_ofd(struct osmo_fd *ofd, int family, int type, int proto, |
| const char *local_host, uint16_t local_port, |
| const char *remote_host, uint16_t remote_port, unsigned int flags); |
| |
| int osmo_sock_init_osa_ofd(struct osmo_fd *ofd, int type, int proto, |
| const struct osmo_sockaddr *local, |
| const struct osmo_sockaddr *remote, |
| unsigned int flags); |
| |
| int osmo_sock_init_sa(struct sockaddr *ss, uint16_t type, |
| uint8_t proto, unsigned int flags); |
| |
| int osmo_sockaddr_is_local(struct sockaddr *addr, unsigned int addrlen); |
| |
| unsigned int osmo_sockaddr_to_str_and_uint(char *addr, unsigned int addr_len, uint16_t *port, |
| const struct sockaddr *sa); |
| size_t osmo_sockaddr_in_to_str_and_uint(char *addr, unsigned int addr_len, uint16_t *port, |
| const struct sockaddr_in *sin); |
| |
| const char *osmo_sockaddr_ntop(const struct sockaddr *sa, char *dst); |
| uint16_t osmo_sockaddr_port(const struct sockaddr *sa); |
| |
| int osmo_sock_unix_init(uint16_t type, uint8_t proto, |
| const char *socket_path, unsigned int flags); |
| |
| int osmo_sock_unix_init_ofd(struct osmo_fd *ofd, uint16_t type, uint8_t proto, |
| const char *socket_path, unsigned int flags); |
| |
| char *osmo_sock_get_name(const void *ctx, int fd); |
| const char *osmo_sock_get_name2(int fd); |
| char *osmo_sock_get_name2_c(const void *ctx, int fd); |
| int osmo_sock_get_name_buf(char *str, size_t str_len, int fd); |
| int osmo_sock_get_ip_and_port(int fd, char *ip, size_t ip_len, char *port, size_t port_len, bool local); |
| int osmo_sock_get_local_ip(int fd, char *host, size_t len); |
| int osmo_sock_get_local_ip_port(int fd, char *port, size_t len); |
| int osmo_sock_get_remote_ip(int fd, char *host, size_t len); |
| int osmo_sock_get_remote_ip_port(int fd, char *port, size_t len); |
| |
| |
| int osmo_sock_mcast_loop_set(int fd, bool enable); |
| int osmo_sock_mcast_ttl_set(int fd, uint8_t ttl); |
| int osmo_sock_mcast_all_set(int fd, bool enable); |
| int osmo_sock_mcast_iface_set(int fd, const char *ifname); |
| int osmo_sock_mcast_subscribe(int fd, const char *grp_addr); |
| |
| int osmo_sock_local_ip(char *local_ip, const char *remote_ip); |
| |
| int osmo_sockaddr_local_ip(struct osmo_sockaddr *local_ip, |
| const struct osmo_sockaddr *remote_ip); |
| int osmo_sockaddr_cmp(const struct osmo_sockaddr *a, |
| const struct osmo_sockaddr *b); |
| |
| const char *osmo_sockaddr_to_str(const struct osmo_sockaddr *sockaddr); |
| char *osmo_sockaddr_to_str_buf(char *buf, size_t buf_len, |
| const struct osmo_sockaddr *sockaddr); |
| |
| int osmo_sock_set_dscp(int fd, uint8_t dscp); |
| int osmo_sock_set_priority(int fd, int prio); |
| |
| #endif /* (!EMBEDDED) */ |
| /*! @} */ |