Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 7 Mar 2015 18:23:33 +0000 (UTC)
From:      Hans Petter Selasky <hselasky@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r279728 - in head/sys: kern sys
Message-ID:  <201503071823.t27INXST087219@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: hselasky
Date: Sat Mar  7 18:23:32 2015
New Revision: 279728
URL: https://svnweb.freebsd.org/changeset/base/279728

Log:
  Add mutex support to the pps_ioctl() API in the kernel.
  Bump kernel version to reflect structure change.
  
  PR:		196897
  MFC after:	1 week

Modified:
  head/sys/kern/kern_tc.c
  head/sys/sys/param.h
  head/sys/sys/timepps.h

Modified: head/sys/kern/kern_tc.c
==============================================================================
--- head/sys/kern/kern_tc.c	Sat Mar  7 18:17:15 2015	(r279727)
+++ head/sys/kern/kern_tc.c	Sat Mar  7 18:23:32 2015	(r279728)
@@ -23,10 +23,8 @@ __FBSDID("$FreeBSD$");
 #include <sys/param.h>
 #include <sys/kernel.h>
 #include <sys/limits.h>
-#ifdef FFCLOCK
 #include <sys/lock.h>
 #include <sys/mutex.h>
-#endif
 #include <sys/sysctl.h>
 #include <sys/syslog.h>
 #include <sys/systm.h>
@@ -1498,7 +1496,10 @@ pps_fetch(struct pps_fetch_args *fapi, s
 		cseq = pps->ppsinfo.clear_sequence;
 		while (aseq == pps->ppsinfo.assert_sequence &&
 		    cseq == pps->ppsinfo.clear_sequence) {
-			err = tsleep(pps, PCATCH, "ppsfch", timo);
+			if (pps->mtx != NULL)
+				err = msleep(pps, pps->mtx, PCATCH, "ppsfch", timo);
+			else
+				err = tsleep(pps, PCATCH, "ppsfch", timo);
 			if (err == EWOULDBLOCK && fapi->timeout.tv_sec == -1) {
 				continue;
 			} else if (err != 0) {

Modified: head/sys/sys/param.h
==============================================================================
--- head/sys/sys/param.h	Sat Mar  7 18:17:15 2015	(r279727)
+++ head/sys/sys/param.h	Sat Mar  7 18:23:32 2015	(r279728)
@@ -58,7 +58,7 @@
  *		in the range 5 to 9.
  */
 #undef __FreeBSD_version
-#define __FreeBSD_version 1100062	/* Master, propagated to newvers */
+#define __FreeBSD_version 1100063	/* Master, propagated to newvers */
 
 /*
  * __FreeBSD_kernel__ indicates that this system uses the kernel of FreeBSD,

Modified: head/sys/sys/timepps.h
==============================================================================
--- head/sys/sys/timepps.h	Sat Mar  7 18:17:15 2015	(r279727)
+++ head/sys/sys/timepps.h	Sat Mar  7 18:23:32 2015	(r279728)
@@ -133,6 +133,8 @@ struct pps_kcbind_args {
 
 #ifdef _KERNEL
 
+struct mtx;
+
 struct pps_state {
 	/* Capture information. */
 	struct timehands *capth;
@@ -140,6 +142,9 @@ struct pps_state {
 	unsigned	capgen;
 	unsigned	capcount;
 
+	/* pointer to mutex protecting this state, if any */
+	struct mtx	*mtx;
+
 	/* State information. */
 	pps_params_t	ppsparam;
 	pps_info_t	ppsinfo;



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