cregit-Linux how code gets into the kernel

Release 4.10 fs/btrfs/acl.c

Directory: fs/btrfs
/*
 * Copyright (C) 2007 Red Hat.  All rights reserved.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public
 * License v2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public
 * License along with this program; if not, write to the
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 * Boston, MA 021110-1307, USA.
 */

#include <linux/fs.h>
#include <linux/string.h>
#include <linux/xattr.h>
#include <linux/posix_acl_xattr.h>
#include <linux/posix_acl.h>
#include <linux/sched.h>
#include <linux/slab.h>

#include "ctree.h"
#include "btrfs_inode.h"
#include "xattr.h"


struct posix_acl *btrfs_get_acl(struct inode *inode, int type) { int size; const char *name; char *value = NULL; struct posix_acl *acl; switch (type) { case ACL_TYPE_ACCESS: name = XATTR_NAME_POSIX_ACL_ACCESS; break; case ACL_TYPE_DEFAULT: name = XATTR_NAME_POSIX_ACL_DEFAULT; break; default: BUG(); } size = __btrfs_getxattr(inode, name, "", 0); if (size > 0) { value = kzalloc(size, GFP_KERNEL); if (!value) return ERR_PTR(-ENOMEM); size = __btrfs_getxattr(inode, name, value, size); } if (size > 0) { acl = posix_acl_from_xattr(&init_user_ns, value, size); } else if (size == -ERANGE || size == -ENODATA || size == 0) { acl = NULL; } else { acl = ERR_PTR(-EIO); } kfree(value); return acl; }

Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik8749.15%110.00%
yan zhengyan zheng4223.73%110.00%
chris masonchris mason2111.86%110.00%
christoph hellwigchristoph hellwig116.21%110.00%
tsutomu itohtsutomu itoh63.39%110.00%
al viroal viro31.69%110.00%
eric w. biedermaneric w. biederman31.69%110.00%
andreas gruenbacherandreas gruenbacher21.13%110.00%
salah trikisalah triki10.56%110.00%
david sterbadavid sterba10.56%110.00%
Total177100.00%10100.00%

/* * Needs to be called with fs_mutex held */
static int __btrfs_set_acl(struct btrfs_trans_handle *trans, struct inode *inode, struct posix_acl *acl, int type) { int ret, size = 0; const char *name; char *value = NULL; switch (type) { case ACL_TYPE_ACCESS: name = XATTR_NAME_POSIX_ACL_ACCESS; if (acl) { ret = posix_acl_update_mode(inode, &inode->i_mode, &acl); if (ret) return ret; } ret = 0; break; case ACL_TYPE_DEFAULT: if (!S_ISDIR(inode->i_mode)) return acl ? -EINVAL : 0; name = XATTR_NAME_POSIX_ACL_DEFAULT; break; default: return -EINVAL; } if (acl) { size = posix_acl_xattr_size(acl->a_count); value = kmalloc(size, GFP_KERNEL); if (!value) { ret = -ENOMEM; goto out; } ret = posix_acl_to_xattr(&init_user_ns, acl, value, size); if (ret < 0) goto out; } ret = __btrfs_setxattr(trans, inode, name, value, size, 0); out: kfree(value); if (!ret) set_cached_acl(inode, type, acl); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik17076.58%321.43%
chris masonchris mason114.95%17.14%
christoph hellwigchristoph hellwig94.05%214.29%
yan zhengyan zheng94.05%17.14%
zheng yanzheng yan73.15%17.14%
al viroal viro52.25%214.29%
jan karajan kara52.25%17.14%
eric w. biedermaneric w. biederman31.35%17.14%
andreas gruenbacherandreas gruenbacher20.90%17.14%
david sterbadavid sterba10.45%17.14%
Total222100.00%14100.00%


int btrfs_set_acl(struct inode *inode, struct posix_acl *acl, int type) { return __btrfs_set_acl(NULL, inode, acl, type); }

Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik1550.00%120.00%
christoph hellwigchristoph hellwig1240.00%240.00%
zheng yanzheng yan26.67%120.00%
daniel bluemandaniel blueman13.33%120.00%
Total30100.00%5100.00%

/* * btrfs_init_acl is already generally called under fs_mutex, so the locking * stuff has been fixed to work with that. If the locking stuff changes, we * need to re-evaluate the acl locking stuff. */
int btrfs_init_acl(struct btrfs_trans_handle *trans, struct inode *inode, struct inode *dir) { struct posix_acl *default_acl, *acl; int ret = 0; /* this happens with subvols */ if (!dir) return 0; ret = posix_acl_create(dir, &inode->i_mode, &default_acl, &acl); if (ret) return ret; if (default_acl) { ret = __btrfs_set_acl(trans, inode, default_acl, ACL_TYPE_DEFAULT); posix_acl_release(default_acl); } if (acl) { if (!ret) ret = __btrfs_set_acl(trans, inode, acl, ACL_TYPE_ACCESS); posix_acl_release(acl); } if (!default_acl && !acl) cache_no_acl(inode); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik9469.12%350.00%
christoph hellwigchristoph hellwig3022.06%116.67%
zheng yanzheng yan85.88%116.67%
al viroal viro42.94%116.67%
Total136100.00%6100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik39365.72%417.39%
christoph hellwigchristoph hellwig6210.37%313.04%
yan zhengyan zheng518.53%14.35%
chris masonchris mason355.85%313.04%
zheng yanzheng yan172.84%14.35%
al viroal viro122.01%313.04%
tsutomu itohtsutomu itoh61.00%14.35%
eric w. biedermaneric w. biederman61.00%14.35%
jan karajan kara50.84%14.35%
andreas gruenbacherandreas gruenbacher40.67%14.35%
tejun heotejun heo30.50%14.35%
david sterbadavid sterba20.33%14.35%
salah trikisalah triki10.17%14.35%
daniel bluemandaniel blueman10.17%14.35%
Total598100.00%23100.00%
Directory: fs/btrfs
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.