cregit-Linux how code gets into the kernel

Release 4.10 fs/sysv/namei.c

Directory: fs/sysv
/*
 *  linux/fs/sysv/namei.c
 *
 *  minix/namei.c
 *  Copyright (C) 1991, 1992  Linus Torvalds
 *
 *  coh/namei.c
 *  Copyright (C) 1993  Pascal Haible, Bruno Haible
 *
 *  sysv/namei.c
 *  Copyright (C) 1993  Bruno Haible
 *  Copyright (C) 1997, 1998  Krzysztof G. Baranowski
 */

#include <linux/pagemap.h>
#include "sysv.h"


static int add_nondir(struct dentry *dentry, struct inode *inode) { int err = sysv_add_link(dentry, inode); if (!err) { d_instantiate(dentry, inode); return 0; } inode_dec_link_count(inode); iput(inode); return err; }

Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds3969.64%125.00%
pre-gitpre-git1628.57%250.00%
alexey dobriyanalexey dobriyan11.79%125.00%
Total56100.00%4100.00%


static int sysv_hash(const struct dentry *dentry, struct qstr *qstr) { /* Truncate the name in place, avoids having to define a compare function. */ if (qstr->len > SYSV_NAMELEN) { qstr->len = SYSV_NAMELEN; qstr->hash = full_name_hash(dentry, qstr->name, qstr->len); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2342.59%120.00%
linus torvaldslinus torvalds2037.04%240.00%
rusty russellrusty russell1018.52%120.00%
nick pigginnick piggin11.85%120.00%
Total54100.00%5100.00%

const struct dentry_operations sysv_dentry_operations = { .d_hash = sysv_hash, };
static struct dentry *sysv_lookup(struct inode * dir, struct dentry * dentry, unsigned int flags) { struct inode * inode = NULL; ino_t ino; if (dentry->d_name.len > SYSV_NAMELEN) return ERR_PTR(-ENAMETOOLONG); ino = sysv_inode_by_name(dentry); if (ino) { inode = sysv_iget(dir->i_sb, ino); if (IS_ERR(inode)) return ERR_CAST(inode); } d_add(dentry, inode); return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5052.08%120.00%
linus torvaldslinus torvalds3637.50%120.00%
david howellsdavid howells66.25%120.00%
al viroal viro33.12%120.00%
trond myklebusttrond myklebust11.04%120.00%
Total96100.00%5100.00%


static int sysv_mknod(struct inode * dir, struct dentry * dentry, umode_t mode, dev_t rdev) { struct inode * inode; int err; if (!old_valid_dev(rdev)) return -EINVAL; inode = sysv_new_inode(dir, mode); err = PTR_ERR(inode); if (!IS_ERR(inode)) { sysv_set_inode(inode, rdev); mark_inode_dirty(inode); err = add_nondir(dentry, inode); } return err; }

Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds3639.13%225.00%
pre-gitpre-git3335.87%337.50%
al viroal viro2223.91%225.00%
andries brouwerandries brouwer11.09%112.50%
Total92100.00%8100.00%


static int sysv_create(struct inode * dir, struct dentry * dentry, umode_t mode, bool excl) { return sysv_mknod(dir, dentry, mode, 0); }

Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds2058.82%120.00%
pre-gitpre-git1029.41%120.00%
al viroal viro38.82%240.00%
trond myklebusttrond myklebust12.94%120.00%
Total34100.00%5100.00%


static int sysv_symlink(struct inode * dir, struct dentry * dentry, const char * symname) { int err = -ENAMETOOLONG; int l = strlen(symname)+1; struct inode * inode; if (l > dir->i_sb->s_blocksize) goto out; inode = sysv_new_inode(dir, S_IFLNK|0777); err = PTR_ERR(inode); if (IS_ERR(inode)) goto out; sysv_set_inode(inode, 0); err = page_symlink(inode, symname, l); if (err) goto out_fail; mark_inode_dirty(inode); err = add_nondir(dentry, inode); out: return err; out_fail: inode_dec_link_count(inode); iput(inode); goto out; }

Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds8962.68%225.00%
pre-gitpre-git5135.92%450.00%
andrew mortonandrew morton10.70%112.50%
alexey dobriyanalexey dobriyan10.70%112.50%
Total142100.00%8100.00%


static int sysv_link(struct dentry * old_dentry, struct inode * dir, struct dentry * dentry) { struct inode *inode = d_inode(old_dentry); inode->i_ctime = current_time(inode); inode_inc_link_count(inode); ihold(inode); return add_nondir(dentry, inode); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3458.62%550.00%
linus torvaldslinus torvalds1525.86%110.00%
deepa dinamanideepa dinamani46.90%110.00%
david howellsdavid howells35.17%110.00%
alexey dobriyanalexey dobriyan11.72%110.00%
al viroal viro11.72%110.00%
Total58100.00%10100.00%


static int sysv_mkdir(struct inode * dir, struct dentry *dentry, umode_t mode) { struct inode * inode; int err; inode_inc_link_count(dir); inode = sysv_new_inode(dir, S_IFDIR|mode); err = PTR_ERR(inode); if (IS_ERR(inode)) goto out_dir; sysv_set_inode(inode, 0); inode_inc_link_count(inode); err = sysv_make_empty(inode, dir); if (err) goto out_fail; err = sysv_add_link(dentry, inode); if (err) goto out_fail; d_instantiate(dentry, inode); out: return err; out_fail: inode_dec_link_count(inode); inode_dec_link_count(inode); iput(inode); out_dir: inode_dec_link_count(dir); goto out; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git7451.75%555.56%
linus torvaldslinus torvalds6344.06%222.22%
alexey dobriyanalexey dobriyan53.50%111.11%
al viroal viro10.70%111.11%
Total143100.00%9100.00%


static int sysv_unlink(struct inode * dir, struct dentry * dentry) { struct inode * inode = d_inode(dentry); struct page * page; struct sysv_dir_entry * de; int err = -ENOENT; de = sysv_find_entry(dentry, &page); if (!de) goto out; err = sysv_delete_entry (de, page); if (err) goto out; inode->i_ctime = dir->i_ctime; inode_dec_link_count(inode); out: return err; }

Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds7984.04%120.00%
pre-gitpre-git1111.70%240.00%
david howellsdavid howells33.19%120.00%
alexey dobriyanalexey dobriyan11.06%120.00%
Total94100.00%5100.00%


static int sysv_rmdir(struct inode * dir, struct dentry * dentry) { struct inode *inode = d_inode(dentry); int err = -ENOTEMPTY; if (sysv_empty_dir(inode)) { err = sysv_unlink(dir, dentry); if (!err) { inode->i_size = 0; inode_dec_link_count(inode); inode_dec_link_count(dir); } } return err; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5065.79%555.56%
linus torvaldslinus torvalds2127.63%222.22%
david howellsdavid howells33.95%111.11%
alexey dobriyanalexey dobriyan22.63%111.11%
Total76100.00%9100.00%

/* * Anybody can rename anything with this: the permission checks are left to the * higher-level routines. */
static int sysv_rename(struct inode * old_dir, struct dentry * old_dentry, struct inode * new_dir, struct dentry * new_dentry, unsigned int flags) { struct inode * old_inode = d_inode(old_dentry); struct inode * new_inode = d_inode(new_dentry); struct page * dir_page = NULL; struct sysv_dir_entry * dir_de = NULL; struct page * old_page; struct sysv_dir_entry * old_de; int err = -ENOENT; if (flags & ~RENAME_NOREPLACE) return -EINVAL; old_de = sysv_find_entry(old_dentry, &old_page); if (!old_de) goto out; if (S_ISDIR(old_inode->i_mode)) { err = -EIO; dir_de = sysv_dotdot(old_inode, &dir_page); if (!dir_de) goto out_old; } if (new_inode) { struct page * new_page; struct sysv_dir_entry * new_de; err = -ENOTEMPTY; if (dir_de && !sysv_empty_dir(new_inode)) goto out_dir; err = -ENOENT; new_de = sysv_find_entry(new_dentry, &new_page); if (!new_de) goto out_dir; sysv_set_link(new_de, new_page, old_inode); new_inode->i_ctime = current_time(new_inode); if (dir_de) drop_nlink(new_inode); inode_dec_link_count(new_inode); } else { err = sysv_add_link(new_dentry, old_inode); if (err) goto out_dir; if (dir_de) inode_inc_link_count(new_dir); } sysv_delete_entry(old_de, old_page); mark_inode_dirty(old_inode); if (dir_de) { sysv_set_link(dir_de, dir_page, new_dir); inode_dec_link_count(old_dir); } return 0; out_dir: if (dir_de) { kunmap(dir_page); put_page(dir_page); } out_old: kunmap(old_page); put_page(old_page); out: return err; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git14945.15%746.67%
linus torvaldslinus torvalds14744.55%16.67%
miklos szeredimiklos szeredi154.55%16.67%
david howellsdavid howells61.82%16.67%
deepa dinamanideepa dinamani41.21%16.67%
alexey dobriyanalexey dobriyan30.91%16.67%
dave hansendave hansen30.91%16.67%
kirill a. shutemovkirill a. shutemov20.61%16.67%
al viroal viro10.30%16.67%
Total330100.00%15100.00%

/* * directories can handle most operations... */ const struct inode_operations sysv_dir_inode_operations = { .create = sysv_create, .lookup = sysv_lookup, .link = sysv_link, .unlink = sysv_unlink, .symlink = sysv_symlink, .mkdir = sysv_mkdir, .rmdir = sysv_rmdir, .mknod = sysv_mknod, .rename = sysv_rename, .getattr = sysv_getattr, };

Overall Contributors

PersonTokensPropCommitsCommitProp
linus torvaldslinus torvalds57445.81%36.98%
pre-gitpre-git54143.18%1432.56%
al viroal viro352.79%1023.26%
art haasart haas221.76%12.33%
david howellsdavid howells211.68%24.65%
miklos szeredimiklos szeredi151.20%12.33%
alexey dobriyanalexey dobriyan141.12%12.33%
rusty russellrusty russell100.80%12.33%
deepa dinamanideepa dinamani80.64%12.33%
dave hansendave hansen30.24%12.33%
kirill a. shutemovkirill a. shutemov20.16%12.33%
trond myklebusttrond myklebust20.16%24.65%
christoph hellwigchristoph hellwig20.16%12.33%
andries brouwerandries brouwer10.08%12.33%
arjan van de venarjan van de ven10.08%12.33%
nick pigginnick piggin10.08%12.33%
andrew mortonandrew morton10.08%12.33%
Total1253100.00%43100.00%
Directory: fs/sysv
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.