summaryrefslogtreecommitdiff
path: root/lib/sockopt.c
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas.abraitis@gmail.com>2019-10-20 12:09:42 +0300
committerGitHub <noreply@github.com>2019-10-20 12:09:42 +0300
commitacf061a9ab9284b7ebf6dffbe2cf5ea6ed9052da (patch)
treee2321f97af25c15a62ccd76b98123d0c9a00fec2 /lib/sockopt.c
parent0a764122e10bf5c3067f8f5dcc7d02f339d18580 (diff)
parent11a9a23664c776cc4cd3794f25f378dc1489e949 (diff)
Merge pull request #5108 from donaldsharp/sendbuffer_size_bgp
Sendbuffer size bgp
Diffstat (limited to 'lib/sockopt.c')
-rw-r--r--lib/sockopt.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/sockopt.c b/lib/sockopt.c
index 8e38a29278..7726d74ff7 100644
--- a/lib/sockopt.c
+++ b/lib/sockopt.c
@@ -72,6 +72,21 @@ int getsockopt_so_sendbuf(const int sock)
return optval;
}
+int getsockopt_so_recvbuf(const int sock)
+{
+ uint32_t optval;
+ socklen_t optlen = sizeof(optval);
+ int ret = getsockopt(sock, SOL_SOCKET, SO_RCVBUF, (char *)&optval,
+ &optlen);
+ if (ret < 0) {
+ flog_err_sys(EC_LIB_SYSTEM_CALL,
+ "fd %d: can't getsockopt SO_RCVBUF: %d (%s)", sock,
+ errno, safe_strerror(errno));
+ return ret;
+ }
+ return optval;
+}
+
static void *getsockopt_cmsg_data(struct msghdr *msgh, int level, int type)
{
struct cmsghdr *cmsg;