[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20241115165541.GB209124@lichtman.org>
Date: Fri, 15 Nov 2024 16:55:41 +0000
From: Nir Lichtman <nir@...htman.org>
To: viro@...iv.linux.org.uk, brauner@...nel.org, jack@...e.cz,
ebiederm@...ssion.com, kees@...nel.org,
linux-kernel@...r.kernel.org
Subject: [PATCH] exec: fix no kernel module found error to be more clear
Problem: Before starting the enumeration of the supported formats the
default return value is set to no entity which is misleading since if
the kernel module of the binary format is not found, it would return no
entity to user mode which is misleading since it is signaling that a
file was not found, but in this case the more suitable error is that the
executable has an unsupported format
Solution: Refactor to return no-exec error instead
Signed-off-by: Nir Lichtman <nir@...htman.org>
---
fs/exec.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/fs/exec.c b/fs/exec.c
index 3394de5882af..6324f9546b09 100644
--- a/fs/exec.c
+++ b/fs/exec.c
@@ -1740,7 +1740,7 @@ static int search_binary_handler(struct linux_binprm *bprm)
if (retval)
return retval;
- retval = -ENOENT;
+ retval = -ENOEXEC;
retry:
read_lock(&binfmt_lock);
list_for_each_entry(fmt, &formats, lh) {
--
2.39.2
Powered by blists - more mailing lists