summaryrefslogtreecommitdiffstats
path: root/ucs2-lib/inc/ucs_pmfifos.h
diff options
context:
space:
mode:
Diffstat (limited to 'ucs2-lib/inc/ucs_pmfifos.h')
-rw-r--r--ucs2-lib/inc/ucs_pmfifos.h128
1 files changed, 0 insertions, 128 deletions
diff --git a/ucs2-lib/inc/ucs_pmfifos.h b/ucs2-lib/inc/ucs_pmfifos.h
deleted file mode 100644
index fb815dc..0000000
--- a/ucs2-lib/inc/ucs_pmfifos.h
+++ /dev/null
@@ -1,128 +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 class CPmFifos
- *
- * \cond UCS_INTERNAL_DOC
- * \addtogroup G_PMFIFOS
- * @{
- */
-
-#ifndef UCS_PMFIFOS_H
-#define UCS_PMFIFOS_H
-
-/*------------------------------------------------------------------------------------------------*/
-/* Includes */
-/*------------------------------------------------------------------------------------------------*/
-#include "ucs_rules.h"
-#include "ucs_base.h"
-#include "ucs_pmfifo.h"
-#include "ucs_pmchannel.h"
-
-#ifdef __cplusplus
-extern "C"
-{
-#endif
-
-/*------------------------------------------------------------------------------------------------*/
-/* Macros */
-/*------------------------------------------------------------------------------------------------*/
-#define FIFOS_SYNC_TIMEOUT 50U /*!< \brief Synchronization timeout in milliseconds */
-#define FIFOS_SYNC_RETRIES 40U /*!< \brief Maximum number of synchronization retries after timeout */
-#define FIFOS_UNSYNC_TIMEOUT 200U /*!< \brief Un-synchronization timeout in milliseconds */
-#define FIFOS_UNSYNC_RETRIES 0U /*!< \brief Un-synchronization retries */
-
-/*------------------------------------------------------------------------------------------------*/
-/* Internal types */
-/*------------------------------------------------------------------------------------------------*/
-/*! \brief The synchronization status of all FIFOs */
-typedef enum Fifos_SyncState_
-{
- FIFOS_S_UNSYNCED, /*!< \brief Not all FIFOs are synchronized */
- FIFOS_S_SYNCING, /*!< \brief FIFOs synchronization has started */
- FIFOS_S_SYNCED, /*!< \brief All FIFOs are synchronized */
- FIFOS_S_UNSYNCING /*!< \brief FIFOs un-synchronization has started */
-
-} Fifos_SyncState_t;
-
-/*! \brief PMS Events */
-typedef enum Fifos_Event_
-{
- FIFOS_EV_SYNC_LOST = 0, /*!< \brief Synchronization of at least one FIFO is lost */
- FIFOS_EV_SYNC_ESTABLISHED = 1, /*!< \brief Synchronization of all FIFOs is established */
- FIFOS_EV_SYNC_FAILED = 2, /*!< \brief The initial synchronization of FIFOs failed */
- FIFOS_EV_UNSYNC_COMPLETE = 3, /*!< \brief Un-synchronization of all FIFOs has succeeded */
- FIFOS_EV_UNSYNC_FAILED = 4 /*!< \brief Un-synchronization of all FIFOs has failed */
-
-} Fifos_Event_t;
-
-/*! \brief The class CPmFifos*/
-typedef struct CPmFifos_
-{
- CBase *base_ptr; /*!< \brief Reference to base object */
- uint8_t ucs_inst_id; /*!< \brief UNICENS instance ID */
- CPmChannel *channel_ptr; /*!< \brief UNICENS instance ID */
-
- CPmFifo *fifos[PMP_MAX_NUM_FIFOS]; /*!< \brief Reference to assigned FIFOs */
-
- CObserver obs_icm; /*!< \brief Observes ICM synchronization state */
- CObserver obs_rcm; /*!< \brief Observes ICM synchronization state */
- CObserver obs_mcm; /*!< \brief Observes MCM synchronization state */
- Fifos_SyncState_t state; /*!< \brief The Overall synchronization state */
- uint8_t sync_cnt; /*!< \brief The current count of synchronization command */
-
- uint8_t cmd_retries; /*!< \brief The number of sync/un-sync retries */
- uint16_t cmd_timeout; /*!< \brief The the timeout to retry sync/un-sync */
- bool unsync_initial; /*!< \brief Specifies if un-sync complete shall un-initialize the channel */
-
- CSubject event_subject; /*!< \brief Subject to report synchronization result */
- CTimer init_timer; /*!< \brief Timer elapses on synchronization timeout */
-
-} CPmFifos;
-
-/*------------------------------------------------------------------------------------------------*/
-/* Function prototypes */
-/*------------------------------------------------------------------------------------------------*/
-extern void Fifos_Ctor(CPmFifos *self, CBase *base_ptr, CPmChannel *channel_ptr, CPmFifo *icm_fifo_ptr, CPmFifo *mcm_fifo_ptr, CPmFifo *rcm_fifo_ptr);
-extern void Fifos_AddEventObserver(CPmFifos *self, CObserver *obs_ptr);
-extern void Fifos_RemoveEventObserver(CPmFifos *self, CObserver *obs_ptr);
-extern void Fifos_Synchronize(CPmFifos *self, bool reset_cnt, bool force_sync);
-extern void Fifos_Unsynchronize(CPmFifos *self, bool reset_cnt, bool initial);
-extern void Fifos_ForceTermination(CPmFifos *self);
-extern void Fifos_ConfigureSyncParams(CPmFifos *self, uint8_t retries, uint16_t timeout);
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif
-
-#endif /* UCS_PMFIFOS_H */
-
-/*!
- * @}
- * \endcond
- */
-
-/*------------------------------------------------------------------------------------------------*/
-/* End of file */
-/*------------------------------------------------------------------------------------------------*/
-