Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 26 Jan 2016 01:15:19 +0000 (UTC)
From:      Mark Johnston <markj@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r294757 - head/sys/kern
Message-ID:  <201601260115.u0Q1FJWf011729@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: markj
Date: Tue Jan 26 01:15:18 2016
New Revision: 294757
URL: https://svnweb.freebsd.org/changeset/base/294757

Log:
  Evaluate the sysctl_running fail point before taking the sysctl lock.
  
  The fail point handler may sleep, but this is not permitted while holding a
  rm read lock.
  
  MFC after:	1 week
  Sponsored by:	EMC / Isilon Storage Division

Modified:
  head/sys/kern/kern_sysctl.c

Modified: head/sys/kern/kern_sysctl.c
==============================================================================
--- head/sys/kern/kern_sysctl.c	Tue Jan 26 01:02:19 2016	(r294756)
+++ head/sys/kern/kern_sysctl.c	Tue Jan 26 01:15:18 2016	(r294757)
@@ -166,6 +166,8 @@ sysctl_root_handler_locked(struct sysctl
 	if (!(oid->oid_kind & CTLFLAG_MPSAFE))
 		mtx_unlock(&Giant);
 
+	KFAIL_POINT_ERROR(_debug_fail_point, sysctl_running, error);
+
 	if (tracker != NULL)
 		SYSCTL_RLOCK(tracker);
 	else
@@ -1838,8 +1840,6 @@ sysctl_root(SYSCTL_HANDLER_ARGS)
 #endif
 	error = sysctl_root_handler_locked(oid, arg1, arg2, req, &tracker);
 
-	KFAIL_POINT_ERROR(_debug_fail_point, sysctl_running, error);
-
 out:
 	SYSCTL_RUNLOCK(&tracker);
 	return (error);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201601260115.u0Q1FJWf011729>