[RFC PATCH v3 27/59] do_sys_openat2(): get rid of useless check, switch to CLASS(filename)

Al Viro posted 59 patches 1 month, 3 weeks ago
[RFC PATCH v3 27/59] do_sys_openat2(): get rid of useless check, switch to CLASS(filename)
Posted by Al Viro 1 month, 3 weeks ago
do_file_open() will do the right thing is given ERR_PTR() for name...

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
---
 fs/open.c | 12 +++---------
 1 file changed, 3 insertions(+), 9 deletions(-)

diff --git a/fs/open.c b/fs/open.c
index 3d2e2a2554c5..ac8dedea8daf 100644
--- a/fs/open.c
+++ b/fs/open.c
@@ -1425,18 +1425,12 @@ static int do_sys_openat2(int dfd, const char __user *filename,
 			  struct open_how *how)
 {
 	struct open_flags op;
-	struct filename *tmp __free(putname) = NULL;
-	int err;
-
-	err = build_open_flags(how, &op);
+	int err = build_open_flags(how, &op);
 	if (unlikely(err))
 		return err;
 
-	tmp = getname(filename);
-	if (IS_ERR(tmp))
-		return PTR_ERR(tmp);
-
-	return FD_ADD(how->flags, do_file_open(dfd, tmp, &op));
+	CLASS(filename, name)(filename);
+	return FD_ADD(how->flags, do_file_open(dfd, name, &op));
 }
 
 int do_sys_open(int dfd, const char __user *filename, int flags, umode_t mode)
-- 
2.47.3
Re: [RFC PATCH v3 27/59] do_sys_openat2(): get rid of useless check, switch to CLASS(filename)
Posted by Askar Safin 1 month, 3 weeks ago
Al Viro <viro@zeniv.linux.org.uk>:
> do_file_open() will do the right thing is given ERR_PTR() for name...

Maybe you meant "right thing if given"?

-- 
Askar Safin
Re: [RFC PATCH v3 27/59] do_sys_openat2(): get rid of useless check, switch to CLASS(filename)
Posted by Al Viro 1 month, 3 weeks ago
On Tue, Dec 16, 2025 at 11:08:58PM +0300, Askar Safin wrote:
> Al Viro <viro@zeniv.linux.org.uk>:
> > do_file_open() will do the right thing is given ERR_PTR() for name...
> 
> Maybe you meant "right thing if given"?

d'oh...