cregit-Linux how code gets into the kernel

Release 4.7 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(qstr->name, qstr->len); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2344.23%125.00%
linus torvaldslinus torvalds1834.62%125.00%
rusty russellrusty russell1019.23%125.00%
nick pigginnick piggin11.92%125.00%
Total52100.00%4100.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_SEC; inode_inc_link_count(inode); ihold(inode); return add_nondir(dentry, inode); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3461.82%550.00%
linus torvaldslinus torvalds1527.27%110.00%
david howellsdavid howells35.45%110.00%
alexey dobriyanalexey dobriyan11.82%110.00%
andi kleenandi kleen11.82%110.00%
al viroal viro11.82%110.00%
Total55100.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) { 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; 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_SEC; 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-git14947.76%750.00%
linus torvaldslinus torvalds14747.12%17.14%
david howellsdavid howells61.92%17.14%
dave hansendave hansen30.96%17.14%
alexey dobriyanalexey dobriyan30.96%17.14%
kirill a. shutemovkirill a. shutemov20.64%17.14%
al viroal viro10.32%17.14%
andi kleenandi kleen10.32%17.14%
Total312100.00%14100.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 torvalds57246.50%24.88%
pre-gitpre-git54143.98%1434.15%
al viroal viro352.85%1024.39%
art haasart haas221.79%12.44%
david howellsdavid howells211.71%24.88%
alexey dobriyanalexey dobriyan141.14%12.44%
rusty russellrusty russell100.81%12.44%
dave hansendave hansen30.24%12.44%
andi kleenandi kleen20.16%12.44%
trond myklebusttrond myklebust20.16%24.88%
christoph hellwigchristoph hellwig20.16%12.44%
kirill a. shutemovkirill a. shutemov20.16%12.44%
nick pigginnick piggin10.08%12.44%
arjan van de venarjan van de ven10.08%12.44%
andries brouwerandries brouwer10.08%12.44%
andrew mortonandrew morton10.08%12.44%
Total1230100.00%41100.00%
Directory: fs/sysv
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}