Module Name:    src
Committed By:   jnemeth
Date:           Thu Nov 18 09:50:47 UTC 2010

Modified Files:
        src/sys/kern: kern_module_vfs.c

Log Message:
if autoloading check for a noautoload=true property and if found,
deny the autoload


To generate a diff of this commit:
cvs rdiff -u -r1.7 -r1.8 src/sys/kern/kern_module_vfs.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/kern/kern_module_vfs.c
diff -u src/sys/kern/kern_module_vfs.c:1.7 src/sys/kern/kern_module_vfs.c:1.8
--- src/sys/kern/kern_module_vfs.c:1.7	Thu Jun 24 13:03:11 2010
+++ src/sys/kern/kern_module_vfs.c	Thu Nov 18 09:50:47 2010
@@ -1,4 +1,4 @@
-/*	$NetBSD: kern_module_vfs.c,v 1.7 2010/06/24 13:03:11 hannken Exp $	*/
+/*	$NetBSD: kern_module_vfs.c,v 1.8 2010/11/18 09:50:47 jnemeth Exp $	*/
 
 /*-
  * Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_module_vfs.c,v 1.7 2010/06/24 13:03:11 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_module_vfs.c,v 1.8 2010/11/18 09:50:47 jnemeth Exp $");
 
 #define _MODULE_INTERNAL
 #include <sys/param.h>
@@ -65,10 +65,13 @@
 	char *path;
 	bool nochroot;
 	int error;
+	prop_bool_t noload;
+	prop_dictionary_t moduledict;
 
 	nochroot = false;
 	error = 0;
 	path = NULL;
+	moduledict = NULL;
 	if (filedictp)
 		*filedictp = NULL;
 	path = PNBUF_GET();
@@ -99,13 +102,27 @@
 	/*
 	 * Load and process <module>.prop if it exists.
 	 */
-	if ((flags & MODCTL_NO_PROP) == 0 && filedictp) {
-		error = module_load_plist_vfs(path, nochroot, filedictp);
+	if (((flags & MODCTL_NO_PROP) == 0 && filedictp) || autoload) {
+		error = module_load_plist_vfs(path, nochroot, &moduledict);
 		if (error != 0) {
 			module_print("plist load returned error %d for `%s'",
 			    error, path);
 			if (error != ENOENT)
 				goto fail;
+		} else if (autoload) {
+			noload = prop_dictionary_get(moduledict, "noautoload");
+			if (noload != NULL && prop_bool_true(noload)) {
+				module_error("autoloading is disallowed for %s",
+				    path);
+				error = EPERM;
+				goto fail;
+			}
+		}
+		if (error == 0) {	/* can get here if error == ENOENT */
+			if ((flags & MODCTL_NO_PROP) == 0 && filedictp)
+				*filedictp = moduledict;
+			else 
+				prop_object_release(moduledict);
 		}
 	}
 

Reply via email to