Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 30 Nov 2008 13:18:35 +0000 (UTC)
From:      Konstantin Belousov <kib@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r185474 - head/share/man/man9
Message-ID:  <200811301318.mAUDIZHr091092@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: kib
Date: Sun Nov 30 13:18:35 2008
New Revision: 185474
URL: http://svn.freebsd.org/changeset/base/185474

Log:
  Clarify the reason to not use the volatile string as an argument to CTR
  macros. Note the logging of file and line.
  
  Reviewed by:	dchagin
  MFC after:	3 days

Modified:
  head/share/man/man9/ktr.9

Modified: head/share/man/man9/ktr.9
==============================================================================
--- head/share/man/man9/ktr.9	Sun Nov 30 12:21:46 2008	(r185473)
+++ head/share/man/man9/ktr.9	Sun Nov 30 13:18:35 2008	(r185474)
@@ -24,7 +24,7 @@
 .\"
 .\" $FreeBSD$
 .\"
-.Dd December 27, 2005
+.Dd November 30, 2008
 .Dt KTR 9
 .Os
 .Sh NAME
@@ -84,9 +84,16 @@ Following the
 .Fa format
 string are zero to five arguments referenced by
 .Fa format .
+Each event is logged with a file name and source line number of the
+originating CTR call, and a timestamp in addition to the log message.
+.Pp
+The event is stored in the circular buffer with supplied arguments as is,
+and formatting is done at the dump time.
+Do not use pointers to the objects with limited lifetime, for instance,
+strings, because the pointer may become invalid when buffer is printed.
+.Pp
 Note that the different macros differ only in the number of arguments each
 one takes, as indicated by its name.
-Each event is logged with a timestamp in addition to the log message.
 .Pp
 The
 .Va ktr_entries
@@ -121,13 +128,11 @@ mi_switch()
 	 * Pick a new current process and record its start time.
 	 */
 	...
-	CTR3(KTR_PROC, "mi_switch: old proc %p (pid %d, %s)", p, p->p_pid,
-	    p->p_comm);
+	CTR3(KTR_PROC, "mi_switch: old proc %p (pid %d)", p, p->p_pid);
 	...
 	cpu_switch();
 	...
-	CTR3(KTR_PROC, "mi_switch: new proc %p (pid %d, %s)", p, p->p_pid,
-	    p->p_comm);
+	CTR3(KTR_PROC, "mi_switch: new proc %p (pid %d)", p, p->p_pid);
 	...
 }
 .Ed



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