]> git.proxmox.com Git - ovs.git/blame - lib/socket-util.h
jsonrpc: Increment sequence number when connection actually made.
[ovs.git] / lib / socket-util.h
CommitLineData
064af421 1/*
afc1d536 2 * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015 Nicira, Inc.
064af421 3 *
a14bc59f
BP
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
064af421 7 *
a14bc59f
BP
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
064af421
BP
15 */
16
17#ifndef SOCKET_UTIL_H
18#define SOCKET_UTIL_H 1
19
0f0b5401 20#include <errno.h>
064af421 21#include <sys/types.h>
8e47be77 22#include <sys/socket.h>
72af4a85 23#include <sys/time.h>
dd23522f 24#include <sys/un.h>
064af421
BP
25#include <netinet/in.h>
26#include <stdbool.h>
dbba996b 27#include "openvswitch/types.h"
14235530 28#include <netinet/in_systm.h>
f125905c 29#include <netinet/ip.h>
064af421 30
fd245f1d
BP
31struct ds;
32
064af421 33int set_nonblocking(int fd);
a0505c49 34void xset_nonblocking(int fd);
b7cefbf7 35void setsockopt_tcp_nodelay(int fd);
afc1d536 36int set_dscp(int fd, int family, uint8_t dscp);
a0505c49 37
9835576b 38bool addr_is_ipv6(const char *host_name);
064af421 39int lookup_ip(const char *host_name, struct in_addr *address);
d31f1109 40int lookup_ipv6(const char *host_name, struct in6_addr *address);
13f2ef97
BP
41
42int lookup_hostname(const char *host_name, struct in_addr *);
43
c1c19657 44int get_socket_rcvbuf(int sock);
064af421 45int check_connection_completion(int fd);
064af421 46void drain_fd(int fd, size_t n_packets);
dbba996b 47ovs_be32 guess_netmask(ovs_be32 ip);
064af421 48
52f8a75e 49bool inet_parse_active(const char *target, uint16_t default_port,
e731d71b 50 struct sockaddr_storage *ssp);
4f2eb9a7 51int inet_open_active(int style, const char *target, uint16_t default_port,
e731d71b 52 struct sockaddr_storage *ssp, int *fdp, uint8_t dscp);
d98fa503 53
995337c4 54bool inet_parse_passive(const char *target, int default_port,
e731d71b 55 struct sockaddr_storage *ssp);
36775dad 56int inet_open_passive(int style, const char *target, int default_port,
b52ecd96
GS
57 struct sockaddr_storage *ssp, uint8_t dscp,
58 bool kernel_print_port);
78ff0270 59
064af421
BP
60int read_fully(int fd, void *, size_t, size_t *bytes_read);
61int write_fully(int fd, const void *, size_t, size_t *bytes_written);
62
8e71cf88 63int fsync_parent_dir(const char *file_name);
26efd256 64int get_mtime(const char *file_name, struct timespec *mtime);
8e71cf88 65
f89ffb0e
BP
66char *describe_fd(int fd);
67
f125905c
MM
68/* Default value of dscp bits for connection between controller and manager.
69 * Value of IPTOS_PREC_INTERNETCONTROL = 0xc0 which is defined
cea15768
EJ
70 * in <netinet/ip.h> is used. */
71#define DSCP_DEFAULT (IPTOS_PREC_INTERNETCONTROL >> 2)
f125905c 72
e731d71b
AS
73/* Functions for working with sockaddr_storage that might contain an IPv4 or
74 * IPv6 address. */
75uint16_t ss_get_port(const struct sockaddr_storage *);
fd245f1d 76void ss_format_address(const struct sockaddr_storage *, struct ds *);
e731d71b 77size_t ss_length(const struct sockaddr_storage *);
b26f46a4 78const char *sock_strerror(int error);
e731d71b 79
7f1e1c7f
GS
80#ifndef _WIN32
81void xpipe(int fds[2]);
82void xpipe_nonblocking(int fds[2]);
83
84int drain_rcvbuf(int fd);
85
86int make_unix_socket(int style, bool nonblock,
87 const char *bind_path, const char *connect_path);
dd23522f 88int get_unix_name_len(const struct sockaddr_un *sun, socklen_t sun_len);
7f1e1c7f 89
8a8c1b93
BP
90/* Universal sendmmsg support.
91 *
92 * Some platforms, such as new enough Linux and FreeBSD, support sendmmsg, but
93 * other platforms (or older ones) do not. We add the following infrastructure
94 * to allow all code to use sendmmsg, regardless of platform support:
95 *
96 * - For platforms that lack sendmmsg entirely, we emulate it.
97 *
98 * - Some platforms have sendmmsg() in the C library but not in the kernel.
99 * For example, this is true if a Linux system has a newer glibc with an
100 * old kernel. To compensate, even if sendmmsg() appears to be available,
101 * we still wrap it with a handler that uses our emulation if sendmmsg()
102 * returns ENOSYS.
103 */
104#ifndef HAVE_STRUCT_MMSGHDR_MSG_LEN
105struct mmsghdr {
106 struct msghdr msg_hdr;
107 unsigned int msg_len;
108};
109#endif
110#ifndef HAVE_SENDMMSG
111int sendmmsg(int, struct mmsghdr *, unsigned int, unsigned int);
112#else
113#define sendmmsg wrap_sendmmsg
114int wrap_sendmmsg(int, struct mmsghdr *, unsigned int, unsigned int);
115#endif
116
7f1e1c7f
GS
117/* Helpers for calling ioctl() on an AF_INET socket. */
118struct ifreq;
119int af_inet_ioctl(unsigned long int command, const void *arg);
120int af_inet_ifreq_ioctl(const char *name, struct ifreq *,
121 unsigned long int cmd, const char *cmd_name);
122
123#define closesocket close
124#endif
125
5ea1366b 126#ifdef _WIN32
a35f3d61
AS
127static inline int make_unix_socket(int style, bool nonblock,
128 const char *bind_path,
129 const char *connect_path)
130{
131 return -EINVAL;
132}
133
5ea1366b
GS
134/* Windows defines the 'optval' argument as char * instead of void *. */
135#define setsockopt(sock, level, optname, optval, optlen) \
136 rpl_setsockopt(sock, level, optname, optval, optlen)
137static inline int rpl_setsockopt(int sock, int level, int optname,
138 const void *optval, socklen_t optlen)
139{
140 return (setsockopt)(sock, level, optname, optval, optlen);
141}
9390ef7f
GS
142
143#define getsockopt(sock, level, optname, optval, optlen) \
144 rpl_getsockopt(sock, level, optname, optval, optlen)
145static inline int rpl_getsockopt(int sock, int level, int optname,
146 void *optval, socklen_t *optlen)
147{
148 return (getsockopt)(sock, level, optname, optval, optlen);
149}
5ea1366b
GS
150#endif
151
0f0b5401
GS
152/* In Windows platform, errno is not set for socket calls.
153 * The last error has to be gotten from WSAGetLastError(). */
154static inline int sock_errno(void)
155{
156#ifdef _WIN32
157 return WSAGetLastError();
158#else
159 return errno;
160#endif
161}
162
064af421 163#endif /* socket-util.h */