cregit-Linux how code gets into the kernel

Release 4.7 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 == -ENOENT || size == -ENODATA || size == 0) { /* FIXME, who returns -ENOENT? I think nobody */ acl = NULL; } else { acl = ERR_PTR(-EIO); } kfree(value); return acl; }

Contributors

PersonTokensPropCommitsCommitProp
josef bacikjosef bacik8849.44%111.11%
yan zhengyan zheng4223.60%111.11%
chris masonchris mason2212.36%111.11%
christoph hellwigchristoph hellwig116.18%111.11%
tsutomu itohtsutomu itoh63.37%111.11%
al viroal viro31.69%111.11%
eric w. biedermaneric w. biederman31.69%111.11%
andreas gruenbacherandreas gruenbacher21.12%111.11%
david sterbadavid sterba10.56%111.11%
Total178100.00%9100.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_equiv_mode(acl, &inode->i_mode); if (ret < 0) return ret; if (ret == 0) acl = NULL; } 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 bacik17475.32%321.43%
chris masonchris mason114.76%17.14%
liu boliu bo104.33%17.14%
christoph hellwigchristoph hellwig93.90%214.29%
yan zhengyan zheng93.90%17.14%
zheng yanzheng yan73.03%17.14%
al viroal viro52.16%214.29%
eric w. biedermaneric w. biederman31.30%17.14%
andreas gruenbacherandreas gruenbacher20.87%17.14%
david sterbadavid sterba10.43%17.14%
Total231100.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 bacik39865.46%418.18%
christoph hellwigchristoph hellwig6210.20%313.64%
yan zhengyan zheng518.39%14.55%
chris masonchris mason365.92%313.64%
zheng yanzheng yan172.80%14.55%
al viroal viro121.97%313.64%
liu boliu bo101.64%14.55%
eric w. biedermaneric w. biederman60.99%14.55%
tsutomu itohtsutomu itoh60.99%14.55%
andreas gruenbacherandreas gruenbacher40.66%14.55%
tejun heotejun heo30.49%14.55%
david sterbadavid sterba20.33%14.55%
daniel bluemandaniel blueman10.16%14.55%
Total608100.00%22100.00%
Directory: fs/btrfs
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}