svn commit: r249328 - head/usr.sbin/ctladm

Edward Tomasz Napierala trasz at FreeBSD.org
Wed Apr 10 08:48:11 UTC 2013


Author: trasz
Date: Wed Apr 10 08:48:10 2013
New Revision: 249328
URL: http://svnweb.freebsd.org/changeset/base/249328

Log:
  Make ctladm(8) try to load ctl.ko kernel module if needed.
  
  Reviewed by:	ken

Modified:
  head/usr.sbin/ctladm/ctladm.c

Modified: head/usr.sbin/ctladm/ctladm.c
==============================================================================
--- head/usr.sbin/ctladm/ctladm.c	Wed Apr 10 08:09:25 2013	(r249327)
+++ head/usr.sbin/ctladm/ctladm.c	Wed Apr 10 08:48:10 2013	(r249328)
@@ -47,6 +47,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <sys/param.h>
+#include <sys/linker.h>
 #include <sys/queue.h>
 #include <sys/callout.h>
 #include <sys/sbuf.h>
@@ -3814,6 +3815,7 @@ main(int argc, char **argv)
 	int retval, fd;
 	int retries;
 	int initid;
+	int saved_errno;
 
 	retval = 0;
 	cmdargs = CTLADM_ARG_NONE;
@@ -3963,6 +3965,14 @@ main(int argc, char **argv)
 	if ((cmdargs & CTLADM_ARG_DEVICE)
 	 && (command != CTLADM_CMD_HELP)) {
 		fd = open(device, O_RDWR);
+		if (fd == -1 && errno == ENOENT) {
+			saved_errno = errno;
+			retval = kldload("ctl");
+			if (retval != -1)
+				fd = open(device, O_RDWR);
+			else
+				errno = saved_errno;
+		}
 		if (fd == -1) {
 			fprintf(stderr, "%s: error opening %s: %s\n",
 				argv[0], device, strerror(errno));


More information about the svn-src-head mailing list