[Bugs] [Bug 1595524] New: rmdir is leaking softlinks to directories in .glusterfs

bugzilla at redhat.com bugzilla at redhat.com
Wed Jun 27 04:53:36 UTC 2018


https://bugzilla.redhat.com/show_bug.cgi?id=1595524

            Bug ID: 1595524
           Summary: rmdir is leaking softlinks to directories in
                    .glusterfs
           Product: GlusterFS
           Version: 4.1
         Component: posix
          Assignee: bugs at gluster.org
          Reporter: pkarampu at redhat.com
                CC: bugs at gluster.org
        Depends On: 1595190



+++ This bug was initially created as a clone of Bug #1595190 +++

Description of problem:
storage/posix: Fix posix_symlinks_match()

1) snprintf into linkname_expected should happen with PATH_MAX
2) comparison should happen with linkname_actual with string linkname_expected

114    posix_symlinks_match (xlator_t *this, loc_t *loc, uuid_t gfid)
115    {
116            struct posix_private *priv = NULL;
117            char linkname_actual[PATH_MAX] = {0,};
118            char linkname_expected[PATH_MAX] = {0};
119            char *dir_handle = NULL;
(gdb) 
120            size_t len = 0;
121            size_t handle_size = 0;
122            gf_boolean_t ret = _gf_false;
123    
124            priv = this->private;
125            handle_size = POSIX_GFID_HANDLE_SIZE(priv->base_path_length);
126            dir_handle = alloca0 (handle_size);
127    
128            snprintf (linkname_expected, handle_size,
"../../%02x/%02x/%s/%s",

<<<<<<<<< s/handle_size/PATH_MAX

129                      loc->pargfid[0], loc->pargfid[1], uuid_utoa
(loc->pargfid),
(gdb) 
130                      loc->name);
131    
132            MAKE_HANDLE_GFID_PATH (dir_handle, this, gfid, NULL);
133            len = sys_readlink (dir_handle, linkname_actual, PATH_MAX);
134            if (len < 0)
135                    goto out;
136            linkname_actual[len] = '\0';
137    
138            if (!strncmp (linkname_actual, linkname_expected, handle_size))
139                    ret = _gf_true;
(gdb) p handle_size
$12 = 77
(gdb) q
A debugging session is active.

(gdb) p linkname_actual 
$9 =
"../../78/2f/782f8b99-a965-4b32-95ff-b698fdb0a08e/_gqac023.sbu.lab.eng.bos.redhat.com_00_1_.d",
'\000' <repeats 4003 times>
(gdb) p linkname_expected 
$10 =
"../../78/2f/782f8b99-a965-4b32-95ff-b698fdb0a08e/_gqac023.sbu.lab.eng.bos.re",
'\000' <repeats 4019 times>


Version-Release number of selected component (if applicable):


How reproducible:


Steps to Reproduce:
1.
2.
3.

Actual results:


Expected results:


Additional info:

--- Additional comment from Worker Ant on 2018-06-26 08:20:45 EDT ---

REVIEW: https://review.gluster.org/20392 (storage/posix: Fix
posix_symlinks_match()) posted (#1) for review on master by Pranith Kumar
Karampuri

--- Additional comment from Worker Ant on 2018-06-26 23:21:51 EDT ---

COMMIT: https://review.gluster.org/20392 committed in master by "Pranith Kumar
Karampuri" <pkarampu at redhat.com> with a commit message- storage/posix: Fix
posix_symlinks_match()

1) snprintf into linkname_expected should happen with PATH_MAX
2) comparison should happen with linkname_actual with complete
   string linkname_expected

fixes bz#1595190
Change-Id: Ic3b3c362dc6c69c046b9a13e031989be47ecff14
Signed-off-by: Pranith Kumar K <pkarampu at redhat.com>


Referenced Bugs:

https://bugzilla.redhat.com/show_bug.cgi?id=1595190
[Bug 1595190] rmdir is leaking softlinks to directories in .glusterfs
-- 
You are receiving this mail because:
You are on the CC list for the bug.
You are the assignee for the bug.


More information about the Bugs mailing list