svn commit: r337545 - in head/sys: conf kern sys

Kyle Evans kevans at FreeBSD.org
Thu Aug 9 17:47:49 UTC 2018


Author: kevans
Date: Thu Aug  9 17:47:47 2018
New Revision: 337545
URL: https://svnweb.freebsd.org/changeset/base/337545

Log:
  BOOT_TAG: Make a config(5) option, expose as sysctl and loader tunable
  
  BOOT_TAG lived shortly in sys/msgbuf.h, but this wasn't necessarily great
  for changing it or removing it. Move it into subr_prf.c and add options for
  it to opt_printf.h.
  
  One can specify both the BOOT_TAG and BOOT_TAG_SZ (really, size of the
  buffer that holds the BOOT_TAG). We expose it as kern.boot_tag and also add
  a loader tunable by the same name that we'll fetch upon initialization of
  the msgbuf.
  
  This allows for flexibility and also ensures that there's a consistent way
  to figure out the boot tag of the running kernel, rather than relying on
  headers to be in-sync.
  
  Prodded super-super-lightly by:	imp

Modified:
  head/sys/conf/NOTES
  head/sys/conf/options
  head/sys/kern/subr_prf.c
  head/sys/sys/msgbuf.h

Modified: head/sys/conf/NOTES
==============================================================================
--- head/sys/conf/NOTES	Thu Aug  9 17:42:27 2018	(r337544)
+++ head/sys/conf/NOTES	Thu Aug  9 17:47:47 2018	(r337545)
@@ -145,6 +145,16 @@ options 	INCLUDE_CONFIG_FILE     # Include this file i
 options 	BOOTVERBOSE=1
 options 	BOOTHOWTO=RB_MULTIPLE
 
+#
+# Compile-time defaults for dmesg boot tagging
+#
+# Default boot tag; may use 'kern.boot_tag' loader tunable to override.  The
+# current boot's tag is also exposed via the 'kern.boot_tag' sysctl.
+options 	BOOT_TAG=\"---<<BOOT>>---\"
+# Maximum boot tag size the kernel's static buffer should accomodate.  Maximum
+# size for both BOOT_TAG and the assocated tunable.
+options 	BOOT_TAG_SZ=32
+
 options 	GEOM_BDE		# Disk encryption.
 options 	GEOM_BSD		# BSD disklabels (obsolete, gone in 12)
 options 	GEOM_CACHE		# Disk cache.

Modified: head/sys/conf/options
==============================================================================
--- head/sys/conf/options	Thu Aug  9 17:42:27 2018	(r337544)
+++ head/sys/conf/options	Thu Aug  9 17:47:47 2018	(r337545)
@@ -811,6 +811,8 @@ TERMINAL_NORM_ATTR	opt_teken.h
 
 # options for printf
 PRINTF_BUFR_SIZE	opt_printf.h
+BOOT_TAG		opt_printf.h
+BOOT_TAG_SZ		opt_printf.h
 
 # kbd options
 KBD_DISABLE_KEYMAP_LOAD	opt_kbd.h

Modified: head/sys/kern/subr_prf.c
==============================================================================
--- head/sys/kern/subr_prf.c	Thu Aug  9 17:42:27 2018	(r337544)
+++ head/sys/kern/subr_prf.c	Thu Aug  9 17:47:47 2018	(r337545)
@@ -124,6 +124,18 @@ static bool msgbufmapped;		/* Set when safe to use msg
 int msgbuftrigger;
 struct msgbuf *msgbufp;
 
+#ifndef BOOT_TAG_SZ
+#define	BOOT_TAG_SZ	32
+#endif
+#ifndef BOOT_TAG
+/* Tag used to mark the start of a boot in dmesg */
+#define	BOOT_TAG	"---<<BOOT>>---"
+#endif
+
+static char current_boot_tag[BOOT_TAG_SZ + 1] = BOOT_TAG;
+SYSCTL_STRING(_kern, OID_AUTO, boot_tag, CTLFLAG_RDTUN | CTLFLAG_NOFETCH,
+    current_boot_tag, 0, "Tag added to dmesg at start of boot");
+
 static int log_console_output = 1;
 SYSCTL_INT(_kern, OID_AUTO, log_console_output, CTLFLAG_RWTUN,
     &log_console_output, 0, "Duplicate console output to the syslog");
@@ -1025,9 +1037,13 @@ msgbufinit(void *ptr, int size)
 
 	size -= sizeof(*msgbufp);
 	cp = (char *)ptr;
+	/* Attempt to fetch kern.boot_tag tunable on first mapping */
+	if (!msgbufmapped)
+		TUNABLE_STR_FETCH("kern.boot_tag", current_boot_tag,
+		    BOOT_TAG_SZ + 1);
 	msgbufp = (struct msgbuf *)(cp + size);
 	msgbuf_reinit(msgbufp, cp, size);
-	msgbuf_addstr(msgbufp, -1, BOOT_TAG, 0);
+	msgbuf_addstr(msgbufp, -1, current_boot_tag, 0);
 	if (msgbufmapped && oldp != msgbufp)
 		msgbuf_copy(oldp, msgbufp);
 	msgbufmapped = true;

Modified: head/sys/sys/msgbuf.h
==============================================================================
--- head/sys/sys/msgbuf.h	Thu Aug  9 17:42:27 2018	(r337544)
+++ head/sys/sys/msgbuf.h	Thu Aug  9 17:47:47 2018	(r337545)
@@ -60,9 +60,6 @@ struct msgbuf {
 /* Subtract sequence numbers.  Note that only positive values result. */
 #define	MSGBUF_SEQSUB(mbp, seq1, seq2)	(MSGBUF_SEQNORM((mbp), (seq1) - (seq2)))
 
-/* Tag used to mark the start of a boot in dmesg */
-#define	BOOT_TAG  "---<<BOOT>>---"
-
 #ifdef _KERNEL
 extern int	msgbufsize;
 extern int	msgbuftrigger;


More information about the svn-src-all mailing list