123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- #ifndef DEEPHISTORY_H_
- #define DEEPHISTORY_H_
- #include "sc_types.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*! \file Header of the state machine 'DeepHistory'.
- */
- //! enumeration of all states
- typedef enum {
- DeepHistory_mainRegion_State1 ,
- DeepHistory_mainRegion_State2 ,
- DeepHistory_mainRegion_State2__region0_a ,
- DeepHistory_mainRegion_State2__region0_State4 ,
- DeepHistory_mainRegion_State2__region0_State4__region0_State6 ,
- DeepHistory_mainRegion_State2__region0_State4__region0_State7 ,
- DeepHistory_mainRegion_State2__region0_State4__region0_State7__region0_State8 ,
- DeepHistory_mainRegion_State2__region0_State4__region0_State7__region0_State9 ,
- DeepHistory_mainRegion_State2__region0_State5 ,
- DeepHistory_last_state
- } DeepHistoryStates;
- //! Type definition of the data structure for the DeepHistoryIface interface scope.
- typedef struct {
- sc_boolean event1_raised;
- sc_boolean event2_raised;
- sc_boolean event3_raised;
- sc_boolean event4_raised;
- sc_boolean event5_raised;
- sc_boolean event6_raised;
- sc_boolean event7_raised;
- sc_boolean event8_raised;
- sc_boolean event9_raised;
- } DeepHistoryIface;
- //! the maximum number of orthogonal states defines the dimension of the state configuration vector.
- #define DEEPHISTORY_MAX_ORTHOGONAL_STATES 1
- //! dimension of the state configuration vector for history states
- #define DEEPHISTORY_MAX_HISTORY_STATES 3
- /*! Type definition of the data structure for the DeepHistory state machine.
- This data structure has to be allocated by the client code. */
- typedef struct {
- DeepHistoryStates stateConfVector[DEEPHISTORY_MAX_ORTHOGONAL_STATES];
- DeepHistoryStates historyVector[DEEPHISTORY_MAX_HISTORY_STATES];
- sc_ushort stateConfVectorPosition;
-
- DeepHistoryIface iface;
- } DeepHistory;
- /*! Initializes the DeepHistory state machine data structures. Must be called before first usage.*/
- extern void deepHistory_init(DeepHistory* handle);
- /*! Activates the state machine */
- extern void deepHistory_enter(DeepHistory* handle);
- /*! Deactivates the state machine */
- extern void deepHistory_exit(DeepHistory* handle);
- /*! Performs a 'run to completion' step. */
- extern void deepHistory_runCycle(DeepHistory* handle);
- /*! Raises the in event 'event1' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event1(DeepHistory* handle);
- /*! Raises the in event 'event2' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event2(DeepHistory* handle);
- /*! Raises the in event 'event3' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event3(DeepHistory* handle);
- /*! Raises the in event 'event4' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event4(DeepHistory* handle);
- /*! Raises the in event 'event5' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event5(DeepHistory* handle);
- /*! Raises the in event 'event6' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event6(DeepHistory* handle);
- /*! Raises the in event 'event7' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event7(DeepHistory* handle);
- /*! Raises the in event 'event8' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event8(DeepHistory* handle);
- /*! Raises the in event 'event9' that is defined in the default interface scope. */
- extern void deepHistoryIface_raise_event9(DeepHistory* handle);
- /*! Checks if the specified state is active. */
- extern sc_boolean deepHistory_isActive(DeepHistory* handle, DeepHistoryStates state);
- #ifdef __cplusplus
- }
- #endif
- #endif /* DEEPHISTORY_H_ */
|