[PATCH 1/2] sync: kill evil and syncv1 in one shot

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]




From: "Fabio M. Di Nitto" <fdinitto@xxxxxxxxxx>

this change breaks onwire compatibility.

cpg is the only user of sync_* interface and it's the only
service that will require extra testing.

Signed-off-by: Fabio M. Di Nitto <fdinitto@xxxxxxxxxx>
---
 exec/Makefile.am            |    8 +-
 exec/apidef.c               |    1 -
 exec/cfg.c                  |    3 +-
 exec/cpg.c                  |    7 +-
 exec/evil.c                 |  540 -------------------------------
 exec/evil.h                 |   55 ----
 exec/evs.c                  |    3 +-
 exec/ipc_glue.c             |   43 ---
 exec/main.c                 |  111 +------
 exec/mainconfig.c           |   31 --
 exec/mainconfig.h           |    4 -
 exec/mon.c                  |    3 +-
 exec/pload.c                |    3 +-
 exec/quorum.c               |    1 -
 exec/sync.c                 |  744 +++++++++++++++++++++++++------------------
 exec/sync.h                 |   45 +--
 exec/syncv2.c               |  623 ------------------------------------
 exec/syncv2.h               |   62 ----
 exec/util.c                 |   15 +-
 exec/votequorum.c           |    3 +-
 exec/vsf_quorum.c           |    3 +-
 exec/wd.c                   |    3 +-
 include/corosync/coroapi.h  |   19 +-
 include/corosync/corodefs.h |   30 +--
 man/corosync.conf.5         |   12 -
 25 files changed, 496 insertions(+), 1876 deletions(-)
 delete mode 100644 exec/evil.c
 delete mode 100644 exec/evil.h
 delete mode 100644 exec/syncv2.c
 delete mode 100644 exec/syncv2.h

diff --git a/exec/Makefile.am b/exec/Makefile.am
index 07a77c5..2e33033 100644
--- a/exec/Makefile.am
+++ b/exec/Makefile.am
@@ -47,10 +47,10 @@ sbin_PROGRAMS		= corosync
 
 libtotem_pg_a_SOURCES	= $(TOTEM_SRC)
 
-corosync_SOURCES	= evil.c vsf_ykd.c coroparse.c vsf_quorum.c syncv2.c \
+corosync_SOURCES	= vsf_ykd.c coroparse.c vsf_quorum.c sync.c \
 			  logsys.c cfg.c cmap.c cpg.c evs.c mon.c pload.c \
 			  votequorum.c wd.c util.c schedwrk.c main.c \
-			  apidef.c quorum.c sync.c icmap.c timer.c \
+			  apidef.c quorum.c icmap.c timer.c \
 			  ipc_glue.c service.c mainconfig.c totemconfig.c
 corosync_LDADD		= -ltotem_pg -lcorosync_common $(LIBQB_LIBS) $(statgrab_LIBS)
 corosync_DEPENDENCIES	= libtotem_pg.so.$(SONAME) ../common_lib/libcorosync_common.so
@@ -64,10 +64,10 @@ SHARED_LIBS_SO		= $(SHARED_LIBS:%.so.$(SONAME)=%.so)
 SHARED_LIBS_SO_TWO	= $(SHARED_LIBS:%.so.$(SONAME)=%.so.$(SOMAJOR))
 
 noinst_HEADERS		= apidef.h crypto.h mainconfig.h main.h \
-			  quorum.h service.h sync.h timer.h totemconfig.h \
+			  quorum.h service.h timer.h totemconfig.h \
 			  totemmrp.h totemnet.h totemudp.h totemiba.h totemrrp.h \
 			  totemudpu.h totemsrp.h util.h vsf.h schedwrk.h \
-			  evil.h syncv2.h fsm.h votequorum.h vsf_ykd.h
+			  sync.h fsm.h votequorum.h vsf_ykd.h
 
 if BUILD_DARWIN
 libtotem_pg.so.$(SONAME): $(TOTEM_OBJS)
diff --git a/exec/apidef.c b/exec/apidef.c
index bc3a559..d48cbcb 100644
--- a/exec/apidef.c
+++ b/exec/apidef.c
@@ -48,7 +48,6 @@
 #include <corosync/logsys.h>
 #include "util.h"
 #include "timer.h"
-#include "sync.h"
 #include "quorum.h"
 #include "schedwrk.h"
 #include "main.h"
diff --git a/exec/cfg.c b/exec/cfg.c
index 29ea8bb..659bd99 100644
--- a/exec/cfg.c
+++ b/exec/cfg.c
@@ -234,8 +234,7 @@ struct corosync_service_engine cfg_service_engine = {
 	.exec_init_fn				= cfg_exec_init_fn,
 	.exec_engine				= cfg_exec_engine,
 	.exec_engine_count			= sizeof (cfg_exec_engine) / sizeof (struct corosync_exec_handler),
-	.confchg_fn				= cfg_confchg_fn,
-	.sync_mode				= CS_SYNC_V1
+	.confchg_fn				= cfg_confchg_fn
 };
 
 struct corosync_service_engine *cfg_get_service_engine_ver0 (void)
diff --git a/exec/cpg.c b/exec/cpg.c
index bf8692b..da60d80 100644
--- a/exec/cpg.c
+++ b/exec/cpg.c
@@ -285,7 +285,7 @@ static void downlist_messages_delete (void);
 
 static void downlist_master_choose_and_send (void);
 
-static void cpg_sync_init_v2 (
+static void cpg_sync_init (
 	const unsigned int *trans_list,
 	size_t trans_list_entries,
 	const unsigned int *member_list,
@@ -406,8 +406,7 @@ struct corosync_service_engine cpg_service_engine = {
 	.exec_dump_fn				= NULL,
 	.exec_engine				= cpg_exec_engine,
 	.exec_engine_count		        = sizeof (cpg_exec_engine) / sizeof (struct corosync_exec_handler),
-	.sync_mode				= CS_SYNC_V1_APIV2,
-	.sync_init                              = (sync_init_v1_fn_t)cpg_sync_init_v2,
+	.sync_init                              = cpg_sync_init,
 	.sync_process                           = cpg_sync_process,
 	.sync_activate                          = cpg_sync_activate,
 	.sync_abort                             = cpg_sync_abort
@@ -459,7 +458,7 @@ struct downlist_msg {
 
 static struct req_exec_cpg_downlist g_req_exec_cpg_downlist;
 
-static void cpg_sync_init_v2 (
+static void cpg_sync_init (
 	const unsigned int *trans_list,
 	size_t trans_list_entries,
 	const unsigned int *member_list,
diff --git a/exec/evil.c b/exec/evil.c
deleted file mode 100644
index bd1ba2d..0000000
--- a/exec/evil.c
+++ /dev/null
@@ -1,540 +0,0 @@
-/*
- * Copyright (c) 2002-2006 MontaVista Software, Inc.
- * Copyright (c) 2006-2012 Red Hat, Inc.
- *
- * All rights reserved.
- *
- * Author: Steven Dake (sdake@xxxxxxxxxx)
- *
- * This software licensed under BSD license, the text of which follows:
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- *   this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright notice,
- *   this list of conditions and the following disclaimer in the documentation
- *   and/or other materials provided with the distribution.
- * - Neither the name of the MontaVista Software, Inc. nor the names of its
- *   contributors may be used to endorse or promote products derived from this
- *   software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
-/*
- * Don't look, you will be disappointed
- */
-
-#include <config.h>
-
-#include <pthread.h>
-#include <assert.h>
-#include <sys/types.h>
-#include <sys/poll.h>
-#include <sys/uio.h>
-#include <sys/mman.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <sys/time.h>
-#include <sys/resource.h>
-#include <sys/stat.h>
-#if defined(COROSYNC_BSD) || defined(COROSYNC_DARWIN)
-#include <sys/sysctl.h>
-#else
-#include <sys/sysinfo.h>
-#endif
-#include <netinet/in.h>
-#include <arpa/inet.h>
-#include <unistd.h>
-#include <fcntl.h>
-#include <stdlib.h>
-#include <stdio.h>
-#include <errno.h>
-#include <sched.h>
-#include <time.h>
-
-#include <corosync/totem/totempg.h>
-#include <corosync/swab.h>
-#include <corosync/corotypes.h>
-#include <corosync/corodefs.h>
-#include <corosync/list.h>
-#include <corosync/config.h>
-#include <corosync/coroapi.h>
-#include <corosync/logsys.h>
-#include <qb/qbipcs.h>
-#include "sync.h"
-#include "evil.h"
-
-static unsigned int my_evt_checked_in = 0;
-
-static unsigned int my_member_list_entries;
-
-static struct corosync_api_v1 *api = NULL;
-
-static void clm_sync_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id);
-
-static int clm_sync_process (void);
-
-static void clm_sync_activate (void);
-
-static void clm_sync_abort (void);
-
-static void evt_sync_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id);
-
-static int evt_sync_process (void);
-
-static void evt_sync_activate (void);
-
-static void evt_sync_abort (void);
-
-static int clm_hack_init (void);
-
-static void deliver_fn_evt_compat (
-	unsigned int nodeid,
-	unsigned int service,
-	unsigned int fn_id,
-	const void *msg,
-	unsigned int endian_conversion_required);
-
-static struct sync_callbacks clm_sync_operations = {
-	.api_version		= 1,
-	.name			= "dummy CLM service",
-	.sync_init_api.sync_init_v1 = clm_sync_init,
-	.sync_process		= clm_sync_process,
-	.sync_activate		= clm_sync_activate,
-	.sync_abort		= clm_sync_abort,
-};
-
-static struct sync_callbacks evt_sync_operations = {
-	.api_version		= 1,
-	.name			= "dummy EVT service",
-	.sync_init_api.sync_init_v1 = evt_sync_init,
-	.sync_process		= evt_sync_process,
-	.sync_activate		= evt_sync_activate,
-	.sync_abort		= evt_sync_abort,
-};
-
-
-static void sync_dummy_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id)
-{
-}
-
-static int sync_dummy_process (void)
-{
-	return (0);
-}
-
-static void sync_dummy_activate (void)
-{
-}
-
-static void sync_dummy_abort (void)
-{
-}
-
-void evil_init (struct corosync_api_v1 *api_in)
-{
-	api = api_in;
-	clm_hack_init ();
-}
-
-extern int evil_callbacks_load (int sync_id,
-	struct sync_callbacks *callbacks)
-{
-	int sync_dummy_found = 1;
-	int callbacks_init = 1;
-
-	memset (callbacks, 0, sizeof (struct sync_callbacks));
-	switch (sync_id) {
-		case EVS_SERVICE:
-			callbacks_init = 0;
-			break;
-		case CLM_SERVICE:
-			/*
-			 * ugh
-			 */
-			memcpy (callbacks, &clm_sync_operations, sizeof (struct sync_callbacks));
-			callbacks_init = 0;
-			break;
-		case AMF_SERVICE:
-			callbacks->name = "dummy AMF service";
-			break;
-		case CKPT_SERVICE:
-			callbacks->name = "dummy CKPT service";
-			break;
-		case EVT_SERVICE:
-			/*
-			 * double ugh
-			 */
-			memcpy (callbacks, &evt_sync_operations, sizeof (struct sync_callbacks));
-			callbacks_init = 0;
-			break;
-		case LCK_SERVICE:
-			callbacks_init = 0;
-			break;
-		case MSG_SERVICE:
-			callbacks_init = 0;
-			break;
-		case CFG_SERVICE:
-			callbacks_init = 0;
-			break;
-		case CPG_SERVICE:
-			callbacks->name = "dummy CPG service";
-			break;
-		case CONFDB_SERVICE:
-			callbacks_init = 0;
-			break;
-		default:
-			callbacks_init = 0;
-			sync_dummy_found = 0;
-			break;
-
-	}
-	if (callbacks_init) {
-		callbacks->sync_init_api.sync_init_v1 = sync_dummy_init;
-		callbacks->sync_process = sync_dummy_process;
-		callbacks->sync_activate = sync_dummy_activate;
-		callbacks->sync_abort = sync_dummy_abort;
-	}
-
-	if (sync_dummy_found == 0) {
-		return (-1);
-	}
-	return (0);
-}
-
-void evil_deliver_fn (
-	unsigned int nodeid,
-	unsigned int service,
-	unsigned int fn_id,
-	const void *msg,
-	unsigned int endian_conversion_required)
-{
-	if (service == EVT_SERVICE) {
-		deliver_fn_evt_compat (
-			nodeid,
-			service,
-			fn_id,
-			msg,
-			endian_conversion_required);
-	}
-}
-
-/*
- * This sends the clm nodejoin message required by clm services
- * on whitetank as well as the event service
- */
-enum clm_message_req_types {
-	MESSAGE_REQ_EXEC_CLM_NODEJOIN = 0
-};
-
-#define MAR_CLM_MAX_ADDRESS_LENGTH 64
-
-#define SA_MAX_NAME_LENGTH 256
-
-typedef enum {
-	MAR_CLM_AF_INET = 1,
-	MAR_CLM_AF_INET6 = 2
-} mar_clm_node_address_family_t;
-
-typedef struct {
-	unsigned short length __attribute__((aligned(8)));
-	mar_clm_node_address_family_t family __attribute__((aligned(8)));
-	unsigned char value[MAR_CLM_MAX_ADDRESS_LENGTH] __attribute__((aligned(8)));
-} mar_clm_node_address_t;
-
-typedef uint8_t mar_uint8_t;
-
-typedef uint16_t mar_uint16_t;
-
-typedef uint32_t mar_uint32_t;
-
-typedef uint64_t mar_uint64_t;
-
-typedef struct {
-	mar_uint16_t length __attribute__((aligned(8)));
-	mar_uint8_t value[SA_MAX_NAME_LENGTH] __attribute__((aligned(8)));
-} mar_name_t;
-
-typedef struct {
-	mar_uint32_t node_id __attribute__((aligned(8)));
-	mar_clm_node_address_t node_address __attribute__((aligned(8)));
-	mar_name_t node_name __attribute__((aligned(8)));
-	mar_uint32_t member __attribute__((aligned(8)));
-	mar_uint64_t boot_timestamp __attribute__((aligned(8)));
-	mar_uint64_t initial_view_number __attribute__((aligned(8)));
-} mar_clm_cluster_node_t;
-
-mar_clm_cluster_node_t my_cluster_node;
-
-struct req_exec_clm_nodejoin {
-	struct qb_ipc_request_header header __attribute__((aligned(8)));
-	mar_clm_cluster_node_t cluster_node __attribute__((aligned(8)));
-};
-
-static void my_cluster_node_load (void)
-{
-	struct totem_ip_address interfaces[INTERFACE_MAX];
-	unsigned int iface_count;
-	char **status;
-	const char *iface_string;
-
-	totempg_ifaces_get (
-		totempg_my_nodeid_get (),
-		interfaces,
-		&status,
-		&iface_count);
-
-	iface_string = totemip_print (&interfaces[0]);
-
-	sprintf ((char *)my_cluster_node.node_address.value, "%s",
-		iface_string);
-	my_cluster_node.node_address.length =
-		strlen ((char *)my_cluster_node.node_address.value);
-	if (totempg_my_family_get () == AF_INET) {
-		my_cluster_node.node_address.family = MAR_CLM_AF_INET;
-	} else
-	if (totempg_my_family_get () == AF_INET6) {
-		my_cluster_node.node_address.family = MAR_CLM_AF_INET6;
-	} else {
-		assert (0);
-	}
-
-	strcpy ((char *)my_cluster_node.node_name.value,
-		(char *)my_cluster_node.node_address.value);
-	my_cluster_node.node_name.length =
-		my_cluster_node.node_address.length;
-	my_cluster_node.node_id = totempg_my_nodeid_get ();
-	my_cluster_node.member = 1;
-}
-
-static int clm_hack_init (void)
-{
-
-#if defined(COROSYNC_LINUX)
-	struct sysinfo s_info;
-	time_t current_time;
-	sysinfo (&s_info);
-	current_time = time (NULL);
-	 /* (currenttime (s) - uptime (s)) * 1 billion (ns) / 1 (s) */
-	my_cluster_node.boot_timestamp = ((uint64_t)(current_time - s_info.uptime)) * 1000000000ULL;
-#elif defined(COROSYNC_BSD) || defined(COROSYNC_DARWIN)
-	int mib[2] = { CTL_KERN, KERN_BOOTTIME };
-	struct timeval boot_time;
-	size_t size = sizeof(boot_time);
-
-	if ( sysctl(mib, 2, &boot_time, &size, NULL, 0) == -1 )
-		boot_time.tv_sec = time (NULL);
-	 /* (currenttime (s) - uptime (s)) * 1 billion (ns) / 1 (s) */
-	my_cluster_node.boot_timestamp = ((uint64_t)boot_time.tv_sec) * 1000000000ULL;
-#else /* defined(CTL_KERN) && defined(KERN_BOOTTIME) */
-	#warning "no bootime support"
-#endif
-
-	return (0);
-}
-
-static int clm_nodejoin_send (void)
-{
-	struct req_exec_clm_nodejoin req_exec_clm_nodejoin;
-	struct iovec req_exec_clm_iovec;
-	int result;
-
-	my_cluster_node_load ();
-
-	req_exec_clm_nodejoin.header.size = sizeof (struct req_exec_clm_nodejoin);
-	req_exec_clm_nodejoin.header.id =
-		SERVICE_ID_MAKE (CLM_SERVICE, MESSAGE_REQ_EXEC_CLM_NODEJOIN);
-
-	my_cluster_node.initial_view_number = 0;
-
-	memcpy (&req_exec_clm_nodejoin.cluster_node, &my_cluster_node,
-		sizeof (mar_clm_cluster_node_t));
-
-	req_exec_clm_iovec.iov_base = (char *)&req_exec_clm_nodejoin;
-	req_exec_clm_iovec.iov_len = sizeof (req_exec_clm_nodejoin);
-
-	result = api->totem_mcast (&req_exec_clm_iovec, 1, TOTEMPG_AGREED);
-
-	return (result);
-}
-
-/*
- * This is a noop for this service
- */
-static void clm_sync_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id)
-{
-	return;
-}
-
-static int clm_sync_process (void)
-{
-	/*
-	 * Send node information to other nodes
-	 */
-	return (clm_nodejoin_send ());
-}
-
-/*
- * This is a noop for this service
- */
-static void clm_sync_activate (void)
-{
-	return;
-}
-
-/*
- * This is a noop for this service
- */
-static void clm_sync_abort (void)
-{
-	return;
-}
-
-enum evt_sync_states {
-	EVT_SYNC_PART_ONE,
-	EVT_SYNC_PART_TWO,
-	EVT_SYNC_PART_THREE,
-	EVT_SYNC_PART_FOUR,
-	EVT_SYNC_DONE
-};
-
-static enum evt_sync_states evt_sync_state;
-
-enum evt_chan_ops {
-	EVT_OPEN_CHAN_OP,               /* chc_chan */
-	EVT_CLOSE_CHAN_OP,              /* chc_close_unlink_chan */
-	EVT_UNLINK_CHAN_OP,             /* chc_close_unlink_chan */
-	EVT_CLEAR_RET_OP,               /* chc_event_id */
-	EVT_SET_ID_OP,                  /* chc_set_id */
-	EVT_CONF_DONE,                  /* no data used */
-	EVT_OPEN_COUNT,                 /* chc_set_opens */
-	EVT_OPEN_COUNT_DONE             /* no data used */
-};
-
-enum evt_message_req_types {
-	MESSAGE_REQ_EXEC_EVT_EVENTDATA = 0,
-	MESSAGE_REQ_EXEC_EVT_CHANCMD = 1,
-	MESSAGE_REQ_EXEC_EVT_RECOVERY_EVENTDATA = 2
-};
-
-struct req_evt_chan_command {
-	struct qb_ipc_request_header chc_head __attribute__((aligned(8)));
-	mar_uint32_t chc_op __attribute__((aligned(8)));
-};
-
-static void evt_sync_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id)
-{
-	my_member_list_entries = member_list_entries;
-	my_evt_checked_in = 0;
-
-	evt_sync_state = EVT_SYNC_PART_ONE;
-	return;
-}
-
-static int evt_sync_process (void)
-{
-	int res;
-	struct req_evt_chan_command cpkt;
-	struct iovec chn_iovec;
-
-	memset(&cpkt, 0, sizeof(cpkt));
-	cpkt.chc_head.id =
-		SERVICE_ID_MAKE(EVT_SERVICE, MESSAGE_REQ_EXEC_EVT_CHANCMD);
-	cpkt.chc_head.size = sizeof(cpkt);
-	chn_iovec.iov_base = &cpkt;
-	chn_iovec.iov_len = cpkt.chc_head.size;
-
-	if (evt_sync_state == EVT_SYNC_PART_ONE) {
-		cpkt.chc_op = EVT_OPEN_COUNT_DONE;
-
-		res = api->totem_mcast(&chn_iovec, 1,TOTEMPG_AGREED);
-		if (res == -1) {
-			return (res);
-		}
-		evt_sync_state = EVT_SYNC_PART_TWO;
-	}
-	if (evt_sync_state == EVT_SYNC_PART_THREE) {
-		cpkt.chc_op = EVT_CONF_DONE;
-		res = api->totem_mcast(&chn_iovec, 1,TOTEMPG_AGREED);
-		if (res == -1) {
-			return (res);
-		}
-		evt_sync_state = EVT_SYNC_PART_FOUR;
-	}
-	if (evt_sync_state == EVT_SYNC_DONE) {
-		return (0);
-	}
-	return (-1);
-}
-
-static void evt_sync_activate (void)
-{
-	return;
-}
-
-static void evt_sync_abort (void)
-{
-	return;
-}
-
-static void deliver_fn_evt_compat (
-	unsigned int nodeid,
-	unsigned int service,
-	unsigned int fn_id,
-	const void *msg,
-	unsigned int endian_conversion_required)
-{
-	const struct req_evt_chan_command *cpkt = msg;
-	unsigned int operation;
-
-	if (fn_id != MESSAGE_REQ_EXEC_EVT_CHANCMD) {
-		return;
-	}
-	operation = cpkt->chc_op;
-
-	if (endian_conversion_required) {
-		operation = swab32 (operation);
-	}
-
-	switch (operation) {
-	case EVT_OPEN_COUNT_DONE:
-		if (++my_evt_checked_in == my_member_list_entries) {
-			evt_sync_state = EVT_SYNC_PART_THREE;
-			my_evt_checked_in = 0;
-		}
-		break;
-	case EVT_CONF_DONE:
-		if (++my_evt_checked_in == my_member_list_entries) {
-			evt_sync_state = EVT_SYNC_DONE;
-			my_evt_checked_in = 0;
-		}
-		break;
-	}
-}
diff --git a/exec/evil.h b/exec/evil.h
deleted file mode 100644
index 390712f..0000000
--- a/exec/evil.h
+++ /dev/null
@@ -1,55 +0,0 @@
-/*
- * Copyright (c) 2002-2006 MontaVista Software, Inc.
- * Copyright (c) 2006-2009 Red Hat, Inc.
- *
- * All rights reserved.
- *
- * Author: Steven Dake (sdake@xxxxxxxxxx)
- *
- * This software licensed under BSD license, the text of which follows:
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- *   this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright notice,
- *   this list of conditions and the following disclaimer in the documentation
- *   and/or other materials provided with the distribution.
- * - Neither the name of the MontaVista Software, Inc. nor the names of its
- *   contributors may be used to endorse or promote products derived from this
- *   software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
-/*
- * Don't look, you will be disappointed
- */
-
-#ifndef EVIL_H_DEFINED
-#define EVIL_H_DEFINED
-
-extern void evil_init (struct corosync_api_v1 *api_in);
-
-extern int evil_callbacks_load (
-	int sync_id,
-        struct sync_callbacks *callbacks);
-
-extern void evil_deliver_fn (
-        unsigned int nodeid,
-        unsigned int service,
-        unsigned int fn_id,
-        const void *msg,
-        unsigned int endian_conversion_required);
-
-#endif /* EVIL_H_DEFINED */
diff --git a/exec/evs.c b/exec/evs.c
index 5cb5754..6667341 100644
--- a/exec/evs.c
+++ b/exec/evs.c
@@ -152,8 +152,7 @@ struct corosync_service_engine evs_service_engine = {
 	.exec_engine_count	= sizeof (evs_exec_engine) / sizeof (struct corosync_exec_handler),
 	.confchg_fn		= evs_confchg_fn,
 	.exec_init_fn		= evs_exec_init_fn,
-	.exec_dump_fn		= NULL,
-	.sync_mode		= CS_SYNC_V1
+	.exec_dump_fn		= NULL
 };
 
 static DECLARE_LIST_INIT (confchg_notify);
diff --git a/exec/ipc_glue.c b/exec/ipc_glue.c
index 12789ad..71a804a 100644
--- a/exec/ipc_glue.c
+++ b/exec/ipc_glue.c
@@ -56,7 +56,6 @@
 
 #include "mainconfig.h"
 #include "sync.h"
-#include "syncv2.h"
 #include "timer.h"
 #include "main.h"
 #include "util.h"
@@ -122,63 +121,21 @@ static const char* cs_ipcs_serv_short_name(int32_t service_id)
 	case EVS_SERVICE:
 		name = "evs";
 		break;
-	case CLM_SERVICE:
-		name = "saClm";
-		break;
-	case AMF_SERVICE:
-		name = "saAmf";
-		break;
-	case CKPT_SERVICE:
-		name = "saCkpt";
-		break;
-	case EVT_SERVICE:
-		name = "saEvt";
-		break;
-	case LCK_SERVICE:
-		name = "saLck";
-		break;
-	case MSG_SERVICE:
-		name = "saMsg";
-		break;
 	case CFG_SERVICE:
 		name = "cfg";
 		break;
 	case CPG_SERVICE:
 		name = "cpg";
 		break;
-	case CMAN_SERVICE:
-		name = "cman";
-		break;
-	case PCMK_SERVICE:
-		name = "pacemaker.engine";
-		break;
-	case CONFDB_SERVICE:
-		name = "confdb";
-		break;
 	case QUORUM_SERVICE:
 		name = "quorum";
 		break;
 	case PLOAD_SERVICE:
 		name = "pload";
 		break;
-	case TMR_SERVICE:
-		name = "saTmr";
-		break;
 	case VOTEQUORUM_SERVICE:
 		name = "votequorum";
 		break;
-	case NTF_SERVICE:
-		name = "saNtf";
-		break;
-	case AMF_V2_SERVICE:
-		name = "saAmfV2";
-		break;
-	case TST_SV1_SERVICE:
-		name = "tst";
-		break;
-	case TST_SV2_SERVICE:
-		name = "tst2";
-		break;
 	case MON_SERVICE:
 		name = "mon";
 		break;
diff --git a/exec/main.c b/exec/main.c
index 158dea9..e957831 100644
--- a/exec/main.c
+++ b/exec/main.c
@@ -115,13 +115,11 @@
 #include "totemconfig.h"
 #include "main.h"
 #include "sync.h"
-#include "syncv2.h"
 #include "timer.h"
 #include "util.h"
 #include "apidef.h"
 #include "service.h"
 #include "schedwrk.h"
-#include "evil.h"
 
 #ifdef HAVE_SMALL_MEMORY_FOOTPRINT
 #define IPC_LOGSYS_SIZE			1024*64
@@ -146,8 +144,6 @@ static struct totem_logging_configuration totem_logging_configuration;
 
 static struct corosync_api_v1 *api = NULL;
 
-static enum cs_sync_mode minimum_sync_mode;
-
 static int sync_in_process = 1;
 
 static qb_loop_t *corosync_poll_handle;
@@ -258,72 +254,17 @@ static void corosync_sync_completed (void)
 	cs_ipcs_sync_state_changed(sync_in_process);
 }
 
-static int corosync_sync_callbacks_retrieve (int sync_id,
-	struct sync_callbacks *callbacks)
-{
-	unsigned int corosync_service_index;
-	int res;
-
-	for (corosync_service_index = 0;
-		corosync_service_index < SERVICE_HANDLER_MAXIMUM_COUNT;
-		corosync_service_index++) {
-
-		if (corosync_service[corosync_service_index] != NULL
-			&& (corosync_service[corosync_service_index]->sync_mode == CS_SYNC_V1
-				|| corosync_service[corosync_service_index]->sync_mode == CS_SYNC_V1_APIV2)) {
-			if (corosync_service_index == sync_id) {
-				break;
-			}
-		}
-	}
-	/*
-	 * Try to load backwards compat sync engines
-	 */
-	if (corosync_service_index == SERVICE_HANDLER_MAXIMUM_COUNT) {
-		res = evil_callbacks_load (sync_id, callbacks);
-		return (res);
-	}
-	callbacks->name = corosync_service[corosync_service_index]->name;
-	callbacks->sync_init_api.sync_init_v1 = corosync_service[corosync_service_index]->sync_init;
-	callbacks->api_version = 1;
-	if (corosync_service[corosync_service_index]->sync_mode == CS_SYNC_V1_APIV2) {
-		callbacks->api_version = 2;
-	}
-	callbacks->sync_process = corosync_service[corosync_service_index]->sync_process;
-	callbacks->sync_activate = corosync_service[corosync_service_index]->sync_activate;
-	callbacks->sync_abort = corosync_service[corosync_service_index]->sync_abort;
-	return (0);
-}
-
-static int corosync_sync_v2_callbacks_retrieve (
+static int corosync_sync_callbacks_retrieve (
 	int service_id,
 	struct sync_callbacks *callbacks)
 {
-	int res;
-
-	if (minimum_sync_mode == CS_SYNC_V2 && service_id == CLM_SERVICE && corosync_service[CLM_SERVICE] == NULL) {
-		res = evil_callbacks_load (service_id, callbacks);
-		return (res);
-	}
-	if (minimum_sync_mode == CS_SYNC_V2 && service_id == EVT_SERVICE && corosync_service[EVT_SERVICE] == NULL) {
-		res = evil_callbacks_load (service_id, callbacks);
-		return (res);
-	}
 	if (corosync_service[service_id] == NULL) {
 		return (-1);
 	}
-	if (minimum_sync_mode == CS_SYNC_V1 && corosync_service[service_id]->sync_mode != CS_SYNC_V2) {
-		return (-1);
-	}
 
 	callbacks->name = corosync_service[service_id]->name;
 
-	callbacks->api_version = 1;
-	if (corosync_service[service_id]->sync_mode == CS_SYNC_V1_APIV2) {
-		callbacks->api_version = 2;
-	}
-
-	callbacks->sync_init_api.sync_init_v1 = corosync_service[service_id]->sync_init;
+	callbacks->sync_init = corosync_service[service_id]->sync_init;
 	callbacks->sync_process = corosync_service[service_id]->sync_process;
 	callbacks->sync_activate = corosync_service[service_id]->sync_activate;
 	callbacks->sync_abort = corosync_service[service_id]->sync_abort;
@@ -406,13 +347,13 @@ static void confchg_fn (
 	}
 
 	if (abort_activate) {
-		sync_v2_abort ();
+		sync_abort ();
 	}
-	if (minimum_sync_mode == CS_SYNC_V2 && configuration_type == TOTEM_CONFIGURATION_TRANSITIONAL) {
-		sync_v2_save_transitional (member_list, member_list_entries, ring_id);
+	if (configuration_type == TOTEM_CONFIGURATION_TRANSITIONAL) {
+		sync_save_transitional (member_list, member_list_entries, ring_id);
 	}
-	if (minimum_sync_mode == CS_SYNC_V2 && configuration_type == TOTEM_CONFIGURATION_REGULAR) {
-		sync_v2_start (member_list, member_list_entries, ring_id);
+	if (configuration_type == TOTEM_CONFIGURATION_REGULAR) {
+		sync_start (member_list, member_list_entries, ring_id);
 	}
 }
 
@@ -677,11 +618,6 @@ static void deliver_fn (
 	service = id >> 16;
 	fn_id = id & 0xffff;
 
-	if (corosync_service[service] == NULL && service == EVT_SERVICE) {
-		evil_deliver_fn (nodeid, service, fn_id, msg,
-			endian_conversion_required);
-	}
-
 	if (!corosync_service[service]) {
 		return;
 	}
@@ -928,33 +864,13 @@ static void main_service_ready (void)
 		log_printf (LOGSYS_LEVEL_ERROR, "Could not initialize default services");
 		corosync_exit_error (COROSYNC_DONE_INIT_SERVICES);
 	}
-	evil_init (api);
 	cs_ipcs_init();
 	corosync_totem_stats_init ();
 	corosync_fplay_control_init ();
 	corosync_totem_dynamic_init ();
-	if (minimum_sync_mode == CS_SYNC_V2) {
-		log_printf (LOGSYS_LEVEL_NOTICE,
-		       "Compatibility mode set to none.  Using V2 of the synchronization engine.");
-		sync_v2_init (
-			corosync_sync_v2_callbacks_retrieve,
-			corosync_sync_completed);
-	} else
-	if (minimum_sync_mode == CS_SYNC_V1) {
-		log_printf (LOGSYS_LEVEL_NOTICE,
-			"Compatibility mode set to whitetank.  Using V1 and V2 of the synchronization engine.");
-		sync_register (
-			corosync_sync_callbacks_retrieve,
-			sync_v2_memb_list_determine,
-			sync_v2_memb_list_abort,
-			sync_v2_start);
-
-		sync_v2_init (
-			corosync_sync_v2_callbacks_retrieve,
-			corosync_sync_completed);
-	}
-
-
+	sync_init (
+		corosync_sync_callbacks_retrieve,
+		corosync_sync_completed);
 }
 
 static enum e_corosync_done corosync_flock (const char *lockfile, pid_t pid)
@@ -1204,13 +1120,6 @@ int main (int argc, char **argv, char **envp)
 	totem_config.totem_logging_configuration.log_printf = _logsys_log_printf;
 	logsys_config_apply();
 
-	res = corosync_main_config_compatibility_read (&minimum_sync_mode,
-		&error_string);
-	if (res == -1) {
-		log_printf (LOGSYS_LEVEL_ERROR, "%s", error_string);
-		corosync_exit_error (COROSYNC_DONE_MAINCONFIGREAD);
-	}
-
 	/*
 	 * Now we are fully initialized.
 	 */
diff --git a/exec/mainconfig.c b/exec/mainconfig.c
index 25bd157..bf860d0 100644
--- a/exec/mainconfig.c
+++ b/exec/mainconfig.c
@@ -540,34 +540,3 @@ parse_error:
 	*error_string = error_string_response;
 	return (-1);
 }
-
-int corosync_main_config_compatibility_read (
-        enum cs_sync_mode *minimum_sync_mode,
-        const char **error_string)
-{
-	const char *error_reason = error_string_response;
-	char *value;
-
-	*minimum_sync_mode = CS_SYNC_V1;
-	if (icmap_get_string("compatibility", &value) == CS_OK) {
-		if (strcmp (value, "whitetank") == 0) {
-			*minimum_sync_mode = CS_SYNC_V1;
-		} else
-		if (strcmp (value, "none") == 0) {
-			*minimum_sync_mode = CS_SYNC_V2;
-		} else {
-
-			snprintf (error_string_response, sizeof (error_string_response),
-				"Invalid compatibility option '%s' specified, must be none or whitetank.\n", value);
-			goto parse_error;
-		}
-		free(value);
-	}
-
-	return 0;
-
-parse_error:
-	*error_string = error_reason;
-	free(value);
-	return (-1);
-}
diff --git a/exec/mainconfig.h b/exec/mainconfig.h
index ad64c83..0c3dce7 100644
--- a/exec/mainconfig.h
+++ b/exec/mainconfig.h
@@ -52,8 +52,4 @@ struct dynamic_service {
 extern int corosync_main_config_read (
 	const char **error_string);
 
-extern int corosync_main_config_compatibility_read (
-	enum cs_sync_mode *minimum_sync_mode,
-	const char **error_string);
-
 #endif /* MAINCONFIG_H_DEFINED */
diff --git a/exec/mon.c b/exec/mon.c
index 913dc36..f220abd 100644
--- a/exec/mon.c
+++ b/exec/mon.c
@@ -75,8 +75,7 @@ struct corosync_service_engine mon_service_engine = {
 	.exec_engine_count	= 0,
 	.confchg_fn		= NULL,
 	.exec_init_fn		= mon_exec_init_fn,
-	.exec_dump_fn		= NULL,
-	.sync_mode		= CS_SYNC_V2
+	.exec_dump_fn		= NULL
 };
 
 static DECLARE_LIST_INIT (confchg_notify);
diff --git a/exec/pload.c b/exec/pload.c
index 893f577..8301477 100644
--- a/exec/pload.c
+++ b/exec/pload.c
@@ -164,8 +164,7 @@ struct corosync_service_engine pload_service_engine = {
 	.exec_engine_count	= sizeof (pload_exec_engine) / sizeof (struct corosync_exec_handler),
 	.confchg_fn		= pload_confchg_fn,
 	.exec_init_fn		= pload_exec_init_fn,
-	.exec_dump_fn		= NULL,
-	.sync_mode		= CS_SYNC_V2
+	.exec_dump_fn		= NULL
 };
 
 static DECLARE_LIST_INIT (confchg_notify);
diff --git a/exec/quorum.c b/exec/quorum.c
index 7470150..d4837a2 100644
--- a/exec/quorum.c
+++ b/exec/quorum.c
@@ -58,7 +58,6 @@
 
 #include "quorum.h"
 #include "main.h"
-#include "sync.h"
 #include "vsf.h"
 
 LOGSYS_DECLARE_SUBSYS ("QUORUM");
diff --git a/exec/sync.c b/exec/sync.c
index be42568..2998988 100644
--- a/exec/sync.c
+++ b/exec/sync.c
@@ -1,6 +1,5 @@
 /*
- * Copyright (c) 2005-2006 MontaVista Software, Inc.
- * Copyright (c) 2006-2012 Red Hat, Inc.
+ * Copyright (c) 2009-2012 Red Hat, Inc.
  *
  * All rights reserved.
  *
@@ -56,63 +55,104 @@
 #include <corosync/totem/totem.h>
 #include <corosync/logsys.h>
 #include <qb/qbipc_common.h>
+#include "schedwrk.h"
 #include "quorum.h"
 #include "sync.h"
 
 LOGSYS_DECLARE_SUBSYS ("SYNC");
 
 #define MESSAGE_REQ_SYNC_BARRIER 0
+#define MESSAGE_REQ_SYNC_SERVICE_BUILD 1
+#define MESSAGE_REQ_SYNC_MEMB_DETERMINE 2
 
-struct barrier_data {
-	unsigned int nodeid;
-	int completed;
+enum sync_process_state {
+	INIT,
+	PROCESS,
+	ACTIVATE
 };
 
-static const struct memb_ring_id *sync_ring_id;
+enum sync_state {
+	SYNC_SERVICELIST_BUILD,
+	SYNC_PROCESS,
+	SYNC_BARRIER
+};
+
+struct service_entry {
+	int service_id;
+	void (*sync_init) (
+		const unsigned int *trans_list,
+		size_t trans_list_entries,
+		const unsigned int *member_list,
+		size_t member_list_entries,
+		const struct memb_ring_id *ring_id);
+	void (*sync_abort) (void);
+	int (*sync_process) (void);
+	void (*sync_activate) (void);
+	enum sync_process_state state;
+	char name[128];
+};
+
+struct processor_entry {
+	int nodeid;
+	int received;
+};
 
-static int (*sync_callbacks_retrieve) (int sync_id, struct sync_callbacks *callack);
+struct req_exec_memb_determine_message {
+	struct qb_ipc_request_header header __attribute__((aligned(8)));
+	struct memb_ring_id ring_id __attribute__((aligned(8)));
+};
 
-static void (*sync_started) (
-	const struct memb_ring_id *ring_id);
+struct req_exec_service_build_message {
+	struct qb_ipc_request_header header __attribute__((aligned(8)));
+	struct memb_ring_id ring_id __attribute__((aligned(8)));
+	int service_list_entries __attribute__((aligned(8)));
+	int service_list[128] __attribute__((aligned(8)));
+};
 
-static void (*sync_aborted) (void);
+struct req_exec_barrier_message {
+	struct qb_ipc_request_header header __attribute__((aligned(8)));
+	struct memb_ring_id ring_id __attribute__((aligned(8)));
+};
 
-static struct sync_callbacks sync_callbacks;
+static enum sync_state my_state = SYNC_BARRIER;
 
-static int sync_processing = 0;
+static struct memb_ring_id my_ring_id;
 
-static void (*sync_next_start) (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id);
+static struct memb_ring_id my_memb_determine_ring_id;
+
+static int my_memb_determine = 0;
 
-static int sync_recovery_index = 0;
+static unsigned int my_memb_determine_list[PROCESSOR_COUNT_MAX];
 
-static void *sync_callback_token_handle = 0;
+static unsigned int my_memb_determine_list_entries = 0;
 
-static struct barrier_data barrier_data_confchg[PROCESSOR_COUNT_MAX];
+static int my_processing_idx = 0;
 
-static size_t barrier_data_confchg_entries;
+static hdb_handle_t my_schedwrk_handle;
 
-static struct barrier_data barrier_data_process[PROCESSOR_COUNT_MAX];
+static struct processor_entry my_processor_list[PROCESSOR_COUNT_MAX];
 
 static unsigned int my_member_list[PROCESSOR_COUNT_MAX];
 
 static unsigned int my_trans_list[PROCESSOR_COUNT_MAX];
 
-static unsigned int my_member_list_entries;
+static size_t my_member_list_entries = 0;
+
+static size_t my_trans_list_entries = 0;
 
-static unsigned int my_trans_list_entries;
+static int my_processor_list_entries = 0;
 
-static int sync_barrier_send (const struct memb_ring_id *ring_id);
+static struct service_entry my_service_list[128];
 
-static int sync_start_process (enum totem_callback_token_type type,
-			       const void *data);
+static int my_service_list_entries = 0;
 
-static void sync_service_init (struct memb_ring_id *ring_id);
+static const struct memb_ring_id sync_ring_id;
 
-static int sync_service_process (enum totem_callback_token_type type,
-				 const void *data);
+static struct service_entry my_initial_service_list[PROCESSOR_COUNT_MAX];
+
+static int my_initial_service_list_entries;
+
+static void (*sync_synchronization_completed) (void);
 
 static void sync_deliver_fn (
 	unsigned int nodeid,
@@ -120,21 +160,9 @@ static void sync_deliver_fn (
 	unsigned int msg_len,
 	int endian_conversion_required);
 
-static void sync_confchg_fn (
-	enum totem_configuration_type configuration_type,
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const unsigned int *left_list,
-	size_t left_list_entries,
-	const unsigned int *joined_list,
-	size_t joined_list_entries,
-	const struct memb_ring_id *ring_id);
-
-static void sync_primary_callback_fn (
-        const unsigned int *view_list,
-        size_t view_list_entries,
-        const struct memb_ring_id *ring_id);
+static int schedwrk_processor (const void *context);
 
+static void sync_process_enter (void);
 
 static struct totempg_group sync_group = {
     .group      = "sync",
@@ -143,344 +171,450 @@ static struct totempg_group sync_group = {
 
 static void *sync_group_handle;
 
-struct req_exec_sync_barrier_start {
-	struct qb_ipc_request_header header;
-	struct memb_ring_id ring_id;
-};
-
-/*
- * Send a barrier data structure
- */
-static int sync_barrier_send (const struct memb_ring_id *ring_id)
+int sync_init (
+        int (*sync_callbacks_retrieve) (
+                int service_id,
+                struct sync_callbacks *callbacks),
+        void (*synchronization_completed) (void))
 {
-	struct req_exec_sync_barrier_start req_exec_sync_barrier_start;
-	struct iovec iovec;
-	int res;
+	unsigned int res;
+	int i;
+	struct sync_callbacks sync_callbacks;
 
-	req_exec_sync_barrier_start.header.size = sizeof (struct req_exec_sync_barrier_start);
-	req_exec_sync_barrier_start.header.id = MESSAGE_REQ_SYNC_BARRIER;
+	res = totempg_groups_initialize (
+		&sync_group_handle,
+		sync_deliver_fn,
+		NULL);
+	if (res == -1) {
+		log_printf (LOGSYS_LEVEL_ERROR,
+			"Couldn't initialize groups interface.");
+		return (-1);
+	}
 
-	memcpy (&req_exec_sync_barrier_start.ring_id, ring_id,
-		sizeof (struct memb_ring_id));
+	res = totempg_groups_join (
+		sync_group_handle,
+		&sync_group,
+		1);
+	if (res == -1) {
+		log_printf (LOGSYS_LEVEL_ERROR, "Couldn't join group.");
+		return (-1);
+	}
 
-	iovec.iov_base = (char *)&req_exec_sync_barrier_start;
-	iovec.iov_len = sizeof (req_exec_sync_barrier_start);
+	sync_synchronization_completed = synchronization_completed;
+	for (i = 0; i < 64; i++) {
+		res = sync_callbacks_retrieve (i, &sync_callbacks);
+		if (res == -1) {
+			continue;
+		}
+		if (sync_callbacks.sync_init == NULL) {
+			continue;
+		}
+		my_initial_service_list[my_initial_service_list_entries].state =
+			INIT;
+		my_initial_service_list[my_initial_service_list_entries].service_id = i;
+		strcpy (my_initial_service_list[my_initial_service_list_entries].name,
+			sync_callbacks.name);
+		my_initial_service_list[my_initial_service_list_entries].sync_init = sync_callbacks.sync_init;
+		my_initial_service_list[my_initial_service_list_entries].sync_process = sync_callbacks.sync_process;
+		my_initial_service_list[my_initial_service_list_entries].sync_abort = sync_callbacks.sync_abort;
+		my_initial_service_list[my_initial_service_list_entries].sync_activate = sync_callbacks.sync_activate;
+		my_initial_service_list_entries += 1;
+	}
+	return (0);
+}
+
+static void sync_barrier_handler (unsigned int nodeid, const void *msg)
+{
+	const struct req_exec_barrier_message *req_exec_barrier_message = msg;
+	int i;
+	int barrier_reached = 1;
 
-	res = totempg_groups_mcast_joined (sync_group_handle, &iovec, 1, TOTEMPG_AGREED);
+	if (memcmp (&my_ring_id, &req_exec_barrier_message->ring_id,
+		sizeof (struct memb_ring_id)) != 0) {
 
-	return (res);
+		log_printf (LOGSYS_LEVEL_DEBUG, "barrier for old ring - discarding");
+		return;
+	}
+	for (i = 0; i < my_processor_list_entries; i++) {
+		if (my_processor_list[i].nodeid == nodeid) {
+			my_processor_list[i].received = 1;
+		}
+	}
+	for (i = 0; i < my_processor_list_entries; i++) {
+		if (my_processor_list[i].received == 0) {
+			barrier_reached = 0;
+		}
+	}
+	if (barrier_reached) {
+		log_printf (LOGSYS_LEVEL_DEBUG, "Committing synchronization for %s",
+			my_service_list[my_processing_idx].name);
+		my_service_list[my_processing_idx].state = ACTIVATE;
+		my_service_list[my_processing_idx].sync_activate ();
+
+		my_processing_idx += 1;
+		if (my_service_list_entries == my_processing_idx) {
+			my_memb_determine_list_entries = 0;
+			sync_synchronization_completed ();
+		} else {
+			sync_process_enter ();
+		}
+	}
 }
 
-static void sync_start_init (const struct memb_ring_id *ring_id)
+static void dummy_sync_init (
+	const unsigned int *trans_list,
+	size_t trans_list_entries,
+	const unsigned int *member_list,
+	size_t member_list_entries,
+	const struct memb_ring_id *ring_id)
 {
-	totempg_callback_token_create (
-		&sync_callback_token_handle,
-		TOTEM_CALLBACK_TOKEN_SENT,
-		0, /* don't delete after callback */
-		sync_start_process,
-		ring_id);
 }
 
-static void sync_service_init (struct memb_ring_id *ring_id)
+static void dummy_sync_abort (void)
 {
-	if (sync_callbacks.api_version == 1) {
-		sync_callbacks.sync_init_api.sync_init_v1 (my_member_list,
-			my_member_list_entries, ring_id);
-	} else {
-		sync_callbacks.sync_init_api.sync_init_v2 (my_trans_list,
-			my_trans_list_entries,
-			my_member_list, my_member_list_entries, ring_id);
-	}
-	totempg_callback_token_destroy (&sync_callback_token_handle);
-
-	/*
-	 * Create the token callback for the processing
-	 */
-	totempg_callback_token_create (
-		&sync_callback_token_handle,
-		TOTEM_CALLBACK_TOKEN_SENT,
-		0, /* don't delete after callback */
-		sync_service_process,
-		ring_id);
 }
 
-static int sync_start_process (enum totem_callback_token_type type,
-			       const void *data)
+static int dummy_sync_process (void)
 {
-	int res;
-	const struct memb_ring_id *ring_id = data;
-
-	res = sync_barrier_send (ring_id);
-	if (res == 0) {
-		/*
-		 * Delete the token callback for the barrier
-		 */
-		totempg_callback_token_destroy (&sync_callback_token_handle);
-	}
 	return (0);
 }
 
-static void sync_callbacks_load (void)
+static void dummy_sync_activate (void)
 {
-	int res;
+}
 
-	for (;;) {
-		res = sync_callbacks_retrieve (sync_recovery_index,
-			&sync_callbacks);
+static int service_entry_compare (const void *a, const void *b)
+{
+	const struct service_entry *service_entry_a = a;
+	const struct service_entry *service_entry_b = b;
 
-		/*
-		 * No more service handlers have sync callbacks at this time
-	`	 */
-		if (res == -1) {
-			sync_processing = 0;
-			break;
-		}
-		sync_recovery_index += 1;
-		if (sync_callbacks.sync_init_api.sync_init_v1) {
-			break;
-		}
-	}
+	return (service_entry_a->service_id > service_entry_b->service_id);
 }
 
-static int sync_service_process (enum totem_callback_token_type type,
-				 const void *data)
+static void sync_memb_determine (unsigned int nodeid, const void *msg)
 {
-	int res;
-	const struct memb_ring_id *ring_id = data;
+	const struct req_exec_memb_determine_message *req_exec_memb_determine_message = msg;
+	int found = 0;
+	int i;
 
+	if (memcmp (&req_exec_memb_determine_message->ring_id,
+		&my_memb_determine_ring_id, sizeof (struct memb_ring_id)) != 0) {
 
-	/*
-	 * If process operation not from this ring id, then ignore it and stop
-	 * processing
-	 */
-	if (memcmp (ring_id, sync_ring_id, sizeof (struct memb_ring_id)) != 0) {
-		return (0);
+		log_printf (LOGSYS_LEVEL_DEBUG, "memb determine for old ring - discarding");
+		return;
 	}
 
-	/*
-	 * If process returns 0, then its time to activate
-	 * and start the next service's synchronization
-	 */
-	res = sync_callbacks.sync_process ();
-	if (res != 0) {
-		return (0);
+	my_memb_determine = 1;
+	for (i = 0; i < my_memb_determine_list_entries; i++) {
+		if (my_memb_determine_list[i] == nodeid) {
+			found = 1;
+		}
 	}
-	totempg_callback_token_destroy (&sync_callback_token_handle);
+	if (found == 0) {
+		my_memb_determine_list[my_memb_determine_list_entries] = nodeid;
+		my_memb_determine_list_entries += 1;
+	}
+}
 
-	sync_start_init (ring_id);
+static void sync_service_build_handler (unsigned int nodeid, const void *msg)
+{
+	const struct req_exec_service_build_message *req_exec_service_build_message = msg;
+	int i, j;
+	int barrier_reached = 1;
+	int found;
+	int qsort_trigger = 0;
 
-	return (0);
+	if (memcmp (&my_ring_id, &req_exec_service_build_message->ring_id,
+		sizeof (struct memb_ring_id)) != 0) {
+		log_printf (LOGSYS_LEVEL_DEBUG, "service build for old ring - discarding");
+		return;
+	}
+	for (i = 0; i < req_exec_service_build_message->service_list_entries; i++) {
+
+		found = 0;
+		for (j = 0; j < my_service_list_entries; j++) {
+			if (req_exec_service_build_message->service_list[i] ==
+				my_service_list[j].service_id) {
+				found = 1;
+				break;
+			}
+		}
+		if (found == 0) {
+			my_service_list[my_service_list_entries].state =
+				INIT;
+			my_service_list[my_service_list_entries].service_id =
+				req_exec_service_build_message->service_list[i];
+			sprintf (my_service_list[my_service_list_entries].name,
+				"External Service (id = %d)\n",
+				req_exec_service_build_message->service_list[i]);
+			my_service_list[my_service_list_entries].sync_init =
+				dummy_sync_init;
+			my_service_list[my_service_list_entries].sync_abort =
+				dummy_sync_abort;
+			my_service_list[my_service_list_entries].sync_process =
+				dummy_sync_process;
+			my_service_list[my_service_list_entries].sync_activate =
+				dummy_sync_activate;
+			my_service_list_entries += 1;
+
+			qsort_trigger = 1;
+		}
+	}
+	if (qsort_trigger) {
+		qsort (my_service_list, my_service_list_entries,
+			sizeof (struct service_entry), service_entry_compare);
+	}
+	for (i = 0; i < my_processor_list_entries; i++) {
+		if (my_processor_list[i].nodeid == nodeid) {
+			my_processor_list[i].received = 1;
+		}
+	}
+	for (i = 0; i < my_processor_list_entries; i++) {
+		if (my_processor_list[i].received == 0) {
+			barrier_reached = 0;
+		}
+	}
+	if (barrier_reached) {
+		sync_process_enter ();
+	}
 }
 
-int sync_register (
-	int (*callbacks_retrieve) (
-		int sync_id,
-		struct sync_callbacks *callbacks),
-
-	void (*started) (
-		const struct memb_ring_id *ring_id),
+static void sync_deliver_fn (
+	unsigned int nodeid,
+	const void *msg,
+	unsigned int msg_len,
+	int endian_conversion_required)
+{
+	struct qb_ipc_request_header *header = (struct qb_ipc_request_header *)msg;
 
-	void (*aborted) (void),
+	switch (header->id) {
+		case MESSAGE_REQ_SYNC_BARRIER:
+			sync_barrier_handler (nodeid, msg);
+			break;
+		case MESSAGE_REQ_SYNC_SERVICE_BUILD:
+			sync_service_build_handler (nodeid, msg);
+			break;
+		case MESSAGE_REQ_SYNC_MEMB_DETERMINE:
+			sync_memb_determine (nodeid, msg);
+			break;
+	}
+}
 
-	void (*next_start) (
-		const unsigned int *member_list,
-		size_t member_list_entries,
-		const struct memb_ring_id *ring_id))
+static void memb_determine_message_transmit (void)
 {
-	unsigned int res;
+	struct iovec iovec;
+	struct req_exec_memb_determine_message req_exec_memb_determine_message;
 
-	res = totempg_groups_initialize (
-		&sync_group_handle,
-		sync_deliver_fn,
-		sync_confchg_fn);
-	if (res == -1) {
-		log_printf (LOGSYS_LEVEL_ERROR,
-			"Couldn't initialize groups interface.");
-		return (-1);
-	}
+	req_exec_memb_determine_message.header.size = sizeof (struct req_exec_memb_determine_message);
+	req_exec_memb_determine_message.header.id = MESSAGE_REQ_SYNC_MEMB_DETERMINE;
 
-	res = totempg_groups_join (
-		sync_group_handle,
-		&sync_group,
-		1);
-	if (res == -1) {
-		log_printf (LOGSYS_LEVEL_ERROR, "Couldn't join group.");
-		return (-1);
-	}
+	memcpy (&req_exec_memb_determine_message.ring_id,
+		&my_memb_determine_ring_id,
+		sizeof (struct memb_ring_id));
 
-	sync_callbacks_retrieve = callbacks_retrieve;
-	sync_next_start = next_start;
-	sync_started = started;
-	sync_aborted = aborted;
-	return (0);
-}
+	iovec.iov_base = (char *)&req_exec_memb_determine_message;
+	iovec.iov_len = sizeof (req_exec_memb_determine_message);
 
+	(void)totempg_groups_mcast_joined (sync_group_handle,
+		&iovec, 1, TOTEMPG_AGREED);
+}
 
-static void sync_primary_callback_fn (
-	const unsigned int *view_list,
-	size_t view_list_entries,
-	const struct memb_ring_id *ring_id)
+static void barrier_message_transmit (void)
 {
-	int i;
+	struct iovec iovec;
+	struct req_exec_barrier_message req_exec_barrier_message;
 
+	req_exec_barrier_message.header.size = sizeof (struct req_exec_barrier_message);
+	req_exec_barrier_message.header.id = MESSAGE_REQ_SYNC_BARRIER;
 
-	/*
-	 * Execute configuration change for synchronization service
-	 */
-	sync_processing = 1;
+	memcpy (&req_exec_barrier_message.ring_id, &my_ring_id,
+		sizeof (struct memb_ring_id));
 
-	totempg_callback_token_destroy (&sync_callback_token_handle);
+	iovec.iov_base = (char *)&req_exec_barrier_message;
+	iovec.iov_len = sizeof (req_exec_barrier_message);
 
-	sync_recovery_index = 0;
-	memset (&barrier_data_confchg, 0, sizeof (barrier_data_confchg));
-	for (i = 0; i < view_list_entries; i++) {
-		barrier_data_confchg[i].nodeid = view_list[i];
-		barrier_data_confchg[i].completed = 0;
-	}
-	memcpy (barrier_data_process, barrier_data_confchg,
-		sizeof (barrier_data_confchg));
-	barrier_data_confchg_entries = view_list_entries;
-	sync_start_init (sync_ring_id);
+	(void)totempg_groups_mcast_joined (sync_group_handle,
+		&iovec, 1, TOTEMPG_AGREED);
 }
 
-static struct memb_ring_id deliver_ring_id;
-
-static void sync_endian_convert (struct req_exec_sync_barrier_start
-				 *req_exec_sync_barrier_start)
+static void service_build_message_transmit (struct req_exec_service_build_message *service_build_message)
 {
-	totemip_copy_endian_convert(&req_exec_sync_barrier_start->ring_id.rep,
-		&req_exec_sync_barrier_start->ring_id.rep);
-	req_exec_sync_barrier_start->ring_id.seq = swab64 (req_exec_sync_barrier_start->ring_id.seq);
+	struct iovec iovec;
+
+	service_build_message->header.size = sizeof (struct req_exec_service_build_message);
+	service_build_message->header.id = MESSAGE_REQ_SYNC_SERVICE_BUILD;
+
+	memcpy (&service_build_message->ring_id, &my_ring_id,
+		sizeof (struct memb_ring_id));
+
+	iovec.iov_base = (void *)service_build_message;
+	iovec.iov_len = sizeof (struct req_exec_service_build_message);
 
+	(void)totempg_groups_mcast_joined (sync_group_handle,
+		&iovec, 1, TOTEMPG_AGREED);
 }
 
-static void sync_deliver_fn (
-	unsigned int nodeid,
-	const void *msg,
-	unsigned int msg_len,
-	int endian_conversion_required)
+static void sync_barrier_enter (void)
 {
-	struct req_exec_sync_barrier_start *req_exec_sync_barrier_start =
-		(struct req_exec_sync_barrier_start *)msg;
-	unsigned int barrier_completed;
-	int i;
-
-	log_printf (LOGSYS_LEVEL_DEBUG, "confchg entries %lu",
-		    (unsigned long int) barrier_data_confchg_entries);
-	if (endian_conversion_required) {
-		sync_endian_convert (req_exec_sync_barrier_start);
-	}
+	my_state = SYNC_BARRIER;
+	barrier_message_transmit ();
+}
 
-	barrier_completed = 1;
+static void sync_process_enter (void)
+{
+	int i;
 
-	memcpy (&deliver_ring_id, &req_exec_sync_barrier_start->ring_id,
-		sizeof (struct memb_ring_id));
+	my_state = SYNC_PROCESS;
 
 	/*
-	 * Is this barrier from this configuration, if not, ignore it
+	 * No sync services
 	 */
-	if (memcmp (&req_exec_sync_barrier_start->ring_id, sync_ring_id,
-		sizeof (struct memb_ring_id)) != 0) {
+	if (my_service_list_entries == 0) {
+		my_state = SYNC_SERVICELIST_BUILD;
+		my_memb_determine_list_entries = 0;
+		sync_synchronization_completed ();
 		return;
 	}
-
-	/*
-	 * Set completion for source_addr's address
-	 */
-	for (i = 0; i < barrier_data_confchg_entries; i++) {
-		if (nodeid == barrier_data_process[i].nodeid) {
-			barrier_data_process[i].completed = 1;
-			log_printf (LOGSYS_LEVEL_DEBUG,
-				"Barrier Start Received From %d",
-				barrier_data_process[i].nodeid);
-			break;
-		}
+	for (i = 0; i < my_processor_list_entries; i++) {
+		my_processor_list[i].received = 0;
 	}
+	schedwrk_create (&my_schedwrk_handle,
+		schedwrk_processor,
+		NULL);
+}
 
-	/*
-	 * Test if barrier is complete
-	 */
-	for (i = 0; i < barrier_data_confchg_entries; i++) {
-		log_printf (LOGSYS_LEVEL_DEBUG,
-			"Barrier completion status for nodeid %d = %d. ",
-			barrier_data_process[i].nodeid,
-			barrier_data_process[i].completed);
-		if (barrier_data_process[i].completed == 0) {
-			barrier_completed = 0;
-		}
-	}
-	if (barrier_completed) {
-		log_printf (LOGSYS_LEVEL_DEBUG,
-			"Synchronization barrier completed");
+static void sync_servicelist_build_enter (
+	const unsigned int *member_list,
+	size_t member_list_entries,
+	const struct memb_ring_id *ring_id)
+{
+	struct req_exec_service_build_message service_build;
+	int i;
+
+	my_state = SYNC_SERVICELIST_BUILD;
+	for (i = 0; i < member_list_entries; i++) {
+		my_processor_list[i].nodeid = member_list[i];
+		my_processor_list[i].received = 0;
 	}
-	/*
-	 * This sync is complete so activate and start next service sync
-	 */
-	if (barrier_completed && sync_callbacks.sync_activate) {
-		sync_callbacks.sync_activate ();
+	my_processor_list_entries = member_list_entries;
 
-		log_printf (LOGSYS_LEVEL_DEBUG,
-			"Committing synchronization for (%s)",
-			sync_callbacks.name);
+	memcpy (my_member_list, member_list,
+		member_list_entries * sizeof (unsigned int));
+	my_member_list_entries = member_list_entries;
+
+	my_processing_idx = 0;
+
+	memcpy (my_service_list, my_initial_service_list,
+		sizeof (struct service_entry) *
+			my_initial_service_list_entries);
+	my_service_list_entries = my_initial_service_list_entries;
+
+	for (i = 0; i < my_initial_service_list[i].service_id; i++) {
+		service_build.service_list[i] =
+			my_initial_service_list[i].service_id;
 	}
+	service_build.service_list_entries = i;
 
-	/*
-	 * Start synchronization if the barrier has completed
-	 */
-	if (barrier_completed) {
-		memcpy (barrier_data_process, barrier_data_confchg,
-			sizeof (barrier_data_confchg));
-
-		sync_callbacks_load();
-
-		/*
-		 * if sync service found, execute it
-		 */
-		if (sync_processing && sync_callbacks.sync_init_api.sync_init_v1) {
-			log_printf (LOGSYS_LEVEL_DEBUG,
-				"Synchronization actions starting for (%s)",
-				sync_callbacks.name);
-			sync_service_init (&deliver_ring_id);
+	service_build_message_transmit (&service_build);
+}
+
+static int schedwrk_processor (const void *context)
+{
+	int res = 0;
+
+	if (my_service_list[my_processing_idx].state == INIT) {
+		unsigned int old_trans_list[PROCESSOR_COUNT_MAX];
+		size_t old_trans_list_entries = 0;
+		int o, m;
+		my_service_list[my_processing_idx].state = PROCESS;
+
+		memcpy (old_trans_list, my_trans_list, my_trans_list_entries *
+			sizeof (unsigned int));
+		old_trans_list_entries = my_trans_list_entries;
+
+		my_trans_list_entries = 0;
+		for (o = 0; o < old_trans_list_entries; o++) {
+			for (m = 0; m < my_member_list_entries; m++) {
+				if (old_trans_list[o] == my_member_list[m]) {
+					my_trans_list[my_trans_list_entries] = my_member_list[m];
+					my_trans_list_entries++;
+					break;
+				}
+			}
 		}
-		if (sync_processing == 0) {
-			sync_next_start (my_member_list, my_member_list_entries, sync_ring_id);
+
+		my_service_list[my_processing_idx].sync_init (my_trans_list,
+			my_trans_list_entries, my_member_list,
+			my_member_list_entries,
+			&my_ring_id);
+	}
+	if (my_service_list[my_processing_idx].state == PROCESS) {
+		my_service_list[my_processing_idx].state = PROCESS;
+		res = my_service_list[my_processing_idx].sync_process ();
+		if (res == 0) {
+			sync_barrier_enter();
+		} else {
+			return (-1);
 		}
 	}
-	return;
+	return (0);
 }
 
-static void sync_confchg_fn (
-	enum totem_configuration_type configuration_type,
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const unsigned int *left_list,
-	size_t left_list_entries,
-	const unsigned int *joined_list,
-	size_t joined_list_entries,
-	const struct memb_ring_id *ring_id)
+void sync_start (
+        const unsigned int *member_list,
+        size_t member_list_entries,
+        const struct memb_ring_id *ring_id)
 {
-	sync_ring_id = ring_id;
+	ENTER();
+	memcpy (&my_ring_id, ring_id, sizeof (struct memb_ring_id));
 
-	if (configuration_type != TOTEM_CONFIGURATION_REGULAR) {
-		memcpy (my_trans_list, member_list, member_list_entries *
-			sizeof (unsigned int));
-		my_trans_list_entries = member_list_entries;
-		return;
+	if (my_memb_determine) {
+		my_memb_determine = 0;
+		sync_servicelist_build_enter (my_memb_determine_list,
+			my_memb_determine_list_entries, ring_id);
+	} else {
+		sync_servicelist_build_enter (member_list, member_list_entries,
+			ring_id);
 	}
-	memcpy (my_member_list, member_list, member_list_entries * sizeof (unsigned int));
-	my_member_list_entries = member_list_entries;
+}
+
+void sync_save_transitional (
+        const unsigned int *member_list,
+        size_t member_list_entries,
+        const struct memb_ring_id *ring_id)
+{
+	ENTER();
+	memcpy (my_trans_list, member_list, member_list_entries *
+		sizeof (unsigned int));
+	my_trans_list_entries = member_list_entries;
+}
 
-	sync_aborted ();
-	if (sync_processing && sync_callbacks.sync_abort != NULL) {
-		sync_callbacks.sync_abort ();
-		sync_callbacks.sync_activate = NULL;
+void sync_abort (void)
+{
+	ENTER();
+	if (my_state == SYNC_PROCESS) {
+		schedwrk_destroy (my_schedwrk_handle);
+		my_service_list[my_processing_idx].sync_abort ();
 	}
 
-	sync_started (
-		ring_id);
+	/* this will cause any "old" barrier messages from causing
+	 * problems.
+	 */
+	memset (&my_ring_id, 0,	sizeof (struct memb_ring_id));
+}
 
-	sync_primary_callback_fn (
-		member_list,
-		member_list_entries,
-		ring_id);
+void sync_memb_list_determine (const struct memb_ring_id *ring_id)
+{
+	ENTER();
+	memcpy (&my_memb_determine_ring_id, ring_id,
+		sizeof (struct memb_ring_id));
+
+	memb_determine_message_transmit ();
+}
+
+void sync_memb_list_abort (void)
+{
+	ENTER();
+	my_memb_determine_list_entries = 0;
+	memset (&my_memb_determine_ring_id, 0, sizeof (struct memb_ring_id));
 }
diff --git a/exec/sync.h b/exec/sync.h
index 7913a0a..ee2f076 100644
--- a/exec/sync.h
+++ b/exec/sync.h
@@ -1,6 +1,5 @@
 /*
- * Copyright (c) 2002-2004 MontaVista Software, Inc.
- * Copyright (c) 2006-2010 Red Hat, Inc.
+ * Copyright (c) 2009-2010 Red Hat, Inc.
  *
  * All rights reserved.
  *
@@ -36,47 +35,39 @@
 #ifndef SYNC_H_DEFINED
 #define SYNC_H_DEFINED
 
-#include <netinet/in.h>
-#include <corosync/totem/totempg.h>
-#include "totemsrp.h"
-
-union sync_init_api {
-	void (*sync_init_v1) (
-		const unsigned int *member_list,
-		size_t member_list_entries,
-		const struct memb_ring_id *ring_id);
-
-	void (*sync_init_v2) (
+struct sync_callbacks {
+	void (*sync_init) (
 		const unsigned int *trans_list,
 		size_t trans_list_entries,
 		const unsigned int *member_list,
 		size_t member_list_entries,
 		const struct memb_ring_id *ring_id);
-};
-
-struct sync_callbacks {
-	int api_version;
-	union sync_init_api sync_init_api;
 	int (*sync_process) (void);
 	void (*sync_activate) (void);
 	void (*sync_abort) (void);
 	const char *name;
 };
 
-int sync_register (
+extern int sync_init (
 	int (*sync_callbacks_retrieve) (
-		int sync_id,
+		int service_id,
 		struct sync_callbacks *callbacks),
+	void (*synchronization_completed) (void));
 
-	void (*sync_started) (
-		const struct memb_ring_id *ring_id),
+extern void sync_start (
+        const unsigned int *member_list,
+        size_t member_list_entries,
+        const struct memb_ring_id *ring_id);
 
-	void (*sync_aborted) (void),
+extern void sync_save_transitional (
+        const unsigned int *member_list,
+        size_t member_list_entries,
+        const struct memb_ring_id *ring_id);
 
-	void (*next_start) (
-		const unsigned int *member_list,
-		size_t member_list_entries,
-		const struct memb_ring_id *ring_id));
+extern void sync_abort (void);
+
+extern void sync_memb_list_determine (const struct memb_ring_id *ring_id);
 
+extern void sync_memb_list_abort (void);
 
 #endif /* SYNC_H_DEFINED */
diff --git a/exec/syncv2.c b/exec/syncv2.c
deleted file mode 100644
index e50c23e..0000000
--- a/exec/syncv2.c
+++ /dev/null
@@ -1,623 +0,0 @@
-/*
- * Copyright (c) 2009-2012 Red Hat, Inc.
- *
- * All rights reserved.
- *
- * Author: Steven Dake (sdake@xxxxxxxxxx)
- *
- * This software licensed under BSD license, the text of which follows:
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- *   this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright notice,
- *   this list of conditions and the following disclaimer in the documentation
- *   and/or other materials provided with the distribution.
- * - Neither the name of the MontaVista Software, Inc. nor the names of its
- *   contributors may be used to endorse or promote products derived from this
- *   software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
-#include <config.h>
-
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <sys/ioctl.h>
-#include <netinet/in.h>
-#include <sys/uio.h>
-#include <unistd.h>
-#include <fcntl.h>
-#include <stdlib.h>
-#include <stdio.h>
-#include <errno.h>
-#include <time.h>
-#include <unistd.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-
-#include <corosync/corotypes.h>
-#include <corosync/swab.h>
-#include <corosync/totem/totempg.h>
-#include <corosync/totem/totem.h>
-#include <corosync/logsys.h>
-#include <qb/qbipc_common.h>
-#include "schedwrk.h"
-#include "quorum.h"
-#include "sync.h"
-#include "syncv2.h"
-
-LOGSYS_DECLARE_SUBSYS ("SYNCV2");
-
-#define MESSAGE_REQ_SYNC_BARRIER 0
-#define MESSAGE_REQ_SYNC_SERVICE_BUILD 1
-#define MESSAGE_REQ_SYNC_MEMB_DETERMINE 2
-
-enum sync_process_state {
-	INIT,
-	PROCESS,
-	ACTIVATE
-};
-
-enum sync_state {
-	SYNC_SERVICELIST_BUILD,
-	SYNC_PROCESS,
-	SYNC_BARRIER
-};
-
-struct service_entry {
-	int service_id;
-	int api_version;
-	union sync_init_api sync_init_api;
-	void (*sync_abort) (void);
-	int (*sync_process) (void);
-	void (*sync_activate) (void);
-	enum sync_process_state state;
-	char name[128];
-};
-
-struct processor_entry {
-	int nodeid;
-	int received;
-};
-
-struct req_exec_memb_determine_message {
-	struct qb_ipc_request_header header __attribute__((aligned(8)));
-	struct memb_ring_id ring_id __attribute__((aligned(8)));
-};
-
-struct req_exec_service_build_message {
-	struct qb_ipc_request_header header __attribute__((aligned(8)));
-	struct memb_ring_id ring_id __attribute__((aligned(8)));
-	int service_list_entries __attribute__((aligned(8)));
-	int service_list[128] __attribute__((aligned(8)));
-};
-
-struct req_exec_barrier_message {
-	struct qb_ipc_request_header header __attribute__((aligned(8)));
-	struct memb_ring_id ring_id __attribute__((aligned(8)));
-};
-
-static enum sync_state my_state = SYNC_BARRIER;
-
-static struct memb_ring_id my_ring_id;
-
-static struct memb_ring_id my_memb_determine_ring_id;
-
-static int my_memb_determine = 0;
-
-static unsigned int my_memb_determine_list[PROCESSOR_COUNT_MAX];
-
-static unsigned int my_memb_determine_list_entries = 0;
-
-static int my_processing_idx = 0;
-
-static hdb_handle_t my_schedwrk_handle;
-
-static struct processor_entry my_processor_list[PROCESSOR_COUNT_MAX];
-
-static unsigned int my_member_list[PROCESSOR_COUNT_MAX];
-
-static unsigned int my_trans_list[PROCESSOR_COUNT_MAX];
-
-static size_t my_member_list_entries = 0;
-
-static size_t my_trans_list_entries = 0;
-
-static int my_processor_list_entries = 0;
-
-static struct service_entry my_service_list[128];
-
-static int my_service_list_entries = 0;
-
-static const struct memb_ring_id sync_ring_id;
-
-static struct service_entry my_initial_service_list[PROCESSOR_COUNT_MAX];
-
-static int my_initial_service_list_entries;
-
-static void (*sync_synchronization_completed) (void);
-
-static void sync_deliver_fn (
-	unsigned int nodeid,
-	const void *msg,
-	unsigned int msg_len,
-	int endian_conversion_required);
-
-static int schedwrk_processor (const void *context);
-
-static void sync_process_enter (void);
-
-static struct totempg_group sync_group = {
-    .group      = "syncv2",
-    .group_len  = 6
-};
-
-static void *sync_group_handle;
-
-int sync_v2_init (
-        int (*sync_callbacks_retrieve) (
-                int service_id,
-                struct sync_callbacks *callbacks),
-        void (*synchronization_completed) (void))
-{
-	unsigned int res;
-	int i;
-	struct sync_callbacks sync_callbacks;
-
-	res = totempg_groups_initialize (
-		&sync_group_handle,
-		sync_deliver_fn,
-		NULL);
-	if (res == -1) {
-		log_printf (LOGSYS_LEVEL_ERROR,
-			"Couldn't initialize groups interface.");
-		return (-1);
-	}
-
-	res = totempg_groups_join (
-		sync_group_handle,
-		&sync_group,
-		1);
-	if (res == -1) {
-		log_printf (LOGSYS_LEVEL_ERROR, "Couldn't join group.");
-		return (-1);
-	}
-
-	sync_synchronization_completed = synchronization_completed;
-	for (i = 0; i < 64; i++) {
-		res = sync_callbacks_retrieve (i, &sync_callbacks);
-		if (res == -1) {
-			continue;
-		}
-		if (sync_callbacks.sync_init_api.sync_init_v1 == NULL) {
-			continue;
-		}
-		my_initial_service_list[my_initial_service_list_entries].state =
-			INIT;
-		my_initial_service_list[my_initial_service_list_entries].service_id = i;
-		strcpy (my_initial_service_list[my_initial_service_list_entries].name,
-			sync_callbacks.name);
-		my_initial_service_list[my_initial_service_list_entries].api_version = sync_callbacks.api_version;
-		my_initial_service_list[my_initial_service_list_entries].sync_init_api = sync_callbacks.sync_init_api;
-		my_initial_service_list[my_initial_service_list_entries].sync_process = sync_callbacks.sync_process;
-		my_initial_service_list[my_initial_service_list_entries].sync_abort = sync_callbacks.sync_abort;
-		my_initial_service_list[my_initial_service_list_entries].sync_activate = sync_callbacks.sync_activate;
-		my_initial_service_list_entries += 1;
-	}
-	return (0);
-}
-
-static void sync_barrier_handler (unsigned int nodeid, const void *msg)
-{
-	const struct req_exec_barrier_message *req_exec_barrier_message = msg;
-	int i;
-	int barrier_reached = 1;
-
-	if (memcmp (&my_ring_id, &req_exec_barrier_message->ring_id,
-		sizeof (struct memb_ring_id)) != 0) {
-
-		log_printf (LOGSYS_LEVEL_DEBUG, "barrier for old ring - discarding");
-		return;
-	}
-	for (i = 0; i < my_processor_list_entries; i++) {
-		if (my_processor_list[i].nodeid == nodeid) {
-			my_processor_list[i].received = 1;
-		}
-	}
-	for (i = 0; i < my_processor_list_entries; i++) {
-		if (my_processor_list[i].received == 0) {
-			barrier_reached = 0;
-		}
-	}
-	if (barrier_reached) {
-		log_printf (LOGSYS_LEVEL_DEBUG, "Committing synchronization for %s",
-			my_service_list[my_processing_idx].name);
-		my_service_list[my_processing_idx].state = ACTIVATE;
-		my_service_list[my_processing_idx].sync_activate ();
-
-		my_processing_idx += 1;
-		if (my_service_list_entries == my_processing_idx) {
-			my_memb_determine_list_entries = 0;
-			sync_synchronization_completed ();
-		} else {
-			sync_process_enter ();
-		}
-	}
-}
-
-static void dummy_sync_init (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id)
-{
-}
-
-static void dummy_sync_abort (void)
-{
-}
-
-static int dummy_sync_process (void)
-{
-	return (0);
-}
-
-static void dummy_sync_activate (void)
-{
-}
-
-static int service_entry_compare (const void *a, const void *b)
-{
-	const struct service_entry *service_entry_a = a;
-	const struct service_entry *service_entry_b = b;
-
-	return (service_entry_a->service_id > service_entry_b->service_id);
-}
-
-static void sync_memb_determine (unsigned int nodeid, const void *msg)
-{
-	const struct req_exec_memb_determine_message *req_exec_memb_determine_message = msg;
-	int found = 0;
-	int i;
-
-	if (memcmp (&req_exec_memb_determine_message->ring_id,
-		&my_memb_determine_ring_id, sizeof (struct memb_ring_id)) != 0) {
-
-		log_printf (LOGSYS_LEVEL_DEBUG, "memb determine for old ring - discarding");
-		return;
-	}
-
-	my_memb_determine = 1;
-	for (i = 0; i < my_memb_determine_list_entries; i++) {
-		if (my_memb_determine_list[i] == nodeid) {
-			found = 1;
-		}
-	}
-	if (found == 0) {
-		my_memb_determine_list[my_memb_determine_list_entries] = nodeid;
-		my_memb_determine_list_entries += 1;
-	}
-}
-
-static void sync_service_build_handler (unsigned int nodeid, const void *msg)
-{
-	const struct req_exec_service_build_message *req_exec_service_build_message = msg;
-	int i, j;
-	int barrier_reached = 1;
-	int found;
-	int qsort_trigger = 0;
-
-	if (memcmp (&my_ring_id, &req_exec_service_build_message->ring_id,
-		sizeof (struct memb_ring_id)) != 0) {
-		log_printf (LOGSYS_LEVEL_DEBUG, "service build for old ring - discarding");
-		return;
-	}
-	for (i = 0; i < req_exec_service_build_message->service_list_entries; i++) {
-
-		found = 0;
-		for (j = 0; j < my_service_list_entries; j++) {
-			if (req_exec_service_build_message->service_list[i] ==
-				my_service_list[j].service_id) {
-				found = 1;
-				break;
-			}
-		}
-		if (found == 0) {
-			my_service_list[my_service_list_entries].state =
-				INIT;
-			my_service_list[my_service_list_entries].service_id =
-				req_exec_service_build_message->service_list[i];
-			sprintf (my_service_list[my_service_list_entries].name,
-				"External Service (id = %d)\n",
-				req_exec_service_build_message->service_list[i]);
-			my_service_list[my_service_list_entries].api_version = 1;
-			my_service_list[my_service_list_entries].sync_init_api.sync_init_v1 =
-				dummy_sync_init;
-			my_service_list[my_service_list_entries].sync_abort =
-				dummy_sync_abort;
-			my_service_list[my_service_list_entries].sync_process =
-				dummy_sync_process;
-			my_service_list[my_service_list_entries].sync_activate =
-				dummy_sync_activate;
-			my_service_list_entries += 1;
-
-			qsort_trigger = 1;
-		}
-	}
-	if (qsort_trigger) {
-		qsort (my_service_list, my_service_list_entries,
-			sizeof (struct service_entry), service_entry_compare);
-	}
-	for (i = 0; i < my_processor_list_entries; i++) {
-		if (my_processor_list[i].nodeid == nodeid) {
-			my_processor_list[i].received = 1;
-		}
-	}
-	for (i = 0; i < my_processor_list_entries; i++) {
-		if (my_processor_list[i].received == 0) {
-			barrier_reached = 0;
-		}
-	}
-	if (barrier_reached) {
-		sync_process_enter ();
-	}
-}
-
-static void sync_deliver_fn (
-	unsigned int nodeid,
-	const void *msg,
-	unsigned int msg_len,
-	int endian_conversion_required)
-{
-	struct qb_ipc_request_header *header = (struct qb_ipc_request_header *)msg;
-
-	switch (header->id) {
-		case MESSAGE_REQ_SYNC_BARRIER:
-			sync_barrier_handler (nodeid, msg);
-			break;
-		case MESSAGE_REQ_SYNC_SERVICE_BUILD:
-			sync_service_build_handler (nodeid, msg);
-			break;
-		case MESSAGE_REQ_SYNC_MEMB_DETERMINE:
-			sync_memb_determine (nodeid, msg);
-			break;
-	}
-}
-
-static void memb_determine_message_transmit (void)
-{
-	struct iovec iovec;
-	struct req_exec_memb_determine_message req_exec_memb_determine_message;
-
-	req_exec_memb_determine_message.header.size = sizeof (struct req_exec_memb_determine_message);
-	req_exec_memb_determine_message.header.id = MESSAGE_REQ_SYNC_MEMB_DETERMINE;
-
-	memcpy (&req_exec_memb_determine_message.ring_id,
-		&my_memb_determine_ring_id,
-		sizeof (struct memb_ring_id));
-
-	iovec.iov_base = (char *)&req_exec_memb_determine_message;
-	iovec.iov_len = sizeof (req_exec_memb_determine_message);
-
-	(void)totempg_groups_mcast_joined (sync_group_handle,
-		&iovec, 1, TOTEMPG_AGREED);
-}
-
-static void barrier_message_transmit (void)
-{
-	struct iovec iovec;
-	struct req_exec_barrier_message req_exec_barrier_message;
-
-	req_exec_barrier_message.header.size = sizeof (struct req_exec_barrier_message);
-	req_exec_barrier_message.header.id = MESSAGE_REQ_SYNC_BARRIER;
-
-	memcpy (&req_exec_barrier_message.ring_id, &my_ring_id,
-		sizeof (struct memb_ring_id));
-
-	iovec.iov_base = (char *)&req_exec_barrier_message;
-	iovec.iov_len = sizeof (req_exec_barrier_message);
-
-	(void)totempg_groups_mcast_joined (sync_group_handle,
-		&iovec, 1, TOTEMPG_AGREED);
-}
-
-static void service_build_message_transmit (struct req_exec_service_build_message *service_build_message)
-{
-	struct iovec iovec;
-
-	service_build_message->header.size = sizeof (struct req_exec_service_build_message);
-	service_build_message->header.id = MESSAGE_REQ_SYNC_SERVICE_BUILD;
-
-	memcpy (&service_build_message->ring_id, &my_ring_id,
-		sizeof (struct memb_ring_id));
-
-	iovec.iov_base = (void *)service_build_message;
-	iovec.iov_len = sizeof (struct req_exec_service_build_message);
-
-	(void)totempg_groups_mcast_joined (sync_group_handle,
-		&iovec, 1, TOTEMPG_AGREED);
-}
-
-static void sync_barrier_enter (void)
-{
-	my_state = SYNC_BARRIER;
-	barrier_message_transmit ();
-}
-
-static void sync_process_enter (void)
-{
-	int i;
-
-	my_state = SYNC_PROCESS;
-
-	/*
-	 * No syncv2 services
-	 */
-	if (my_service_list_entries == 0) {
-		my_state = SYNC_SERVICELIST_BUILD;
-		my_memb_determine_list_entries = 0;
-		sync_synchronization_completed ();
-		return;
-	}
-	for (i = 0; i < my_processor_list_entries; i++) {
-		my_processor_list[i].received = 0;
-	}
-	schedwrk_create (&my_schedwrk_handle,
-		schedwrk_processor,
-		NULL);
-}
-
-static void sync_servicelist_build_enter (
-	const unsigned int *member_list,
-	size_t member_list_entries,
-	const struct memb_ring_id *ring_id)
-{
-	struct req_exec_service_build_message service_build;
-	int i;
-
-	my_state = SYNC_SERVICELIST_BUILD;
-	for (i = 0; i < member_list_entries; i++) {
-		my_processor_list[i].nodeid = member_list[i];
-		my_processor_list[i].received = 0;
-	}
-	my_processor_list_entries = member_list_entries;
-
-	memcpy (my_member_list, member_list,
-		member_list_entries * sizeof (unsigned int));
-	my_member_list_entries = member_list_entries;
-
-	my_processing_idx = 0;
-
-	memcpy (my_service_list, my_initial_service_list,
-		sizeof (struct service_entry) *
-			my_initial_service_list_entries);
-	my_service_list_entries = my_initial_service_list_entries;
-
-	for (i = 0; i < my_initial_service_list[i].service_id; i++) {
-		service_build.service_list[i] =
-			my_initial_service_list[i].service_id;
-	}
-	service_build.service_list_entries = i;
-
-	service_build_message_transmit (&service_build);
-}
-
-static int schedwrk_processor (const void *context)
-{
-	int res = 0;
-
-	if (my_service_list[my_processing_idx].state == INIT) {
-		my_service_list[my_processing_idx].state = PROCESS;
-		if (my_service_list[my_processing_idx].api_version == 1) {
-			my_service_list[my_processing_idx].sync_init_api.sync_init_v1 (my_member_list,
-				my_member_list_entries,
-				&my_ring_id);
-		} else {
-			unsigned int old_trans_list[PROCESSOR_COUNT_MAX];
-			size_t old_trans_list_entries = 0;
-			int o, m;
-
-			memcpy (old_trans_list, my_trans_list, my_trans_list_entries *
-				sizeof (unsigned int));
-			old_trans_list_entries = my_trans_list_entries;
-
-			my_trans_list_entries = 0;
-			for (o = 0; o < old_trans_list_entries; o++) {
-				for (m = 0; m < my_member_list_entries; m++) {
-					if (old_trans_list[o] == my_member_list[m]) {
-						my_trans_list[my_trans_list_entries] = my_member_list[m];
-						my_trans_list_entries++;
-						break;
-					}
-				}
-			}
-
-			my_service_list[my_processing_idx].sync_init_api.sync_init_v2 (my_trans_list,
-				my_trans_list_entries, my_member_list,
-				my_member_list_entries,
-				&my_ring_id);
-		}
-	}
-	if (my_service_list[my_processing_idx].state == PROCESS) {
-		my_service_list[my_processing_idx].state = PROCESS;
-		res = my_service_list[my_processing_idx].sync_process ();
-		if (res == 0) {
-			sync_barrier_enter();
-		} else {
-			return (-1);
-		}
-	}
-	return (0);
-}
-
-void sync_v2_start (
-        const unsigned int *member_list,
-        size_t member_list_entries,
-        const struct memb_ring_id *ring_id)
-{
-	ENTER();
-	memcpy (&my_ring_id, ring_id, sizeof (struct memb_ring_id));
-
-	if (my_memb_determine) {
-		my_memb_determine = 0;
-		sync_servicelist_build_enter (my_memb_determine_list,
-			my_memb_determine_list_entries, ring_id);
-	} else {
-		sync_servicelist_build_enter (member_list, member_list_entries,
-			ring_id);
-	}
-}
-
-void sync_v2_save_transitional (
-        const unsigned int *member_list,
-        size_t member_list_entries,
-        const struct memb_ring_id *ring_id)
-{
-	ENTER();
-	memcpy (my_trans_list, member_list, member_list_entries *
-		sizeof (unsigned int));
-	my_trans_list_entries = member_list_entries;
-}
-
-void sync_v2_abort (void)
-{
-	ENTER();
-	if (my_state == SYNC_PROCESS) {
-		schedwrk_destroy (my_schedwrk_handle);
-		my_service_list[my_processing_idx].sync_abort ();
-	}
-
-	/* this will cause any "old" barrier messages from causing
-	 * problems.
-	 */
-	memset (&my_ring_id, 0,	sizeof (struct memb_ring_id));
-}
-
-void sync_v2_memb_list_determine (const struct memb_ring_id *ring_id)
-{
-	ENTER();
-	memcpy (&my_memb_determine_ring_id, ring_id,
-		sizeof (struct memb_ring_id));
-
-	memb_determine_message_transmit ();
-}
-
-void sync_v2_memb_list_abort (void)
-{
-	ENTER();
-	my_memb_determine_list_entries = 0;
-	memset (&my_memb_determine_ring_id, 0, sizeof (struct memb_ring_id));
-}
diff --git a/exec/syncv2.h b/exec/syncv2.h
deleted file mode 100644
index 5cb318a..0000000
--- a/exec/syncv2.h
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright (c) 2009-2010 Red Hat, Inc.
- *
- * All rights reserved.
- *
- * Author: Steven Dake (sdake@xxxxxxxxxx)
- *
- * This software licensed under BSD license, the text of which follows:
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- *   this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright notice,
- *   this list of conditions and the following disclaimer in the documentation
- *   and/or other materials provided with the distribution.
- * - Neither the name of the MontaVista Software, Inc. nor the names of its
- *   contributors may be used to endorse or promote products derived from this
- *   software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#ifndef SYNCV2_H_DEFINED
-#define SYNCV2_H_DEFINED
-
-#include "sync.h"
-
-extern int sync_v2_init (
-	int (*sync_callbacks_retrieve) (
-		int service_id,
-		struct sync_callbacks *callbacks),
-	void (*synchronization_completed) (void));
-
-extern void sync_v2_start (
-        const unsigned int *member_list,
-        size_t member_list_entries,
-        const struct memb_ring_id *ring_id);
-
-extern void sync_v2_save_transitional (
-        const unsigned int *member_list,
-        size_t member_list_entries,
-        const struct memb_ring_id *ring_id);
-
-extern void sync_v2_abort (void);
-
-extern void sync_v2_memb_list_determine (const struct memb_ring_id *ring_id);
-
-extern void sync_v2_memb_list_abort (void);
-
-#endif /* SYNC_H_DEFINED */
diff --git a/exec/util.c b/exec/util.c
index 9a44275..c0d5c8b 100644
--- a/exec/util.c
+++ b/exec/util.c
@@ -59,27 +59,14 @@ struct service_names {
 static struct service_names servicenames[] =
 {
 	{ "EVS", EVS_SERVICE },
-	{ "CLM", CLM_SERVICE },
-	{ "AMF", AMF_SERVICE },
-	{ "CKPT", CKPT_SERVICE },
-	{ "EVT", EVT_SERVICE },
-	{ "LCK", LCK_SERVICE },
-	{ "MSG", MSG_SERVICE },
 	{ "CFG", CFG_SERVICE },
 	{ "CPG", CPG_SERVICE },
-	{ "CMAN", CMAN_SERVICE },
-	{ "PCMK", PCMK_SERVICE },
-	{ "CONFDB", CONFDB_SERVICE },
 	{ "QUORUM", QUORUM_SERVICE },
 	{ "PLOAD", PLOAD_SERVICE },
-	{ "TMR", TMR_SERVICE },
 	{ "VOTEQUORUM", VOTEQUORUM_SERVICE },
-	{ "NTF", NTF_SERVICE },
-	{ "AMF", AMF_V2_SERVICE },
-	{ "TST", TST_SV1_SERVICE },
-	{ "TST", TST_SV2_SERVICE },
 	{ "MON", MON_SERVICE },
 	{ "WD", WD_SERVICE },
+	{ "CMAP", CMAP_SERVICE },
 	{ NULL, -1 }
 };
 
diff --git a/exec/votequorum.c b/exec/votequorum.c
index 4d1fda8..3362c66 100644
--- a/exec/votequorum.c
+++ b/exec/votequorum.c
@@ -380,8 +380,7 @@ static struct corosync_service_engine votequorum_service_engine = {
 	.exec_exit_fn			= votequorum_exec_exit_fn,
 	.exec_engine			= votequorum_exec_engine,
 	.exec_engine_count		= sizeof (votequorum_exec_engine) / sizeof (struct corosync_exec_handler),
-	.confchg_fn			= votequorum_confchg_fn,
-	.sync_mode			= CS_SYNC_V1
+	.confchg_fn			= votequorum_confchg_fn
 };
 
 struct corosync_service_engine *votequorum_get_service_engine_ver0 (void)
diff --git a/exec/vsf_quorum.c b/exec/vsf_quorum.c
index 54abd1e..9cab2d2 100644
--- a/exec/vsf_quorum.c
+++ b/exec/vsf_quorum.c
@@ -194,8 +194,7 @@ static struct corosync_service_engine quorum_service_handler = {
 	.lib_exit_fn				= quorum_lib_exit_fn,
 	.lib_engine				= quorum_lib_service,
 	.exec_init_fn				= quorum_exec_init_fn,
-	.lib_engine_count			= sizeof (quorum_lib_service) / sizeof (struct corosync_lib_handler),
-	.sync_mode				= CS_SYNC_V1
+	.lib_engine_count			= sizeof (quorum_lib_service) / sizeof (struct corosync_lib_handler)
 };
 
 struct corosync_service_engine *vsf_quorum_get_service_engine_ver0 (void)
diff --git a/exec/wd.c b/exec/wd.c
index 4066388..5194ea7 100644
--- a/exec/wd.c
+++ b/exec/wd.c
@@ -105,8 +105,7 @@ struct corosync_service_engine wd_service_engine = {
 	.confchg_fn		= NULL,
 	.exec_init_fn		= wd_exec_init_fn,
 	.exec_exit_fn		= wd_exec_exit_fn,
-	.exec_dump_fn		= NULL,
-	.sync_mode		= CS_SYNC_V2
+	.exec_dump_fn		= NULL
 };
 
 static DECLARE_LIST_INIT (confchg_notify);
diff --git a/include/corosync/coroapi.h b/include/corosync/coroapi.h
index d78f8aa..cbadeeb 100644
--- a/include/corosync/coroapi.h
+++ b/include/corosync/coroapi.h
@@ -142,12 +142,6 @@ enum cs_flow_control_state {
 
 #endif /* COROSYNC_FLOW_CONTROL_STATE */
 
-enum cs_sync_mode {
-	CS_SYNC_V1	 = 0,
-	CS_SYNC_V2	 = 1,
-	CS_SYNC_V1_APIV2 = 2
-};
-
 typedef enum {
 	COROSYNC_FATAL_ERROR_EXIT = -1,
 	COROSYNC_LIBAIS_SOCKET = -6,
@@ -429,11 +423,6 @@ struct corosync_service_engine_iface_ver0 {
         struct corosync_service_engine *(*corosync_get_service_engine_ver0) (void);
 };
 
-typedef void (*sync_init_v1_fn_t) (
-		const unsigned int *member_list,
-		size_t member_list_entries,
-		const struct memb_ring_id *ring_id) ;
-
 struct corosync_service_engine {
 	const char *name;
 	unsigned short id;
@@ -459,8 +448,12 @@ struct corosync_service_engine {
 		const unsigned int *left_list, size_t left_list_entries,
 		const unsigned int *joined_list, size_t joined_list_entries,
 		const struct memb_ring_id *ring_id);
-	enum cs_sync_mode sync_mode;
-	sync_init_v1_fn_t sync_init;
+	void (*sync_init) (
+		const unsigned int *trans_list,
+		size_t trans_list_entries,
+		const unsigned int *member_list,
+		size_t member_list_entries,
+		const struct memb_ring_id *ring_id);
 	int (*sync_process) (void);
 	void (*sync_activate) (void);
 	void (*sync_abort) (void);
diff --git a/include/corosync/corodefs.h b/include/corosync/corodefs.h
index 19d6a9c..c391c57 100644
--- a/include/corosync/corodefs.h
+++ b/include/corosync/corodefs.h
@@ -39,28 +39,14 @@
 
 enum corosync_service_types {
 	EVS_SERVICE = 0,
-	CLM_SERVICE = 1,
-	AMF_SERVICE = 2,
-	CKPT_SERVICE = 3,
-	EVT_SERVICE = 4,
-	LCK_SERVICE = 5,
-	MSG_SERVICE = 6,
-	CFG_SERVICE = 7,
-	CPG_SERVICE = 8,
-	CMAN_SERVICE = 9,
-	PCMK_SERVICE = 10,
-	CONFDB_SERVICE = 11,
-	QUORUM_SERVICE = 12,
-	PLOAD_SERVICE = 13,
-	TMR_SERVICE = 14,
-	VOTEQUORUM_SERVICE = 15,
-	NTF_SERVICE = 16,
-	AMF_V2_SERVICE = 17,
-	TST_SV1_SERVICE = 18,
-	TST_SV2_SERVICE = 19,
-	MON_SERVICE = 20,
-	WD_SERVICE = 21,
-	CMAP_SERVICE = 22,
+	CFG_SERVICE = 1,
+	CPG_SERVICE = 2,
+	QUORUM_SERVICE = 3,
+	PLOAD_SERVICE = 4,
+	VOTEQUORUM_SERVICE = 5,
+	MON_SERVICE = 6,
+	WD_SERVICE = 7,
+	CMAP_SERVICE = 8,
 };
 
 #ifdef HAVE_SMALL_MEMORY_FOOTPRINT
diff --git a/man/corosync.conf.5 b/man/corosync.conf.5
index f6e5dab..3fe4da5 100644
--- a/man/corosync.conf.5
+++ b/man/corosync.conf.5
@@ -60,18 +60,6 @@ This top level directive contains configuration options for nodes in cluster.
 
 .PP
 .PP
-It is also possible to specify the top level parameter
-.B compatibility.
-This directive indicates the level of compatibility requested by the user.  The
-option whitetank can be specified to remain backward compatable with
-openais-0.80.z.  The option none can be specified to only be compatable
-with corosync-1.Y.Z.  Extra processing during configuration changes is
-required to remain backward compatable.
-
-The default is whitetank. (backwards compatibility)
-
-.PP
-.PP
 Within the
 .B totem
 directive, an interface directive is required.  There is also one configuration
-- 
1.7.7.6

_______________________________________________
discuss mailing list
discuss@xxxxxxxxxxxx
http://lists.corosync.org/mailman/listinfo/discuss


[Corosync Project]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]    [Yosemite Photos]    [Free Online Dating]     [Linux Kernel]     [Linux SCSI]     [XFree86]

Add to Google Powered by Linux