summaryrefslogtreecommitdiffstats
path: root/ucs2-lib/inc/ucs_rsm.h
diff options
context:
space:
mode:
Diffstat (limited to 'ucs2-lib/inc/ucs_rsm.h')
-rw-r--r--ucs2-lib/inc/ucs_rsm.h161
1 files changed, 161 insertions, 0 deletions
diff --git a/ucs2-lib/inc/ucs_rsm.h b/ucs2-lib/inc/ucs_rsm.h
new file mode 100644
index 0000000..261542a
--- /dev/null
+++ b/ucs2-lib/inc/ucs_rsm.h
@@ -0,0 +1,161 @@
+/*------------------------------------------------------------------------------------------------*/
+/* UNICENS V2.1.0-3491 */
+/* Copyright (c) 2017 Microchip Technology Germany II GmbH & Co. KG. */
+/* */
+/* This program is free software: you can redistribute it and/or modify */
+/* it under the terms of the GNU General Public License as published by */
+/* the Free Software Foundation, either version 2 of the License, or */
+/* (at your option) any later version. */
+/* */
+/* This program is distributed in the hope that it will be useful, */
+/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
+/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
+/* GNU General Public License for more details. */
+/* */
+/* You should have received a copy of the GNU General Public License */
+/* along with this program. If not, see <http://www.gnu.org/licenses/>. */
+/* */
+/* You may also obtain this software under a propriety license from Microchip. */
+/* Please contact Microchip for further information. */
+/*------------------------------------------------------------------------------------------------*/
+
+
+/*!
+ * \file
+ * \brief Internal header file of the Remote Sync Manager.
+ *
+ * \cond UCS_INTERNAL_DOC
+ * \addtogroup G_RSM
+ * @{
+ */
+
+
+#ifndef UCS_RSM_H
+#define UCS_RSM_H
+
+/*------------------------------------------------------------------------------------------------*/
+/* Includes */
+/*------------------------------------------------------------------------------------------------*/
+#include "ucs_net.h"
+#include "ucs_base.h"
+#include "ucs_inic.h"
+#include "ucs_ret_pb.h"
+#include "ucs_obs.h"
+#include "ucs_rsm_pv.h"
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+
+/*------------------------------------------------------------------------------------------------*/
+/* Enumerations */
+/*------------------------------------------------------------------------------------------------*/
+/*! \brief RSM internal state transitions */
+typedef enum Rsm_StateTransition_
+{
+ RSM_ST_IDLE, /*!< \brief Transition to "Idle" state */
+ RSM_ST_SYNC_REQ, /*!< \brief Transition to "Sync Request" state */
+ RSM_ST_NTF_REQ, /*!< \brief Transition to "Notification Request" state */
+ RSM_ST_NTF_CLEAR, /*!< \brief Transition to "Notification Clear" state */
+ RSM_ST_NTF_ALL, /*!< \brief Transition to "All Notification" state */
+ RSM_ST_NTF_GPIO, /*!< \brief Transition to "Gpio Notification" state */
+ RSM_ST_SYNC_SUCC, /*!< \brief Transition to "Sync Success" state */
+ RSM_ST_SYNC_ERR /*!< \brief Transition to "Sync Error" state */
+
+} Rsm_StateTransition_t;
+
+/*------------------------------------------------------------------------------------------------*/
+/* Structures */
+/*------------------------------------------------------------------------------------------------*/
+/*! \brief Stores data required by RSM during initialization. */
+typedef struct Rsm_InitData_
+{
+ CBase *base_ptr; /*!< \brief Reference to base instance */
+ CInic *inic_ptr; /*!< \brief Reference to INIC instance */
+ CNetworkManagement *net_ptr; /*!< \brief Reference to Network instance */
+
+} Rsm_InitData_t;
+
+/*! \brief Stores information required for a RSM device. */
+typedef struct Rsm_DeviceInfos_
+{
+ /*! \brief State of the device */
+ Rsm_DevSyncState_t sync_state;
+ /*! \brief next state transition */
+ Rsm_StateTransition_t next_st;
+ /*! \brief stores the current result */
+ Rsm_Result_t curr_result;
+ /*! \brief stores the current user data that'll be passes to curr_res_cb_fptr */
+ void * curr_user_data;
+ /*! \brief current result callback function ptr */
+ Rsm_ResultCb_t curr_res_cb_fptr;
+
+} Rsm_DeviceInfos_t;
+
+/*! \brief Stores parameter used for signaling RSM event. */
+typedef struct Rsm_EventParam_
+{
+ /*! \brief own current device address */
+ uint16_t own_device_address;
+ /*! \brief max node position */
+ uint8_t max_node_pos;
+ /*! \brief Result observer used for sockets, ports and connections */
+ CSingleObserver stdresult_observer;
+ /*! \brief Observer used to monitor ICM or MCM Tx Message objects availability */
+ CObserver txavailability_observer;
+ /*! \brief Observer used to monitor MNS initialization result */
+ CMaskedObserver ucsinit_observer;
+ /*! \brief Observe MOST Network status in Net module */
+ CMaskedObserver nwstatus_observer;
+ /*! \brief Own subject to notify the SyncLost event */
+ CSubject subject;
+
+} Rsm_EventParam_t;
+
+/*! \brief Class structure of the Remote Sync Management. */
+typedef struct CRemoteSyncManagement_
+{
+ /*! \brief Reference to an INIC instance */
+ CInic *inic_ptr;
+ /*! \brief Reference to a base instance */
+ CBase *base_ptr;
+ /*! \brief Reference to a network instance */
+ CNetworkManagement *net_ptr;
+ /*! \brief RSM DeviceInfos list */
+ Rsm_DeviceInfos_t dev_infos;
+ /*! \brief stores the last synclost cause */
+ Rsm_SyncLostCause_t last_synclost_cause;
+ /*! \brief Parameter object for the RSM Event */
+ Rsm_EventParam_t event_param;
+ /*! \brief Service instance for the scheduler */
+ CService rsm_srv;
+
+} CRemoteSyncManagement;
+
+/*------------------------------------------------------------------------------------------------*/
+/* Prototypes of class CRemoteSyncManagement */
+/*------------------------------------------------------------------------------------------------*/
+extern void Rsm_Ctor(CRemoteSyncManagement * self, Rsm_InitData_t * init_ptr);
+extern void Rsm_AddObserver(CRemoteSyncManagement * self, CObserver * obs);
+extern void Rsm_DelObserver(CRemoteSyncManagement * self, CObserver * obs_ptr);
+extern Ucs_Return_t Rsm_SyncDev(CRemoteSyncManagement * self, void* user_data, Rsm_ResultCb_t sync_complete_fptr);
+extern Rsm_DevSyncState_t Rsm_GetDevState(CRemoteSyncManagement * self);
+extern void Rsm_ReportSyncLost (CRemoteSyncManagement * self);
+
+#ifdef __cplusplus
+} /* extern "C" */
+#endif
+
+#endif /* #ifndef UCS_RSM_H */
+
+/*!
+ * @}
+ * \endcond
+ */
+
+/*------------------------------------------------------------------------------------------------*/
+/* End of file */
+/*------------------------------------------------------------------------------------------------*/
+