From: Linus Torvalds Date: Fri, 13 May 2011 18:51:01 +0000 (-0700) Subject: vfs: micro-optimize acl_permission_check() X-Git-Tag: firefly_0821_release~7613^2~1444 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=26cf46be954a2dd391d32eeaf7d07c3a953dcc5a;p=firefly-linux-kernel-4.4.55.git vfs: micro-optimize acl_permission_check() It's a hot function, and we're better off not mixing types in the mask calculations. The compiler just ends up mixing 16-bit and 32-bit operations, for no good reason. So do everything in 'unsigned int' rather than mixing 'unsigned int' masking with a 'umode_t' (16-bit) mode variable. This, together with the parent commit (47a150edc2ae: "Cache user_ns in struct cred") makes acl_permission_check() much nicer. Signed-off-by: Linus Torvalds --- diff --git a/fs/namei.c b/fs/namei.c index 54fc993e3027..e3c4f112ebf7 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -179,7 +179,7 @@ EXPORT_SYMBOL(putname); static int acl_permission_check(struct inode *inode, int mask, unsigned int flags, int (*check_acl)(struct inode *inode, int mask, unsigned int flags)) { - umode_t mode = inode->i_mode; + unsigned int mode = inode->i_mode; mask &= MAY_READ | MAY_WRITE | MAY_EXEC;