diff mbox series

fs: tidy up do_sys_openat2() with likely/unlikely

Message ID 20250320092331.1921700-1-mjguzik@gmail.com (mailing list archive)
State New
Headers show
Series fs: tidy up do_sys_openat2() with likely/unlikely | expand

Commit Message

Mateusz Guzik March 20, 2025, 9:23 a.m. UTC
Otherwise gcc 13 generates conditional forward jumps (aka branch
mispredict by default) for build_open_flags() being succesfull.

Signed-off-by: Mateusz Guzik <mjguzik@gmail.com>
---

maybe i'll get around to do it a full pass instead of sending byte-sized
patchen. someone(tm) should definitely do it.

 fs/open.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

Comments

Christian Brauner March 20, 2025, 9:42 a.m. UTC | #1
On Thu, 20 Mar 2025 10:23:31 +0100, Mateusz Guzik wrote:
> Otherwise gcc 13 generates conditional forward jumps (aka branch
> mispredict by default) for build_open_flags() being succesfull.
> 
> 

Applied to the vfs-6.15.misc branch of the vfs/vfs.git tree.
Patches in the vfs-6.15.misc branch should appear in linux-next soon.

Please report any outstanding bugs that were missed during review in a
new review to the original patch series allowing us to drop it.

It's encouraged to provide Acked-bys and Reviewed-bys even though the
patch has now been applied. If possible patch trailers will be updated.

Note that commit hashes shown below are subject to change due to rebase,
trailer updates or similar. If in doubt, please check the listed branch.

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs.git
branch: vfs-6.15.misc

[1/1] fs: tidy up do_sys_openat2() with likely/unlikely
      https://git.kernel.org/vfs/vfs/c/d5a05a5a44a9
Jan Kara March 20, 2025, 10:49 a.m. UTC | #2
On Thu 20-03-25 10:23:31, Mateusz Guzik wrote:
> Otherwise gcc 13 generates conditional forward jumps (aka branch
> mispredict by default) for build_open_flags() being succesfull.
> 
> Signed-off-by: Mateusz Guzik <mjguzik@gmail.com>

Looks good. Feel free to add:

Reviewed-by: Jan Kara <jack@suse.cz>

								Honza

> ---
> 
> maybe i'll get around to do it a full pass instead of sending byte-sized
> patchen. someone(tm) should definitely do it.
> 
>  fs/open.c | 9 +++++----
>  1 file changed, 5 insertions(+), 4 deletions(-)
> 
> diff --git a/fs/open.c b/fs/open.c
> index bdbf03f799a1..a9063cca9911 100644
> --- a/fs/open.c
> +++ b/fs/open.c
> @@ -1413,18 +1413,19 @@ static int do_sys_openat2(int dfd, const char __user *filename,
>  			  struct open_how *how)
>  {
>  	struct open_flags op;
> -	int fd = build_open_flags(how, &op);
>  	struct filename *tmp;
> +	int err, fd;
>  
> -	if (fd)
> -		return fd;
> +	err = build_open_flags(how, &op);
> +	if (unlikely(err))
> +		return err;
>  
>  	tmp = getname(filename);
>  	if (IS_ERR(tmp))
>  		return PTR_ERR(tmp);
>  
>  	fd = get_unused_fd_flags(how->flags);
> -	if (fd >= 0) {
> +	if (likely(fd >= 0)) {
>  		struct file *f = do_filp_open(dfd, tmp, &op);
>  		if (IS_ERR(f)) {
>  			put_unused_fd(fd);
> -- 
> 2.43.0
>
diff mbox series

Patch

diff --git a/fs/open.c b/fs/open.c
index bdbf03f799a1..a9063cca9911 100644
--- a/fs/open.c
+++ b/fs/open.c
@@ -1413,18 +1413,19 @@  static int do_sys_openat2(int dfd, const char __user *filename,
 			  struct open_how *how)
 {
 	struct open_flags op;
-	int fd = build_open_flags(how, &op);
 	struct filename *tmp;
+	int err, fd;
 
-	if (fd)
-		return fd;
+	err = build_open_flags(how, &op);
+	if (unlikely(err))
+		return err;
 
 	tmp = getname(filename);
 	if (IS_ERR(tmp))
 		return PTR_ERR(tmp);
 
 	fd = get_unused_fd_flags(how->flags);
-	if (fd >= 0) {
+	if (likely(fd >= 0)) {
 		struct file *f = do_filp_open(dfd, tmp, &op);
 		if (IS_ERR(f)) {
 			put_unused_fd(fd);