diff options
-rw-r--r-- | sys/kern/uipc_socket.c | 17 | ||||
-rw-r--r-- | sys/sys/socket.h | 3 |
2 files changed, 20 insertions, 0 deletions
diff --git a/sys/kern/uipc_socket.c b/sys/kern/uipc_socket.c index 378d542..c5aab5f 100644 --- a/sys/kern/uipc_socket.c +++ b/sys/kern/uipc_socket.c @@ -1677,6 +1677,7 @@ sosetopt(so, sopt) break; } break; + case SO_LABEL: #ifdef MAC error = sooptcopyin(sopt, &extmac, sizeof extmac, @@ -1689,6 +1690,7 @@ sosetopt(so, sopt) error = EOPNOTSUPP; #endif break; + default: error = ENOPROTOOPT; break; @@ -1817,6 +1819,7 @@ integer: tv.tv_usec = (optval % hz) * tick; error = sooptcopyout(sopt, &tv, sizeof tv); break; + case SO_LABEL: #ifdef MAC error = sooptcopyin(sopt, &extmac, sizeof(extmac), @@ -1832,6 +1835,7 @@ integer: error = EOPNOTSUPP; #endif break; + case SO_PEERLABEL: #ifdef MAC error = sooptcopyin(sopt, &extmac, sizeof(extmac), @@ -1847,6 +1851,19 @@ integer: error = EOPNOTSUPP; #endif break; + + case SO_LISTENQLIMIT: + optval = so->so_qlimit; + goto integer; + + case SO_LISTENQLEN: + optval = so->so_qlen; + goto integer; + + case SO_LISTENINCQLEN: + optval = so->so_incqlen; + goto integer; + default: error = ENOPROTOOPT; break; diff --git a/sys/sys/socket.h b/sys/sys/socket.h index 176343d..bb00346 100644 --- a/sys/sys/socket.h +++ b/sys/sys/socket.h @@ -133,6 +133,9 @@ typedef __uid_t uid_t; #if __BSD_VISIBLE #define SO_LABEL 0x1009 /* socket's MAC label */ #define SO_PEERLABEL 0x1010 /* socket's peer's MAC label */ +#define SO_LISTENQLIMIT 0x1011 /* socket's backlog limit */ +#define SO_LISTENQLEN 0x1012 /* socket's complete queue length */ +#define SO_LISTENINCQLEN 0x1013 /* socket's incomplete queue length */ #endif /* |