From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 6725 invoked by alias); 21 Aug 2009 21:19:41 -0000 Received: (qmail 6638 invoked by alias); 21 Aug 2009 21:19:40 -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: RHEL55 - 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/RHEL55 X-Git-Reftype: branch X-Git-Oldrev: 9b060401c0c58405e9d6bfecb57acbfaeb717080 X-Git-Newrev: 93873dac8ab08f63700d76abe61d70693548323e From: Lon Hohberger Message-Id: <20090821211913.05E3C120231@lists.fedorahosted.org> Date: Fri, 21 Aug 2009 21:19:00 -0000 X-Scanned-By: MIMEDefang 2.67 on 10.5.11.18 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/msg00236.txt.bz2 Gitweb: http://git.fedorahosted.org/git/cluster.git?p=cluster.git;a=commitdiff;h=93873dac8ab08f63700d76abe61d70693548323e Commit: 93873dac8ab08f63700d76abe61d70693548323e Parent: 9b060401c0c58405e9d6bfecb57acbfaeb717080 Author: Lon Hohberger AuthorDate: Fri Jul 31 15:41:58 2009 -0400 Committer: Lon Hohberger CommitterDate: Fri Aug 21 17:16:54 2009 -0400 rgmanager: Preserve incarnations across config changes Resolves: rhbz506094 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 */