cregit-Linux how code gets into the kernel

Release 4.10 fs/reiserfs/xattr_security.c

Directory: fs/reiserfs
#include "reiserfs.h"
#include <linux/errno.h>
#include <linux/fs.h>
#include <linux/pagemap.h>
#include <linux/xattr.h>
#include <linux/slab.h>
#include "xattr.h"
#include <linux/security.h>
#include <linux/uaccess.h>


static int security_get(const struct xattr_handler *handler, struct dentry *unused, struct inode *inode, const char *name, void *buffer, size_t size) { if (IS_PRIVATE(inode)) return -EPERM; return reiserfs_xattr_get(inode, xattr_full_name(handler, name), buffer, size); }

Contributors

PersonTokensPropCommitsCommitProp
andrew mortonandrew morton4166.13%116.67%
al viroal viro1320.97%233.33%
andreas gruenbacherandreas gruenbacher69.68%116.67%
christoph hellwigchristoph hellwig11.61%116.67%
jeff mahoneyjeff mahoney11.61%116.67%
Total62100.00%6100.00%


static int security_set(const struct xattr_handler *handler, struct dentry *unused, struct inode *inode, const char *name, const void *buffer, size_t size, int flags) { if (IS_PRIVATE(inode)) return -EPERM; return reiserfs_xattr_set(inode, xattr_full_name(handler, name), buffer, size, flags); }

Contributors

PersonTokensPropCommitsCommitProp
andrew mortonandrew morton4769.12%116.67%
al viroal viro1319.12%233.33%
andreas gruenbacherandreas gruenbacher68.82%116.67%
christoph hellwigchristoph hellwig11.47%116.67%
jeff mahoneyjeff mahoney11.47%116.67%
Total68100.00%6100.00%


static bool security_list(struct dentry *dentry) { return !IS_PRIVATE(d_inode(dentry)); }

Contributors

PersonTokensPropCommitsCommitProp
andrew mortonandrew morton1047.62%116.67%
david howellsdavid howells314.29%116.67%
christoph hellwigchristoph hellwig314.29%116.67%
andreas gruenbacherandreas gruenbacher314.29%116.67%
jeff mahoneyjeff mahoney29.52%233.33%
Total21100.00%6100.00%

/* Initializes the security context for a new inode and returns the number * of blocks needed for the transaction. If successful, reiserfs_security * must be released using reiserfs_security_free when the caller is done. */
int reiserfs_security_init(struct inode *dir, struct inode *inode, const struct qstr *qstr, struct reiserfs_security_handle *sec) { int blocks = 0; int error; sec->name = NULL; /* Don't add selinux attributes on xattrs - they'll never get used */ if (IS_PRIVATE(dir)) return 0; error = security_old_inode_init_security(inode, dir, qstr, &sec->name, &sec->value, &sec->length); if (error) { if (error == -EOPNOTSUPP) error = 0; sec->name = NULL; sec->value = NULL; sec->length = 0; return error; } if (sec->length && reiserfs_xattrs_initialized(inode->i_sb)) { blocks = reiserfs_xattr_jcreate_nblocks(inode) + reiserfs_xattr_nblocks(inode, sec->length); /* We don't want to count the directories twice if we have * a default ACL. */ REISERFS_I(inode)->i_flags |= i_has_xattr_dir; } return blocks; }

Contributors

PersonTokensPropCommitsCommitProp
jeff mahoneyjeff mahoney15094.34%360.00%
eric pariseric paris85.03%120.00%
mimi zoharmimi zohar10.63%120.00%
Total159100.00%5100.00%


int reiserfs_security_write(struct reiserfs_transaction_handle *th, struct inode *inode, struct reiserfs_security_handle *sec) { int error; if (strlen(sec->name) < sizeof(XATTR_SECURITY_PREFIX)) return -EINVAL; error = reiserfs_xattr_set_handle(th, inode, sec->name, sec->value, sec->length, XATTR_CREATE); if (error == -ENODATA || error == -EOPNOTSUPP) error = 0; return error; }

Contributors

PersonTokensPropCommitsCommitProp
jeff mahoneyjeff mahoney83100.00%1100.00%
Total83100.00%1100.00%


void reiserfs_security_free(struct reiserfs_security_handle *sec) { kfree(sec->name); kfree(sec->value); sec->name = NULL; sec->value = NULL; }

Contributors

PersonTokensPropCommitsCommitProp
jeff mahoneyjeff mahoney36100.00%1100.00%
Total36100.00%1100.00%

const struct xattr_handler reiserfs_xattr_security_handler = { .prefix = XATTR_SECURITY_PREFIX, .get = security_get, .set = security_set, .list = security_list, };

Overall Contributors

PersonTokensPropCommitsCommitProp
jeff mahoneyjeff mahoney27957.64%523.81%
andrew mortonandrew morton13227.27%14.76%
al viroal viro367.44%628.57%
andreas gruenbacherandreas gruenbacher153.10%29.52%
eric pariseric paris81.65%14.76%
christoph hellwigchristoph hellwig51.03%14.76%
david howellsdavid howells30.62%14.76%
tejun heotejun heo30.62%14.76%
stephen hemmingerstephen hemminger10.21%14.76%
mimi zoharmimi zohar10.21%14.76%
fabian frederickfabian frederick10.21%14.76%
Total484100.00%21100.00%
Directory: fs/reiserfs
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.