cregit-Linux how code gets into the kernel

Release 4.16 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 Bacik8749.15%110.00%
Yan Zheng4324.29%110.00%
Chris Mason2011.30%110.00%
Christoph Hellwig116.21%110.00%
Tsutomu Itoh63.39%110.00%
Al Viro31.69%110.00%
Eric W. Biedermann31.69%110.00%
Andreas Gruenbacher21.13%110.00%
Salah Triki10.56%110.00%
David 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; 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 Bacik15883.16%325.00%
Christoph Hellwig94.74%216.67%
Zheng Yan73.68%18.33%
Yan Zheng52.63%18.33%
Chris Mason31.58%18.33%
Eric W. Biedermann31.58%18.33%
Al Viro21.05%18.33%
Andreas Gruenbacher21.05%18.33%
David Sterba10.53%18.33%
Total190100.00%12100.00%


int btrfs_set_acl(struct inode *inode, struct posix_acl *acl, int type) { int ret; umode_t old_mode = inode->i_mode; if (type == ACL_TYPE_ACCESS && acl) { ret = posix_acl_update_mode(inode, &inode->i_mode, &acl); if (ret) return ret; } ret = __btrfs_set_acl(NULL, inode, acl, type); if (ret) inode->i_mode = old_mode; return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Jan Kara3540.70%116.67%
Ernesto A. Fernández2225.58%116.67%
Josef Bacik1517.44%116.67%
Christoph Hellwig1213.95%233.33%
Zheng Yan22.33%116.67%
Total86100.00%6100.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 Bacik9569.85%350.00%
Christoph Hellwig3022.06%116.67%
Zheng Yan75.15%116.67%
Al Viro42.94%116.67%
Total136100.00%6100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Josef Bacik38261.41%418.18%
Christoph Hellwig629.97%313.64%
Yan Zheng487.72%14.55%
Jan Kara355.63%14.55%
Chris Mason264.18%313.64%
Ernesto A. Fernández223.54%14.55%
Zheng Yan162.57%14.55%
Al Viro91.45%29.09%
Eric W. Biedermann60.96%14.55%
Tsutomu Itoh60.96%14.55%
Andreas Gruenbacher40.64%14.55%
Tejun Heo30.48%14.55%
David Sterba20.32%14.55%
Salah Triki10.16%14.55%
Total622100.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.
Created with cregit.