diff options
author | truckman <truckman@FreeBSD.org> | 2002-07-28 19:59:31 +0000 |
---|---|---|
committer | truckman <truckman@FreeBSD.org> | 2002-07-28 19:59:31 +0000 |
commit | b1555a27432152cc7817d0c592bbcebf95fdfd19 (patch) | |
tree | 6dda6f0898c9f15fca929e63e72b3882862e67e1 /sys/netncp | |
parent | 5bd1876975f34760da2eea4bfce9c738127d36ca (diff) | |
download | FreeBSD-src-b1555a27432152cc7817d0c592bbcebf95fdfd19.zip FreeBSD-src-b1555a27432152cc7817d0c592bbcebf95fdfd19.tar.gz |
Wire the sysctl output buffer before grabbing any locks to prevent
SYSCTL_OUT() from blocking while locks are held. This should
only be done when it would be inconvenient to make a temporary copy of
the data and defer calling SYSCTL_OUT() until after the locks are
released.
Diffstat (limited to 'sys/netncp')
-rw-r--r-- | sys/netncp/ncp_conn.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/sys/netncp/ncp_conn.c b/sys/netncp/ncp_conn.c index 85f4163..14b8d7b 100644 --- a/sys/netncp/ncp_conn.c +++ b/sys/netncp/ncp_conn.c @@ -633,6 +633,7 @@ ncp_sysctl_connstat(SYSCTL_HANDLER_ARGS) { /* struct ucred *cred = req->p->p_ucred;*/ error = 0; + sysctl_wire_old_buffer(req, 0); ncp_conn_locklist(LK_SHARED, req->p); error = SYSCTL_OUT(req, &ncp_conn_cnt, sizeof(ncp_conn_cnt)); SLIST_FOREACH(ncp, &conn_list, nc_next) { |