diff options
| author | Anand V. Avati <avati@gluster.com> | 2009-03-26 17:29:52 +0530 | 
|---|---|---|
| committer | Anand V. Avati <avati@amp.gluster.com> | 2009-03-26 23:40:36 +0530 | 
| commit | 6c28cb81b2a326a416968932919ea9d19f3b56ab (patch) | |
| tree | 5372159ae39ac1d2cd4a88a7de3caf1217d2a7fd /libglusterfs/src/inode.c | |
| parent | 675e8b4a1f07668a6145c16283b68daa165a7a0c (diff) | |
fix duplicate setting of values in inode->ctx and fd->ctx
this patch avoids setting of duplicate key/value pairs in the context.
note that consumers have to explicitly check for previous existance of key
to avoid any kind of resource leak resulting from this overwrite.
Signed-off-by: Anand V. Avati <avati@amp.gluster.com>
Diffstat (limited to 'libglusterfs/src/inode.c')
| -rw-r--r-- | libglusterfs/src/inode.c | 18 | 
1 files changed, 13 insertions, 5 deletions
diff --git a/libglusterfs/src/inode.c b/libglusterfs/src/inode.c index c62d7ca9e7c..90a84f95561 100644 --- a/libglusterfs/src/inode.c +++ b/libglusterfs/src/inode.c @@ -1109,20 +1109,28 @@ __inode_ctx_put (inode_t *inode, xlator_t *xlator, uint64_t value)  {          int ret = 0;          int index = 0; +        int put_idx = -1;          for (index = 0; index < xlator->ctx->xl_count; index++) { -                if (!inode->_ctx[index].key ||  -                    (inode->_ctx[index].key == (uint64_t)(long)xlator)) +                if (!inode->_ctx[index].key) { +                        if (put_idx == -1) +                                put_idx = index; +                        /* dont break, to check if key already exists +                           further on */ +                } +                if (inode->_ctx[index].key == (uint64_t)(long) xlator) { +                        put_idx = index;                          break; +                }          } -        if (index == xlator->ctx->xl_count) { +        if (put_idx == -1) {                  ret = -1;                  goto out;;          } -        inode->_ctx[index].key   = (uint64_t)(long) xlator; -        inode->_ctx[index].value = value; +        inode->_ctx[put_idx].key   = (uint64_t)(long) xlator; +        inode->_ctx[put_idx].value = value;  out:          return ret;  }  | 
