diff options
Diffstat (limited to 'libglusterfs')
| -rw-r--r-- | libglusterfs/src/inode.c | 7 | ||||
| -rw-r--r-- | libglusterfs/src/inode.h | 2 | 
2 files changed, 8 insertions, 1 deletions
diff --git a/libglusterfs/src/inode.c b/libglusterfs/src/inode.c index 6b29749e933..b8f1539b2f4 100644 --- a/libglusterfs/src/inode.c +++ b/libglusterfs/src/inode.c @@ -132,6 +132,7 @@ __dentry_unset (dentry_t *dentry)          __dentry_unhash (dentry);          list_del_init (&dentry->inode_list); +        list_del_init (&dentry->parent_list);          GF_FREE (dentry->name);          dentry->name = NULL; @@ -141,6 +142,7 @@ __dentry_unset (dentry_t *dentry)                  dentry->parent = NULL;          } +        dentry->inode = NULL;          mem_put (dentry);  } @@ -604,6 +606,7 @@ __dentry_create (inode_t *inode, inode_t *parent, const char *name)          INIT_LIST_HEAD (&newd->inode_list);          INIT_LIST_HEAD (&newd->hash); +        INIT_LIST_HEAD (&newd->parent_list);          newd->name = gf_strdup (name);          if (newd->name == NULL) { @@ -616,8 +619,9 @@ __dentry_create (inode_t *inode, inode_t *parent, const char *name)                  newd->parent = __inode_ref (parent);          list_add (&newd->inode_list, &inode->dentry_list); -        newd->inode = inode; +        list_add (&newd->parent_list, &parent->children); +        newd->inode = inode;  out:          return newd;  } @@ -648,6 +652,7 @@ __inode_create (inode_table_t *table)          INIT_LIST_HEAD (&newi->list);          INIT_LIST_HEAD (&newi->hash);          INIT_LIST_HEAD (&newi->dentry_list); +        INIT_LIST_HEAD (&newi->children);          newi->_ctx = GF_CALLOC (1,                                  (sizeof (struct _inode_ctx) * table->ctxcount), diff --git a/libglusterfs/src/inode.h b/libglusterfs/src/inode.h index 658477700c0..96f67c05629 100644 --- a/libglusterfs/src/inode.h +++ b/libglusterfs/src/inode.h @@ -60,6 +60,7 @@ struct _inode_table {  struct _dentry {          struct list_head   inode_list;   /* list of dentries of inode */          struct list_head   hash;         /* hash table pointers */ +        struct list_head   parent_list;  /* list of parent's children */          inode_t           *inode;        /* inode of this directory entry */          char              *name;         /* name of the directory entry */          inode_t           *parent;       /* directory of the entry */ @@ -99,6 +100,7 @@ struct _inode {          struct list_head     dentry_list;   /* list of directory entries for this inode */          struct list_head     hash;          /* hash table pointers */          struct list_head     list;          /* active/lru/purge */ +        struct list_head     children;      /* list of children */          struct _inode_ctx   *_ctx;    /* replacement for dict_t *(inode->ctx) */  };  | 
