aboutsummaryrefslogtreecommitdiffstats
path: root/ucs2-lib/inc/ucs_nsm.h
diff options
context:
space:
mode:
authorRonan Le Martret <ronan.lemartret@iot.bzh>2017-06-12 11:17:04 +0200
committerRonan Le Martret <ronan.lemartret@iot.bzh>2017-06-29 14:40:09 +0200
commitec59d20bafb3acaaff2bbcab185a074825319e20 (patch)
tree2262fa512acadeb1dfa68bad7b2bb5a5c7de2467 /ucs2-lib/inc/ucs_nsm.h
parenta57c0b35c05c84f31ec09d3ac46b298555aa0cfb (diff)
Update package
* use sub module for ucs2-lib (tmp fork from IoT.bzh github) * add packaging for native build Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh>
Diffstat (limited to 'ucs2-lib/inc/ucs_nsm.h')
-rw-r--r--ucs2-lib/inc/ucs_nsm.h200
1 files changed, 0 insertions, 200 deletions
diff --git a/ucs2-lib/inc/ucs_nsm.h b/ucs2-lib/inc/ucs_nsm.h
deleted file mode 100644
index 7c2be23..0000000
--- a/ucs2-lib/inc/ucs_nsm.h
+++ /dev/null
@@ -1,200 +0,0 @@
-/*------------------------------------------------------------------------------------------------*/
-/* 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 Node Scripting Management.
- *
- * \cond UCS_INTERNAL_DOC
- * \addtogroup G_NSM
- * @{
- */
-#ifndef UCS_NSM_H
-#define UCS_NSM_H
-
-/*------------------------------------------------------------------------------------------------*/
-/* Includes */
-/*------------------------------------------------------------------------------------------------*/
-#include "ucs_base.h"
-#include "ucs_ret_pb.h"
-#include "ucs_rsm.h"
-#include "ucs_nsm_pb.h"
-
-#ifdef __cplusplus
-extern "C"
-{
-#endif
-
-/*------------------------------------------------------------------------------------------------*/
-/* Enumerators */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief This enumerator specifies the kind of result - Target or Transmission. */
-typedef enum Ns_ResultType_
-{
- /*!< \brief Specifies the result of the scripting from target device (typically INIC function-specific error) */
- NS_RESULT_TYPE_TGT_SCRIPT = 0x00U,
- /*!< \brief Specifies the result of the remote synchronization from target device (typically INIC function-specific error) */
- NS_RESULT_TYPE_TGT_SYNC = 0x01U,
- /*!< \brief Specifies the transmission error information that occurred on the MOST network. */
- NS_RESULT_TYPE_TX = 0x02U
-
-} Ns_ResultType_t;
-
-/*------------------------------------------------------------------------------------------------*/
-/* Structures */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief Detailed information used for I2C results. */
-typedef struct Nsm_ResultDetails_
-{
- /*! \brief Specifies the type of the current asynchronous result.
- * \details The following briefly describes the different types of results available:
- * - \b NS_RESULT_TYPE_TGT: target results, typically INIC function-specific error found on target device. \n Refer to \em inic_result to get the detailed information.
- * - \b NS_RESULT_TYPE_TX: transmission results, typically transmission error on the MOST network. \n Refer to \em tx_result to get the transmission information.
- */
- Ns_ResultType_t result_type;
- /*! \brief Holds the status of the transmission. */
- Ucs_MsgTxStatus_t tx_result;
- /*! \brief Holds the results of the target device. */
- Ucs_StdResult_t inic_result;
-
-} Nsm_ResultDetails_t;
-
-/*! \brief Stores the NodeScript result for internal use. */
-typedef struct Nsm_Result_
-{
- /*! \brief Result code. */
- Ucs_Ns_ResultCode_t code;
- /*! \brief Detailed information on the returned result. */
- Nsm_ResultDetails_t details;
-
-} Nsm_Result_t;
-
-/*! \brief Stores data required by NSM during initialization. */
-typedef struct Nsm_InitData_
-{
- CBase *base_ptr; /*!< \brief Reference to base instance */
- CTransceiver * rcm_ptr; /*!< \brief Reference to RCM transceiver instance */
- CRemoteSyncManagement * rsm_ptr; /*!< \brief Reference to RSM instance */
-
-} Nsm_InitData_t;
-
-/*! \brief Structure holds parameters for API locking */
-typedef struct Script_ApiLock_
-{
- /*! \brief Flag to lock the API */
- bool api;
- /*! \brief API locking instance for Scripting function */
- CApiLocking rcm_api;
- /*! \brief Observer used for locking timeouts for Scripting function */
- CSingleObserver observer;
-
-} Script_ApiLock_t;
-
-/*------------------------------------------------------------------------------------------------*/
-/* Type definitions */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief Function signature used for the results of the Scripting Manager.
- * \param user_ptr Reference to the called user instance.
- * \param result Result of the scripting operation.
- */
-typedef void (*Nsm_ResultCb_t)(void * user_ptr, Nsm_Result_t result);
-
-/*! \brief Function signature used for the results of the Scripting Manager.
- * \param tel_ptr Reference to the message object.
- * \param user_ptr Reference to the user argument.
- * \return Returns \c true to discard the message and free it to the pool (no-pass). Otherwise, returns
- * \c false (pass).
- */
-typedef bool (*Nsm_RxFilterCb_t)(Msg_MostTel_t *tel_ptr, void *user_ptr);
-
-/*------------------------------------------------------------------------------------------------*/
-/* Structures */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief Class structure of the Node Scripting Management. */
-typedef struct CNodeScriptManagement_
-{
- /*!< \brief Reference to a base instance */
- CBase *base_ptr;
- /*!< \brief Reference to RCM instance */
- CTransceiver * rcm_ptr;
- /*!< \brief Reference to RSM instance */
- CRemoteSyncManagement * rsm_ptr;
- /*!< \brief Reference to the timer management */
- CTimerManagement * tm_ptr;
- /*!< \brief Timer for pausing script */
- CTimer script_pause;
- /*!< \brief Service instance for the scheduler */
- CService nsm_srv;
- /*!< \brief Observer used to monitor UCS initialization result */
- CMaskedObserver ucsinit_observer;
- /*!< \brief Observer used to monitor UCS termination event */
- CMaskedObserver ucstermination_observer;
- /*!< \brief Flag to lock the API */
- Script_ApiLock_t lock;
- /*!< \brief Current reference to the script table */
- Ucs_Ns_Script_t * curr_sript_ptr;
- /*!< \brief Current result for internal use */
- Nsm_Result_t curr_internal_result;
- /*!< \brief Current script size */
- uint8_t curr_sript_size;
- /*!< \brief Current script pause */
- uint16_t curr_pause;
- /*!< \brief Flag to determine whether the private api is used or not */
- bool is_private_api_used;
- /*!< \brief Reference to the user instance */
- void * curr_user_ptr;
- /*!< \brief RX filter callback function */
- Nsm_RxFilterCb_t curr_rxfilter_fptr;
- /*!< \brief Private result callback function pointer for current script */
- Nsm_ResultCb_t curr_pv_result_fptr;
- /*!< \brief Current reference to the Node used in public API */
- Ucs_Rm_Node_t * curr_node_ptr;
- /*!< \brief Public result callback function pointer for current script */
- Ucs_Ns_ResultCb_t curr_pb_result_fptr;
- /*!< \brief Target address of the device to be looked for */
- uint16_t target_address;
-
-} CNodeScriptManagement;
-
-/*------------------------------------------------------------------------------------------------*/
-/* Prototypes of class CRemoteSyncManagement */
-/*------------------------------------------------------------------------------------------------*/
-extern void Nsm_Ctor(CNodeScriptManagement * self, Nsm_InitData_t * init_ptr);
-extern Ucs_Return_t Nsm_Run_Pb(CNodeScriptManagement * self, Ucs_Rm_Node_t * node_ptr, Ucs_Ns_ResultCb_t pb_result_fptr);
-extern Ucs_Return_t Nsm_Run_Pv(CNodeScriptManagement * self, Ucs_Ns_Script_t * script, uint8_t size, void * user_ptr, Nsm_RxFilterCb_t rx_filter_fptr, Nsm_ResultCb_t result_fptr);
-extern bool Nsm_OnRcmRxFilter(void *self, Msg_MostTel_t *tel_ptr);
-extern bool Nsm_IsLocked(CNodeScriptManagement * self);
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif
-
-#endif /* #ifndef UCS_NSM_H */
-
-/*!
- * @}
- * \endcond
- */
-
-/*------------------------------------------------------------------------------------------------*/
-/* End of file */
-/*------------------------------------------------------------------------------------------------*/
-