1 /*
2  * Copyright 2021-2023 NXP
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  */
6 #ifndef OSIF_H
7 #define OSIF_H
8 
9 /**
10 *   @file
11 *
12 *   @addtogroup osif_drv
13 *   @{
14 */
15 
16 #ifdef __cplusplus
17 extern "C"{
18 #endif
19 
20 
21 /*==================================================================================================
22 *                                          INCLUDE FILES
23 * 1) system and project includes
24 * 2) needed interfaces from external units
25 * 3) internal and external interfaces from this unit
26 ==================================================================================================*/
27 #include "OsIf_Internal.h"
28 #include "OsIf_Cfg.h"
29 
30 /*==================================================================================================
31 *                                 SOURCE FILE VERSION INFORMATION
32 ==================================================================================================*/
33 #define OSIF_VENDOR_ID                    43
34 #define OSIF_AR_RELEASE_MAJOR_VERSION     4
35 #define OSIF_AR_RELEASE_MINOR_VERSION     7
36 #define OSIF_AR_RELEASE_REVISION_VERSION  0
37 #define OSIF_SW_MAJOR_VERSION             1
38 #define OSIF_SW_MINOR_VERSION             0
39 #define OSIF_SW_PATCH_VERSION             0
40 
41 /*==================================================================================================
42 *                                       FILE VERSION CHECKS
43 ==================================================================================================*/
44 /* Check if OsIf.h file and OsIf_Internal.h file are of the same vendor */
45 #if (OSIF_VENDOR_ID != OSIF_INTERNAL_VENDOR_ID)
46     #error "OsIf.h and OsIf_Internal.h have different vendor ids"
47 #endif
48 /* Check if OsIf.h file and OsIf_Internal.h file are of the same Autosar version */
49 #if ((OSIF_AR_RELEASE_MAJOR_VERSION    != OSIF_INTERNAL_AR_RELEASE_MAJOR_VERSION) || \
50      (OSIF_AR_RELEASE_MINOR_VERSION    != OSIF_INTERNAL_AR_RELEASE_MINOR_VERSION) || \
51      (OSIF_AR_RELEASE_REVISION_VERSION != OSIF_INTERNAL_AR_RELEASE_REVISION_VERSION))
52     #error "AUTOSAR Version Numbers of OsIf.h and OsIf_Internal.h are different"
53 #endif
54 /* Check if OsIf.h file and OsIf_Internal.h file are of the same Software version */
55 #if ((OSIF_SW_MAJOR_VERSION != OSIF_INTERNAL_SW_MAJOR_VERSION) || \
56      (OSIF_SW_MINOR_VERSION != OSIF_INTERNAL_SW_MINOR_VERSION) || \
57      (OSIF_SW_PATCH_VERSION != OSIF_INTERNAL_SW_PATCH_VERSION) \
58     )
59     #error "Software Version Numbers of OsIf.h and OsIf_Internal.h are different"
60 #endif
61 
62 /* Check if OsIf.h file and OsIf_Cfg.h file are of the same vendor */
63 #if (OSIF_VENDOR_ID != OSIF_CFG_VENDOR_ID)
64     #error "OsIf.h and OsIf_Cfg.h have different vendor ids"
65 #endif
66 /* Check if OsIf.h file and OsIf_Cfg.h file are of the same Autosar version */
67 #if ((OSIF_AR_RELEASE_MAJOR_VERSION    != OSIF_CFG_AR_RELEASE_MAJOR_VERSION) || \
68      (OSIF_AR_RELEASE_MINOR_VERSION    != OSIF_CFG_AR_RELEASE_MINOR_VERSION) || \
69      (OSIF_AR_RELEASE_REVISION_VERSION != OSIF_CFG_AR_RELEASE_REVISION_VERSION))
70     #error "AUTOSAR Version Numbers of OsIf.h and OsIf_Cfg.h are different"
71 #endif
72 /* Check if OsIf.h file and OsIf_Cfg.h file are of the same Software version */
73 #if ((OSIF_SW_MAJOR_VERSION != OSIF_CFG_SW_MAJOR_VERSION) || \
74      (OSIF_SW_MINOR_VERSION != OSIF_CFG_SW_MINOR_VERSION) || \
75      (OSIF_SW_PATCH_VERSION != OSIF_CFG_SW_PATCH_VERSION) \
76     )
77     #error "Software Version Numbers of OsIf.h and OsIf_Cfg.h are different"
78 #endif
79 
80 /*==================================================================================================
81 *                                            CONSTANTS
82 ==================================================================================================*/
83 
84 /*==================================================================================================
85 *                                       DEFINES AND MACROS
86 ==================================================================================================*/
87 
88 /*==================================================================================================
89 *                                              ENUMS
90 ==================================================================================================*/
91 /*!
92  * @brief OsIf Counter type
93  *
94  * Counter type.
95  *
96  * @detail The dummy counter of Osif is meant as a loop-counter timeout mechanism that requirement no
97  * additional resource (hardware and software). It was meant to replace the typical loop timeout of decrementing
98  * a variable each time the loop was executed until the counter reaches zero. Usage of OsIf replaced these loop counters
99  * within RTD, so the advantage is that these timeouts can be configured to be simple loop counters
100  * (using the dummy counter), not changing the RTD code.
101  */
102 typedef enum
103 {
104     OSIF_COUNTER_DUMMY, /**< dummy counter */
105 #if (OSIF_USE_SYSTEM_TIMER == STD_ON)
106     OSIF_COUNTER_SYSTEM, /**< system counter */
107 #endif /* (OSIF_USE_SYSTEM_TIMER == STD_ON) */
108 #if (OSIF_USE_CUSTOM_TIMER == STD_ON)
109     OSIF_COUNTER_CUSTOM /**< custom counter */
110 #endif /* (OSIF_USE_CUSTOM_TIMER == STD_ON) */
111 } OsIf_CounterType;
112 
113 /*==================================================================================================
114 *                                  STRUCTURES AND OTHER TYPEDEFS
115 ==================================================================================================*/
116 
117 /*==================================================================================================
118 *                                  GLOBAL VARIABLE DECLARATIONS
119 ==================================================================================================*/
120 
121 /*==================================================================================================
122 *                                       FUNCTION PROTOTYPES
123 ==================================================================================================*/
124 #define BASENXP_START_SEC_CODE
125 #include "BaseNXP_MemMap.h"
126 
127 /*!
128  * @brief Initialize OsIf
129  *
130  * This function initializes the OsIf module and should be called during startup, before every
131  * other intialization other than Mcu.
132  *
133  */
134 void OsIf_Init(const void* Config);
135 
136 /*!
137  * @brief Get the current value counter
138  *
139  * This function returns the current value of the counter.
140  *
141  * @param[in] SelectedCounter the type of counter to use
142  * @return the current value of the counter
143  */
144 uint32 OsIf_GetCounter(OsIf_CounterType SelectedCounter);
145 
146 /*!
147  * @brief Get the elapsed value from a reference point
148  *
149  * This function returns the delta time in ticks compared to a reference, and updates the reference.
150  *
151  * @param[inout] CurrentRef reference counter value, updated to current counter value
152  * @param[in] SelectedCounter the type of counter to use
153  * @return the elapsed time
154  */
155 uint32 OsIf_GetElapsed(uint32 * const CurrentRef, OsIf_CounterType SelectedCounter);
156 
157 /*!
158  * @brief Set a new frequency used for time conversion (microseconds to ticks)
159  *
160  * This function stores a new timer frequency used for time conversion computations
161  *
162  * @param[in] Freq the new frequency
163  * @param[in] SelectedCounter the type of counter to use
164  */
165 void OsIf_SetTimerFrequency(uint32 Freq, OsIf_CounterType SelectedCounter);
166 
167 /*!
168  * @brief Convert microseconds to ticks
169  *
170  * This function converts a value from microsecond units to ticks units.
171  *
172  * @param[in] Micros microseconds value
173  * @param[in] SelectedCounter the type of counter to use
174  * @return the equivalent value in ticks
175  */
176 uint32 OsIf_MicrosToTicks(uint32 Micros, OsIf_CounterType SelectedCounter);
177 
178 #define BASENXP_STOP_SEC_CODE
179 #include "BaseNXP_MemMap.h"
180 
181 #ifdef __cplusplus
182 }
183 #endif
184 
185 /** @} */
186 
187 #endif /* OSIF_H */
188