From: Kay Sievers Date: Sun, 28 Oct 2012 03:59:38 +0000 (+0100) Subject: libudev: hwdb - cleanup list before getting new properties X-Git-Tag: v196~194 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=9485d98d7741604c3d728edaed60b02ad63b71df;hp=23b7245397ac3d21b2386e7b33d9e4ae3db3c8a1;ds=sidebyside libudev: hwdb - cleanup list before getting new properties --- diff --git a/src/libudev/libudev-hwdb.c b/src/libudev/libudev-hwdb.c index a3f815f83..8fe24a432 100644 --- a/src/libudev/libudev-hwdb.c +++ b/src/libudev/libudev-hwdb.c @@ -338,10 +338,10 @@ _public_ struct udev_hwdb *udev_hwdb_unref(struct udev_hwdb *hwdb) { hwdb->refcount--; if (hwdb->refcount > 0) return hwdb; - if (hwdb->f) - fclose(hwdb->f); if (hwdb->map) munmap((void *)hwdb->map, hwdb->st.st_size); + if (hwdb->f) + fclose(hwdb->f); udev_list_cleanup(&hwdb->properties_list); free(hwdb); return NULL; @@ -382,6 +382,7 @@ _public_ struct udev_list_entry *udev_hwdb_get_properties_list_entry(struct udev return NULL; } + udev_list_cleanup(&hwdb->properties_list); err = trie_search_f(hwdb, modalias); if (err < 0) { errno = -err;