svn commit: r271182 - head/sys/kern
Adrian Chadd
adrian at freebsd.org
Fri Sep 5 23:30:26 UTC 2014
How's this look?
adrian at testbox1:~/work/freebsd/head/src % svnlite diff sys/kern/
Index: sys/kern/uipc_socket.c
===================================================================
--- sys/kern/uipc_socket.c (revision 271182)
+++ sys/kern/uipc_socket.c (working copy)
@@ -448,10 +448,12 @@
mac_socket_destroy(so);
#endif
CURVNET_SET(so->so_vnet);
- if (V_socket_hhh[HHOOK_SOCKET_CLOSE]->hhh_nhooks > 0)
+ if (V_socket_hhh[HHOOK_SOCKET_CLOSE]->hhh_nhooks > 0) {
hhook_run_socket(so, NULL, HHOOK_SOCKET_CLOSE);
- CURVNET_RESTORE();
-
+ CURVNET_RESTORE();
+ } else {
+ CURVNET_RESTORE();
+ }
crfree(so->so_cred);
khelp_destroy_osd(&so->osd);
sx_destroy(&so->so_snd.sb_sx);
@@ -3245,6 +3247,7 @@
filt_soread(struct knote *kn, long hint)
{
struct socket *so;
+ int ret;
so = kn->kn_fp->f_data;
SOCKBUF_LOCK_ASSERT(&so->so_rcv);
@@ -3266,11 +3269,15 @@
}
CURVNET_SET(so->so_vnet);
- if (V_socket_hhh[HHOOK_FILT_SOREAD]->hhh_nhooks > 0)
+ if (V_socket_hhh[HHOOK_FILT_SOREAD]->hhh_nhooks > 0) {
/* This hook returning non-zero indicates an event, not error */
- return (hhook_run_socket(so, NULL, HHOOK_FILT_SOREAD));
- CURVNET_RESTORE();
-
+ ret = (hhook_run_socket(so, NULL, HHOOK_FILT_SOREAD));
+ CURVNET_RESTORE();
+ return (ret);
+ } else {
+ CURVNET_RESTORE();
+ }
+
return (0);
}
More information about the svn-src-all
mailing list