LCOV - code coverage report
Current view: top level - fs - open.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 435 605 71.9 %
Date: 2022-03-28 16:04:14 Functions: 41 80 51.2 %
Branches: 196 380 51.6 %

           Branch data     Line data    Source code
       1                 :            : // SPDX-License-Identifier: GPL-2.0-only
       2                 :            : /*
       3                 :            :  *  linux/fs/open.c
       4                 :            :  *
       5                 :            :  *  Copyright (C) 1991, 1992  Linus Torvalds
       6                 :            :  */
       7                 :            : 
       8                 :            : #include <linux/string.h>
       9                 :            : #include <linux/mm.h>
      10                 :            : #include <linux/file.h>
      11                 :            : #include <linux/fdtable.h>
      12                 :            : #include <linux/fsnotify.h>
      13                 :            : #include <linux/module.h>
      14                 :            : #include <linux/tty.h>
      15                 :            : #include <linux/namei.h>
      16                 :            : #include <linux/backing-dev.h>
      17                 :            : #include <linux/capability.h>
      18                 :            : #include <linux/securebits.h>
      19                 :            : #include <linux/security.h>
      20                 :            : #include <linux/mount.h>
      21                 :            : #include <linux/fcntl.h>
      22                 :            : #include <linux/slab.h>
      23                 :            : #include <linux/uaccess.h>
      24                 :            : #include <linux/fs.h>
      25                 :            : #include <linux/personality.h>
      26                 :            : #include <linux/pagemap.h>
      27                 :            : #include <linux/syscalls.h>
      28                 :            : #include <linux/rcupdate.h>
      29                 :            : #include <linux/audit.h>
      30                 :            : #include <linux/falloc.h>
      31                 :            : #include <linux/fs_struct.h>
      32                 :            : #include <linux/ima.h>
      33                 :            : #include <linux/dnotify.h>
      34                 :            : #include <linux/compat.h>
      35                 :            : 
      36                 :            : #include "internal.h"
      37                 :            : 
      38                 :        178 : int do_truncate(struct dentry *dentry, loff_t length, unsigned int time_attrs,
      39                 :            :         struct file *filp)
      40                 :            : {
      41                 :        178 :         int ret;
      42                 :        178 :         struct iattr newattrs;
      43                 :            : 
      44                 :            :         /* Not pretty: "inode->i_size" shouldn't really be signed. But it is. */
      45         [ +  - ]:        178 :         if (length < 0)
      46                 :            :                 return -EINVAL;
      47                 :            : 
      48                 :        178 :         newattrs.ia_size = length;
      49                 :        178 :         newattrs.ia_valid = ATTR_SIZE | time_attrs;
      50         [ +  - ]:        178 :         if (filp) {
      51                 :        178 :                 newattrs.ia_file = filp;
      52                 :        178 :                 newattrs.ia_valid |= ATTR_FILE;
      53                 :            :         }
      54                 :            : 
      55                 :            :         /* Remove suid, sgid, and file capabilities on truncate too */
      56                 :        178 :         ret = dentry_needs_remove_privs(dentry);
      57         [ +  - ]:        178 :         if (ret < 0)
      58                 :            :                 return ret;
      59         [ -  + ]:        178 :         if (ret)
      60                 :          0 :                 newattrs.ia_valid |= ret | ATTR_FORCE;
      61                 :            : 
      62                 :        178 :         inode_lock(dentry->d_inode);
      63                 :            :         /* Note any delegations or leases have already been broken: */
      64                 :        178 :         ret = notify_change(dentry, &newattrs, NULL);
      65                 :        178 :         inode_unlock(dentry->d_inode);
      66                 :        178 :         return ret;
      67                 :            : }
      68                 :            : 
      69                 :          0 : long vfs_truncate(const struct path *path, loff_t length)
      70                 :            : {
      71                 :          0 :         struct inode *inode;
      72                 :          0 :         long error;
      73                 :            : 
      74                 :          0 :         inode = path->dentry->d_inode;
      75                 :            : 
      76                 :            :         /* For directories it's -EISDIR, for other non-regulars - -EINVAL */
      77         [ #  # ]:          0 :         if (S_ISDIR(inode->i_mode))
      78                 :            :                 return -EISDIR;
      79         [ #  # ]:          0 :         if (!S_ISREG(inode->i_mode))
      80                 :            :                 return -EINVAL;
      81                 :            : 
      82                 :          0 :         error = mnt_want_write(path->mnt);
      83         [ #  # ]:          0 :         if (error)
      84                 :          0 :                 goto out;
      85                 :            : 
      86                 :          0 :         error = inode_permission(inode, MAY_WRITE);
      87         [ #  # ]:          0 :         if (error)
      88                 :          0 :                 goto mnt_drop_write_and_out;
      89                 :            : 
      90                 :          0 :         error = -EPERM;
      91         [ #  # ]:          0 :         if (IS_APPEND(inode))
      92                 :          0 :                 goto mnt_drop_write_and_out;
      93                 :            : 
      94                 :          0 :         error = get_write_access(inode);
      95         [ #  # ]:          0 :         if (error)
      96                 :          0 :                 goto mnt_drop_write_and_out;
      97                 :            : 
      98                 :            :         /*
      99                 :            :          * Make sure that there are no leases.  get_write_access() protects
     100                 :            :          * against the truncate racing with a lease-granting setlease().
     101                 :            :          */
     102                 :          0 :         error = break_lease(inode, O_WRONLY);
     103         [ #  # ]:          0 :         if (error)
     104                 :          0 :                 goto put_write_and_out;
     105                 :            : 
     106                 :          0 :         error = locks_verify_truncate(inode, NULL, length);
     107         [ #  # ]:          0 :         if (!error)
     108                 :          0 :                 error = security_path_truncate(path);
     109                 :          0 :         if (!error)
     110                 :          0 :                 error = do_truncate(path->dentry, length, 0, NULL);
     111                 :            : 
     112                 :          0 : put_write_and_out:
     113                 :          0 :         put_write_access(inode);
     114                 :          0 : mnt_drop_write_and_out:
     115                 :          0 :         mnt_drop_write(path->mnt);
     116                 :            : out:
     117                 :            :         return error;
     118                 :            : }
     119                 :            : EXPORT_SYMBOL_GPL(vfs_truncate);
     120                 :            : 
     121                 :          0 : long do_sys_truncate(const char __user *pathname, loff_t length)
     122                 :            : {
     123                 :          0 :         unsigned int lookup_flags = LOOKUP_FOLLOW;
     124                 :          0 :         struct path path;
     125                 :          0 :         int error;
     126                 :            : 
     127         [ #  # ]:          0 :         if (length < 0)      /* sorry, but loff_t says... */
     128                 :            :                 return -EINVAL;
     129                 :            : 
     130                 :          0 : retry:
     131                 :          0 :         error = user_path_at(AT_FDCWD, pathname, lookup_flags, &path);
     132         [ #  # ]:          0 :         if (!error) {
     133                 :          0 :                 error = vfs_truncate(&path, length);
     134                 :          0 :                 path_put(&path);
     135                 :            :         }
     136   [ #  #  #  # ]:          0 :         if (retry_estale(error, lookup_flags)) {
     137                 :          0 :                 lookup_flags |= LOOKUP_REVAL;
     138                 :          0 :                 goto retry;
     139                 :            :         }
     140                 :            :         return error;
     141                 :            : }
     142                 :            : 
     143                 :          0 : SYSCALL_DEFINE2(truncate, const char __user *, path, long, length)
     144                 :            : {
     145                 :          0 :         return do_sys_truncate(path, length);
     146                 :            : }
     147                 :            : 
     148                 :            : #ifdef CONFIG_COMPAT
     149                 :          0 : COMPAT_SYSCALL_DEFINE2(truncate, const char __user *, path, compat_off_t, length)
     150                 :            : {
     151                 :          0 :         return do_sys_truncate(path, length);
     152                 :            : }
     153                 :            : #endif
     154                 :            : 
     155                 :        126 : long do_sys_ftruncate(unsigned int fd, loff_t length, int small)
     156                 :            : {
     157                 :        126 :         struct inode *inode;
     158                 :        126 :         struct dentry *dentry;
     159                 :        126 :         struct fd f;
     160                 :        126 :         int error;
     161                 :            : 
     162                 :        126 :         error = -EINVAL;
     163         [ -  + ]:        126 :         if (length < 0)
     164                 :          0 :                 goto out;
     165                 :        126 :         error = -EBADF;
     166                 :        126 :         f = fdget(fd);
     167         [ -  + ]:        126 :         if (!f.file)
     168                 :          0 :                 goto out;
     169                 :            : 
     170                 :            :         /* explicitly opened as large or we are on 64-bit box */
     171         [ +  - ]:        126 :         if (f.file->f_flags & O_LARGEFILE)
     172                 :        126 :                 small = 0;
     173                 :            : 
     174                 :        126 :         dentry = f.file->f_path.dentry;
     175                 :        126 :         inode = dentry->d_inode;
     176                 :        126 :         error = -EINVAL;
     177   [ +  -  -  + ]:        126 :         if (!S_ISREG(inode->i_mode) || !(f.file->f_mode & FMODE_WRITE))
     178                 :          0 :                 goto out_putf;
     179                 :            : 
     180                 :        126 :         error = -EINVAL;
     181                 :            :         /* Cannot ftruncate over 2^31 bytes without large file support */
     182         [ -  + ]:        126 :         if (small && length > MAX_NON_LFS)
     183                 :          0 :                 goto out_putf;
     184                 :            : 
     185                 :        126 :         error = -EPERM;
     186                 :            :         /* Check IS_APPEND on real upper inode */
     187         [ -  + ]:        126 :         if (IS_APPEND(file_inode(f.file)))
     188                 :          0 :                 goto out_putf;
     189                 :            : 
     190                 :        126 :         sb_start_write(inode->i_sb);
     191                 :        126 :         error = locks_verify_truncate(inode, f.file, length);
     192         [ +  - ]:        126 :         if (!error)
     193                 :        126 :                 error = security_path_truncate(&f.file->f_path);
     194                 :        126 :         if (!error)
     195                 :        126 :                 error = do_truncate(dentry, length, ATTR_MTIME|ATTR_CTIME, f.file);
     196                 :        126 :         sb_end_write(inode->i_sb);
     197                 :        126 : out_putf:
     198         [ -  + ]:        126 :         fdput(f);
     199                 :        126 : out:
     200                 :        126 :         return error;
     201                 :            : }
     202                 :            : 
     203                 :        252 : SYSCALL_DEFINE2(ftruncate, unsigned int, fd, unsigned long, length)
     204                 :            : {
     205                 :        126 :         return do_sys_ftruncate(fd, length, 1);
     206                 :            : }
     207                 :            : 
     208                 :            : #ifdef CONFIG_COMPAT
     209                 :          0 : COMPAT_SYSCALL_DEFINE2(ftruncate, unsigned int, fd, compat_ulong_t, length)
     210                 :            : {
     211                 :          0 :         return do_sys_ftruncate(fd, length, 1);
     212                 :            : }
     213                 :            : #endif
     214                 :            : 
     215                 :            : /* LFS versions of truncate are only needed on 32 bit machines */
     216                 :            : #if BITS_PER_LONG == 32
     217                 :            : SYSCALL_DEFINE2(truncate64, const char __user *, path, loff_t, length)
     218                 :            : {
     219                 :            :         return do_sys_truncate(path, length);
     220                 :            : }
     221                 :            : 
     222                 :            : SYSCALL_DEFINE2(ftruncate64, unsigned int, fd, loff_t, length)
     223                 :            : {
     224                 :            :         return do_sys_ftruncate(fd, length, 0);
     225                 :            : }
     226                 :            : #endif /* BITS_PER_LONG == 32 */
     227                 :            : 
     228                 :            : 
     229                 :         26 : int vfs_fallocate(struct file *file, int mode, loff_t offset, loff_t len)
     230                 :            : {
     231         [ +  - ]:         26 :         struct inode *inode = file_inode(file);
     232                 :         26 :         long ret;
     233                 :            : 
     234         [ +  - ]:         26 :         if (offset < 0 || len <= 0)
     235                 :            :                 return -EINVAL;
     236                 :            : 
     237                 :            :         /* Return error if mode is not supported */
     238         [ +  - ]:         26 :         if (mode & ~FALLOC_FL_SUPPORTED_MASK)
     239                 :            :                 return -EOPNOTSUPP;
     240                 :            : 
     241                 :            :         /* Punch hole and zero range are mutually exclusive */
     242         [ +  - ]:         26 :         if ((mode & (FALLOC_FL_PUNCH_HOLE | FALLOC_FL_ZERO_RANGE)) ==
     243                 :            :             (FALLOC_FL_PUNCH_HOLE | FALLOC_FL_ZERO_RANGE))
     244                 :            :                 return -EOPNOTSUPP;
     245                 :            : 
     246                 :            :         /* Punch hole must have keep size set */
     247         [ +  - ]:         26 :         if ((mode & FALLOC_FL_PUNCH_HOLE) &&
     248                 :            :             !(mode & FALLOC_FL_KEEP_SIZE))
     249                 :            :                 return -EOPNOTSUPP;
     250                 :            : 
     251                 :            :         /* Collapse range should only be used exclusively. */
     252         [ -  + ]:         26 :         if ((mode & FALLOC_FL_COLLAPSE_RANGE) &&
     253         [ #  # ]:          0 :             (mode & ~FALLOC_FL_COLLAPSE_RANGE))
     254                 :            :                 return -EINVAL;
     255                 :            : 
     256                 :            :         /* Insert range should only be used exclusively. */
     257         [ -  + ]:         26 :         if ((mode & FALLOC_FL_INSERT_RANGE) &&
     258         [ #  # ]:          0 :             (mode & ~FALLOC_FL_INSERT_RANGE))
     259                 :            :                 return -EINVAL;
     260                 :            : 
     261                 :            :         /* Unshare range should only be used with allocate mode. */
     262         [ -  + ]:         26 :         if ((mode & FALLOC_FL_UNSHARE_RANGE) &&
     263         [ #  # ]:          0 :             (mode & ~(FALLOC_FL_UNSHARE_RANGE | FALLOC_FL_KEEP_SIZE)))
     264                 :            :                 return -EINVAL;
     265                 :            : 
     266         [ +  - ]:         26 :         if (!(file->f_mode & FMODE_WRITE))
     267                 :            :                 return -EBADF;
     268                 :            : 
     269                 :            :         /*
     270                 :            :          * We can only allow pure fallocate on append only files
     271                 :            :          */
     272   [ -  +  -  - ]:         26 :         if ((mode & ~FALLOC_FL_KEEP_SIZE) && IS_APPEND(inode))
     273                 :            :                 return -EPERM;
     274                 :            : 
     275         [ +  - ]:         26 :         if (IS_IMMUTABLE(inode))
     276                 :            :                 return -EPERM;
     277                 :            : 
     278                 :            :         /*
     279                 :            :          * We cannot allow any fallocate operation on an active swapfile
     280                 :            :          */
     281         [ +  - ]:         26 :         if (IS_SWAPFILE(inode))
     282                 :            :                 return -ETXTBSY;
     283                 :            : 
     284                 :            :         /*
     285                 :            :          * Revalidate the write permissions, in case security policy has
     286                 :            :          * changed since the files were opened.
     287                 :            :          */
     288                 :         26 :         ret = security_file_permission(file, MAY_WRITE);
     289         [ +  - ]:         26 :         if (ret)
     290                 :            :                 return ret;
     291                 :            : 
     292         [ +  - ]:         26 :         if (S_ISFIFO(inode->i_mode))
     293                 :            :                 return -ESPIPE;
     294                 :            : 
     295         [ +  - ]:         26 :         if (S_ISDIR(inode->i_mode))
     296                 :            :                 return -EISDIR;
     297                 :            : 
     298         [ +  - ]:         26 :         if (!S_ISREG(inode->i_mode) && !S_ISBLK(inode->i_mode))
     299                 :            :                 return -ENODEV;
     300                 :            : 
     301                 :            :         /* Check for wrap through zero too */
     302   [ +  -  +  - ]:         26 :         if (((offset + len) > inode->i_sb->s_maxbytes) || ((offset + len) < 0))
     303                 :            :                 return -EFBIG;
     304                 :            : 
     305         [ +  - ]:         26 :         if (!file->f_op->fallocate)
     306                 :            :                 return -EOPNOTSUPP;
     307                 :            : 
     308                 :         26 :         file_start_write(file);
     309                 :         26 :         ret = file->f_op->fallocate(file, mode, offset, len);
     310                 :            : 
     311                 :            :         /*
     312                 :            :          * Create inotify and fanotify events.
     313                 :            :          *
     314                 :            :          * To keep the logic simple always create events if fallocate succeeds.
     315                 :            :          * This implies that events are even created if the file size remains
     316                 :            :          * unchanged, e.g. when using flag FALLOC_FL_KEEP_SIZE.
     317                 :            :          */
     318         [ +  - ]:         26 :         if (ret == 0)
     319                 :         26 :                 fsnotify_modify(file);
     320                 :            : 
     321         [ +  - ]:         26 :         file_end_write(file);
     322                 :         26 :         return ret;
     323                 :            : }
     324                 :            : EXPORT_SYMBOL_GPL(vfs_fallocate);
     325                 :            : 
     326                 :         26 : int ksys_fallocate(int fd, int mode, loff_t offset, loff_t len)
     327                 :            : {
     328                 :         26 :         struct fd f = fdget(fd);
     329                 :         26 :         int error = -EBADF;
     330                 :            : 
     331         [ +  - ]:         26 :         if (f.file) {
     332                 :         26 :                 error = vfs_fallocate(f.file, mode, offset, len);
     333         [ -  + ]:         26 :                 fdput(f);
     334                 :            :         }
     335                 :         26 :         return error;
     336                 :            : }
     337                 :            : 
     338                 :         52 : SYSCALL_DEFINE4(fallocate, int, fd, int, mode, loff_t, offset, loff_t, len)
     339                 :            : {
     340                 :         26 :         return ksys_fallocate(fd, mode, offset, len);
     341                 :            : }
     342                 :            : 
     343                 :            : /*
     344                 :            :  * access() needs to use the real uid/gid, not the effective uid/gid.
     345                 :            :  * We do this by temporarily clearing all FS-related capabilities and
     346                 :            :  * switching the fsuid/fsgid around to the real ones.
     347                 :            :  */
     348                 :      43671 : long do_faccessat(int dfd, const char __user *filename, int mode)
     349                 :            : {
     350                 :      43671 :         const struct cred *old_cred;
     351                 :      43671 :         struct cred *override_cred;
     352                 :      43671 :         struct path path;
     353                 :      43671 :         struct inode *inode;
     354                 :      43671 :         int res;
     355                 :      43671 :         unsigned int lookup_flags = LOOKUP_FOLLOW;
     356                 :            : 
     357         [ +  - ]:      43671 :         if (mode & ~S_IRWXO)        /* where's F_OK, X_OK, W_OK, R_OK? */
     358                 :            :                 return -EINVAL;
     359                 :            : 
     360                 :      43671 :         override_cred = prepare_creds();
     361         [ +  - ]:      43671 :         if (!override_cred)
     362                 :            :                 return -ENOMEM;
     363                 :            : 
     364                 :      43671 :         override_cred->fsuid = override_cred->uid;
     365                 :      43671 :         override_cred->fsgid = override_cred->gid;
     366                 :            : 
     367         [ +  - ]:      43671 :         if (!issecure(SECURE_NO_SETUID_FIXUP)) {
     368                 :            :                 /* Clear the capabilities if we switch to a non-root user */
     369         [ +  + ]:      43671 :                 kuid_t root_uid = make_kuid(override_cred->user_ns, 0);
     370         [ +  + ]:      43671 :                 if (!uid_eq(override_cred->uid, root_uid))
     371                 :         39 :                         cap_clear(override_cred->cap_effective);
     372                 :            :                 else
     373                 :      43632 :                         override_cred->cap_effective =
     374                 :            :                                 override_cred->cap_permitted;
     375                 :            :         }
     376                 :            : 
     377                 :            :         /*
     378                 :            :          * The new set of credentials can *only* be used in
     379                 :            :          * task-synchronous circumstances, and does not need
     380                 :            :          * RCU freeing, unless somebody then takes a separate
     381                 :            :          * reference to it.
     382                 :            :          *
     383                 :            :          * NOTE! This is _only_ true because this credential
     384                 :            :          * is used purely for override_creds() that installs
     385                 :            :          * it as the subjective cred. Other threads will be
     386                 :            :          * accessing ->real_cred, not the subjective cred.
     387                 :            :          *
     388                 :            :          * If somebody _does_ make a copy of this (using the
     389                 :            :          * 'get_current_cred()' function), that will clear the
     390                 :            :          * non_rcu field, because now that other user may be
     391                 :            :          * expecting RCU freeing. But normal thread-synchronous
     392                 :            :          * cred accesses will keep things non-RCY.
     393                 :            :          */
     394                 :      43671 :         override_cred->non_rcu = 1;
     395                 :            : 
     396                 :      43671 :         old_cred = override_creds(override_cred);
     397                 :      43671 : retry:
     398                 :      43671 :         res = user_path_at(dfd, filename, lookup_flags, &path);
     399         [ +  + ]:      43671 :         if (res)
     400                 :      30445 :                 goto out;
     401                 :            : 
     402         [ +  + ]:      13226 :         inode = d_backing_inode(path.dentry);
     403                 :            : 
     404   [ +  +  +  - ]:      13226 :         if ((mode & MAY_EXEC) && S_ISREG(inode->i_mode)) {
     405                 :            :                 /*
     406                 :            :                  * MAY_EXEC on regular files is denied if the fs is mounted
     407                 :            :                  * with the "noexec" flag.
     408                 :            :                  */
     409                 :        520 :                 res = -EACCES;
     410         [ -  + ]:        520 :                 if (path_noexec(&path))
     411                 :          0 :                         goto out_path_release;
     412                 :            :         }
     413                 :            : 
     414                 :      13226 :         res = inode_permission(inode, mode | MAY_ACCESS);
     415                 :            :         /* SuS v2 requires we report a read only fs too */
     416   [ +  +  +  +  :      13226 :         if (res || !(mode & S_IWOTH) || special_file(inode->i_mode))
          +  -  +  -  -  
                      + ]
     417                 :      12992 :                 goto out_path_release;
     418                 :            :         /*
     419                 :            :          * This is a rare case where using __mnt_is_readonly()
     420                 :            :          * is OK without a mnt_want/drop_write() pair.  Since
     421                 :            :          * no actual write to the fs is performed here, we do
     422                 :            :          * not need to telegraph to that to anyone.
     423                 :            :          *
     424                 :            :          * By doing this, we accept that this access is
     425                 :            :          * inherently racy and know that the fs may change
     426                 :            :          * state before we even see this result.
     427                 :            :          */
     428         [ +  - ]:        234 :         if (__mnt_is_readonly(path.mnt))
     429                 :          0 :                 res = -EROFS;
     430                 :            : 
     431                 :        234 : out_path_release:
     432                 :      13226 :         path_put(&path);
     433   [ -  +  -  + ]:      26452 :         if (retry_estale(res, lookup_flags)) {
     434                 :          0 :                 lookup_flags |= LOOKUP_REVAL;
     435                 :          0 :                 goto retry;
     436                 :            :         }
     437                 :      13226 : out:
     438                 :      43671 :         revert_creds(old_cred);
     439                 :      43671 :         put_cred(override_cred);
     440                 :      43671 :         return res;
     441                 :            : }
     442                 :            : 
     443                 :        416 : SYSCALL_DEFINE3(faccessat, int, dfd, const char __user *, filename, int, mode)
     444                 :            : {
     445                 :        208 :         return do_faccessat(dfd, filename, mode);
     446                 :            : }
     447                 :            : 
     448                 :      86900 : SYSCALL_DEFINE2(access, const char __user *, filename, int, mode)
     449                 :            : {
     450                 :      43450 :         return do_faccessat(AT_FDCWD, filename, mode);
     451                 :            : }
     452                 :            : 
     453                 :      38844 : int ksys_chdir(const char __user *filename)
     454                 :            : {
     455                 :      38844 :         struct path path;
     456                 :      38844 :         int error;
     457                 :      38844 :         unsigned int lookup_flags = LOOKUP_FOLLOW | LOOKUP_DIRECTORY;
     458                 :      38844 : retry:
     459                 :      38844 :         error = user_path_at(AT_FDCWD, filename, lookup_flags, &path);
     460         [ -  + ]:      38844 :         if (error)
     461                 :          0 :                 goto out;
     462                 :            : 
     463                 :      38844 :         error = inode_permission(path.dentry->d_inode, MAY_EXEC | MAY_CHDIR);
     464         [ -  + ]:      38844 :         if (error)
     465                 :          0 :                 goto dput_and_out;
     466                 :            : 
     467                 :      38844 :         set_fs_pwd(current->fs, &path);
     468                 :            : 
     469                 :      38844 : dput_and_out:
     470                 :      38844 :         path_put(&path);
     471   [ -  +  -  + ]:      77688 :         if (retry_estale(error, lookup_flags)) {
     472                 :          0 :                 lookup_flags |= LOOKUP_REVAL;
     473                 :          0 :                 goto retry;
     474                 :            :         }
     475                 :      38844 : out:
     476                 :      38844 :         return error;
     477                 :            : }
     478                 :            : 
     479                 :      77636 : SYSCALL_DEFINE1(chdir, const char __user *, filename)
     480                 :            : {
     481                 :      38818 :         return ksys_chdir(filename);
     482                 :            : }
     483                 :            : 
     484                 :      13442 : SYSCALL_DEFINE1(fchdir, unsigned int, fd)
     485                 :            : {
     486                 :       6721 :         struct fd f = fdget_raw(fd);
     487                 :       6721 :         int error;
     488                 :            : 
     489                 :       6721 :         error = -EBADF;
     490         [ -  + ]:       6721 :         if (!f.file)
     491                 :          0 :                 goto out;
     492                 :            : 
     493                 :       6721 :         error = -ENOTDIR;
     494         [ -  + ]:       6721 :         if (!d_can_lookup(f.file->f_path.dentry))
     495                 :          0 :                 goto out_putf;
     496                 :            : 
     497                 :       6721 :         error = inode_permission(file_inode(f.file), MAY_EXEC | MAY_CHDIR);
     498         [ -  + ]:       6721 :         if (!error)
     499                 :       6721 :                 set_fs_pwd(current->fs, &f.file->f_path);
     500                 :          0 : out_putf:
     501         [ -  + ]:       6721 :         fdput(f);
     502                 :       6721 : out:
     503                 :       6721 :         return error;
     504                 :            : }
     505                 :            : 
     506                 :         52 : int ksys_chroot(const char __user *filename)
     507                 :            : {
     508                 :         52 :         struct path path;
     509                 :         52 :         int error;
     510                 :         52 :         unsigned int lookup_flags = LOOKUP_FOLLOW | LOOKUP_DIRECTORY;
     511                 :         52 : retry:
     512                 :         52 :         error = user_path_at(AT_FDCWD, filename, lookup_flags, &path);
     513         [ -  + ]:         52 :         if (error)
     514                 :          0 :                 goto out;
     515                 :            : 
     516                 :         52 :         error = inode_permission(path.dentry->d_inode, MAY_EXEC | MAY_CHDIR);
     517         [ -  + ]:         52 :         if (error)
     518                 :          0 :                 goto dput_and_out;
     519                 :            : 
     520                 :         52 :         error = -EPERM;
     521         [ -  + ]:         52 :         if (!ns_capable(current_user_ns(), CAP_SYS_CHROOT))
     522                 :          0 :                 goto dput_and_out;
     523                 :         52 :         error = security_path_chroot(&path);
     524                 :         52 :         if (error)
     525                 :            :                 goto dput_and_out;
     526                 :            : 
     527                 :         52 :         set_fs_root(current->fs, &path);
     528                 :         52 :         error = 0;
     529                 :         52 : dput_and_out:
     530                 :         52 :         path_put(&path);
     531   [ -  +  -  + ]:        104 :         if (retry_estale(error, lookup_flags)) {
     532                 :          0 :                 lookup_flags |= LOOKUP_REVAL;
     533                 :          0 :                 goto retry;
     534                 :            :         }
     535                 :         52 : out:
     536                 :         52 :         return error;
     537                 :            : }
     538                 :            : 
     539                 :         52 : SYSCALL_DEFINE1(chroot, const char __user *, filename)
     540                 :            : {
     541                 :         26 :         return ksys_chroot(filename);
     542                 :            : }
     543                 :            : 
     544                 :       4173 : static int chmod_common(const struct path *path, umode_t mode)
     545                 :            : {
     546                 :       4173 :         struct inode *inode = path->dentry->d_inode;
     547                 :       4173 :         struct inode *delegated_inode = NULL;
     548                 :       4173 :         struct iattr newattrs;
     549                 :       4173 :         int error;
     550                 :            : 
     551                 :       4173 :         error = mnt_want_write(path->mnt);
     552         [ +  - ]:       4173 :         if (error)
     553                 :            :                 return error;
     554                 :       4173 : retry_deleg:
     555                 :       4173 :         inode_lock(inode);
     556                 :       4173 :         error = security_path_chmod(path, mode);
     557                 :       4173 :         if (error)
     558                 :            :                 goto out_unlock;
     559                 :       4173 :         newattrs.ia_mode = (mode & S_IALLUGO) | (inode->i_mode & ~S_IALLUGO);
     560                 :       4173 :         newattrs.ia_valid = ATTR_MODE | ATTR_CTIME;
     561                 :       4173 :         error = notify_change(path->dentry, &newattrs, &delegated_inode);
     562                 :            : out_unlock:
     563                 :       4173 :         inode_unlock(inode);
     564         [ -  + ]:       4173 :         if (delegated_inode) {
     565                 :          0 :                 error = break_deleg_wait(&delegated_inode);
     566         [ #  # ]:          0 :                 if (!error)
     567                 :          0 :                         goto retry_deleg;
     568                 :            :         }
     569                 :       4173 :         mnt_drop_write(path->mnt);
     570                 :       4173 :         return error;
     571                 :            : }
     572                 :            : 
     573                 :       2327 : int ksys_fchmod(unsigned int fd, umode_t mode)
     574                 :            : {
     575                 :       2327 :         struct fd f = fdget(fd);
     576                 :       2327 :         int err = -EBADF;
     577                 :            : 
     578         [ +  - ]:       2327 :         if (f.file) {
     579                 :       2327 :                 audit_file(f.file);
     580                 :       2327 :                 err = chmod_common(&f.file->f_path, mode);
     581         [ -  + ]:       2327 :                 fdput(f);
     582                 :            :         }
     583                 :       2327 :         return err;
     584                 :            : }
     585                 :            : 
     586                 :       4654 : SYSCALL_DEFINE2(fchmod, unsigned int, fd, umode_t, mode)
     587                 :            : {
     588                 :       2327 :         return ksys_fchmod(fd, mode);
     589                 :            : }
     590                 :            : 
     591                 :       1846 : int do_fchmodat(int dfd, const char __user *filename, umode_t mode)
     592                 :            : {
     593                 :       1846 :         struct path path;
     594                 :       1846 :         int error;
     595                 :       1846 :         unsigned int lookup_flags = LOOKUP_FOLLOW;
     596                 :       1846 : retry:
     597                 :       1846 :         error = user_path_at(dfd, filename, lookup_flags, &path);
     598         [ +  - ]:       1846 :         if (!error) {
     599                 :       1846 :                 error = chmod_common(&path, mode);
     600                 :       1846 :                 path_put(&path);
     601   [ -  +  -  + ]:       3692 :                 if (retry_estale(error, lookup_flags)) {
     602                 :          0 :                         lookup_flags |= LOOKUP_REVAL;
     603                 :          0 :                         goto retry;
     604                 :            :                 }
     605                 :            :         }
     606                 :       1846 :         return error;
     607                 :            : }
     608                 :            : 
     609                 :          0 : SYSCALL_DEFINE3(fchmodat, int, dfd, const char __user *, filename,
     610                 :            :                 umode_t, mode)
     611                 :            : {
     612                 :          0 :         return do_fchmodat(dfd, filename, mode);
     613                 :            : }
     614                 :            : 
     615                 :       3614 : SYSCALL_DEFINE2(chmod, const char __user *, filename, umode_t, mode)
     616                 :            : {
     617                 :       1807 :         return do_fchmodat(AT_FDCWD, filename, mode);
     618                 :            : }
     619                 :            : 
     620                 :            : static int chown_common(const struct path *path, uid_t user, gid_t group)
     621                 :            : {
     622                 :            :         struct inode *inode = path->dentry->d_inode;
     623                 :            :         struct inode *delegated_inode = NULL;
     624                 :            :         int error;
     625                 :            :         struct iattr newattrs;
     626                 :            :         kuid_t uid;
     627                 :            :         kgid_t gid;
     628                 :            : 
     629                 :            :         uid = make_kuid(current_user_ns(), user);
     630                 :            :         gid = make_kgid(current_user_ns(), group);
     631                 :            : 
     632                 :            : retry_deleg:
     633                 :            :         newattrs.ia_valid =  ATTR_CTIME;
     634                 :            :         if (user != (uid_t) -1) {
     635                 :            :                 if (!uid_valid(uid))
     636                 :            :                         return -EINVAL;
     637                 :            :                 newattrs.ia_valid |= ATTR_UID;
     638                 :            :                 newattrs.ia_uid = uid;
     639                 :            :         }
     640                 :            :         if (group != (gid_t) -1) {
     641                 :            :                 if (!gid_valid(gid))
     642                 :            :                         return -EINVAL;
     643                 :            :                 newattrs.ia_valid |= ATTR_GID;
     644                 :            :                 newattrs.ia_gid = gid;
     645                 :            :         }
     646                 :            :         if (!S_ISDIR(inode->i_mode))
     647                 :            :                 newattrs.ia_valid |=
     648                 :            :                         ATTR_KILL_SUID | ATTR_KILL_SGID | ATTR_KILL_PRIV;
     649                 :            :         inode_lock(inode);
     650                 :            :         error = security_path_chown(path, uid, gid);
     651                 :            :         if (!error)
     652                 :            :                 error = notify_change(path->dentry, &newattrs, &delegated_inode);
     653                 :            :         inode_unlock(inode);
     654                 :            :         if (delegated_inode) {
     655                 :            :                 error = break_deleg_wait(&delegated_inode);
     656                 :            :                 if (!error)
     657                 :            :                         goto retry_deleg;
     658                 :            :         }
     659                 :            :         return error;
     660                 :            : }
     661                 :            : 
     662                 :       1417 : int do_fchownat(int dfd, const char __user *filename, uid_t user, gid_t group,
     663                 :            :                 int flag)
     664                 :            : {
     665                 :       1417 :         struct path path;
     666                 :       1417 :         int error = -EINVAL;
     667                 :       1417 :         int lookup_flags;
     668                 :            : 
     669         [ -  + ]:       1417 :         if ((flag & ~(AT_SYMLINK_NOFOLLOW | AT_EMPTY_PATH)) != 0)
     670                 :          0 :                 goto out;
     671                 :            : 
     672                 :       1417 :         lookup_flags = (flag & AT_SYMLINK_NOFOLLOW) ? 0 : LOOKUP_FOLLOW;
     673         [ +  + ]:       1417 :         if (flag & AT_EMPTY_PATH)
     674                 :         26 :                 lookup_flags |= LOOKUP_EMPTY;
     675                 :       1391 : retry:
     676                 :       1417 :         error = user_path_at(dfd, filename, lookup_flags, &path);
     677         [ -  + ]:       1417 :         if (error)
     678                 :          0 :                 goto out;
     679                 :       1417 :         error = mnt_want_write(path.mnt);
     680         [ -  + ]:       1417 :         if (error)
     681                 :          0 :                 goto out_release;
     682                 :       1417 :         error = chown_common(&path, user, group);
     683                 :       1417 :         mnt_drop_write(path.mnt);
     684                 :       1417 : out_release:
     685                 :       1417 :         path_put(&path);
     686   [ -  +  -  + ]:       2834 :         if (retry_estale(error, lookup_flags)) {
     687                 :          0 :                 lookup_flags |= LOOKUP_REVAL;
     688                 :          0 :                 goto retry;
     689                 :            :         }
     690                 :       1417 : out:
     691                 :       1417 :         return error;
     692                 :            : }
     693                 :            : 
     694                 :         52 : SYSCALL_DEFINE5(fchownat, int, dfd, const char __user *, filename, uid_t, user,
     695                 :            :                 gid_t, group, int, flag)
     696                 :            : {
     697                 :         26 :         return do_fchownat(dfd, filename, user, group, flag);
     698                 :            : }
     699                 :            : 
     700                 :       2704 : SYSCALL_DEFINE3(chown, const char __user *, filename, uid_t, user, gid_t, group)
     701                 :            : {
     702                 :       1352 :         return do_fchownat(AT_FDCWD, filename, user, group, 0);
     703                 :            : }
     704                 :            : 
     705                 :          0 : SYSCALL_DEFINE3(lchown, const char __user *, filename, uid_t, user, gid_t, group)
     706                 :            : {
     707                 :          0 :         return do_fchownat(AT_FDCWD, filename, user, group,
     708                 :            :                            AT_SYMLINK_NOFOLLOW);
     709                 :            : }
     710                 :            : 
     711                 :        195 : int ksys_fchown(unsigned int fd, uid_t user, gid_t group)
     712                 :            : {
     713                 :        195 :         struct fd f = fdget(fd);
     714                 :        195 :         int error = -EBADF;
     715                 :            : 
     716         [ -  + ]:        195 :         if (!f.file)
     717                 :          0 :                 goto out;
     718                 :            : 
     719                 :        195 :         error = mnt_want_write_file(f.file);
     720         [ -  + ]:        195 :         if (error)
     721                 :          0 :                 goto out_fput;
     722                 :        195 :         audit_file(f.file);
     723                 :        195 :         error = chown_common(&f.file->f_path, user, group);
     724                 :        195 :         mnt_drop_write_file(f.file);
     725                 :        195 : out_fput:
     726         [ +  + ]:        195 :         fdput(f);
     727                 :        195 : out:
     728                 :        195 :         return error;
     729                 :            : }
     730                 :            : 
     731                 :        390 : SYSCALL_DEFINE3(fchown, unsigned int, fd, uid_t, user, gid_t, group)
     732                 :            : {
     733                 :        195 :         return ksys_fchown(fd, user, group);
     734                 :            : }
     735                 :            : 
     736                 :     539655 : static int do_dentry_open(struct file *f,
     737                 :            :                           struct inode *inode,
     738                 :            :                           int (*open)(struct inode *, struct file *))
     739                 :            : {
     740                 :     539655 :         static const struct file_operations empty_fops = {};
     741                 :     539655 :         int error;
     742                 :            : 
     743                 :     539655 :         path_get(&f->f_path);
     744                 :     539655 :         f->f_inode = inode;
     745                 :     539655 :         f->f_mapping = inode->i_mapping;
     746                 :            : 
     747                 :            :         /* Ensure that we skip any errors that predate opening of the file */
     748                 :     539655 :         f->f_wb_err = filemap_sample_wb_err(f->f_mapping);
     749                 :            : 
     750         [ +  + ]:     539655 :         if (unlikely(f->f_flags & O_PATH)) {
     751                 :     302523 :                 f->f_mode = FMODE_PATH | FMODE_OPENED;
     752                 :     302523 :                 f->f_op = &empty_fops;
     753                 :     302523 :                 return 0;
     754                 :            :         }
     755                 :            : 
     756                 :            :         /* Any file opened for execve()/uselib() has to be a regular file. */
     757   [ +  +  -  + ]:     237132 :         if (unlikely(f->f_flags & FMODE_EXEC && !S_ISREG(inode->i_mode))) {
     758                 :          0 :                 error = -EACCES;
     759                 :          0 :                 goto cleanup_file;
     760                 :            :         }
     761                 :            : 
     762   [ +  +  +  +  :     237132 :         if (f->f_mode & FMODE_WRITE && !special_file(inode->i_mode)) {
             +  +  +  - ]
     763                 :      17277 :                 error = get_write_access(inode);
     764         [ -  + ]:      17277 :                 if (unlikely(error))
     765                 :          0 :                         goto cleanup_file;
     766                 :      17277 :                 error = __mnt_want_write(f->f_path.mnt);
     767         [ -  + ]:      17277 :                 if (unlikely(error)) {
     768                 :          0 :                         put_write_access(inode);
     769                 :          0 :                         goto cleanup_file;
     770                 :            :                 }
     771                 :      17277 :                 f->f_mode |= FMODE_WRITER;
     772                 :            :         }
     773                 :            : 
     774                 :            :         /* POSIX.1-2008/SUSv4 Section XSI 2.9.7 */
     775         [ +  + ]:     237132 :         if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))
     776                 :     233669 :                 f->f_mode |= FMODE_ATOMIC_POS;
     777                 :            : 
     778   [ +  -  +  - ]:     237132 :         f->f_op = fops_get(inode->i_fop);
     779   [ -  +  -  + ]:     237132 :         if (WARN_ON(!f->f_op)) {
     780                 :          0 :                 error = -ENODEV;
     781                 :          0 :                 goto cleanup_all;
     782                 :            :         }
     783                 :            : 
     784                 :     237132 :         error = security_file_open(f);
     785         [ -  + ]:     237132 :         if (error)
     786                 :          0 :                 goto cleanup_all;
     787                 :            : 
     788                 :     237132 :         error = break_lease(locks_inode(f), f->f_flags);
     789         [ -  + ]:     237132 :         if (error)
     790                 :          0 :                 goto cleanup_all;
     791                 :            : 
     792                 :            :         /* normally all 3 are set; ->open() can clear them if needed */
     793                 :     237132 :         f->f_mode |= FMODE_LSEEK | FMODE_PREAD | FMODE_PWRITE;
     794         [ +  - ]:     237132 :         if (!open)
     795                 :     237132 :                 open = f->f_op->open;
     796         [ +  + ]:     237132 :         if (open) {
     797                 :     227210 :                 error = open(inode, f);
     798         [ +  + ]:     227197 :                 if (error)
     799                 :       6812 :                         goto cleanup_all;
     800                 :            :         }
     801                 :     230307 :         f->f_mode |= FMODE_OPENED;
     802         [ +  + ]:     230307 :         if ((f->f_mode & (FMODE_READ | FMODE_WRITE)) == FMODE_READ)
     803                 :     211457 :                 i_readcount_inc(inode);
     804         [ +  + ]:     230307 :         if ((f->f_mode & FMODE_READ) &&
     805   [ +  +  +  + ]:     214382 :              likely(f->f_op->read || f->f_op->read_iter))
     806                 :     214356 :                 f->f_mode |= FMODE_CAN_READ;
     807         [ +  + ]:     230307 :         if ((f->f_mode & FMODE_WRITE) &&
     808   [ +  +  +  + ]:      18850 :              likely(f->f_op->write || f->f_op->write_iter))
     809                 :      18837 :                 f->f_mode |= FMODE_CAN_WRITE;
     810                 :            : 
     811                 :     230307 :         f->f_write_hint = WRITE_LIFE_NOT_SET;
     812                 :     230307 :         f->f_flags &= ~(O_CREAT | O_EXCL | O_NOCTTY | O_TRUNC);
     813                 :            : 
     814                 :     230307 :         file_ra_state_init(&f->f_ra, f->f_mapping->host->i_mapping);
     815                 :            : 
     816                 :            :         /* NB: we're sure to have correct a_ops only after f_op->open */
     817         [ -  + ]:     230307 :         if (f->f_flags & O_DIRECT) {
     818   [ #  #  #  # ]:          0 :                 if (!f->f_mapping->a_ops || !f->f_mapping->a_ops->direct_IO)
     819                 :            :                         return -EINVAL;
     820                 :            :         }
     821                 :            : 
     822                 :            :         /*
     823                 :            :          * XXX: Huge page cache doesn't support writing yet. Drop all page
     824                 :            :          * cache for this file before processing writes.
     825                 :            :          */
     826                 :     230307 :         if ((f->f_mode & FMODE_WRITE) && filemap_nr_thps(inode->i_mapping))
     827                 :            :                 truncate_pagecache(inode, 0);
     828                 :            : 
     829                 :            :         return 0;
     830                 :            : 
     831                 :       6812 : cleanup_all:
     832   [ -  +  -  + ]:       6812 :         if (WARN_ON_ONCE(error > 0))
     833                 :          0 :                 error = -EINVAL;
     834         [ +  - ]:       6812 :         fops_put(f->f_op);
     835         [ +  - ]:       6812 :         if (f->f_mode & FMODE_WRITER) {
     836                 :          0 :                 put_write_access(inode);
     837                 :          0 :                 __mnt_drop_write(f->f_path.mnt);
     838                 :            :         }
     839                 :       6812 : cleanup_file:
     840                 :       6812 :         path_put(&f->f_path);
     841                 :       6812 :         f->f_path.mnt = NULL;
     842                 :       6812 :         f->f_path.dentry = NULL;
     843                 :       6812 :         f->f_inode = NULL;
     844                 :       6812 :         return error;
     845                 :            : }
     846                 :            : 
     847                 :            : /**
     848                 :            :  * finish_open - finish opening a file
     849                 :            :  * @file: file pointer
     850                 :            :  * @dentry: pointer to dentry
     851                 :            :  * @open: open callback
     852                 :            :  * @opened: state of open
     853                 :            :  *
     854                 :            :  * This can be used to finish opening a file passed to i_op->atomic_open().
     855                 :            :  *
     856                 :            :  * If the open callback is set to NULL, then the standard f_op->open()
     857                 :            :  * filesystem callback is substituted.
     858                 :            :  *
     859                 :            :  * NB: the dentry reference is _not_ consumed.  If, for example, the dentry is
     860                 :            :  * the return value of d_splice_alias(), then the caller needs to perform dput()
     861                 :            :  * on it after finish_open().
     862                 :            :  *
     863                 :            :  * Returns zero on success or -errno if the open failed.
     864                 :            :  */
     865                 :          0 : int finish_open(struct file *file, struct dentry *dentry,
     866                 :            :                 int (*open)(struct inode *, struct file *))
     867                 :            : {
     868         [ #  # ]:          0 :         BUG_ON(file->f_mode & FMODE_OPENED); /* once it's opened, it's opened */
     869                 :            : 
     870                 :          0 :         file->f_path.dentry = dentry;
     871                 :          0 :         return do_dentry_open(file, d_backing_inode(dentry), open);
     872                 :            : }
     873                 :            : EXPORT_SYMBOL(finish_open);
     874                 :            : 
     875                 :            : /**
     876                 :            :  * finish_no_open - finish ->atomic_open() without opening the file
     877                 :            :  *
     878                 :            :  * @file: file pointer
     879                 :            :  * @dentry: dentry or NULL (as returned from ->lookup())
     880                 :            :  *
     881                 :            :  * This can be used to set the result of a successful lookup in ->atomic_open().
     882                 :            :  *
     883                 :            :  * NB: unlike finish_open() this function does consume the dentry reference and
     884                 :            :  * the caller need not dput() it.
     885                 :            :  *
     886                 :            :  * Returns "0" which must be the return value of ->atomic_open() after having
     887                 :            :  * called this function.
     888                 :            :  */
     889                 :          0 : int finish_no_open(struct file *file, struct dentry *dentry)
     890                 :            : {
     891                 :          0 :         file->f_path.dentry = dentry;
     892                 :          0 :         return 0;
     893                 :            : }
     894                 :            : EXPORT_SYMBOL(finish_no_open);
     895                 :            : 
     896                 :          0 : char *file_path(struct file *filp, char *buf, int buflen)
     897                 :            : {
     898                 :          0 :         return d_path(&filp->f_path, buf, buflen);
     899                 :            : }
     900                 :            : EXPORT_SYMBOL(file_path);
     901                 :            : 
     902                 :            : /**
     903                 :            :  * vfs_open - open the file at the given path
     904                 :            :  * @path: path to open
     905                 :            :  * @file: newly allocated file with f_flag initialized
     906                 :            :  * @cred: credentials to use
     907                 :            :  */
     908                 :     539655 : int vfs_open(const struct path *path, struct file *file)
     909                 :            : {
     910                 :     539655 :         file->f_path = *path;
     911                 :     539642 :         return do_dentry_open(file, d_backing_inode(path->dentry), NULL);
     912                 :            : }
     913                 :            : 
     914                 :         13 : struct file *dentry_open(const struct path *path, int flags,
     915                 :            :                          const struct cred *cred)
     916                 :            : {
     917                 :         13 :         int error;
     918                 :         13 :         struct file *f;
     919                 :            : 
     920         [ -  + ]:         13 :         validate_creds(cred);
     921                 :            : 
     922                 :            :         /* We must always pass in a valid mount pointer. */
     923         [ -  + ]:         13 :         BUG_ON(!path->mnt);
     924                 :            : 
     925                 :         13 :         f = alloc_empty_file(flags, cred);
     926         [ +  - ]:         13 :         if (!IS_ERR(f)) {
     927                 :         13 :                 error = vfs_open(path, f);
     928         [ -  + ]:         13 :                 if (error) {
     929                 :          0 :                         fput(f);
     930                 :          0 :                         f = ERR_PTR(error);
     931                 :            :                 }
     932                 :            :         }
     933                 :         13 :         return f;
     934                 :            : }
     935                 :            : EXPORT_SYMBOL(dentry_open);
     936                 :            : 
     937                 :          0 : struct file *open_with_fake_path(const struct path *path, int flags,
     938                 :            :                                 struct inode *inode, const struct cred *cred)
     939                 :            : {
     940                 :          0 :         struct file *f = alloc_empty_file_noaccount(flags, cred);
     941         [ #  # ]:          0 :         if (!IS_ERR(f)) {
     942                 :          0 :                 int error;
     943                 :            : 
     944                 :          0 :                 f->f_path = *path;
     945                 :          0 :                 error = do_dentry_open(f, inode, NULL);
     946         [ #  # ]:          0 :                 if (error) {
     947                 :          0 :                         fput(f);
     948                 :          0 :                         f = ERR_PTR(error);
     949                 :            :                 }
     950                 :            :         }
     951                 :          0 :         return f;
     952                 :            : }
     953                 :            : EXPORT_SYMBOL(open_with_fake_path);
     954                 :            : 
     955                 :            : #define WILL_CREATE(flags)      (flags & (O_CREAT | __O_TMPFILE))
     956                 :            : #define O_PATH_FLAGS            (O_DIRECTORY | O_NOFOLLOW | O_PATH | O_CLOEXEC)
     957                 :            : 
     958                 :     633656 : inline struct open_how build_open_how(int flags, umode_t mode)
     959                 :            : {
     960                 :     633656 :         struct open_how how = {
     961                 :          0 :                 .flags = flags & VALID_OPEN_FLAGS,
     962                 :            :                 .mode = mode & S_IALLUGO,
     963                 :            :         };
     964                 :            : 
     965                 :            :         /* O_PATH beats everything else. */
     966         [ #  # ]:          0 :         if (how.flags & O_PATH)
     967                 :     344110 :                 how.flags &= O_PATH_FLAGS;
     968                 :            :         /* Modes should only be set for create-like flags. */
     969   [ +  +  -  -  :     633656 :         if (!WILL_CREATE(how.flags))
             +  -  -  - ]
     970                 :     622819 :                 how.mode = 0;
     971                 :     633656 :         return how;
     972                 :            : }
     973                 :            : 
     974                 :     633656 : inline int build_open_flags(const struct open_how *how, struct open_flags *op)
     975                 :            : {
     976                 :     633656 :         int flags = how->flags;
     977                 :     633656 :         int lookup_flags = 0;
     978                 :     633656 :         int acc_mode = ACC_MODE(flags);
     979                 :            : 
     980                 :            :         /* Must never be set by userspace */
     981                 :     633656 :         flags &= ~(FMODE_NONOTIFY | O_CLOEXEC);
     982                 :            : 
     983                 :            :         /*
     984                 :            :          * Older syscalls implicitly clear all of the invalid flags or argument
     985                 :            :          * values before calling build_open_flags(), but openat2(2) checks all
     986                 :            :          * of its arguments.
     987                 :            :          */
     988         [ +  - ]:     633656 :         if (flags & ~VALID_OPEN_FLAGS)
     989                 :            :                 return -EINVAL;
     990         [ +  - ]:     633656 :         if (how->resolve & ~VALID_RESOLVE_FLAGS)
     991                 :            :                 return -EINVAL;
     992                 :            : 
     993                 :            :         /* Deal with the mode. */
     994         [ +  + ]:     633656 :         if (WILL_CREATE(flags)) {
     995         [ +  - ]:      10837 :                 if (how->mode & ~S_IALLUGO)
     996                 :            :                         return -EINVAL;
     997                 :      10837 :                 op->mode = how->mode | S_IFREG;
     998                 :            :         } else {
     999         [ +  - ]:     622819 :                 if (how->mode != 0)
    1000                 :            :                         return -EINVAL;
    1001                 :     622819 :                 op->mode = 0;
    1002                 :            :         }
    1003                 :            : 
    1004                 :            :         /*
    1005                 :            :          * In order to ensure programs get explicit errors when trying to use
    1006                 :            :          * O_TMPFILE on old kernels, O_TMPFILE is implemented such that it
    1007                 :            :          * looks like (O_DIRECTORY|O_RDWR & ~O_CREAT) to old kernels. But we
    1008                 :            :          * have to require userspace to explicitly set it.
    1009                 :            :          */
    1010         [ -  + ]:     633656 :         if (flags & __O_TMPFILE) {
    1011         [ #  # ]:          0 :                 if ((flags & O_TMPFILE_MASK) != O_TMPFILE)
    1012                 :            :                         return -EINVAL;
    1013         [ #  # ]:          0 :                 if (!(acc_mode & MAY_WRITE))
    1014                 :            :                         return -EINVAL;
    1015                 :            :         }
    1016         [ +  + ]:     633656 :         if (flags & O_PATH) {
    1017                 :            :                 /* O_PATH only permits certain other flags to be set. */
    1018         [ +  - ]:     344110 :                 if (flags & ~O_PATH_FLAGS)
    1019                 :            :                         return -EINVAL;
    1020                 :            :                 acc_mode = 0;
    1021                 :            :         }
    1022                 :            : 
    1023                 :            :         /*
    1024                 :            :          * O_SYNC is implemented as __O_SYNC|O_DSYNC.  As many places only
    1025                 :            :          * check for O_DSYNC if the need any syncing at all we enforce it's
    1026                 :            :          * always set instead of having to deal with possibly weird behaviour
    1027                 :            :          * for malicious applications setting only __O_SYNC.
    1028                 :            :          */
    1029         [ -  + ]:     633656 :         if (flags & __O_SYNC)
    1030                 :          0 :                 flags |= O_DSYNC;
    1031                 :            : 
    1032                 :     633656 :         op->open_flag = flags;
    1033                 :            : 
    1034                 :            :         /* O_TRUNC implies we need access checks for write permissions */
    1035         [ +  + ]:     633656 :         if (flags & O_TRUNC)
    1036                 :       3978 :                 acc_mode |= MAY_WRITE;
    1037                 :            : 
    1038                 :            :         /* Allow the LSM permission hook to distinguish append
    1039                 :            :            access from general write access. */
    1040         [ +  + ]:     633656 :         if (flags & O_APPEND)
    1041                 :        221 :                 acc_mode |= MAY_APPEND;
    1042                 :            : 
    1043                 :     633656 :         op->acc_mode = acc_mode;
    1044                 :            : 
    1045         [ +  + ]:     633656 :         op->intent = flags & O_PATH ? 0 : LOOKUP_OPEN;
    1046                 :            : 
    1047         [ +  + ]:     633656 :         if (flags & O_CREAT) {
    1048                 :      10837 :                 op->intent |= LOOKUP_CREATE;
    1049         [ +  + ]:      10837 :                 if (flags & O_EXCL)
    1050                 :       3991 :                         op->intent |= LOOKUP_EXCL;
    1051                 :            :         }
    1052                 :            : 
    1053         [ +  + ]:     633656 :         if (flags & O_DIRECTORY)
    1054                 :      12272 :                 lookup_flags |= LOOKUP_DIRECTORY;
    1055         [ +  + ]:     633656 :         if (!(flags & O_NOFOLLOW))
    1056                 :     280797 :                 lookup_flags |= LOOKUP_FOLLOW;
    1057                 :            : 
    1058         [ -  + ]:     633656 :         if (how->resolve & RESOLVE_NO_XDEV)
    1059                 :          0 :                 lookup_flags |= LOOKUP_NO_XDEV;
    1060         [ -  + ]:     633656 :         if (how->resolve & RESOLVE_NO_MAGICLINKS)
    1061                 :          0 :                 lookup_flags |= LOOKUP_NO_MAGICLINKS;
    1062         [ -  + ]:     633656 :         if (how->resolve & RESOLVE_NO_SYMLINKS)
    1063                 :          0 :                 lookup_flags |= LOOKUP_NO_SYMLINKS;
    1064         [ -  + ]:     633656 :         if (how->resolve & RESOLVE_BENEATH)
    1065                 :          0 :                 lookup_flags |= LOOKUP_BENEATH;
    1066         [ -  + ]:     633656 :         if (how->resolve & RESOLVE_IN_ROOT)
    1067                 :          0 :                 lookup_flags |= LOOKUP_IN_ROOT;
    1068                 :            : 
    1069                 :     633656 :         op->lookup_flags = lookup_flags;
    1070                 :     633656 :         return 0;
    1071                 :            : }
    1072                 :            : 
    1073                 :            : /**
    1074                 :            :  * file_open_name - open file and return file pointer
    1075                 :            :  *
    1076                 :            :  * @name:       struct filename containing path to open
    1077                 :            :  * @flags:      open flags as per the open(2) second argument
    1078                 :            :  * @mode:       mode for the new file if O_CREAT is set, else ignored
    1079                 :            :  *
    1080                 :            :  * This is the helper to open a file from kernelspace if you really
    1081                 :            :  * have to.  But in generally you should not do this, so please move
    1082                 :            :  * along, nothing to see here..
    1083                 :            :  */
    1084                 :        104 : struct file *file_open_name(struct filename *name, int flags, umode_t mode)
    1085                 :            : {
    1086                 :        104 :         struct open_flags op;
    1087         [ -  + ]:        104 :         struct open_how how = build_open_how(flags, mode);
    1088                 :        104 :         int err = build_open_flags(&how, &op);
    1089         [ -  + ]:        104 :         if (err)
    1090                 :          0 :                 return ERR_PTR(err);
    1091                 :        104 :         return do_filp_open(AT_FDCWD, name, &op);
    1092                 :            : }
    1093                 :            : 
    1094                 :            : /**
    1095                 :            :  * filp_open - open file and return file pointer
    1096                 :            :  *
    1097                 :            :  * @filename:   path to open
    1098                 :            :  * @flags:      open flags as per the open(2) second argument
    1099                 :            :  * @mode:       mode for the new file if O_CREAT is set, else ignored
    1100                 :            :  *
    1101                 :            :  * This is the helper to open a file from kernelspace if you really
    1102                 :            :  * have to.  But in generally you should not do this, so please move
    1103                 :            :  * along, nothing to see here..
    1104                 :            :  */
    1105                 :        104 : struct file *filp_open(const char *filename, int flags, umode_t mode)
    1106                 :            : {
    1107                 :        104 :         struct filename *name = getname_kernel(filename);
    1108         [ +  - ]:        104 :         struct file *file = ERR_CAST(name);
    1109                 :            :         
    1110         [ +  - ]:        104 :         if (!IS_ERR(name)) {
    1111                 :        104 :                 file = file_open_name(name, flags, mode);
    1112                 :        104 :                 putname(name);
    1113                 :            :         }
    1114                 :        104 :         return file;
    1115                 :            : }
    1116                 :            : EXPORT_SYMBOL(filp_open);
    1117                 :            : 
    1118                 :          0 : struct file *file_open_root(struct dentry *dentry, struct vfsmount *mnt,
    1119                 :            :                             const char *filename, int flags, umode_t mode)
    1120                 :            : {
    1121                 :          0 :         struct open_flags op;
    1122         [ #  # ]:          0 :         struct open_how how = build_open_how(flags, mode);
    1123                 :          0 :         int err = build_open_flags(&how, &op);
    1124         [ #  # ]:          0 :         if (err)
    1125                 :          0 :                 return ERR_PTR(err);
    1126                 :          0 :         return do_file_open_root(dentry, mnt, filename, &op);
    1127                 :            : }
    1128                 :            : EXPORT_SYMBOL(file_open_root);
    1129                 :            : 
    1130                 :     633552 : static long do_sys_openat2(int dfd, const char __user *filename,
    1131                 :            :                            struct open_how *how)
    1132                 :            : {
    1133                 :     633552 :         struct open_flags op;
    1134                 :     633552 :         int fd = build_open_flags(how, &op);
    1135                 :     633552 :         struct filename *tmp;
    1136                 :            : 
    1137         [ -  + ]:     633552 :         if (fd)
    1138                 :          0 :                 return fd;
    1139                 :            : 
    1140                 :     633552 :         tmp = getname(filename);
    1141         [ -  + ]:     633552 :         if (IS_ERR(tmp))
    1142                 :          0 :                 return PTR_ERR(tmp);
    1143                 :            : 
    1144                 :     633552 :         fd = get_unused_fd_flags(how->flags);
    1145         [ +  - ]:     633552 :         if (fd >= 0) {
    1146                 :     633552 :                 struct file *f = do_filp_open(dfd, tmp, &op);
    1147         [ +  + ]:     633539 :                 if (IS_ERR(f)) {
    1148                 :     123992 :                         put_unused_fd(fd);
    1149                 :     123992 :                         fd = PTR_ERR(f);
    1150                 :            :                 } else {
    1151                 :     509547 :                         fsnotify_open(f);
    1152                 :     509547 :                         fd_install(fd, f);
    1153                 :            :                 }
    1154                 :            :         }
    1155                 :     633539 :         putname(tmp);
    1156                 :     633539 :         return fd;
    1157                 :            : }
    1158                 :            : 
    1159                 :     633552 : long do_sys_open(int dfd, const char __user *filename, int flags, umode_t mode)
    1160                 :            : {
    1161         [ +  + ]:     633552 :         struct open_how how = build_open_how(flags, mode);
    1162                 :     633552 :         return do_sys_openat2(dfd, filename, &how);
    1163                 :            : }
    1164                 :            : 
    1165                 :            : 
    1166                 :          0 : SYSCALL_DEFINE3(open, const char __user *, filename, int, flags, umode_t, mode)
    1167                 :            : {
    1168                 :          0 :         return ksys_open(filename, flags, mode);
    1169                 :            : }
    1170                 :            : 
    1171                 :    1267013 : SYSCALL_DEFINE4(openat, int, dfd, const char __user *, filename, int, flags,
    1172                 :            :                 umode_t, mode)
    1173                 :            : {
    1174                 :     633513 :         if (force_o_largefile())
    1175                 :     633513 :                 flags |= O_LARGEFILE;
    1176                 :     633513 :         return do_sys_open(dfd, filename, flags, mode);
    1177                 :            : }
    1178                 :            : 
    1179                 :          0 : SYSCALL_DEFINE4(openat2, int, dfd, const char __user *, filename,
    1180                 :            :                 struct open_how __user *, how, size_t, usize)
    1181                 :            : {
    1182                 :          0 :         int err;
    1183                 :          0 :         struct open_how tmp;
    1184                 :            : 
    1185                 :          0 :         BUILD_BUG_ON(sizeof(struct open_how) < OPEN_HOW_SIZE_VER0);
    1186                 :          0 :         BUILD_BUG_ON(sizeof(struct open_how) != OPEN_HOW_SIZE_LATEST);
    1187                 :            : 
    1188         [ #  # ]:          0 :         if (unlikely(usize < OPEN_HOW_SIZE_VER0))
    1189                 :            :                 return -EINVAL;
    1190                 :            : 
    1191         [ #  # ]:          0 :         err = copy_struct_from_user(&tmp, sizeof(tmp), how, usize);
    1192                 :          0 :         if (err)
    1193                 :          0 :                 return err;
    1194                 :            : 
    1195                 :            :         /* O_LARGEFILE is only allowed for non-O_PATH. */
    1196         [ #  # ]:          0 :         if (!(tmp.flags & O_PATH) && force_o_largefile())
    1197                 :          0 :                 tmp.flags |= O_LARGEFILE;
    1198                 :            : 
    1199                 :          0 :         return do_sys_openat2(dfd, filename, &tmp);
    1200                 :            : }
    1201                 :            : 
    1202                 :            : #ifdef CONFIG_COMPAT
    1203                 :            : /*
    1204                 :            :  * Exactly like sys_open(), except that it doesn't set the
    1205                 :            :  * O_LARGEFILE flag.
    1206                 :            :  */
    1207                 :          0 : COMPAT_SYSCALL_DEFINE3(open, const char __user *, filename, int, flags, umode_t, mode)
    1208                 :            : {
    1209                 :          0 :         return do_sys_open(AT_FDCWD, filename, flags, mode);
    1210                 :            : }
    1211                 :            : 
    1212                 :            : /*
    1213                 :            :  * Exactly like sys_openat(), except that it doesn't set the
    1214                 :            :  * O_LARGEFILE flag.
    1215                 :            :  */
    1216                 :          0 : COMPAT_SYSCALL_DEFINE4(openat, int, dfd, const char __user *, filename, int, flags, umode_t, mode)
    1217                 :            : {
    1218                 :          0 :         return do_sys_open(dfd, filename, flags, mode);
    1219                 :            : }
    1220                 :            : #endif
    1221                 :            : 
    1222                 :            : #ifndef __alpha__
    1223                 :            : 
    1224                 :            : /*
    1225                 :            :  * For backward compatibility?  Maybe this should be moved
    1226                 :            :  * into arch/i386 instead?
    1227                 :            :  */
    1228                 :         26 : SYSCALL_DEFINE2(creat, const char __user *, pathname, umode_t, mode)
    1229                 :            : {
    1230                 :         13 :         return ksys_open(pathname, O_CREAT | O_WRONLY | O_TRUNC, mode);
    1231                 :            : }
    1232                 :            : 
    1233                 :            : #endif
    1234                 :            : 
    1235                 :            : /*
    1236                 :            :  * "id" is the POSIX thread ID. We use the
    1237                 :            :  * files pointer for this..
    1238                 :            :  */
    1239                 :     654582 : int filp_close(struct file *filp, fl_owner_t id)
    1240                 :            : {
    1241                 :     654582 :         int retval = 0;
    1242                 :            : 
    1243         [ -  + ]:     654582 :         if (!file_count(filp)) {
    1244                 :          0 :                 printk(KERN_ERR "VFS: Close: file count is 0\n");
    1245                 :          0 :                 return 0;
    1246                 :            :         }
    1247                 :            : 
    1248         [ +  + ]:     654582 :         if (filp->f_op->flush)
    1249                 :         39 :                 retval = filp->f_op->flush(filp, id);
    1250                 :            : 
    1251         [ +  + ]:     654582 :         if (likely(!(filp->f_mode & FMODE_PATH))) {
    1252                 :     351877 :                 dnotify_flush(filp, id);
    1253                 :     351877 :                 locks_remove_posix(filp, id);
    1254                 :            :         }
    1255                 :     654582 :         fput(filp);
    1256                 :     654582 :         return retval;
    1257                 :            : }
    1258                 :            : 
    1259                 :            : EXPORT_SYMBOL(filp_close);
    1260                 :            : 
    1261                 :            : /*
    1262                 :            :  * Careful here! We test whether the file pointer is NULL before
    1263                 :            :  * releasing the fd. This ensures that one clone task can't release
    1264                 :            :  * an fd while another clone is opening it.
    1265                 :            :  */
    1266                 :    1143518 : SYSCALL_DEFINE1(close, unsigned int, fd)
    1267                 :            : {
    1268                 :     571759 :         int retval = __close_fd(current->files, fd);
    1269                 :            : 
    1270                 :            :         /* can't restart close syscall because file table entry was cleared */
    1271   [ +  -  -  + ]:     571759 :         if (unlikely(retval == -ERESTARTSYS ||
    1272                 :            :                      retval == -ERESTARTNOINTR ||
    1273                 :            :                      retval == -ERESTARTNOHAND ||
    1274                 :            :                      retval == -ERESTART_RESTARTBLOCK))
    1275                 :          0 :                 retval = -EINTR;
    1276                 :            : 
    1277                 :     571759 :         return retval;
    1278                 :            : }
    1279                 :            : 
    1280                 :            : /*
    1281                 :            :  * This routine simulates a hangup on the tty, to arrange that users
    1282                 :            :  * are given clean terminals at login time.
    1283                 :            :  */
    1284                 :          0 : SYSCALL_DEFINE0(vhangup)
    1285                 :            : {
    1286         [ #  # ]:          0 :         if (capable(CAP_SYS_TTY_CONFIG)) {
    1287                 :          0 :                 tty_vhangup_self();
    1288                 :          0 :                 return 0;
    1289                 :            :         }
    1290                 :            :         return -EPERM;
    1291                 :            : }
    1292                 :            : 
    1293                 :            : /*
    1294                 :            :  * Called when an inode is about to be open.
    1295                 :            :  * We use this to disallow opening large files on 32bit systems if
    1296                 :            :  * the caller didn't specify O_LARGEFILE.  On 64bit systems we force
    1297                 :            :  * on this flag in sys_open.
    1298                 :            :  */
    1299                 :     173238 : int generic_file_open(struct inode * inode, struct file * filp)
    1300                 :            : {
    1301   [ +  +  -  + ]:     173238 :         if (!(filp->f_flags & O_LARGEFILE) && i_size_read(inode) > MAX_NON_LFS)
    1302                 :          0 :                 return -EOVERFLOW;
    1303                 :            :         return 0;
    1304                 :            : }
    1305                 :            : 
    1306                 :            : EXPORT_SYMBOL(generic_file_open);
    1307                 :            : 
    1308                 :            : /*
    1309                 :            :  * This is used by subsystems that don't want seekable
    1310                 :            :  * file descriptors. The function is not supposed to ever fail, the only
    1311                 :            :  * reason it returns an 'int' and not 'void' is so that it can be plugged
    1312                 :            :  * directly into file_operations structure.
    1313                 :            :  */
    1314                 :       1287 : int nonseekable_open(struct inode *inode, struct file *filp)
    1315                 :            : {
    1316                 :       1287 :         filp->f_mode &= ~(FMODE_LSEEK | FMODE_PREAD | FMODE_PWRITE);
    1317                 :       1287 :         return 0;
    1318                 :            : }
    1319                 :            : 
    1320                 :            : EXPORT_SYMBOL(nonseekable_open);
    1321                 :            : 
    1322                 :            : /*
    1323                 :            :  * stream_open is used by subsystems that want stream-like file descriptors.
    1324                 :            :  * Such file descriptors are not seekable and don't have notion of position
    1325                 :            :  * (file.f_pos is always 0 and ppos passed to .read()/.write() is always NULL).
    1326                 :            :  * Contrary to file descriptors of other regular files, .read() and .write()
    1327                 :            :  * can run simultaneously.
    1328                 :            :  *
    1329                 :            :  * stream_open never fails and is marked to return int so that it could be
    1330                 :            :  * directly used as file_operations.open .
    1331                 :            :  */
    1332                 :       4992 : int stream_open(struct inode *inode, struct file *filp)
    1333                 :            : {
    1334                 :       4992 :         filp->f_mode &= ~(FMODE_LSEEK | FMODE_PREAD | FMODE_PWRITE | FMODE_ATOMIC_POS);
    1335                 :       4992 :         filp->f_mode |= FMODE_STREAM;
    1336                 :       4992 :         return 0;
    1337                 :            : }
    1338                 :            : 
    1339                 :            : EXPORT_SYMBOL(stream_open);

Generated by: LCOV version 1.14