summaryrefslogtreecommitdiffstats
path: root/ucs2-lib/inc/ucs_segmentation.h
diff options
context:
space:
mode:
Diffstat (limited to 'ucs2-lib/inc/ucs_segmentation.h')
-rw-r--r--ucs2-lib/inc/ucs_segmentation.h144
1 files changed, 0 insertions, 144 deletions
diff --git a/ucs2-lib/inc/ucs_segmentation.h b/ucs2-lib/inc/ucs_segmentation.h
deleted file mode 100644
index 849517f..0000000
--- a/ucs2-lib/inc/ucs_segmentation.h
+++ /dev/null
@@ -1,144 +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 AMS Segmentation Class
- *
- * \cond UCS_INTERNAL_DOC
- * \addtogroup G_AMSSEGM
- * @{
- */
-
-#ifndef UCS_SEGMENTATION_H
-#define UCS_SEGMENTATION_H
-
-/*------------------------------------------------------------------------------------------------*/
-/* Includes */
-/*------------------------------------------------------------------------------------------------*/
-#include "ucs_message.h"
-#include "ucs_amsmessage.h"
-#include "ucs_amspool.h"
-#include "ucs_base.h"
-
-#ifdef __cplusplus
-extern "C"
-{
-#endif
-
-/*------------------------------------------------------------------------------------------------*/
-/* Macros */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief Defines the maximum payload size of a single transfer in bytes */
-#define SEGM_MAX_SIZE_TEL 45U
-
-/*------------------------------------------------------------------------------------------------*/
-/* Types */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief Collection of possible segmentation errors */
-typedef enum Segm_Error_
-{
- SEGM_ERR_1 = 1, /*!< \brief The first segment is missing. */
-
- SEGM_ERR_2 = 2, /*!< \brief The device is not able to receive a message of this size.
- * MNS specific: The allocation of user provided payload failed.
- */
- SEGM_ERR_3 = 3, /*!< \brief Unexpected segment number. */
-
- SEGM_ERR_4 = 4, /*!< \brief Too many unfinished segmentation messages were pending. */
-
- SEGM_ERR_5 = 5, /*!< \brief A timeout occurred while waiting for the next segment. */
-
- SEGM_ERR_6 = 6, /*!< \brief The Device is not capable to handle segmented messages.
- * MNS specific: The application did not assign the payload allocation
- * function in Ucs_Ams_InitData_t prior calling Ucs_Init().
- */
- SEGM_ERR_7 = 7 /*!< \brief Segmented message has not been finished before the arrival of
- * another message with the identical FBlockID, InstID, FktID, and
- * OPType sent by the same node.
- */
-} Segm_Error_t;
-
-/*! \brief Segmentation result */
-typedef enum Segm_Result_
-{
- SEGM_RES_OK, /*!< \brief Telegram was processed */
- SEGM_RES_RETRY /*!< \brief Telegram shall be processed again as soon as messages are freed to the Rx pool */
-
-} Segm_Result_t;
-
-/*! \brief Callback function to notify that a segmentation error has occurred
- * \param self The instance
- * \param tel_ptr The affected telegram
- * \param error The segmentation error code (1..7)
- */
-typedef void (*Segm_OnError_t)(void *self, Msg_MostTel_t *tel_ptr, Segm_Error_t error);
-
-/*------------------------------------------------------------------------------------------------*/
-/* Class */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief AMS Segmentation Class
- * \details Performs Tx and Rx Segmentation
- */
-typedef struct CSegmentation_
-{
- CBase *base_ptr; /*!< \brief Reference to base services */
- CAmsMsgPool *pool_ptr; /*!< \brief Reference to object/payload pool */
-
- Segm_OnError_t error_fptr; /*!< \brief Callback function to notify segmentation errors */
- void *error_inst; /*!< \brief Instance which is notified on segmentation errors */
-
- CDlList processing_list; /*!< \brief Segmented and un-finished Rx messages */
- CTimer gc_timer; /*!< \brief Timer to trigger the garbage collector */
- uint16_t rx_default_payload_sz; /*!< \brief Payload size that shall be allocated if size-prefixes
- * segmentation message is missing */
-
-} CSegmentation;
-
-/*------------------------------------------------------------------------------------------------*/
-/* Initialization Methods */
-/*------------------------------------------------------------------------------------------------*/
-extern void Segm_Ctor(CSegmentation *self, CBase *base_ptr, CAmsMsgPool *pool_ptr, uint16_t rx_def_payload_sz);
-extern void Segm_AssignRxErrorHandler(CSegmentation *self, Segm_OnError_t error_fptr, void *error_inst);
-extern void Segm_Cleanup(CSegmentation *self);
-
-/*------------------------------------------------------------------------------------------------*/
-/* Public method prototypes */
-/*------------------------------------------------------------------------------------------------*/
-extern bool Segm_TxBuildSegment(CSegmentation *self, Ucs_AmsTx_Msg_t *msg_ptr, Msg_MostTel_t *tel_ptr);
-extern Ucs_AmsRx_Msg_t* Segm_RxExecuteSegmentation(CSegmentation *self, Msg_MostTel_t *tel_ptr, Segm_Result_t *result_ptr);
-extern void Segm_RxGcScanProcessingHandles(void *self);
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif
-
-#endif /* UCS_SEGMENTATION_H */
-
-/*!
- * @}
- * \endcond
- */
-
-/*------------------------------------------------------------------------------------------------*/
-/* End of file */
-/*------------------------------------------------------------------------------------------------*/
-