Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 13 Nov 2012 03:00:01 +0000 (UTC)
From:      Davide Italiano <davide@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r242942 - in projects/calloutng/sys: kern sys
Message-ID:  <201211130300.qAD301R8066533@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: davide
Date: Tue Nov 13 03:00:01 2012
New Revision: 242942
URL: http://svnweb.freebsd.org/changeset/base/242942

Log:
  Implement TIMESEL(). This macro allow to select between getbinuptime() or
  binuptime() depending on the value passed to it. The rationale behind is
  that the effect of the relative error of getbinuptime() becomes small
  if the intervals we're dealing with increase.
  While here, move some macros to <sys/time.h> in order to avoid code
  duplication.
  
  Reviewed by:	mav

Modified:
  projects/calloutng/sys/kern/kern_clocksource.c
  projects/calloutng/sys/kern/kern_tc.c
  projects/calloutng/sys/kern/kern_timeout.c
  projects/calloutng/sys/sys/time.h

Modified: projects/calloutng/sys/kern/kern_clocksource.c
==============================================================================
--- projects/calloutng/sys/kern/kern_clocksource.c	Tue Nov 13 02:50:39 2012	(r242941)
+++ projects/calloutng/sys/kern/kern_clocksource.c	Tue Nov 13 03:00:01 2012	(r242942)
@@ -147,15 +147,6 @@ struct pcpu_state {
 
 static DPCPU_DEFINE(struct pcpu_state, timerstate);
 
-#define FREQ2BT(freq, bt)						\
-{									\
-	(bt)->sec = 0;							\
-	(bt)->frac = ((uint64_t)0x8000000000000000  / (freq)) << 1;	\
-}
-#define BT2FREQ(bt)							\
-	(((uint64_t)0x8000000000000000 + ((bt)->frac >> 2)) /		\
-	    ((bt)->frac >> 1))
-
 /*
  * Timer broadcast IPI handler.
  */

Modified: projects/calloutng/sys/kern/kern_tc.c
==============================================================================
--- projects/calloutng/sys/kern/kern_tc.c	Tue Nov 13 02:50:39 2012	(r242941)
+++ projects/calloutng/sys/kern/kern_tc.c	Tue Nov 13 03:00:01 2012	(r242942)
@@ -119,6 +119,11 @@ static int timestepwarnings;
 SYSCTL_INT(_kern_timecounter, OID_AUTO, stepwarnings, CTLFLAG_RW,
     &timestepwarnings, 0, "Log time steps");
 
+int tc_timethreshold;
+struct bintime tick_bt;
+SYSCTL_INT(_kern, OID_AUTO, tc_timethreshold, CTLFLAG_RW, 
+    &tc_timethreshold, 0, "Precision threshold for timing measurements"); 
+
 static void tc_windup(void);
 static void cpu_tick_calibrate(int);
 
@@ -1708,6 +1713,7 @@ tc_ticktock(int cnt)
 static void
 inittimecounter(void *dummy)
 {
+	int tick_rate;
 	u_int p;
 
 	/*
@@ -1723,6 +1729,9 @@ inittimecounter(void *dummy)
 	else
 		tc_tick = 1;
 	p = (tc_tick * 1000000) / hz;
+	tc_timethreshold = 20 * imin(1000000000 / hz, 1000000);
+	tick_rate = imax(hz, tc_tick);
+	FREQ2BT(tick_rate, &tick_bt);
 	printf("Timecounters tick every %d.%03u msec\n", p / 1000, p % 1000);
 
 #ifdef FFCLOCK

Modified: projects/calloutng/sys/kern/kern_timeout.c
==============================================================================
--- projects/calloutng/sys/kern/kern_timeout.c	Tue Nov 13 02:50:39 2012	(r242941)
+++ projects/calloutng/sys/kern/kern_timeout.c	Tue Nov 13 03:00:01 2012	(r242942)
@@ -55,6 +55,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/sleepqueue.h>
 #include <sys/sysctl.h>
 #include <sys/smp.h>
+#include <sys/time.h>
 
 #ifdef SMP
 #include <machine/cpu.h>
@@ -171,12 +172,6 @@ struct callout_cpu cc_cpu;
 #define	CC_UNLOCK(cc)	mtx_unlock_spin(&(cc)->cc_lock)
 #define	CC_LOCK_ASSERT(cc)	mtx_assert(&(cc)->cc_lock, MA_OWNED)
 
-#define FREQ2BT(freq, bt)                                               \
-{                                                                       \
-        (bt)->sec = 0;                                                  \
-        (bt)->frac = ((uint64_t)0x8000000000000000  / (freq)) << 1;     \
-}
-
 #define	TIME_T_MAX							\
 	(sizeof(time_t) == (sizeof(int64_t)) ? INT64_MAX : INT32_MAX)
 

Modified: projects/calloutng/sys/sys/time.h
==============================================================================
--- projects/calloutng/sys/sys/time.h	Tue Nov 13 02:50:39 2012	(r242941)
+++ projects/calloutng/sys/sys/time.h	Tue Nov 13 03:00:01 2012	(r242942)
@@ -55,6 +55,21 @@ struct bintime {
 	uint64_t frac;
 };
 
+extern int tc_timethreshold;
+extern struct bintime tick_bt;
+
+#define FREQ2BT(freq, bt)                                               \
+{                                                                       \
+        (bt)->sec = 0;                                                  \
+        (bt)->frac = ((uint64_t)0x8000000000000000  / (freq)) << 1;     \
+}
+#define BT2FREQ(bt)                                                     \
+        (((uint64_t)0x8000000000000000 + ((bt)->frac >> 2)) /           \
+            ((bt)->frac >> 1))
+
+#define TIMESEL(x, bt)          					\
+	(((x) < (c_timethreshold)) ? binuptime(&bt) : getbinuptime(&bt))
+
 static __inline void
 bintime_addx(struct bintime *bt, uint64_t x)
 {



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