diff --git a/WHATS_NEW b/WHATS_NEW index 2672e039f..68a708a21 100644 --- a/WHATS_NEW +++ b/WHATS_NEW @@ -1,5 +1,6 @@ Version 2.02.80 - ==================================== + Speedup command processing by caching resolved config tree. Pass config_tree to renamed function import_vg_from_config_tree(). Detect NULL handle in get_property(). Fix superfluous /usr in ocf_scriptdir instalation path. diff --git a/lib/cache/lvmcache.c b/lib/cache/lvmcache.c index ebd6d4444..0e9cae194 100644 --- a/lib/cache/lvmcache.c +++ b/lib/cache/lvmcache.c @@ -83,6 +83,12 @@ static void _free_cached_vgmetadata(struct lvmcache_vginfo *vginfo) vginfo->vgmetadata = NULL; + /* Release also cached config tree */ + if (vginfo->cft) { + destroy_config_tree(vginfo->cft); + vginfo->cft = NULL; + } + log_debug("Metadata cache: VG %s wiped.", vginfo->vgname); } @@ -651,7 +657,9 @@ struct volume_group *lvmcache_get_vg(const char *vgid, unsigned precommitted) vgid, NULL))) return_NULL; - if (!(vginfo->cft = + /* Build config tree from vgmetadata, if not yet cached */ + if (!vginfo->cft && + !(vginfo->cft = create_config_tree_from_string(fid->fmt->cmd, vginfo->vgmetadata))) { _free_cached_vgmetadata(vginfo); @@ -660,10 +668,8 @@ struct volume_group *lvmcache_get_vg(const char *vgid, unsigned precommitted) if (!(vg = import_vg_from_config_tree(vginfo->cft, fid))) { _free_cached_vgmetadata(vginfo); - destroy_config_tree(vginfo->cft); return_NULL; } - destroy_config_tree(vginfo->cft); log_debug("Using cached %smetadata for VG %s.", vginfo->precommitted ? "pre-committed" : "", vginfo->vgname); diff --git a/lib/cache/lvmcache.h b/lib/cache/lvmcache.h index 8c07a26f4..080f3b5ee 100644 --- a/lib/cache/lvmcache.h +++ b/lib/cache/lvmcache.h @@ -48,6 +48,7 @@ struct lvmcache_vginfo { char *creation_host; char *vgmetadata; /* Copy of VG metadata as format_text string */ struct config_tree *cft; /* Config tree created from vgmetadata */ + /* Lifetime is directly tied to vgmetadata */ unsigned precommitted; /* Is vgmetadata live or precommitted? */ };