|
|
@@ -0,0 +1,329 @@
|
|
|
+/*
|
|
|
+ * Copyright (c) 2002-2005 MontaVista Software, Inc.
|
|
|
+ *
|
|
|
+ * All rights reserved.
|
|
|
+ *
|
|
|
+ * Author: Steven Dake (sdake@mvista.com)
|
|
|
+ *
|
|
|
+ * 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 IPC_CKPT_H_DEFINED
|
|
|
+#define IPC_CKPT_H_DEFINED
|
|
|
+
|
|
|
+#include "../include/ipc_gen.h"
|
|
|
+#include "../include/ais_types.h"
|
|
|
+#include "../include/saCkpt.h"
|
|
|
+
|
|
|
+enum req_lib_ckpt_checkpoint_types {
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTOPEN = 1,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTOPENASYNC,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTCLOSE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTUNLINK,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTRETENTIONDURATIONSET,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_ACTIVEREPLICASET,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTSTATUSGET,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONCREATE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONDELETE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONEXPIRATIONTIMESET,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONWRITE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONOVERWRITE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_SECTIONREAD,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTSYNCHRONIZE,
|
|
|
+ MESSAGE_REQ_CKPT_CHECKPOINT_CHECKPOINTSYNCHRONIZEASYNC,
|
|
|
+ MESSAGE_REQ_CKPT_SECTIONITERATOR_SECTIONITERATORINITIALIZE,
|
|
|
+ MESSAGE_REQ_CKPT_SECTIONITERATOR_SECTIONITERATORNEXT
|
|
|
+};
|
|
|
+
|
|
|
+enum res_lib_ckpt_checkpoint_types {
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTOPEN,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTOPENASYNC,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTCLOSE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTUNLINK,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTRETENTIONDURATIONSET,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_ACTIVEREPLICASET,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTSTATUSGET,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONCREATE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONDELETE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONEXPIRATIONTIMESET,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONWRITE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONOVERWRITE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_SECTIONREAD,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTSYNCHRONIZE,
|
|
|
+ MESSAGE_RES_CKPT_CHECKPOINT_CHECKPOINTSYNCHRONIZEASYNC,
|
|
|
+ MESSAGE_RES_CKPT_SECTIONITERATOR_SECTIONITERATORINITIALIZE,
|
|
|
+ MESSAGE_RES_CKPT_SECTIONITERATOR_SECTIONITERATORNEXT
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_checkpointclose {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_checkpointretentiondurationset {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaTimeT retentionDuration;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_checkpointretentiondurationexpire {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointopen {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaCkptCheckpointCreationAttributesT checkpointCreationAttributes;
|
|
|
+ SaCkptCheckpointOpenFlagsT checkpointOpenFlags;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointopen {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_checkpointopen {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ struct req_lib_ckpt_checkpointopen req_lib_ckpt_checkpointopen;
|
|
|
+};
|
|
|
+
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointopenasync {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaCkptCheckpointCreationAttributesT checkpointCreationAttributes;
|
|
|
+ SaCkptCheckpointOpenFlagsT checkpointOpenFlags;
|
|
|
+ SaInvocationT invocation;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointopenasync {
|
|
|
+ struct res_header header;
|
|
|
+ SaCkptCheckpointHandleT checkpointHandle;
|
|
|
+ SaInvocationT invocation;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointclose {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointclose {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointunlink {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointunlink {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_checkpointunlink {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ struct req_lib_ckpt_checkpointunlink req_lib_ckpt_checkpointunlink;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointretentiondurationset {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaTimeT retentionDuration;
|
|
|
+};
|
|
|
+struct res_lib_ckpt_checkpointretentiondurationset {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_activereplicaset {
|
|
|
+ struct req_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_activereplicaset {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointstatusget {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointstatusget {
|
|
|
+ struct res_header header;
|
|
|
+ SaCkptCheckpointDescriptorT checkpointDescriptor;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectioncreate {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+ SaTimeT expirationTime;
|
|
|
+ SaUint32T initialDataSize;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectioncreate {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_sectioncreate {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectioncreate req_lib_ckpt_sectioncreate; /* this must be last */
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectiondelete {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectiondelete {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+struct req_exec_ckpt_sectiondelete {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectiondelete req_lib_ckpt_sectiondelete; /* this must be last */
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectionexpirationtimeset {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+ SaTimeT expirationTime;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectionexpirationtimeset {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_sectionexpirationtimeset {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectionexpirationtimeset req_lib_ckpt_sectionexpirationtimeset;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectioniteratorinitialize {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaCkptSectionsChosenT sectionsChosen;
|
|
|
+ SaTimeT expirationTime;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectioniteratorinitialize {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectioniteratornext {
|
|
|
+ struct req_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectioniteratornext {
|
|
|
+ struct res_header header;
|
|
|
+ SaCkptSectionDescriptorT sectionDescriptor;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectionwrite {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+ SaOffsetT dataOffset;
|
|
|
+ SaOffsetT dataSize;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectionwrite {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_sectionwrite {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectionwrite req_lib_ckpt_sectionwrite;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectionoverwrite {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+ SaUint32T dataSize;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectionoverwrite {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_sectionoverwrite {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectionoverwrite req_lib_ckpt_sectionoverwrite;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_sectionread {
|
|
|
+ struct req_header header;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ SaUint32T idLen;
|
|
|
+ SaOffsetT dataOffset;
|
|
|
+ SaOffsetT dataSize;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_sectionread {
|
|
|
+ struct res_header header;
|
|
|
+ SaSizeT dataRead;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_exec_ckpt_sectionread {
|
|
|
+ struct req_header header;
|
|
|
+ struct message_source source;
|
|
|
+ SaNameT checkpointName;
|
|
|
+ struct req_lib_ckpt_sectionread req_lib_ckpt_sectionread;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointsynchronize {
|
|
|
+ struct req_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointsynchronize {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+struct req_lib_ckpt_checkpointsynchronizeasync {
|
|
|
+ struct req_header header;
|
|
|
+ SaInvocationT invocation;
|
|
|
+};
|
|
|
+
|
|
|
+struct res_lib_ckpt_checkpointsynchronizeasync {
|
|
|
+ struct res_header header;
|
|
|
+};
|
|
|
+
|
|
|
+#endif /* IPC_CKPT_H_DEFINED */
|