2009-07-08 13:19:16 -07:00
|
|
|
/*
|
2015-02-20 11:30:50 -08:00
|
|
|
* Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015 Nicira, Inc.
|
2009-07-08 13:19:16 -07:00
|
|
|
*
|
2009-06-15 15:11:30 -07:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
2009-07-08 13:19:16 -07:00
|
|
|
*
|
2009-06-15 15:11:30 -07:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2009-07-08 13:19:16 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SOCKET_UTIL_H
|
|
|
|
#define SOCKET_UTIL_H 1
|
|
|
|
|
2014-02-18 10:25:13 -08:00
|
|
|
#include <errno.h>
|
2009-07-08 13:19:16 -07:00
|
|
|
#include <sys/types.h>
|
2011-09-22 21:24:10 +09:00
|
|
|
#include <sys/socket.h>
|
2011-09-22 21:24:11 +09:00
|
|
|
#include <sys/time.h>
|
2016-07-19 17:05:51 -03:00
|
|
|
#include <sys/un.h>
|
2009-07-08 13:19:16 -07:00
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <stdbool.h>
|
2011-03-29 14:42:20 -07:00
|
|
|
#include "openvswitch/types.h"
|
2013-04-22 22:20:11 +09:00
|
|
|
#include <netinet/in_systm.h>
|
2012-03-10 15:58:10 -08:00
|
|
|
#include <netinet/ip.h>
|
2009-07-08 13:19:16 -07:00
|
|
|
|
|
|
|
int set_nonblocking(int fd);
|
2012-05-14 14:40:06 -07:00
|
|
|
void xset_nonblocking(int fd);
|
2014-10-22 15:35:18 -07:00
|
|
|
void setsockopt_tcp_nodelay(int fd);
|
2015-02-20 11:30:50 -08:00
|
|
|
int set_dscp(int fd, int family, uint8_t dscp);
|
2012-05-14 14:40:06 -07:00
|
|
|
|
2015-10-22 15:28:54 -02:00
|
|
|
bool addr_is_ipv6(const char *host_name);
|
2009-07-08 13:19:16 -07:00
|
|
|
int lookup_ip(const char *host_name, struct in_addr *address);
|
2010-12-29 19:03:46 -08:00
|
|
|
int lookup_ipv6(const char *host_name, struct in6_addr *address);
|
2010-09-16 14:28:53 -07:00
|
|
|
|
|
|
|
int lookup_hostname(const char *host_name, struct in_addr *);
|
|
|
|
|
2011-10-14 13:30:29 -07:00
|
|
|
int get_socket_rcvbuf(int sock);
|
2009-07-08 13:19:16 -07:00
|
|
|
int check_connection_completion(int fd);
|
|
|
|
void drain_fd(int fd, size_t n_packets);
|
2011-03-29 14:42:20 -07:00
|
|
|
ovs_be32 guess_netmask(ovs_be32 ip);
|
2009-07-08 13:19:16 -07:00
|
|
|
|
2010-04-26 10:43:55 -07:00
|
|
|
bool inet_parse_active(const char *target, uint16_t default_port,
|
2014-02-06 16:04:05 -08:00
|
|
|
struct sockaddr_storage *ssp);
|
2009-11-23 12:18:59 -08:00
|
|
|
int inet_open_active(int style, const char *target, uint16_t default_port,
|
2014-02-06 16:04:05 -08:00
|
|
|
struct sockaddr_storage *ssp, int *fdp, uint8_t dscp);
|
2010-09-29 10:15:15 -07:00
|
|
|
|
2011-09-13 13:28:49 -07:00
|
|
|
bool inet_parse_passive(const char *target, int default_port,
|
2014-02-06 16:04:05 -08:00
|
|
|
struct sockaddr_storage *ssp);
|
2010-01-07 15:00:47 -08:00
|
|
|
int inet_open_passive(int style, const char *target, int default_port,
|
2014-05-19 11:58:14 -07:00
|
|
|
struct sockaddr_storage *ssp, uint8_t dscp,
|
|
|
|
bool kernel_print_port);
|
2009-06-12 17:05:51 -07:00
|
|
|
|
2009-07-08 13:19:16 -07:00
|
|
|
int read_fully(int fd, void *, size_t, size_t *bytes_read);
|
|
|
|
int write_fully(int fd, const void *, size_t, size_t *bytes_written);
|
|
|
|
|
2010-02-11 15:35:46 -08:00
|
|
|
int fsync_parent_dir(const char *file_name);
|
2010-04-21 10:47:45 -07:00
|
|
|
int get_mtime(const char *file_name, struct timespec *mtime);
|
2010-02-11 15:35:46 -08:00
|
|
|
|
poll-loop: Make wakeup logging more portable and easier to understand.
Until now, when the poll_loop module's log level was turned up to "debug",
it would log a backtrace of the call stack for the event that caused poll()
to wake up in poll_block(). This was pretty useful from time to time to
find out why ovs-vswitchd was using more CPU than expected, because we
could find out what was causing it to wake up.
But there were some issues. One is simply that the backtrace was printed
as a series of hexadecimal numbers, so GDB or another debugger was needed
to translate it into human-readable format. Compiler optimizations meant
that even the human-readable backtrace wasn't, in my experience, as helpful
as it could have been. And, of course, one needed to have the binary to
interpret the backtrace. When the backtrace couldn't be interpreted or
wasn't meaningful, there was essentially nothing to fall back on.
This commit changes the way that "debug" logging for poll_block() wakeups
works. Instead of logging a backtrace, it logs the source code file name
and line number of the call to a poll_loop function, using __FILE__ and
__LINE__. This is by itself much more meaningful than a sequence of
hexadecimal numbers, since no additional interpretation is necessary. It
can be useful even if the Open vSwitch version is only approximately known.
In addition to the file and line, this commit adds, for wakeups caused by
file descriptors, information about the file descriptor itself: what kind
of file it is (regular file, directory, socket, etc.), the name of the file
(on Linux only), and the local and remote endpoints for socket file
descriptors.
Here are a few examples of the new output format:
932-ms timeout at ../ofproto/in-band.c:507
[POLLIN] on fd 20 (192.168.0.20:35388<->192.168.0.3:6633) at ../lib/stream-fd.c:149
[POLLIN] on fd 7 (FIFO pipe:[48049]) at ../lib/fatal-signal.c:168
2011-05-13 13:06:49 -07:00
|
|
|
char *describe_fd(int fd);
|
|
|
|
|
2012-03-10 15:58:10 -08:00
|
|
|
/* Default value of dscp bits for connection between controller and manager.
|
|
|
|
* Value of IPTOS_PREC_INTERNETCONTROL = 0xc0 which is defined
|
2012-04-16 12:09:49 -07:00
|
|
|
* in <netinet/ip.h> is used. */
|
|
|
|
#define DSCP_DEFAULT (IPTOS_PREC_INTERNETCONTROL >> 2)
|
2012-03-10 15:58:10 -08:00
|
|
|
|
2014-02-06 16:04:05 -08:00
|
|
|
/* Functions for working with sockaddr_storage that might contain an IPv4 or
|
|
|
|
* IPv6 address. */
|
|
|
|
uint16_t ss_get_port(const struct sockaddr_storage *);
|
|
|
|
#define SS_NTOP_BUFSIZE (1 + INET6_ADDRSTRLEN + 1)
|
|
|
|
char *ss_format_address(const struct sockaddr_storage *,
|
|
|
|
char *buf, size_t bufsize);
|
|
|
|
size_t ss_length(const struct sockaddr_storage *);
|
2014-02-05 19:50:10 -08:00
|
|
|
const char *sock_strerror(int error);
|
2014-02-06 16:04:05 -08:00
|
|
|
|
2014-05-23 09:35:47 -07:00
|
|
|
#ifndef _WIN32
|
|
|
|
void xpipe(int fds[2]);
|
|
|
|
void xpipe_nonblocking(int fds[2]);
|
|
|
|
|
|
|
|
int drain_rcvbuf(int fd);
|
|
|
|
|
|
|
|
int make_unix_socket(int style, bool nonblock,
|
|
|
|
const char *bind_path, const char *connect_path);
|
2016-07-19 17:05:51 -03:00
|
|
|
int get_unix_name_len(const struct sockaddr_un *sun, socklen_t sun_len);
|
2014-05-23 09:35:47 -07:00
|
|
|
|
|
|
|
/* Helpers for calling ioctl() on an AF_INET socket. */
|
|
|
|
struct ifreq;
|
|
|
|
int af_inet_ioctl(unsigned long int command, const void *arg);
|
|
|
|
int af_inet_ifreq_ioctl(const char *name, struct ifreq *,
|
|
|
|
unsigned long int cmd, const char *cmd_name);
|
|
|
|
|
|
|
|
#define closesocket close
|
|
|
|
#endif
|
|
|
|
|
2014-02-06 07:57:12 -08:00
|
|
|
#ifdef _WIN32
|
2015-07-01 19:01:44 +00:00
|
|
|
static inline int make_unix_socket(int style, bool nonblock,
|
|
|
|
const char *bind_path,
|
|
|
|
const char *connect_path)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2014-02-06 07:57:12 -08:00
|
|
|
/* Windows defines the 'optval' argument as char * instead of void *. */
|
|
|
|
#define setsockopt(sock, level, optname, optval, optlen) \
|
|
|
|
rpl_setsockopt(sock, level, optname, optval, optlen)
|
|
|
|
static inline int rpl_setsockopt(int sock, int level, int optname,
|
|
|
|
const void *optval, socklen_t optlen)
|
|
|
|
{
|
|
|
|
return (setsockopt)(sock, level, optname, optval, optlen);
|
|
|
|
}
|
2014-02-19 09:11:04 -08:00
|
|
|
|
|
|
|
#define getsockopt(sock, level, optname, optval, optlen) \
|
|
|
|
rpl_getsockopt(sock, level, optname, optval, optlen)
|
|
|
|
static inline int rpl_getsockopt(int sock, int level, int optname,
|
|
|
|
void *optval, socklen_t *optlen)
|
|
|
|
{
|
|
|
|
return (getsockopt)(sock, level, optname, optval, optlen);
|
|
|
|
}
|
2014-02-06 07:57:12 -08:00
|
|
|
#endif
|
|
|
|
|
2014-02-18 10:25:13 -08:00
|
|
|
/* In Windows platform, errno is not set for socket calls.
|
|
|
|
* The last error has to be gotten from WSAGetLastError(). */
|
|
|
|
static inline int sock_errno(void)
|
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
|
|
|
return WSAGetLastError();
|
|
|
|
#else
|
|
|
|
return errno;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2009-07-08 13:19:16 -07:00
|
|
|
#endif /* socket-util.h */
|