MCUSW
Mcu.h
Go to the documentation of this file.
1 /*
2 *
3 * Copyright (c) 2023 Texas Instruments Incorporated
4 *
5 * All rights reserved not granted herein.
6 *
7 * Limited License.
8 *
9 * Texas Instruments Incorporated grants a world-wide, royalty-free, non-exclusive
10 * license under copyrights and patents it now or hereafter owns or controls to make,
11 * have made, use, import, offer to sell and sell ("Utilize") this software subject to the
12 * terms herein. With respect to the foregoing patent license, such license is granted
13 * solely to the extent that any such patent is necessary to Utilize the software alone.
14 * The patent license shall not apply to any combinations which include this software,
15 * other than combinations with devices manufactured by or for TI ("TI Devices").
16 * No hardware patent is licensed hereunder.
17 *
18 * Redistributions must preserve existing copyright notices and reproduce this license
19 * (including the above copyright notice and the disclaimer and (if applicable) source
20 * code license limitations below) in the documentation and/or other materials provided
21 * with the distribution
22 *
23 * Redistribution and use in binary form, without modification, are permitted provided
24 * that the following conditions are met:
25 *
26 * * No reverse engineering, decompilation, or disassembly of this software is
27 * permitted with respect to any software provided in binary form.
28 *
29 * * any redistribution and use are licensed by TI for use only with TI Devices.
30 *
31 * * Nothing shall obligate TI to provide you with source code for the software
32 * licensed and provided to you in object code.
33 *
34 * If software source code is provided to you, modification and redistribution of the
35 * source code are permitted provided that the following conditions are met:
36 *
37 * * any redistribution and use of the source code, including any resulting derivative
38 * works, are licensed by TI for use only with TI Devices.
39 *
40 * * any redistribution and use of any object code compiled from the source code
41 * and any resulting derivative works, are licensed by TI for use only with TI Devices.
42 *
43 * Neither the name of Texas Instruments Incorporated nor the names of its suppliers
44 *
45 * may be used to endorse or promote products derived from this software without
46 * specific prior written permission.
47 *
48 * DISCLAIMER.
49 *
50 * THIS SOFTWARE IS PROVIDED BY TI AND TI'S LICENSORS "AS IS" AND ANY EXPRESS
51 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
52 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
53 * IN NO EVENT SHALL TI AND TI'S LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT,
54 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
55 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
56 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
57 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
58 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
59 * OF THE POSSIBILITY OF SUCH DAMAGE.
60 *
61 */
62 
77 #ifndef MCU_H_
78 #define MCU_H_
79 
80 /* ========================================================================== */
81 /* Include Files */
82 /* ========================================================================== */
83 
84 #include "Std_Types.h"
85 #include "Mcu_Cfg.h"
86 #include "EcuM.h"
87 
88 
89 #ifdef __cplusplus
90 extern "C"
91 {
92 #endif
93 
94 /* ========================================================================== */
95 /* Macros & Typedefs */
96 /* ========================================================================== */
97 
98 #define ARRAYSIZE(array) ((sizeof (array) / \
99  sizeof ((array)[0])))
100 
101 
109 #define MCU_SW_MAJOR_VERSION (9U)
110 
111 #define MCU_SW_MINOR_VERSION (0U)
112 
113 #define MCU_SW_PATCH_VERSION (0U)
114 /* @} */
115 
123 #define MCU_AR_RELEASE_MAJOR_VERSION (4U)
124 
125 #define MCU_AR_RELEASE_MINOR_VERSION (3U)
126 
127 #define MCU_AR_RELEASE_REVISION_VERSION (1U)
128 /* @} */
129 
135 #define MCU_VENDOR_ID ((uint16) 44U)
136 
137 #define MCU_MODULE_ID ((uint16) 101U)
138 
139 #define MCU_INSTANCE_ID ((uint8) 0U)
140 /* @} */
141 
150 #define MCU_TEST_CFG_ID_1 (0x01U)
151 
152 #define MCU_TEST_CFG_ID_2 (0x02U)
153 
154 #define MCU_TEST_CFG_ID_3 (0x04U)
155 
163  /*
164  * Design: MCAL-8507,MCAL-8489
165  */
166  #ifndef MCU_E_PARAM_CONFIG
167 
168  #define MCU_E_PARAM_CONFIG (0x0AU)
169  #endif
170 
171 
172  /*
173  * Design: MCAL-8507
174  */
175 
176 #ifndef MCU_E_PARAM_CLOCK
177 
178 #define MCU_E_PARAM_CLOCK (0x0BU)
179 #endif
180 
181 /*
182  * Design: MCAL-8507
183  */
184 #ifndef MCU_E_PARAM_MODE
185 
186 #define MCU_E_PARAM_MODE (0x0CU)
187 #endif
188 
189 /*
190  * Design: MCAL-8507
191  */
192 #ifndef MCU_E_PARAM_RAMSECTION
193 
194 #define MCU_E_PARAM_RAMSECTION (0x0DU)
195 #endif
196 
197 /*
198  * Design: MCAL-8507
199  */
200 #ifndef MCU_E_PLL_NOT_LOCKED
201 
202 #define MCU_E_PLL_NOT_LOCKED (0x0EU)
203 #endif
204 
205 /*
206  * Design: MCAL-8507
207  */
208 #ifndef MCU_E_UNINIT
209 
210 #define MCU_E_UNINIT (0x0FU)
211 #endif
212 
213 /*
214  * Design: MCAL-8507
215  */
216 #ifndef MCU_E_PARAM_POINTER
217 
218 #define MCU_E_PARAM_POINTER (0x10U)
219 #endif
220 
221 /*
222  * Design: MCAL-8507
223  */
224 #ifndef MCU_E_INIT_FAILED
225 
226 #define MCU_E_INIT_FAILED (0x11U)
227 #endif
228 
235  /*
236  * Design: MCAL-8507
237  */
239 #define MCU_STATUS_UNINIT ((uint8)(0U))
240 
241 #define MCU_STATUS_INIT ((uint8)(1U))
242 
252 #define MCU_SID_INIT (0x00U)
253 
254 #define MCU_SID_INIT_RAM_SECTION (0x01U)
255 
256 #define MCU_SID_INIT_CLOCK (0x02U)
257 
258 #define MCU_SID_DISTRIBUTE_PLL_CLOCK (0x03U)
259 
260 #define MCU_SID_GET_PLL_STATUS (0x04U)
261 
262 #define MCU_SID_GET_RESET_REASON (0x05U)
263 
264 #define MCU_SID_GET_RESET_RAW_VALUE (0x06U)
265 
266 #define MCU_SID_PERFORM_RESET (0x07U)
267 
268 #define MCU_SID_SETMODE (0x08U)
269 
270 #define MCU_SID_GET_VERSION_INFO (0x09U)
271 
272 #define MCU_SID_GET_RAM_STATE (0x0AU)
273 /* @} */
274 
275 #if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4)
276 
283 #define MCU_PERFORM_RESET_MODE_COLD ((uint8) 0U)
284 #endif
285 
286 #define MCU_PERFORM_RESET_MODE_WARM ((uint8) 1U)
287 /* @} */
288 #define MCU_E_MODE_FAILURE 0U
289 
290 
291 
292 
293 /*
294  * Design: MCAL-8487,MCAL-8492
295  */
300 typedef uint8 Mcu_ClockType;
301 
302 /*
303  * Design: MCAL-8491,MCAL-8471
304  */
309 typedef uint32 Mcu_RawResetType;
310 
311 /*
312  * Design: MCAL-8406,MCAL-8421
313  */
318 typedef uint8 Mcu_RamSectionType;
319 
320 /*
321  * Design: MCAL-8490,MCAL-8418
322  */
327 typedef uint8 Mcu_ModeType;
328 
329 /* ========================================================================== */
330 /* Structures and Enums */
331 /* ========================================================================== */
332 
333 /*
334  * Design: MCAL-8438
335  */
339  typedef struct
340  {
349  boolean Mcu_InitCfg;
354 
355 
356 
360 typedef P2CONST (Mcu_ClockConfigType, AUTOMATIC, MCU_PBCFG)
362 
363 /*
364 * Design: MCAL-8439,MCAL-8424,MCAL-8405,MCAL-8438,MCAL-8457
365 */
370  typedef struct Mcu_ConfigType_s
371  {
382  } Mcu_ConfigType;
383 
384 
386 extern const struct Mcu_ConfigType_s McuModuleConfiguration_0;
387 
388 
389 
390 
391 /* @} */
392 
393 /* ========================================================================== */
394 /* Function Declarations */
395 /* ========================================================================== */
396 
413 FUNC(void, MCU_CODE) Mcu_Init(
414  P2CONST(Mcu_ConfigType, AUTOMATIC, MCU_PBCFG) ConfigPtr);
415 
416 FUNC(Std_ReturnType, MCU_CODE) Mcu_ClockSetSource(
417  Mcu_ClkModuleIdType moduleId,
418  Mcu_ClkSourceIdType clkSrcId,
419  uint8 clkParentId);
420 
421 #if (STD_ON == MCU_INIT_CLOCK_API)
422 
442 FUNC(Std_ReturnType, MCU_CODE) Mcu_InitClock(Mcu_ClockType ClockSetting);
443 #endif /* MCU_INIT_CLOCK_API */
444 
462 #if(STD_OFF == MCU_NO_PLL)
463 FUNC(Std_ReturnType, MCU_CODE) Mcu_DistributePllClock(void);
464 
465 #endif /* STD_OFF == MCU_NO_PLL */
466 
467 #if (STD_ON == MCU_PERFORM_RESET_API)
468 
484 FUNC(void, MCU_CODE) Mcu_PerformReset(void);
485 
486 #endif /* MCU_PERFORM_RESET_API */
487 
488 #if (STD_ON == MCU_INIT_RAM_API)
489 
510 FUNC(Std_ReturnType, MCU_CODE) Mcu_InitRamSection(
511  Mcu_RamSectionType RamSection);
512 #endif /* MCU_INIT_RAM_API */
513 
514 
515 /* Design: MCAL-8391 */
516 
517 /* This is a Dummy API */
518 
535 FUNC(Mcu_PllStatusType, MCU_CODE) Mcu_GetPllStatus(void);
536 
554 FUNC(Mcu_ResetType, MCU_CODE) Mcu_GetResetReason(void);
555 
574 FUNC(Mcu_RawResetType, MCU_CODE) Mcu_GetResetRawValue(void);
575 
576 #if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4)
577 
594 FUNC(void, MCU_CODE) Mcu_ClearResetReason(void);
595 #endif
596 
597 #if (STD_ON == MCU_GET_RAM_STATE_API)
598 
599 /* This is a Dummy API
600 */
619 FUNC(Mcu_RamStateType, MCU_CODE) Mcu_GetRamState(void);
620 #endif /* MCU_GET_RAM_STATE_API */
621 
622 #if (STD_ON == MCU_GET_VERSION_INFO_API)
623 
646 FUNC(void, MCU_CODE) Mcu_GetVersionInfo(
647  P2VAR(Std_VersionInfoType, AUTOMATIC, MCU_APPL_DATA) versioninfo);
648 #endif /* MCU_GET_VERSION_INFO_API */
649 
650 
651 
669 FUNC(void, MCU_CODE) Mcu_SetMode(P2CONST(Mcu_ModeType, AUTOMATIC, MCU_APPL_DATA) McuMode);
670 
671 
672 
673 
674 #ifdef __cplusplus
675 }
676 #endif
677 
678 #endif /* #ifndef MCU_H_ */
679 
680 /* @} */
Mcu_ClkSourceIdType
This is the type of the clock source in clock tree that is selectable for peripheral....
Definition: Mcu_Cfg.h:402
Mcu_ClkModuleIdType
Clock source config modules id enum.
Definition: Mcu_Cfg.h:301
MCU CONFIG ROOT structure.
Definition: Mcu.h:370
void Mcu_SetMode(const Mcu_ModeType *McuMode)
This service activates the MCU power modes.
Mcu_RawResetType Mcu_GetResetRawValue(void)
The service reads the reset type from the hardware register, if supported.
Mcu_ResetType
This is the type of the reset enumerator containing the subset of reset types. It is not required t...
Definition: Mcu_Cfg.h:245
Mcu_ModuleName
Definition: Mcu_Cfg.h:270
Mcu_ClkSourceIdType Mcu_ClockSourceId
Definition: Mcu.h:343
This file contains generated pre compile configuration file for MCU MCAL driver.
uint8 Mcu_NumberOfClockConfig
Definition: Mcu.h:378
Std_ReturnType(* Mcu_CBKFunctionPtrType)(uint32 moduleId, uint32 clkId, uint64 ParentId)
Pointer to Callback function.
Definition: Mcu_Cfg.h:504
uint8 Mcu_ResetMode
Definition: Mcu.h:374
uint8 Mcu_ClockType
This type specifies the identification (ID) for a ClockType status used by Mcu_InitClock()
Definition: Mcu.h:300
Mcu_RamStateType
Enumeration of ranstate queried by Mcu_GetRamState()
Definition: Mcu_Cfg.h:458
uint8 Mcu_ModeType
This type specifies the identification (ID) for a MCU mode used in Mcu_SetMode()
Definition: Mcu.h:327
Structure for module clock setting.
Definition: Mcu.h:339
Mcu_DomainType
Definition: Mcu_Cfg.h:259
Mcu_RamStateType Mcu_GetRamState(void)
This service provides the actual status of the microcontroller Ram. (if supported)
Mcu_ClkModuleIdType Mcu_ClockModuleId
Definition: Mcu.h:341
Std_ReturnType Mcu_InitClock(Mcu_ClockType ClockSetting)
This service initializes the PLL and other MCU specific clock options.
Mcu_PllStatusType Mcu_GetPllStatus(void)
This service provides the lock status of the PLL.
const struct Mcu_ConfigType_s McuModuleConfiguration_0
MCU Configuration struct declaration.
uint64 Mcu_ClockFrequency
Definition: Mcu.h:351
void Mcu_Init(const Mcu_ConfigType *ConfigPtr)
This service initializes the MCU driver.
Mcu_CBKFunctionPtrType Mcu_CBK_Function
Definition: Mcu.h:380
void Mcu_ClearResetReason(void)
Clear the Mcu Reset reason by clearing the reset reason register.
uint8 Mcu_RamSectionType
This type specifies the identification (ID) for a RAM section used in Mcu_InitRamSection()
Definition: Mcu.h:318
Mcu_DomainType Domain
Definition: Mcu.h:347
void Mcu_GetVersionInfo(Std_VersionInfoType *versioninfo)
This service returns the version information of this module.
boolean Mcu_InitCfg
Definition: Mcu.h:349
void Mcu_PerformReset(void)
The service performs a microcontroller reset.
Std_ReturnType Mcu_DistributePllClock(void)
This service activates the PLL clock to the MCU clock distribution.
Mcu_ModeType Mcu_Mode
Definition: Mcu.h:372
Mcu_PllStatusType
This is a status value returned by the function Mcu_GetPllStatus() of the MCU module.
Definition: Mcu_Cfg.h:420
Std_ReturnType Mcu_InitRamSection(Mcu_RamSectionType RamSection)
This service initializes the RAM section wise.
uint32 Mcu_RawResetType
This type specifies the identification (ID) for a RAW MCU reset status returned by Mcu_GetResetRawVal...
Definition: Mcu.h:309
Mcu_ClockConfigPtrType Mcu_ClockConfig
Definition: Mcu.h:376
Std_ReturnType Mcu_ClockSetSource(Mcu_ClkModuleIdType moduleId, Mcu_ClkSourceIdType clkSrcId, uint8 clkParentId)
Mcu_ResetType Mcu_GetResetReason(void)
The service reads the reset type from the hardware, if supported.
Mcu_ModuleName ModuleName
Definition: Mcu.h:345