3 #include <linux/file.h>
 
   4 #include <linux/module.h>
 
   5 #include <linux/smp_lock.h>
 
   6 #include <linux/namei.h>
 
   8 struct export_operations export_op_default;
 
  10 #define CALL(ops,fun) ((ops->fun)?(ops->fun):export_op_default.fun)
 
  12 #define dprintk(fmt, args...) do{}while(0)
 
  14 static struct dentry *
 
  15 find_acceptable_alias(struct dentry *result,
 
  16                 int (*acceptable)(void *context, struct dentry *dentry),
 
  19         struct dentry *dentry, *toput = NULL;
 
  21         spin_lock(&dcache_lock);
 
  22         list_for_each_entry(dentry, &result->d_inode->i_dentry, d_alias) {
 
  24                 spin_unlock(&dcache_lock);
 
  27                 if (dentry != result && acceptable(context, dentry)) {
 
  31                 spin_lock(&dcache_lock);
 
  34         spin_unlock(&dcache_lock);
 
  42  * find_exported_dentry - helper routine to implement export_operations->decode_fh
 
  43  * @sb:         The &super_block identifying the filesystem
 
  44  * @obj:        An opaque identifier of the object to be found - passed to
 
  46  * @parent:     An optional opqaue identifier of the parent of the object.
 
  47  * @acceptable: A function used to test possible &dentries to see if they are
 
  49  * @context:    A parameter to @acceptable so that it knows on what basis to
 
  52  * find_exported_dentry is the central helper routine to enable file systems
 
  53  * to provide the decode_fh() export_operation.  It's main task is to take
 
  54  * an &inode, find or create an appropriate &dentry structure, and possibly
 
  55  * splice this into the dcache in the correct place.
 
  57  * The decode_fh() operation provided by the filesystem should call
 
  58  * find_exported_dentry() with the same parameters that it received except
 
  59  * that instead of the file handle fragment, pointers to opaque identifiers
 
  60  * for the object and optionally its parent are passed.  The default decode_fh
 
  61  * routine passes one pointer to the start of the filehandle fragment, and
 
  62  * one 8 bytes into the fragment.  It is expected that most filesystems will
 
  63  * take this approach, though the offset to the parent identifier may well be
 
  66  * find_exported_dentry() will call get_dentry to get an dentry pointer from
 
  67  * the file system.  If any &dentry in the d_alias list is acceptable, it will
 
  68  * be returned.  Otherwise find_exported_dentry() will attempt to splice a new
 
  69  * &dentry into the dcache using get_name() and get_parent() to find the
 
  74 find_exported_dentry(struct super_block *sb, void *obj, void *parent,
 
  75                      int (*acceptable)(void *context, struct dentry *de),
 
  78         struct dentry *result = NULL;
 
  79         struct dentry *target_dir;
 
  81         struct export_operations *nops = sb->s_export_op;
 
  84         char nbuf[NAME_MAX+1];
 
  87          * Attempt to find the inode.
 
  89         result = CALL(sb->s_export_op,get_dentry)(sb,obj);
 
  94                 err = PTR_ERR(result);
 
  97         if (S_ISDIR(result->d_inode->i_mode) &&
 
  98             (result->d_flags & DCACHE_DISCONNECTED)) {
 
  99                 /* it is an unconnected directory, we must connect it */
 
 102                 if (acceptable(context, result))
 
 104                 if (S_ISDIR(result->d_inode->i_mode)) {
 
 109                 alias = find_acceptable_alias(result, acceptable, context);
 
 114         /* It's a directory, or we are required to confirm the file's
 
 115          * location in the tree based on the parent information
 
 117         dprintk("find_exported_dentry: need to look harder for %s/%d\n",sb->s_id,*(int*)obj);
 
 118         if (S_ISDIR(result->d_inode->i_mode))
 
 119                 target_dir = dget(result);
 
 124                 target_dir = CALL(sb->s_export_op,get_dentry)(sb,parent);
 
 125                 if (IS_ERR(target_dir))
 
 126                         err = PTR_ERR(target_dir);
 
 127                 if (target_dir == NULL || IS_ERR(target_dir))
 
 131          * Now we need to make sure that target_dir is properly connected.
 
 132          * It may already be, as the flag isn't always updated when connection
 
 134          * So, we walk up parent links until we find a connected directory,
 
 135          * or we run out of directories.  Then we find the parent, find
 
 136          * the name of the child in that parent, and do a lookup.
 
 137          * This should connect the child into the parent
 
 141         /* it is possible that a confused file system might not let us complete 
 
 142          * the path to the root.  For example, if get_parent returns a directory
 
 143          * in which we cannot find a name for the child.  While this implies a
 
 144          * very sick filesystem we don't want it to cause knfsd to spin.  Hence
 
 145          * the noprogress counter.  If we go through the loop 10 times (2 is
 
 146          * probably enough) without getting anywhere, we just give up
 
 149         while (target_dir->d_flags & DCACHE_DISCONNECTED && noprogress++ < 10) {
 
 150                 struct dentry *pd = target_dir;
 
 153                 spin_lock(&pd->d_lock);
 
 154                 while (!IS_ROOT(pd) &&
 
 155                                 (pd->d_parent->d_flags&DCACHE_DISCONNECTED)) {
 
 156                         struct dentry *parent = pd->d_parent;
 
 159                         spin_unlock(&pd->d_lock);
 
 162                         spin_lock(&pd->d_lock);
 
 164                 spin_unlock(&pd->d_lock);
 
 167                         /* must have found a connected parent - great */
 
 168                         spin_lock(&pd->d_lock);
 
 169                         pd->d_flags &= ~DCACHE_DISCONNECTED;
 
 170                         spin_unlock(&pd->d_lock);
 
 172                 } else if (pd == sb->s_root) {
 
 173                         printk(KERN_ERR "export: Eeek filesystem root is not connected, impossible\n");
 
 174                         spin_lock(&pd->d_lock);
 
 175                         pd->d_flags &= ~DCACHE_DISCONNECTED;
 
 176                         spin_unlock(&pd->d_lock);
 
 179                         /* we have hit the top of a disconnected path.  Try
 
 180                          * to find parent and connect
 
 181                          * note: racing with some other process renaming a
 
 182                          * directory isn't much of a problem here.  If someone
 
 183                          * renames the directory, it will end up properly
 
 184                          * connected, which is what we want
 
 189                         mutex_lock(&pd->d_inode->i_mutex);
 
 190                         ppd = CALL(nops,get_parent)(pd);
 
 191                         mutex_unlock(&pd->d_inode->i_mutex);
 
 195                                 dprintk("find_exported_dentry: get_parent of %ld failed, err %d\n",
 
 196                                         pd->d_inode->i_ino, err);
 
 200                         dprintk("find_exported_dentry: find name of %lu in %lu\n", pd->d_inode->i_ino, ppd->d_inode->i_ino);
 
 201                         err = CALL(nops,get_name)(ppd, nbuf, pd);
 
 206                                         /* some race between get_parent and
 
 207                                          * get_name?  just try again
 
 212                         dprintk("find_exported_dentry: found name: %s\n", nbuf);
 
 213                         mutex_lock(&ppd->d_inode->i_mutex);
 
 214                         npd = lookup_one_len(nbuf, ppd, strlen(nbuf));
 
 215                         mutex_unlock(&ppd->d_inode->i_mutex);
 
 218                                 dprintk("find_exported_dentry: lookup failed: %d\n", err);
 
 223                         /* we didn't really want npd, we really wanted
 
 224                          * a side-effect of the lookup.
 
 225                          * hopefully, npd == pd, though it isn't really
 
 226                          * a problem if it isn't
 
 231                                 printk("find_exported_dentry: npd != pd\n");
 
 235                                 /* something went wrong, we have to give up */
 
 243         if (target_dir->d_flags & DCACHE_DISCONNECTED) {
 
 244                 /* something went wrong - oh-well */
 
 249         /* if we weren't after a directory, have one more step to go */
 
 250         if (result != target_dir) {
 
 251                 struct dentry *nresult;
 
 252                 err = CALL(nops,get_name)(target_dir, nbuf, result);
 
 254                         mutex_lock(&target_dir->d_inode->i_mutex);
 
 255                         nresult = lookup_one_len(nbuf, target_dir, strlen(nbuf));
 
 256                         mutex_unlock(&target_dir->d_inode->i_mutex);
 
 257                         if (!IS_ERR(nresult)) {
 
 258                                 if (nresult->d_inode) {
 
 267         /* now result is properly connected, it is our best bet */
 
 268         if (acceptable(context, result))
 
 271         alias = find_acceptable_alias(result, acceptable, context);
 
 275         /* drat - I just cannot find anything acceptable */
 
 277         /* It might be justifiable to return ESTALE here,
 
 278          * but the filehandle at-least looks reasonable good
 
 279          * and it just be a permission problem, so returning
 
 282         return ERR_PTR(-EACCES);
 
 294 static struct dentry *get_parent(struct dentry *child)
 
 296         /* get_parent cannot be supported generically, the locking
 
 298          * instead, we just return EACCES.  If server reboots or inodes
 
 299          * get flushed, you lose
 
 301         return ERR_PTR(-EACCES);
 
 305 struct getdents_callback {
 
 306         char *name;             /* name that was found. It already points to a
 
 307                                    buffer NAME_MAX+1 is size */
 
 308         unsigned long ino;      /* the inum we are looking for */
 
 309         int found;              /* inode matched? */
 
 310         int sequence;           /* sequence counter */
 
 314  * A rather strange filldir function to capture
 
 315  * the name matching the specified inode number.
 
 317 static int filldir_one(void * __buf, const char * name, int len,
 
 318                         loff_t pos, ino_t ino, unsigned int d_type)
 
 320         struct getdents_callback *buf = __buf;
 
 324         if (buf->ino == ino) {
 
 325                 memcpy(buf->name, name, len);
 
 326                 buf->name[len] = '\0';
 
 334  * get_name - default export_operations->get_name function
 
 335  * @dentry: the directory in which to find a name
 
 336  * @name:   a pointer to a %NAME_MAX+1 char buffer to store the name
 
 337  * @child:  the dentry for the child directory.
 
 339  * calls readdir on the parent until it finds an entry with
 
 340  * the same inode number as the child, and returns that.
 
 342 static int get_name(struct dentry *dentry, char *name,
 
 343                         struct dentry *child)
 
 345         struct inode *dir = dentry->d_inode;
 
 348         struct getdents_callback buffer;
 
 351         if (!dir || !S_ISDIR(dir->i_mode))
 
 357          * Open the directory ...
 
 359         file = dentry_open(dget(dentry), NULL, O_RDONLY);
 
 360         error = PTR_ERR(file);
 
 365         if (!file->f_op->readdir)
 
 369         buffer.ino = child->d_inode->i_ino;
 
 373                 int old_seq = buffer.sequence;
 
 375                 error = vfs_readdir(file, filldir_one, &buffer);
 
 384                 if (old_seq == buffer.sequence)
 
 395 static struct dentry *export_iget(struct super_block *sb, unsigned long ino, __u32 generation)
 
 398         /* iget isn't really right if the inode is currently unallocated!!
 
 399          * This should really all be done inside each filesystem
 
 401          * ext2fs' read_inode has been strengthed to return a bad_inode if
 
 402          * the inode had been deleted.
 
 404          * Currently we don't know the generation for parent directory, so
 
 405          * a generation of 0 means "accept any"
 
 408         struct dentry *result;
 
 410                 return ERR_PTR(-ESTALE);
 
 411         inode = iget(sb, ino);
 
 413                 return ERR_PTR(-ENOMEM);
 
 414         if (is_bad_inode(inode)
 
 415             || (generation && inode->i_generation != generation)
 
 417                 /* we didn't find the right inode.. */
 
 418                 dprintk("fh_verify: Inode %lu, Bad count: %d %d or version  %u %u\n",
 
 420                         inode->i_nlink, atomic_read(&inode->i_count),
 
 425                 return ERR_PTR(-ESTALE);
 
 427         /* now to find a dentry.
 
 428          * If possible, get a well-connected one
 
 430         result = d_alloc_anon(inode);
 
 433                 return ERR_PTR(-ENOMEM);
 
 439 static struct dentry *get_object(struct super_block *sb, void *vobjp)
 
 442         unsigned long ino = objp[0];
 
 443         __u32 generation = objp[1];
 
 445         return export_iget(sb, ino, generation);
 
 450  * export_encode_fh - default export_operations->encode_fh function
 
 451  * @dentry:  the dentry to encode
 
 452  * @fh:      where to store the file handle fragment
 
 453  * @max_len: maximum length to store there
 
 454  * @connectable: whether to store parent information
 
 456  * This default encode_fh function assumes that the 32 inode number
 
 457  * is suitable for locating an inode, and that the generation number
 
 458  * can be used to check that it is still valid.  It places them in the
 
 459  * filehandle fragment where export_decode_fh expects to find them.
 
 461 static int export_encode_fh(struct dentry *dentry, __u32 *fh, int *max_len,
 
 464         struct inode * inode = dentry->d_inode;
 
 468         if (len < 2 || (connectable && len < 4))
 
 472         fh[0] = inode->i_ino;
 
 473         fh[1] = inode->i_generation;
 
 474         if (connectable && !S_ISDIR(inode->i_mode)) {
 
 475                 struct inode *parent;
 
 477                 spin_lock(&dentry->d_lock);
 
 478                 parent = dentry->d_parent->d_inode;
 
 479                 fh[2] = parent->i_ino;
 
 480                 fh[3] = parent->i_generation;
 
 481                 spin_unlock(&dentry->d_lock);
 
 491  * export_decode_fh - default export_operations->decode_fh function
 
 492  * @sb:  The superblock
 
 493  * @fh:  pointer to the file handle fragment
 
 494  * @fh_len: length of file handle fragment
 
 495  * @acceptable: function for testing acceptability of dentrys
 
 496  * @context:   context for @acceptable
 
 498  * This is the default decode_fh() function.
 
 499  * a fileid_type of 1 indicates that the filehandlefragment
 
 500  * just contains an object identifier understood by  get_dentry.
 
 501  * a fileid_type of 2 says that there is also a directory
 
 502  * identifier 8 bytes in to the filehandlefragement.
 
 504 static struct dentry *export_decode_fh(struct super_block *sb, __u32 *fh, int fh_len,
 
 506                          int (*acceptable)(void *context, struct dentry *de),
 
 510         parent[0] = parent[1] = 0;
 
 511         if (fh_len < 2 || fileid_type > 2)
 
 513         if (fileid_type == 2) {
 
 514                 if (fh_len > 2) parent[0] = fh[2];
 
 515                 if (fh_len > 3) parent[1] = fh[3];
 
 517         return find_exported_dentry(sb, fh, parent,
 
 518                                    acceptable, context);
 
 521 struct export_operations export_op_default = {
 
 522         .decode_fh      = export_decode_fh,
 
 523         .encode_fh      = export_encode_fh,
 
 525         .get_name       = get_name,
 
 526         .get_parent     = get_parent,
 
 527         .get_dentry     = get_object,
 
 530 EXPORT_SYMBOL(export_op_default);
 
 531 EXPORT_SYMBOL(find_exported_dentry);
 
 533 MODULE_LICENSE("GPL");