Page MenuHomeFreeBSD

Factor out checks for mounted root file system
ClosedPublic

Authored by hselasky on Nov 27 2019, 3:26 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 7:30 AM
Unknown Object (File)
Thu, Jan 2, 4:28 PM
Unknown Object (File)
Dec 22 2024, 6:23 AM
Unknown Object (File)
Dec 18 2024, 2:09 PM
Unknown Object (File)
Dec 17 2024, 3:00 AM
Unknown Object (File)
Dec 11 2024, 12:36 AM
Unknown Object (File)
Dec 10 2024, 2:55 AM
Unknown Object (File)
Nov 30 2024, 2:00 AM
Subscribers

Details

Summary

PR: 241639
MFC after: 1 week
Sponsored by: Mellanox Technologies

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

sys/compat/linuxkpi/common/include/linux/kmod.h
46 ↗(On Diff #64938)

Should you check if p_fd != NULL ?

I wonder if this check should be factored out? It is not only the LinuxKPI which access these code paths too early, but USB drivers loading firmware .ko's can also do the same??

Index: sys/kern/kern_linker.c
===================================================================
--- sys/kern/kern_linker.c	(revision 355108)
+++ sys/kern/kern_linker.c	(working copy)
@@ -2067,6 +2067,7 @@
     struct linker_file *parent, const struct mod_depend *verinfo,
     struct linker_file **lfpp)
 {
+	struct proc *cp = curproc;
 	linker_file_t lfdep;
 	const char *filename;
 	char *pathname;
@@ -2079,13 +2080,13 @@
  		 */
 		KASSERT(verinfo == NULL, ("linker_load_module: verinfo"
 		    " is not NULL"));
-		if (rootvnode == NULL)
+		if (rootvnode == NULL || cp->p_fd == NULL || cp->p_fd->fd_rdir == NULL)
 			return (ENXIO);
 		pathname = linker_search_kld(kldname);
 	} else {
 		if (modlist_lookup2(modname, verinfo) != NULL)
 			return (EEXIST);
-		if (rootvnode == NULL)
+		if (rootvnode == NULL || cp->p_fd == NULL || cp->p_fd->fd_rdir == NULL)
 			return (ENXIO);
 		if (kldname != NULL)
 			pathname = strdup(kldname, M_LINKER);

Why not like this? Or remove the rootvnode == NULL and only test fd_rdir ?

--HPS

hselasky edited reviewers, added: kib; removed: hselasky.
Index: sys/kern/kern_linker.c
===================================================================
--- sys/kern/kern_linker.c	(revision 355108)
+++ sys/kern/kern_linker.c	(working copy)
@@ -2067,6 +2067,7 @@
     struct linker_file *parent, const struct mod_depend *verinfo,
     struct linker_file **lfpp)
 {
+	struct proc *cp = curproc;
 	linker_file_t lfdep;
 	const char *filename;
 	char *pathname;
@@ -2079,13 +2080,13 @@
  		 */
 		KASSERT(verinfo == NULL, ("linker_load_module: verinfo"
 		    " is not NULL"));
-		if (rootvnode == NULL)
+		if (rootvnode == NULL || cp->p_fd == NULL || cp->p_fd->fd_rdir == NULL)
 			return (ENXIO);
 		pathname = linker_search_kld(kldname);
 	} else {
 		if (modlist_lookup2(modname, verinfo) != NULL)
 			return (EEXIST);
-		if (rootvnode == NULL)
+		if (rootvnode == NULL || cp->p_fd == NULL || cp->p_fd->fd_rdir == NULL)
 			return (ENXIO);
 		if (kldname != NULL)
 			pathname = strdup(kldname, M_LINKER);

Why not like this? Or remove the rootvnode == NULL and only test fd_rdir ?

Check for p_fd == NULL is really not needed, because we initalize it even for proc0 with valid file descriptor table.

I think that keeping rootvnode check is still needed/useful.

hselasky retitled this revision from Avoid calling into kern_kldload() for kernel processes. to Factor out checks for mounted root file system.
hselasky edited the summary of this revision. (Show Details)

Keep the rootvnode check in case the root file system gets unmounted.
Update comment.

sys/kern/kern_linker.c
2070 ↗(On Diff #64941)

No initialization in declaration. We usually name the single variable in function designated a process pointer 'p'.

2084 ↗(On Diff #64941)

p_fd == NULL check is not needed.

hselasky marked 2 inline comments as done.

Handle comments from @kib

In fact, I do not see much need in introducing 'p': you reference curproc only once in each branch, so caching the pointer does not save anything.

This revision is now accepted and ready to land.Nov 27 2019, 4:29 PM