[Date Prev][Date Next] [Chronological] [Thread] [Top]

Re: (ITS#8782) Memory leak in ldap_cancel



cheimes@redhat.com wrote:
> Full_Name: Christian Heimes
> Version: 2.4.45
> OS: Fedora
> URL: ftp://ftp.openldap.org/incoming/
> Submission from: (NULL) (2001:16b8:6097:b200:c324:8c3d:7869:1a1b)
> 
> 
> While I was looking for memory leaks in python-ldap, Valgrind detected a memory
> leak in ldap_cancel:

Thanks for the report. Fixed now in master.
> 
> ==30178== 22 (16 direct, 6 indirect) bytes in 1 blocks are definitely lost in
> loss record 27 of 5,810
> ==30178==    at 0x4C2FB6B: malloc (vg_replace_malloc.c:299)
> ==30178==    by 0x14CBD9E4: ber_memalloc_x (memory.c:228)
> ==30178==    by 0x14CBC940: ber_flatten (io.c:437)
> ==30178==    by 0x14A81733: ldap_cancel (cancel.c:50)
> ==30178==    by 0x1485A3BA: l_ldap_cancel (LDAPObject.c:779)
> ==30178==    by 0x4FC24EF: PyCFunction_Call (in
> /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4FF891C: _PyEval_EvalFrameDefault (in
> /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4F590B2: ??? (in /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4F8BE10: ??? (in /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4FC933D: ??? (in /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4FF2EC9: _PyEval_EvalFrameDefault (in
> /usr/lib64/libpython3.6m.so.1.0)
> ==30178==    by 0x4F590B2: ??? (in /usr/lib64/libpython3.6m.so.1.0)
> 
> I think the function is missing a call to ber_bvfree(cancelidvalp).
> 
> python-ldap issue: https://github.com/python-ldap/python-ldap/issues/82
> Code: https://github.com/openldap/openldap/blob/master/libraries/libldap/cancel.c#L43-L55
> 
> 


-- 
   -- Howard Chu
   CTO, Symas Corp.           http://www.symas.com
   Director, Highland Sun     http://highlandsun.com/hyc/
   Chief Architect, OpenLDAP  http://www.openldap.org/project/