2016-02-25 17:27:07 -08:00
|
|
|
#include <assert.h>
|
|
|
|
|
#include <errno.h>
|
|
|
|
|
#include <netinet/in.h>
|
|
|
|
|
#include <netinet/tcp.h>
|
|
|
|
|
#include <sys/socket.h>
|
2016-03-07 15:19:00 -08:00
|
|
|
#include <sys/stat.h>
|
|
|
|
|
#include <sys/types.h>
|
2016-02-25 17:27:07 -08:00
|
|
|
|
|
|
|
|
#include "socket.h"
|
|
|
|
|
|
2016-02-29 22:17:37 -08:00
|
|
|
void socket_pre_bind(int fd) {
|
2016-02-28 22:21:07 -08:00
|
|
|
// Called by transport code; safe to assume that fd is a socket
|
2016-02-28 12:34:43 -08:00
|
|
|
int optval = 1;
|
|
|
|
|
assert(!setsockopt(fd, SOL_SOCKET, SO_REUSEPORT, &optval, sizeof(optval)));
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-29 22:17:37 -08:00
|
|
|
void socket_pre_listen(int fd) {
|
2016-02-28 22:21:07 -08:00
|
|
|
// Called by transport code; safe to assume that fd is a socket
|
2016-02-27 10:12:48 -08:00
|
|
|
int qlen = 5;
|
|
|
|
|
assert(!setsockopt(fd, SOL_TCP, TCP_FASTOPEN, &qlen, sizeof(qlen)));
|
|
|
|
|
}
|
|
|
|
|
|
2016-03-02 19:28:02 -08:00
|
|
|
void socket_ready(int fd) {
|
2016-02-28 22:21:07 -08:00
|
|
|
// Called by transport code; safe to assume that fd is a socket
|
2016-02-25 17:27:07 -08:00
|
|
|
int optval = 1;
|
2016-02-25 17:33:14 -08:00
|
|
|
assert(!setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, &optval, sizeof(optval)));
|
2016-02-25 17:27:07 -08:00
|
|
|
optval = 30;
|
|
|
|
|
assert(!setsockopt(fd, IPPROTO_TCP, TCP_KEEPIDLE, &optval, sizeof(optval)));
|
|
|
|
|
optval = 10;
|
|
|
|
|
assert(!setsockopt(fd, IPPROTO_TCP, TCP_KEEPINTVL, &optval, sizeof(optval)));
|
|
|
|
|
optval = 3;
|
|
|
|
|
assert(!setsockopt(fd, IPPROTO_TCP, TCP_KEEPCNT, &optval, sizeof(optval)));
|
2016-03-02 22:07:48 -08:00
|
|
|
|
|
|
|
|
optval = 60000; // 60s
|
|
|
|
|
assert(!setsockopt(fd, IPPROTO_TCP, TCP_USER_TIMEOUT, &optval, sizeof(optval)));
|
2016-02-25 17:27:07 -08:00
|
|
|
}
|
2016-02-28 22:21:07 -08:00
|
|
|
|
2016-03-02 19:28:02 -08:00
|
|
|
void socket_ready_send(int fd) {
|
2016-02-28 22:50:26 -08:00
|
|
|
int optval = 128; // Lowest value that the kernel will accept
|
2016-02-29 22:17:37 -08:00
|
|
|
int res = setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &optval, sizeof(optval));
|
|
|
|
|
if (res == -1 && errno == ENOTSOCK) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
assert(res == 0);
|
2016-02-28 23:03:18 -08:00
|
|
|
|
|
|
|
|
optval = 128; // Lowest value that the kernel will accept
|
2016-03-02 22:07:48 -08:00
|
|
|
assert(!setsockopt(fd, IPPROTO_TCP, TCP_WINDOW_CLAMP, &optval, sizeof(optval)));
|
2016-02-29 22:17:37 -08:00
|
|
|
}
|
|
|
|
|
|
2016-03-02 21:51:30 -08:00
|
|
|
void socket_connected_send(int fd) {
|
2016-02-29 22:17:37 -08:00
|
|
|
// Called by data flow code; NOT safe to assume that fd is a socket
|
|
|
|
|
int res = shutdown(fd, SHUT_RD);
|
2016-02-28 23:03:18 -08:00
|
|
|
assert(res == 0 || (res == -1 && errno == ENOTSOCK));
|
2016-02-28 22:21:07 -08:00
|
|
|
}
|
|
|
|
|
|
2016-03-02 21:51:30 -08:00
|
|
|
void socket_connected_receive(int fd) {
|
2016-02-28 22:21:07 -08:00
|
|
|
// Called by data flow code; NOT safe to assume that fd is a socket
|
|
|
|
|
int res = shutdown(fd, SHUT_WR);
|
|
|
|
|
assert(res == 0 || (res == -1 && errno == ENOTSOCK));
|
|
|
|
|
}
|