From: Mateusz Nosek <mateusznosek0@xxxxxxxxx> If file is a directory it is surely not regular. Therefore, if 'S_ISREG' check returns false one can be sure that vfs_truncate must returns with error. Introduced patch refactors code to avoid one branch in 'likely' control flow path. Moreover, it marks the proper check with 'unlikely' macro to improve both branch prediction and readability. Changes were tested with gcc 8.3.0 on x86 architecture and it is confirmed that slightly better assembly is generated. Signed-off-by: Mateusz Nosek <mateusznosek0@xxxxxxxxx> --- fs/open.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/fs/open.c b/fs/open.c index 9af548fb841b..69658ea27530 100644 --- a/fs/open.c +++ b/fs/open.c @@ -74,10 +74,12 @@ long vfs_truncate(const struct path *path, loff_t length) inode = path->dentry->d_inode; /* For directories it's -EISDIR, for other non-regulars - -EINVAL */ - if (S_ISDIR(inode->i_mode)) - return -EISDIR; - if (!S_ISREG(inode->i_mode)) - return -EINVAL; + if (unlikely(!S_ISREG(inode->i_mode))) { + if (S_ISDIR(inode->i_mode)) + return -EISDIR; + else + return -EINVAL; + } error = mnt_want_write(path->mnt); if (error) -- 2.20.1