sock/posix: Increase SO_RECVBUF size by default

Everywhere we use this, we increase the size to 2MB.
Just make that the default behavior.

Change-Id: Ie174419a09df1792a0c7311eddd0c2dcefa267b5
Signed-off-by: Ben Walker <benjamin.walker@intel.com>
Reviewed-on: https://review.gerrithub.io/c/spdk/spdk/+/466991
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: Paul Luse <paul.e.luse@intel.com>
Reviewed-by: Jim Harris <james.r.harris@intel.com>
Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com>
This commit is contained in:
Ben Walker 2019-08-30 14:17:10 -07:00
parent 4bb8a88c8e
commit 52ccf4b761
2 changed files with 28 additions and 8 deletions

View File

@ -101,7 +101,7 @@ DEPDIRS-blob_bdev := log thread bdev
DEPDIRS-copy_ioat := log ioat conf thread $(JSON_LIBS) copy DEPDIRS-copy_ioat := log ioat conf thread $(JSON_LIBS) copy
# module/sock # module/sock
DEPDIRS-sock_posix := log sock DEPDIRS-sock_posix := log sock util
DEPDIRS-sock_vpp := log sock util thread DEPDIRS-sock_vpp := log sock util thread
# module/bdev # module/bdev

View File

@ -41,10 +41,12 @@
#include "spdk/log.h" #include "spdk/log.h"
#include "spdk/sock.h" #include "spdk/sock.h"
#include "spdk/string.h"
#include "spdk_internal/sock.h" #include "spdk_internal/sock.h"
#define MAX_TMPBUF 1024 #define MAX_TMPBUF 1024
#define PORTNUMLEN 32 #define PORTNUMLEN 32
#define SO_RCVBUF_SIZE (2 * 1024 * 1024)
struct spdk_posix_sock { struct spdk_posix_sock {
struct spdk_sock base; struct spdk_sock base;
@ -317,9 +319,10 @@ spdk_posix_sock_accept(struct spdk_sock *_sock)
struct spdk_posix_sock *sock = __posix_sock(_sock); struct spdk_posix_sock *sock = __posix_sock(_sock);
struct sockaddr_storage sa; struct sockaddr_storage sa;
socklen_t salen; socklen_t salen;
int rc; int rc, fd;
struct spdk_posix_sock *new_sock; struct spdk_posix_sock *new_sock;
int flag; int flag;
size_t sz;
memset(&sa, 0, sizeof(sa)); memset(&sa, 0, sizeof(sa));
salen = sizeof(sa); salen = sizeof(sa);
@ -332,21 +335,38 @@ spdk_posix_sock_accept(struct spdk_sock *_sock)
return NULL; return NULL;
} }
flag = fcntl(rc, F_GETFL); fd = rc;
if ((!(flag & O_NONBLOCK)) && (fcntl(rc, F_SETFL, flag | O_NONBLOCK) < 0)) {
SPDK_ERRLOG("fcntl can't set nonblocking mode for socket, fd: %d (%d)\n", rc, errno); flag = fcntl(fd, F_GETFL);
close(rc); if ((!(flag & O_NONBLOCK)) && (fcntl(fd, F_SETFL, flag | O_NONBLOCK) < 0)) {
SPDK_ERRLOG("fcntl can't set nonblocking mode for socket, fd: %d (%d)\n", fd, errno);
close(fd);
return NULL; return NULL;
} }
rc = getsockopt(fd, SOL_SOCKET, SO_RCVBUF, &sz, &salen);
if (rc < 0) {
SPDK_ERRLOG("Unable to get recvbuf size for socket fd %d (%s)\n", fd, spdk_strerror(errno));
close(fd);
return NULL;
}
if (sz < SO_RCVBUF_SIZE) {
sz = SO_RCVBUF_SIZE;
rc = setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &sz, sizeof(sz));
if (rc < 0) {
SPDK_WARNLOG("Unable to increase size of rcvbuf for socket fd %d (%s)", fd, spdk_strerror(errno));
}
}
new_sock = calloc(1, sizeof(*sock)); new_sock = calloc(1, sizeof(*sock));
if (new_sock == NULL) { if (new_sock == NULL) {
SPDK_ERRLOG("sock allocation failed\n"); SPDK_ERRLOG("sock allocation failed\n");
close(rc); close(fd);
return NULL; return NULL;
} }
new_sock->fd = rc; new_sock->fd = fd;
return &new_sock->base; return &new_sock->base;
} }