2  * linux/fs/reiserfs/xattr.c
 
   4  * Copyright (c) 2002 by Jeff Mahoney, <jeffm@suse.com>
 
   9  * In order to implement EA/ACLs in a clean, backwards compatible manner,
 
  10  * they are implemented as files in a "private" directory.
 
  11  * Each EA is in it's own file, with the directory layout like so (/ is assumed
 
  12  * to be relative to fs root). Inside the /.reiserfs_priv/xattrs directory,
 
  13  * directories named using the capital-hex form of the objectid and
 
  14  * generation number are used. Inside each directory are individual files
 
  15  * named with the name of the extended attribute.
 
  17  * So, for objectid 12648430, we could have:
 
  18  * /.reiserfs_priv/xattrs/C0FFEE.0/system.posix_acl_access
 
  19  * /.reiserfs_priv/xattrs/C0FFEE.0/system.posix_acl_default
 
  20  * /.reiserfs_priv/xattrs/C0FFEE.0/user.Content-Type
 
  23  * The file contents are the text of the EA. The size is known based on the
 
  24  * stat data describing the file.
 
  26  * In the case of system.posix_acl_access and system.posix_acl_default, since
 
  27  * these are special cases for filesystem ACLs, they are interpreted by the
 
  28  * kernel, in addition, they are negatively and positively cached and attached
 
  29  * to the inode so that unnecessary lookups are avoided.
 
  32 #include <linux/reiserfs_fs.h>
 
  33 #include <linux/capability.h>
 
  34 #include <linux/dcache.h>
 
  35 #include <linux/namei.h>
 
  36 #include <linux/errno.h>
 
  38 #include <linux/file.h>
 
  39 #include <linux/pagemap.h>
 
  40 #include <linux/xattr.h>
 
  41 #include <linux/reiserfs_xattr.h>
 
  42 #include <linux/reiserfs_acl.h>
 
  43 #include <asm/uaccess.h>
 
  44 #include <asm/checksum.h>
 
  45 #include <linux/smp_lock.h>
 
  46 #include <linux/stat.h>
 
  47 #include <asm/semaphore.h>
 
  49 #define FL_READONLY 128
 
  50 #define FL_DIR_SEM_HELD 256
 
  51 #define PRIVROOT_NAME ".reiserfs_priv"
 
  52 #define XAROOT_NAME   "xattrs"
 
  54 static struct reiserfs_xattr_handler *find_xattr_handler_prefix(const char
 
  57 static struct dentry *create_xa_root(struct super_block *sb)
 
  59         struct dentry *privroot = dget(REISERFS_SB(sb)->priv_root);
 
  60         struct dentry *xaroot;
 
  62         /* This needs to be created at mount-time */
 
  64                 return ERR_PTR(-EOPNOTSUPP);
 
  66         xaroot = lookup_one_len(XAROOT_NAME, privroot, strlen(XAROOT_NAME));
 
  69         } else if (!xaroot->d_inode) {
 
  71                 mutex_lock(&privroot->d_inode->i_mutex);
 
  73                     privroot->d_inode->i_op->mkdir(privroot->d_inode, xaroot,
 
  75                 mutex_unlock(&privroot->d_inode->i_mutex);
 
  82                 REISERFS_SB(sb)->xattr_root = dget(xaroot);
 
  90 /* This will return a dentry, or error, refering to the xa root directory.
 
  91  * If the xa root doesn't exist yet, the dentry will be returned without
 
  92  * an associated inode. This dentry can be used with ->mkdir to create
 
  93  * the xa directory. */
 
  94 static struct dentry *__get_xa_root(struct super_block *s)
 
  96         struct dentry *privroot = dget(REISERFS_SB(s)->priv_root);
 
  97         struct dentry *xaroot = NULL;
 
  99         if (IS_ERR(privroot) || !privroot)
 
 102         xaroot = lookup_one_len(XAROOT_NAME, privroot, strlen(XAROOT_NAME));
 
 103         if (IS_ERR(xaroot)) {
 
 105         } else if (!xaroot->d_inode) {
 
 111         REISERFS_SB(s)->xattr_root = dget(xaroot);
 
 118 /* Returns the dentry (or NULL) referring to the root of the extended
 
 119  * attribute directory tree. If it has already been retrieved, it is used.
 
 120  * Otherwise, we attempt to retrieve it from disk. It may also return
 
 121  * a pointer-encoded error.
 
 123 static inline struct dentry *get_xa_root(struct super_block *s)
 
 125         struct dentry *dentry = dget(REISERFS_SB(s)->xattr_root);
 
 128                 dentry = __get_xa_root(s);
 
 133 /* Opens the directory corresponding to the inode's extended attribute store.
 
 134  * If flags allow, the tree to the directory may be created. If creation is
 
 135  * prohibited, -ENODATA is returned. */
 
 136 static struct dentry *open_xa_dir(const struct inode *inode, int flags)
 
 138         struct dentry *xaroot, *xadir;
 
 141         xaroot = get_xa_root(inode->i_sb);
 
 142         if (IS_ERR(xaroot)) {
 
 144         } else if (!xaroot) {
 
 145                 if (flags == 0 || flags & XATTR_CREATE) {
 
 146                         xaroot = create_xa_root(inode->i_sb);
 
 151                         return ERR_PTR(-ENODATA);
 
 154         /* ok, we have xaroot open */
 
 156         snprintf(namebuf, sizeof(namebuf), "%X.%X",
 
 157                  le32_to_cpu(INODE_PKEY(inode)->k_objectid),
 
 158                  inode->i_generation);
 
 159         xadir = lookup_one_len(namebuf, xaroot, strlen(namebuf));
 
 165         if (!xadir->d_inode) {
 
 167                 if (flags == 0 || flags & XATTR_CREATE) {
 
 168                         /* Although there is nothing else trying to create this directory,
 
 169                          * another directory with the same hash may be created, so we need
 
 170                          * to protect against that */
 
 172                             xaroot->d_inode->i_op->mkdir(xaroot->d_inode, xadir,
 
 180                 if (!xadir->d_inode) {
 
 183                         return ERR_PTR(-ENODATA);
 
 191 /* Returns a dentry corresponding to a specific extended attribute file
 
 192  * for the inode. If flags allow, the file is created. Otherwise, a
 
 193  * valid or negative dentry, or an error is returned. */
 
 194 static struct dentry *get_xa_file_dentry(const struct inode *inode,
 
 195                                          const char *name, int flags)
 
 197         struct dentry *xadir, *xafile;
 
 200         xadir = open_xa_dir(inode, flags);
 
 202                 return ERR_PTR(PTR_ERR(xadir));
 
 203         } else if (xadir && !xadir->d_inode) {
 
 205                 return ERR_PTR(-ENODATA);
 
 208         xafile = lookup_one_len(name, xadir, strlen(name));
 
 209         if (IS_ERR(xafile)) {
 
 211                 return ERR_PTR(PTR_ERR(xafile));
 
 214         if (xafile->d_inode) {  /* file exists */
 
 215                 if (flags & XATTR_CREATE) {
 
 220         } else if (flags & XATTR_REPLACE || flags & FL_READONLY) {
 
 223                 /* inode->i_mutex is down, so nothing else can try to create
 
 225                 err = xadir->d_inode->i_op->create(xadir->d_inode, xafile,
 
 226                                                    0700 | S_IFREG, NULL);
 
 237                 xafile = ERR_PTR(err);
 
 241 /* Opens a file pointer to the attribute associated with inode */
 
 242 static struct file *open_xa_file(const struct inode *inode, const char *name,
 
 245         struct dentry *xafile;
 
 248         xafile = get_xa_file_dentry(inode, name, flags);
 
 250                 return ERR_PTR(PTR_ERR(xafile));
 
 251         else if (!xafile->d_inode) {
 
 253                 return ERR_PTR(-ENODATA);
 
 256         fp = dentry_open(xafile, NULL, O_RDWR);
 
 257         /* dentry_open dputs the dentry if it fails */
 
 263  * this is very similar to fs/reiserfs/dir.c:reiserfs_readdir, but
 
 264  * we need to drop the path before calling the filldir struct.  That
 
 265  * would be a big performance hit to the non-xattr case, so I've copied
 
 266  * the whole thing for now. --clm
 
 268  * the big difference is that I go backwards through the directory,
 
 269  * and don't mess with f->f_pos, but the idea is the same.  Do some
 
 270  * action on each and every entry in the directory.
 
 272  * we're called with i_mutex held, so there are no worries about the directory
 
 273  * changing underneath us.
 
 275 static int __xattr_readdir(struct file *filp, void *dirent, filldir_t filldir)
 
 277         struct inode *inode = filp->f_dentry->d_inode;
 
 278         struct cpu_key pos_key; /* key of current position in the directory (key of directory entry) */
 
 279         INITIALIZE_PATH(path_to_entry);
 
 280         struct buffer_head *bh;
 
 282         struct item_head *ih, tmp_ih;
 
 286         char small_buf[32];     /* avoid kmalloc if we can */
 
 287         struct reiserfs_de_head *deh;
 
 292         struct reiserfs_dir_entry de;
 
 294         /* form key for search the next directory entry using f_pos field of
 
 296         next_pos = max_reiserfs_offset(inode);
 
 300                 if (next_pos <= DOT_DOT_OFFSET)
 
 302                 make_cpu_key(&pos_key, inode, next_pos, TYPE_DIRENTRY, 3);
 
 305                     search_by_entry_key(inode->i_sb, &pos_key, &path_to_entry,
 
 307                 if (search_res == IO_ERROR) {
 
 308                         // FIXME: we could just skip part of directory which could
 
 310                         pathrelse(&path_to_entry);
 
 314                 if (search_res == NAME_NOT_FOUND)
 
 317                 set_de_name_and_namelen(&de);
 
 318                 entry_num = de.de_entry_num;
 
 319                 deh = &(de.de_deh[entry_num]);
 
 324                 if (!is_direntry_le_ih(ih)) {
 
 325                         reiserfs_warning(inode->i_sb, "not direntry %h", ih);
 
 328                 copy_item_head(&tmp_ih, ih);
 
 330                 /* we must have found item, that is item of this directory, */
 
 331                 RFALSE(COMP_SHORT_KEYS(&(ih->ih_key), &pos_key),
 
 332                        "vs-9000: found item %h does not match to dir we readdir %K",
 
 335                 if (deh_offset(deh) <= DOT_DOT_OFFSET) {
 
 339                 /* look for the previous entry in the directory */
 
 340                 next_pos = deh_offset(deh) - 1;
 
 342                 if (!de_visible(deh))
 
 343                         /* it is hidden entry */
 
 346                 d_reclen = entry_length(bh, ih, entry_num);
 
 347                 d_name = B_I_DEH_ENTRY_FILE_NAME(bh, ih, deh);
 
 348                 d_off = deh_offset(deh);
 
 349                 d_ino = deh_objectid(deh);
 
 351                 if (!d_name[d_reclen - 1])
 
 352                         d_reclen = strlen(d_name);
 
 354                 if (d_reclen > REISERFS_MAX_NAME(inode->i_sb->s_blocksize)) {
 
 355                         /* too big to send back to VFS */
 
 359                 /* Ignore the .reiserfs_priv entry */
 
 360                 if (reiserfs_xattrs(inode->i_sb) &&
 
 361                     !old_format_only(inode->i_sb) &&
 
 363                     le32_to_cpu(INODE_PKEY
 
 364                                 (REISERFS_SB(inode->i_sb)->priv_root->d_inode)->
 
 368                 if (d_reclen <= 32) {
 
 369                         local_buf = small_buf;
 
 371                         local_buf = kmalloc(d_reclen, GFP_NOFS);
 
 373                                 pathrelse(&path_to_entry);
 
 376                         if (item_moved(&tmp_ih, &path_to_entry)) {
 
 379                                 /* sigh, must retry.  Do this same offset again */
 
 385                 // Note, that we copy name to user space via temporary
 
 386                 // buffer (local_buf) because filldir will block if
 
 387                 // user space buffer is swapped out. At that time
 
 388                 // entry can move to somewhere else
 
 389                 memcpy(local_buf, d_name, d_reclen);
 
 391                 /* the filldir function might need to start transactions,
 
 392                  * or do who knows what.  Release the path now that we've
 
 393                  * copied all the important stuff out of the deh
 
 395                 pathrelse(&path_to_entry);
 
 397                 if (filldir(dirent, local_buf, d_reclen, d_off, d_ino,
 
 399                         if (local_buf != small_buf) {
 
 404                 if (local_buf != small_buf) {
 
 410         pathrelse(&path_to_entry);
 
 415  * this could be done with dedicated readdir ops for the xattr files,
 
 416  * but I want to get something working asap
 
 417  * this is stolen from vfs_readdir
 
 421 int xattr_readdir(struct file *file, filldir_t filler, void *buf)
 
 423         struct inode *inode = file->f_dentry->d_inode;
 
 425         if (!file->f_op || !file->f_op->readdir)
 
 427         mutex_lock(&inode->i_mutex);
 
 428 //        down(&inode->i_zombie);
 
 430         if (!IS_DEADDIR(inode)) {
 
 432                 res = __xattr_readdir(file, buf, filler);
 
 435 //        up(&inode->i_zombie);
 
 436         mutex_unlock(&inode->i_mutex);
 
 441 /* Internal operations on file data */
 
 442 static inline void reiserfs_put_page(struct page *page)
 
 445         page_cache_release(page);
 
 448 static struct page *reiserfs_get_page(struct inode *dir, unsigned long n)
 
 450         struct address_space *mapping = dir->i_mapping;
 
 452         /* We can deadlock if we try to free dentries,
 
 453            and an unlink/rmdir has just occured - GFP_NOFS avoids this */
 
 454         mapping_set_gfp_mask(mapping, GFP_NOFS);
 
 455         page = read_mapping_page(mapping, n, NULL);
 
 457                 wait_on_page_locked(page);
 
 459                 if (!PageUptodate(page))
 
 468         reiserfs_put_page(page);
 
 469         return ERR_PTR(-EIO);
 
 472 static inline __u32 xattr_hash(const char *msg, int len)
 
 474         return csum_partial(msg, len, 0);
 
 477 /* Generic extended attribute operations that can be used by xa plugins */
 
 480  * inode->i_mutex: down
 
 483 reiserfs_xattr_set(struct inode *inode, const char *name, const void *buffer,
 
 484                    size_t buffer_size, int flags)
 
 490         struct address_space *mapping;
 
 492         size_t buffer_pos = 0;
 
 493         struct inode *xinode;
 
 494         struct iattr newattrs;
 
 497         if (get_inode_sd_version(inode) == STAT_DATA_V1)
 
 500         /* Empty xattrs are ok, they're just empty files, no hash */
 
 501         if (buffer && buffer_size)
 
 502                 xahash = xattr_hash(buffer, buffer_size);
 
 505         fp = open_xa_file(inode, name, flags);
 
 511         xinode = fp->f_dentry->d_inode;
 
 512         REISERFS_I(inode)->i_flags |= i_has_xattr_dir;
 
 514         /* we need to copy it off.. */
 
 515         if (xinode->i_nlink > 1) {
 
 517                 err = reiserfs_xattr_del(inode, name);
 
 520                 /* We just killed the old one, we're not replacing anymore */
 
 521                 if (flags & XATTR_REPLACE)
 
 522                         flags &= ~XATTR_REPLACE;
 
 526         /* Resize it so we're ok to write there */
 
 527         newattrs.ia_size = buffer_size;
 
 528         newattrs.ia_valid = ATTR_SIZE | ATTR_CTIME;
 
 529         mutex_lock(&xinode->i_mutex);
 
 530         err = notify_change(fp->f_dentry, &newattrs);
 
 534         mapping = xinode->i_mapping;
 
 535         while (buffer_pos < buffer_size || buffer_pos == 0) {
 
 538                 size_t page_offset = (file_pos & (PAGE_CACHE_SIZE - 1));
 
 539                 if (buffer_size - buffer_pos > PAGE_CACHE_SIZE)
 
 540                         chunk = PAGE_CACHE_SIZE;
 
 542                         chunk = buffer_size - buffer_pos;
 
 544                 page = reiserfs_get_page(xinode, file_pos >> PAGE_CACHE_SHIFT);
 
 551                 data = page_address(page);
 
 554                         struct reiserfs_xattr_header *rxh;
 
 555                         skip = file_pos = sizeof(struct reiserfs_xattr_header);
 
 556                         if (chunk + skip > PAGE_CACHE_SIZE)
 
 557                                 chunk = PAGE_CACHE_SIZE - skip;
 
 558                         rxh = (struct reiserfs_xattr_header *)data;
 
 559                         rxh->h_magic = cpu_to_le32(REISERFS_XATTR_MAGIC);
 
 560                         rxh->h_hash = cpu_to_le32(xahash);
 
 563                 err = mapping->a_ops->prepare_write(fp, page, page_offset,
 
 564                                                     page_offset + chunk + skip);
 
 567                                 memcpy(data + skip, buffer + buffer_pos, chunk);
 
 569                             mapping->a_ops->commit_write(fp, page, page_offset,
 
 570                                                          page_offset + chunk +
 
 574                 reiserfs_put_page(page);
 
 578                 if (err || buffer_size == 0 || !buffer)
 
 582         /* We can't mark the inode dirty if it's not hashed. This is the case
 
 583          * when we're inheriting the default ACL. If we dirty it, the inode
 
 584          * gets marked dirty, but won't (ever) make it onto the dirty list until
 
 585          * it's synced explicitly to clear I_DIRTY. This is bad. */
 
 586         if (!hlist_unhashed(&inode->i_hash)) {
 
 587                 inode->i_ctime = CURRENT_TIME_SEC;
 
 588                 mark_inode_dirty(inode);
 
 592         mutex_unlock(&xinode->i_mutex);
 
 600  * inode->i_mutex: down
 
 603 reiserfs_xattr_get(const struct inode *inode, const char *name, void *buffer,
 
 610         size_t buffer_pos = 0;
 
 612         struct inode *xinode;
 
 618         /* We can't have xattrs attached to v1 items since they don't have
 
 619          * generation numbers */
 
 620         if (get_inode_sd_version(inode) == STAT_DATA_V1)
 
 623         fp = open_xa_file(inode, name, FL_READONLY);
 
 629         xinode = fp->f_dentry->d_inode;
 
 630         isize = xinode->i_size;
 
 631         REISERFS_I(inode)->i_flags |= i_has_xattr_dir;
 
 633         /* Just return the size needed */
 
 634         if (buffer == NULL) {
 
 635                 err = isize - sizeof(struct reiserfs_xattr_header);
 
 639         if (buffer_size < isize - sizeof(struct reiserfs_xattr_header)) {
 
 644         while (file_pos < isize) {
 
 648                 if (isize - file_pos > PAGE_CACHE_SIZE)
 
 649                         chunk = PAGE_CACHE_SIZE;
 
 651                         chunk = isize - file_pos;
 
 653                 page = reiserfs_get_page(xinode, file_pos >> PAGE_CACHE_SHIFT);
 
 660                 data = page_address(page);
 
 662                         struct reiserfs_xattr_header *rxh =
 
 663                             (struct reiserfs_xattr_header *)data;
 
 664                         skip = file_pos = sizeof(struct reiserfs_xattr_header);
 
 666                         /* Magic doesn't match up.. */
 
 667                         if (rxh->h_magic != cpu_to_le32(REISERFS_XATTR_MAGIC)) {
 
 669                                 reiserfs_put_page(page);
 
 670                                 reiserfs_warning(inode->i_sb,
 
 671                                                  "Invalid magic for xattr (%s) "
 
 672                                                  "associated with %k", name,
 
 677                         hash = le32_to_cpu(rxh->h_hash);
 
 679                 memcpy(buffer + buffer_pos, data + skip, chunk);
 
 681                 reiserfs_put_page(page);
 
 686         err = isize - sizeof(struct reiserfs_xattr_header);
 
 688         if (xattr_hash(buffer, isize - sizeof(struct reiserfs_xattr_header)) !=
 
 690                 reiserfs_warning(inode->i_sb,
 
 691                                  "Invalid hash for xattr (%s) associated "
 
 692                                  "with %k", name, INODE_PKEY(inode));
 
 704 __reiserfs_xattr_del(struct dentry *xadir, const char *name, int namelen)
 
 706         struct dentry *dentry;
 
 707         struct inode *dir = xadir->d_inode;
 
 710         dentry = lookup_one_len(name, xadir, namelen);
 
 711         if (IS_ERR(dentry)) {
 
 712                 err = PTR_ERR(dentry);
 
 714         } else if (!dentry->d_inode) {
 
 719         /* Skip directories.. */
 
 720         if (S_ISDIR(dentry->d_inode->i_mode))
 
 723         if (!is_reiserfs_priv_object(dentry->d_inode)) {
 
 724                 reiserfs_warning(dir->i_sb, "OID %08x [%.*s/%.*s] doesn't have "
 
 725                                  "priv flag set [parent is %sset].",
 
 726                                  le32_to_cpu(INODE_PKEY(dentry->d_inode)->
 
 727                                              k_objectid), xadir->d_name.len,
 
 728                                  xadir->d_name.name, namelen, name,
 
 729                                  is_reiserfs_priv_object(xadir->
 
 736         err = dir->i_op->unlink(dir, dentry);
 
 747 int reiserfs_xattr_del(struct inode *inode, const char *name)
 
 752         dir = open_xa_dir(inode, FL_READONLY);
 
 758         err = __reiserfs_xattr_del(dir, name, strlen(name));
 
 762                 inode->i_ctime = CURRENT_TIME_SEC;
 
 763                 mark_inode_dirty(inode);
 
 770 /* The following are side effects of other operations that aren't explicitly
 
 771  * modifying extended attributes. This includes operations such as permissions
 
 772  * or ownership changes, object deletions, etc. */
 
 775 reiserfs_delete_xattrs_filler(void *buf, const char *name, int namelen,
 
 776                               loff_t offset, ino_t ino, unsigned int d_type)
 
 778         struct dentry *xadir = (struct dentry *)buf;
 
 780         return __reiserfs_xattr_del(xadir, name, namelen);
 
 784 /* This is called w/ inode->i_mutex downed */
 
 785 int reiserfs_delete_xattrs(struct inode *inode)
 
 788         struct dentry *dir, *root;
 
 791         /* Skip out, an xattr has no xattrs associated with it */
 
 792         if (is_reiserfs_priv_object(inode) ||
 
 793             get_inode_sd_version(inode) == STAT_DATA_V1 ||
 
 794             !reiserfs_xattrs(inode->i_sb)) {
 
 797         reiserfs_read_lock_xattrs(inode->i_sb);
 
 798         dir = open_xa_dir(inode, FL_READONLY);
 
 799         reiserfs_read_unlock_xattrs(inode->i_sb);
 
 803         } else if (!dir->d_inode) {
 
 808         fp = dentry_open(dir, NULL, O_RDWR);
 
 811                 /* dentry_open dputs the dentry if it fails */
 
 816         err = xattr_readdir(fp, reiserfs_delete_xattrs_filler, dir);
 
 822         /* Leftovers besides . and .. -- that's not good. */
 
 823         if (dir->d_inode->i_nlink <= 2) {
 
 824                 root = get_xa_root(inode->i_sb);
 
 825                 reiserfs_write_lock_xattrs(inode->i_sb);
 
 826                 err = vfs_rmdir(root->d_inode, dir);
 
 827                 reiserfs_write_unlock_xattrs(inode->i_sb);
 
 830                 reiserfs_warning(inode->i_sb,
 
 831                                  "Couldn't remove all entries in directory");
 
 840                 REISERFS_I(inode)->i_flags =
 
 841                     REISERFS_I(inode)->i_flags & ~i_has_xattr_dir;
 
 845 struct reiserfs_chown_buf {
 
 847         struct dentry *xadir;
 
 851 /* XXX: If there is a better way to do this, I'd love to hear about it */
 
 853 reiserfs_chown_xattrs_filler(void *buf, const char *name, int namelen,
 
 854                              loff_t offset, ino_t ino, unsigned int d_type)
 
 856         struct reiserfs_chown_buf *chown_buf = (struct reiserfs_chown_buf *)buf;
 
 857         struct dentry *xafile, *xadir = chown_buf->xadir;
 
 858         struct iattr *attrs = chown_buf->attrs;
 
 861         xafile = lookup_one_len(name, xadir, namelen);
 
 863                 return PTR_ERR(xafile);
 
 864         else if (!xafile->d_inode) {
 
 869         if (!S_ISDIR(xafile->d_inode->i_mode))
 
 870                 err = notify_change(xafile, attrs);
 
 876 int reiserfs_chown_xattrs(struct inode *inode, struct iattr *attrs)
 
 881         struct reiserfs_chown_buf buf;
 
 882         unsigned int ia_valid = attrs->ia_valid;
 
 884         /* Skip out, an xattr has no xattrs associated with it */
 
 885         if (is_reiserfs_priv_object(inode) ||
 
 886             get_inode_sd_version(inode) == STAT_DATA_V1 ||
 
 887             !reiserfs_xattrs(inode->i_sb)) {
 
 890         reiserfs_read_lock_xattrs(inode->i_sb);
 
 891         dir = open_xa_dir(inode, FL_READONLY);
 
 892         reiserfs_read_unlock_xattrs(inode->i_sb);
 
 894                 if (PTR_ERR(dir) != -ENODATA)
 
 897         } else if (!dir->d_inode) {
 
 902         fp = dentry_open(dir, NULL, O_RDWR);
 
 905                 /* dentry_open dputs the dentry if it fails */
 
 911         attrs->ia_valid &= (ATTR_UID | ATTR_GID | ATTR_CTIME);
 
 916         err = xattr_readdir(fp, reiserfs_chown_xattrs_filler, &buf);
 
 922         err = notify_change(dir, attrs);
 
 929         attrs->ia_valid = ia_valid;
 
 933 /* Actual operations that are exported to VFS-land */
 
 936  * Inode operation getxattr()
 
 937  * Preliminary locking: we down dentry->d_inode->i_mutex
 
 940 reiserfs_getxattr(struct dentry * dentry, const char *name, void *buffer,
 
 943         struct reiserfs_xattr_handler *xah = find_xattr_handler_prefix(name);
 
 946         if (!xah || !reiserfs_xattrs(dentry->d_sb) ||
 
 947             get_inode_sd_version(dentry->d_inode) == STAT_DATA_V1)
 
 950         reiserfs_read_lock_xattr_i(dentry->d_inode);
 
 951         reiserfs_read_lock_xattrs(dentry->d_sb);
 
 952         err = xah->get(dentry->d_inode, name, buffer, size);
 
 953         reiserfs_read_unlock_xattrs(dentry->d_sb);
 
 954         reiserfs_read_unlock_xattr_i(dentry->d_inode);
 
 959  * Inode operation setxattr()
 
 961  * dentry->d_inode->i_mutex down
 
 964 reiserfs_setxattr(struct dentry *dentry, const char *name, const void *value,
 
 965                   size_t size, int flags)
 
 967         struct reiserfs_xattr_handler *xah = find_xattr_handler_prefix(name);
 
 971         if (!xah || !reiserfs_xattrs(dentry->d_sb) ||
 
 972             get_inode_sd_version(dentry->d_inode) == STAT_DATA_V1)
 
 975         reiserfs_write_lock_xattr_i(dentry->d_inode);
 
 976         lock = !has_xattr_dir(dentry->d_inode);
 
 978                 reiserfs_write_lock_xattrs(dentry->d_sb);
 
 980                 reiserfs_read_lock_xattrs(dentry->d_sb);
 
 981         err = xah->set(dentry->d_inode, name, value, size, flags);
 
 983                 reiserfs_write_unlock_xattrs(dentry->d_sb);
 
 985                 reiserfs_read_unlock_xattrs(dentry->d_sb);
 
 986         reiserfs_write_unlock_xattr_i(dentry->d_inode);
 
 991  * Inode operation removexattr()
 
 993  * dentry->d_inode->i_mutex down
 
 995 int reiserfs_removexattr(struct dentry *dentry, const char *name)
 
 998         struct reiserfs_xattr_handler *xah = find_xattr_handler_prefix(name);
 
1000         if (!xah || !reiserfs_xattrs(dentry->d_sb) ||
 
1001             get_inode_sd_version(dentry->d_inode) == STAT_DATA_V1)
 
1004         reiserfs_write_lock_xattr_i(dentry->d_inode);
 
1005         reiserfs_read_lock_xattrs(dentry->d_sb);
 
1007         /* Deletion pre-operation */
 
1009                 err = xah->del(dentry->d_inode, name);
 
1014         err = reiserfs_xattr_del(dentry->d_inode, name);
 
1016         dentry->d_inode->i_ctime = CURRENT_TIME_SEC;
 
1017         mark_inode_dirty(dentry->d_inode);
 
1020         reiserfs_read_unlock_xattrs(dentry->d_sb);
 
1021         reiserfs_write_unlock_xattr_i(dentry->d_inode);
 
1025 /* This is what filldir will use:
 
1026  * r_pos will always contain the amount of space required for the entire
 
1027  * list. If r_pos becomes larger than r_size, we need more space and we
 
1028  * return an error indicating this. If r_pos is less than r_size, then we've
 
1029  * filled the buffer successfully and we return success */
 
1030 struct reiserfs_listxattr_buf {
 
1034         struct inode *r_inode;
 
1038 reiserfs_listxattr_filler(void *buf, const char *name, int namelen,
 
1039                           loff_t offset, ino_t ino, unsigned int d_type)
 
1041         struct reiserfs_listxattr_buf *b = (struct reiserfs_listxattr_buf *)buf;
 
1044             || (namelen != 1 && (name[1] != '.' || namelen != 2))) {
 
1045                 struct reiserfs_xattr_handler *xah =
 
1046                     find_xattr_handler_prefix(name);
 
1048                         return 0;       /* Unsupported xattr name, skip it */
 
1050                 /* We call ->list() twice because the operation isn't required to just
 
1051                  * return the name back - we want to make sure we have enough space */
 
1052                 len += xah->list(b->r_inode, name, namelen, NULL);
 
1055                         if (b->r_pos + len + 1 <= b->r_size) {
 
1056                                 char *p = b->r_buf + b->r_pos;
 
1057                                 p += xah->list(b->r_inode, name, namelen, p);
 
1060                         b->r_pos += len + 1;
 
1068  * Inode operation listxattr()
 
1070  * Preliminary locking: we down dentry->d_inode->i_mutex
 
1072 ssize_t reiserfs_listxattr(struct dentry * dentry, char *buffer, size_t size)
 
1077         struct reiserfs_listxattr_buf buf;
 
1079         if (!dentry->d_inode)
 
1082         if (!reiserfs_xattrs(dentry->d_sb) ||
 
1083             get_inode_sd_version(dentry->d_inode) == STAT_DATA_V1)
 
1086         reiserfs_read_lock_xattr_i(dentry->d_inode);
 
1087         reiserfs_read_lock_xattrs(dentry->d_sb);
 
1088         dir = open_xa_dir(dentry->d_inode, FL_READONLY);
 
1089         reiserfs_read_unlock_xattrs(dentry->d_sb);
 
1092                 if (err == -ENODATA)
 
1093                         err = 0;        /* Not an error if there aren't any xattrs */
 
1097         fp = dentry_open(dir, NULL, O_RDWR);
 
1100                 /* dentry_open dputs the dentry if it fails */
 
1105         buf.r_size = buffer ? size : 0;
 
1107         buf.r_inode = dentry->d_inode;
 
1109         REISERFS_I(dentry->d_inode)->i_flags |= i_has_xattr_dir;
 
1111         err = xattr_readdir(fp, reiserfs_listxattr_filler, &buf);
 
1115         if (buf.r_pos > buf.r_size && buffer != NULL)
 
1124         reiserfs_read_unlock_xattr_i(dentry->d_inode);
 
1128 /* This is the implementation for the xattr plugin infrastructure */
 
1129 static struct list_head xattr_handlers = LIST_HEAD_INIT(xattr_handlers);
 
1130 static DEFINE_RWLOCK(handler_lock);
 
1132 static struct reiserfs_xattr_handler *find_xattr_handler_prefix(const char
 
1135         struct reiserfs_xattr_handler *xah = NULL;
 
1136         struct list_head *p;
 
1138         read_lock(&handler_lock);
 
1139         list_for_each(p, &xattr_handlers) {
 
1140                 xah = list_entry(p, struct reiserfs_xattr_handler, handlers);
 
1141                 if (strncmp(xah->prefix, prefix, strlen(xah->prefix)) == 0)
 
1146         read_unlock(&handler_lock);
 
1150 static void __unregister_handlers(void)
 
1152         struct reiserfs_xattr_handler *xah;
 
1153         struct list_head *p, *tmp;
 
1155         list_for_each_safe(p, tmp, &xattr_handlers) {
 
1156                 xah = list_entry(p, struct reiserfs_xattr_handler, handlers);
 
1162         INIT_LIST_HEAD(&xattr_handlers);
 
1165 int __init reiserfs_xattr_register_handlers(void)
 
1168         struct reiserfs_xattr_handler *xah;
 
1169         struct list_head *p;
 
1171         write_lock(&handler_lock);
 
1173         /* If we're already initialized, nothing to do */
 
1174         if (!list_empty(&xattr_handlers)) {
 
1175                 write_unlock(&handler_lock);
 
1179         /* Add the handlers */
 
1180         list_add_tail(&user_handler.handlers, &xattr_handlers);
 
1181         list_add_tail(&trusted_handler.handlers, &xattr_handlers);
 
1182 #ifdef CONFIG_REISERFS_FS_SECURITY
 
1183         list_add_tail(&security_handler.handlers, &xattr_handlers);
 
1185 #ifdef CONFIG_REISERFS_FS_POSIX_ACL
 
1186         list_add_tail(&posix_acl_access_handler.handlers, &xattr_handlers);
 
1187         list_add_tail(&posix_acl_default_handler.handlers, &xattr_handlers);
 
1190         /* Run initializers, if available */
 
1191         list_for_each(p, &xattr_handlers) {
 
1192                 xah = list_entry(p, struct reiserfs_xattr_handler, handlers);
 
1202         /* Clean up other handlers, if any failed */
 
1204                 __unregister_handlers();
 
1206         write_unlock(&handler_lock);
 
1210 void reiserfs_xattr_unregister_handlers(void)
 
1212         write_lock(&handler_lock);
 
1213         __unregister_handlers();
 
1214         write_unlock(&handler_lock);
 
1217 /* This will catch lookups from the fs root to .reiserfs_priv */
 
1219 xattr_lookup_poison(struct dentry *dentry, struct qstr *q1, struct qstr *name)
 
1221         struct dentry *priv_root = REISERFS_SB(dentry->d_sb)->priv_root;
 
1222         if (name->len == priv_root->d_name.len &&
 
1223             name->hash == priv_root->d_name.hash &&
 
1224             !memcmp(name->name, priv_root->d_name.name, name->len)) {
 
1226         } else if (q1->len == name->len &&
 
1227                    !memcmp(q1->name, name->name, name->len))
 
1232 static struct dentry_operations xattr_lookup_poison_ops = {
 
1233         .d_compare = xattr_lookup_poison,
 
1236 /* We need to take a copy of the mount flags since things like
 
1237  * MS_RDONLY don't get set until *after* we're called.
 
1238  * mount_flags != mount_options */
 
1239 int reiserfs_xattr_init(struct super_block *s, int mount_flags)
 
1243         /* We need generation numbers to ensure that the oid mapping is correct
 
1244          * v3.5 filesystems don't have them. */
 
1245         if (!old_format_only(s)) {
 
1246                 set_bit(REISERFS_XATTRS, &(REISERFS_SB(s)->s_mount_opt));
 
1247         } else if (reiserfs_xattrs_optional(s)) {
 
1248                 /* Old format filesystem, but optional xattrs have been enabled
 
1249                  * at mount time. Error out. */
 
1250                 reiserfs_warning(s, "xattrs/ACLs not supported on pre v3.6 "
 
1251                                  "format filesystem. Failing mount.");
 
1255                 /* Old format filesystem, but no optional xattrs have been enabled. This
 
1256                  * means we silently disable xattrs on the filesystem. */
 
1257                 clear_bit(REISERFS_XATTRS, &(REISERFS_SB(s)->s_mount_opt));
 
1260         /* If we don't have the privroot located yet - go find it */
 
1261         if (reiserfs_xattrs(s) && !REISERFS_SB(s)->priv_root) {
 
1262                 struct dentry *dentry;
 
1263                 dentry = lookup_one_len(PRIVROOT_NAME, s->s_root,
 
1264                                         strlen(PRIVROOT_NAME));
 
1265                 if (!IS_ERR(dentry)) {
 
1266                         if (!(mount_flags & MS_RDONLY) && !dentry->d_inode) {
 
1267                                 struct inode *inode = dentry->d_parent->d_inode;
 
1268                                 mutex_lock(&inode->i_mutex);
 
1269                                 err = inode->i_op->mkdir(inode, dentry, 0700);
 
1270                                 mutex_unlock(&inode->i_mutex);
 
1276                                 if (dentry && dentry->d_inode)
 
1278                                                          "Created %s on %s - reserved for "
 
1283                         } else if (!dentry->d_inode) {
 
1288                         err = PTR_ERR(dentry);
 
1290                 if (!err && dentry) {
 
1291                         s->s_root->d_op = &xattr_lookup_poison_ops;
 
1292                         reiserfs_mark_inode_private(dentry->d_inode);
 
1293                         REISERFS_SB(s)->priv_root = dentry;
 
1294                 } else if (!(mount_flags & MS_RDONLY)) {        /* xattrs are unavailable */
 
1295                         /* If we're read-only it just means that the dir hasn't been
 
1296                          * created. Not an error -- just no xattrs on the fs. We'll
 
1297                          * check again if we go read-write */
 
1298                         reiserfs_warning(s, "xattrs/ACLs enabled and couldn't "
 
1299                                          "find/create .reiserfs_priv. Failing mount.");
 
1305         /* This is only nonzero if there was an error initializing the xattr
 
1306          * directory or if there is a condition where we don't support them. */
 
1308                 clear_bit(REISERFS_XATTRS, &(REISERFS_SB(s)->s_mount_opt));
 
1309                 clear_bit(REISERFS_XATTRS_USER, &(REISERFS_SB(s)->s_mount_opt));
 
1310                 clear_bit(REISERFS_POSIXACL, &(REISERFS_SB(s)->s_mount_opt));
 
1313         /* The super_block MS_POSIXACL must mirror the (no)acl mount option. */
 
1314         s->s_flags = s->s_flags & ~MS_POSIXACL;
 
1315         if (reiserfs_posixacl(s))
 
1316                 s->s_flags |= MS_POSIXACL;
 
1321 static int reiserfs_check_acl(struct inode *inode, int mask)
 
1323         struct posix_acl *acl;
 
1324         int error = -EAGAIN; /* do regular unix permission checks by default */
 
1326         reiserfs_read_lock_xattr_i(inode);
 
1327         reiserfs_read_lock_xattrs(inode->i_sb);
 
1329         acl = reiserfs_get_acl(inode, ACL_TYPE_ACCESS);
 
1331         reiserfs_read_unlock_xattrs(inode->i_sb);
 
1332         reiserfs_read_unlock_xattr_i(inode);
 
1336                         error = posix_acl_permission(inode, acl, mask);
 
1337                         posix_acl_release(acl);
 
1338                 } else if (PTR_ERR(acl) != -ENODATA)
 
1339                         error = PTR_ERR(acl);
 
1345 int reiserfs_permission(struct inode *inode, int mask, struct nameidata *nd)
 
1348          * We don't do permission checks on the internal objects.
 
1349          * Permissions are determined by the "owning" object.
 
1351         if (is_reiserfs_priv_object(inode))
 
1355          * Stat data v1 doesn't support ACLs.
 
1357         if (get_inode_sd_version(inode) == STAT_DATA_V1)
 
1358                 return generic_permission(inode, mask, NULL);
 
1360                 return generic_permission(inode, mask, reiserfs_check_acl);