From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 11066 invoked by alias); 12 Aug 2009 14:47:28 -0000 Received: (qmail 10982 invoked by alias); 12 Aug 2009 14:47:26 -0000 X-SWARE-Spam-Status: No, hits=-2.1 required=5.0 tests=AWL,BAYES_00,SPF_HELO_PASS X-Spam-Status: No, hits=-2.1 required=5.0 tests=AWL,BAYES_00,SPF_HELO_PASS X-Spam-Check-By: sourceware.org X-Spam-Checker-Version: SpamAssassin 3.2.5 (2008-06-10) on bastion2.fedora.phx.redhat.com Subject: cluster: RHEL5 - rgmanager: Preserve incarnations across config changes To: cluster-cvs-relay@redhat.com X-Project: Cluster Project X-Git-Module: cluster.git X-Git-Refname: refs/heads/RHEL5 X-Git-Reftype: branch X-Git-Oldrev: 12943f45b4e01d440f59c1797d55a147dffe1eae X-Git-Newrev: 48ea9c79b17f5fd98ab07fb2dc219ffee00bfc89 From: Lon Hohberger Message-Id: <20090812144650.E431E1201E6@lists.fedorahosted.org> Date: Wed, 12 Aug 2009 14:47:00 -0000 X-Scanned-By: MIMEDefang 2.58 on 172.16.52.254 Mailing-List: contact cluster-cvs-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Post: List-Help: , Sender: cluster-cvs-owner@sourceware.org X-SW-Source: 2009-q3/txt/msg00194.txt.bz2 Gitweb: http://git.fedorahosted.org/git/cluster.git?p=cluster.git;a=commitdiff;h=48ea9c79b17f5fd98ab07fb2dc219ffee00bfc89 Commit: 48ea9c79b17f5fd98ab07fb2dc219ffee00bfc89 Parent: 12943f45b4e01d440f59c1797d55a147dffe1eae Author: Lon Hohberger AuthorDate: Fri Jul 31 15:41:58 2009 -0400 Committer: Lon Hohberger CommitterDate: Wed Aug 12 10:46:24 2009 -0400 rgmanager: Preserve incarnations across config changes Red Hat Bugzilla #506094, part 2/3 Signed-off-by: Lon Hohberger --- rgmanager/src/daemons/groups.c | 27 +++++++++++++++++++++++++++ 1 files changed, 27 insertions(+), 0 deletions(-) diff --git a/rgmanager/src/daemons/groups.c b/rgmanager/src/daemons/groups.c index 94fa303..377d2ed 100644 --- a/rgmanager/src/daemons/groups.c +++ b/rgmanager/src/daemons/groups.c @@ -1618,6 +1618,31 @@ dump_config_version(FILE *fp) /** + Copy out the incarnations after doing CONDSTOPs + */ +static int +copy_incarnations(resource_t **leftres, resource_t **rightres) +{ + resource_t *lc, *rc; + int ret; + + list_do(leftres, lc) { + rc = find_resource_by_ref(rightres, lc->r_rule->rr_type, + primary_attr_value(lc)); + /* Resource does not exist */ + if (!rc) + continue; + + /* Ok, see if the resource is the same */ + if (!rescmp(lc, rc)) + rc->r_incarnations = lc->r_incarnations; + } while (!list_done(leftres, lc)); + + return 0; +} + + +/** Initialize resource groups. This reads all the resource groups from CCS, builds the tree, etc. Ideally, we'll have a similar function performing deltas on the two trees so that we can fully support online @@ -1744,6 +1769,8 @@ init_resource_groups(int reconfigure, int do_init, int new_config_version) pthread_rwlock_unlock(&resource_lock); do_condstops(); + + copy_incarnations(&_resources, &reslist); } /* Swap in the new configuration */