MCUSW
Mcu.h
Go to the documentation of this file.
1 /*
2 *
3 * Copyright (c) 2024 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 (1U)
112 
113 #define MCU_SW_PATCH_VERSION (1U)
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 
149  /*
150  * Design: MCAL-8507,MCAL-8489
151  */
152  #ifndef MCU_E_PARAM_CONFIG
153 
154  #define MCU_E_PARAM_CONFIG (0x0AU)
155  #endif
156 
157 
158  /*
159  * Design: MCAL-8507
160  */
161 
162 #ifndef MCU_E_PARAM_CLOCK
163 
164 #define MCU_E_PARAM_CLOCK (0x0BU)
165 #endif
166 
167 /*
168  * Design: MCAL-8507
169  */
170 #ifndef MCU_E_PARAM_MODE
171 
172 #define MCU_E_PARAM_MODE (0x0CU)
173 #endif
174 
175 /*
176  * Design: MCAL-8507
177  */
178 #ifndef MCU_E_PARAM_RAMSECTION
179 
180 #define MCU_E_PARAM_RAMSECTION (0x0DU)
181 #endif
182 
183 /*
184  * Design: MCAL-8507
185  */
186 #ifndef MCU_E_PLL_NOT_LOCKED
187 
188 #define MCU_E_PLL_NOT_LOCKED (0x0EU)
189 #endif
190 
191 /*
192  * Design: MCAL-8507
193  */
194 #ifndef MCU_E_UNINIT
195 
196 #define MCU_E_UNINIT (0x0FU)
197 #endif
198 
199 /*
200  * Design: MCAL-8507
201  */
202 #ifndef MCU_E_PARAM_POINTER
203 
204 #define MCU_E_PARAM_POINTER (0x10U)
205 #endif
206 
207 /*
208  * Design: MCAL-8507
209  */
210 #ifndef MCU_E_INIT_FAILED
211 
212 #define MCU_E_INIT_FAILED (0x11U)
213 #endif
214 
221  /*
222  * Design: MCAL-8507
223  */
225 #define MCU_STATUS_UNINIT ((uint8)(0U))
226 
227 #define MCU_STATUS_INIT ((uint8)(1U))
228 
238 #define MCU_SID_INIT (0x00U)
239 
240 #define MCU_SID_INIT_RAM_SECTION (0x01U)
241 
242 #define MCU_SID_INIT_CLOCK (0x02U)
243 
244 #define MCU_SID_DISTRIBUTE_PLL_CLOCK (0x03U)
245 
246 #define MCU_SID_GET_PLL_STATUS (0x04U)
247 
248 #define MCU_SID_GET_RESET_REASON (0x05U)
249 
250 #define MCU_SID_GET_RESET_RAW_VALUE (0x06U)
251 
252 #define MCU_SID_PERFORM_RESET (0x07U)
253 
254 #define MCU_SID_SETMODE (0x08U)
255 
256 #define MCU_SID_GET_VERSION_INFO (0x09U)
257 
258 #define MCU_SID_GET_RAM_STATE (0x0AU)
259 /* @} */
260 
261 #if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4)
262 
269 #define MCU_PERFORM_RESET_MODE_COLD ((uint8) 0U)
270 #endif
271 
272 #define MCU_PERFORM_RESET_MODE_WARM ((uint8) 1U)
273 /* @} */
274 #define MCU_E_MODE_FAILURE 0U
275 
276 
277 
278 
279 /*
280  * Design: MCAL-8487,MCAL-8492
281  */
286 typedef uint8 Mcu_ClockType;
287 
288 /*
289  * Design: MCAL-8491,MCAL-8471
290  */
295 typedef uint32 Mcu_RawResetType;
296 
297 /*
298  * Design: MCAL-8406,MCAL-8421
299  */
304 typedef uint8 Mcu_RamSectionType;
305 
306 /*
307  * Design: MCAL-8490,MCAL-8418
308  */
313 typedef uint8 Mcu_ModeType;
314 
315 /* ========================================================================== */
316 /* Structures and Enums */
317 /* ========================================================================== */
318 
319 /*
320  * Design: MCAL-8438
321  */
325  typedef struct
326  {
335  boolean Mcu_InitCfg;
340 
341 
342 
346 typedef P2CONST (Mcu_ClockConfigType, AUTOMATIC, MCU_PBCFG)
348 
349 /*
350 * Design: MCAL-8439,MCAL-8424,MCAL-8405,MCAL-8438,MCAL-8457
351 */
356  typedef struct Mcu_ConfigType_s
357  {
368  } Mcu_ConfigType;
369 
370 
372 extern const struct Mcu_ConfigType_s McuModuleConfiguration_0;
373 
374 
375 
376 
377 /* @} */
378 
379 /* ========================================================================== */
380 /* Function Declarations */
381 /* ========================================================================== */
382 
399 FUNC(void, MCU_CODE) Mcu_Init(
400  P2CONST(Mcu_ConfigType, AUTOMATIC, MCU_PBCFG) ConfigPtr);
401 
402 FUNC(Std_ReturnType, MCU_CODE) Mcu_ClockSetSource(
403  Mcu_ClkModuleIdType moduleId,
404  Mcu_ClkSourceIdType clkSrcId,
405  uint8 clkParentId);
406 
407 #if (STD_ON == MCU_INIT_CLOCK_API)
408 
428 FUNC(Std_ReturnType, MCU_CODE) Mcu_InitClock(Mcu_ClockType ClockSetting);
429 #endif /* MCU_INIT_CLOCK_API */
430 
448 #if(STD_OFF == MCU_NO_PLL)
449 FUNC(Std_ReturnType, MCU_CODE) Mcu_DistributePllClock(void);
450 
451 #endif /* STD_OFF == MCU_NO_PLL */
452 
453 #if (STD_ON == MCU_PERFORM_RESET_API)
454 
470 FUNC(void, MCU_CODE) Mcu_PerformReset(void);
471 
472 #endif /* MCU_PERFORM_RESET_API */
473 
474 #if (STD_ON == MCU_INIT_RAM_API)
475 
496 FUNC(Std_ReturnType, MCU_CODE) Mcu_InitRamSection(
497  Mcu_RamSectionType RamSection);
498 #endif /* MCU_INIT_RAM_API */
499 
500 
501 /* Design: MCAL-8391 */
502 
503 /* This is a Dummy API */
504 
521 FUNC(Mcu_PllStatusType, MCU_CODE) Mcu_GetPllStatus(void);
522 
540 FUNC(Mcu_ResetType, MCU_CODE) Mcu_GetResetReason(void);
541 
560 FUNC(Mcu_RawResetType, MCU_CODE) Mcu_GetResetRawValue(void);
561 
562 #if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4)
563 
580 FUNC(void, MCU_CODE) Mcu_ClearResetReason(void);
581 #endif
582 
583 #if (STD_ON == MCU_GET_RAM_STATE_API)
584 
585 /* This is a Dummy API
586 */
605 FUNC(Mcu_RamStateType, MCU_CODE) Mcu_GetRamState(void);
606 #endif /* MCU_GET_RAM_STATE_API */
607 
608 #if (STD_ON == MCU_GET_VERSION_INFO_API)
609 
632 FUNC(void, MCU_CODE) Mcu_GetVersionInfo(
633  P2VAR(Std_VersionInfoType, AUTOMATIC, MCU_APPL_DATA) versioninfo);
634 #endif /* MCU_GET_VERSION_INFO_API */
635 
636 
637 
655 FUNC(void, MCU_CODE) Mcu_SetMode(P2CONST(Mcu_ModeType, AUTOMATIC, MCU_APPL_DATA) McuMode);
656 
657 
658 
659 
660 #ifdef __cplusplus
661 }
662 #endif
663 
664 #endif /* #ifndef MCU_H_ */
665 
666 /* @} */
Mcu_ClkSourceIdType
This is the type of the clock source in clock tree that is selectable for peripheral....
Definition: Mcu_Cfg.h:414
Mcu_ClkModuleIdType
Clock source config modules id enum.
Definition: Mcu_Cfg.h:313
MCU CONFIG ROOT structure.
Definition: Mcu.h:356
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:257
Mcu_ModuleName
Definition: Mcu_Cfg.h:282
Mcu_ClkSourceIdType Mcu_ClockSourceId
Definition: Mcu.h:329
This file contains generated pre compile configuration file for MCU MCAL driver.
uint8 Mcu_NumberOfClockConfig
Definition: Mcu.h:364
Std_ReturnType(* Mcu_CBKFunctionPtrType)(uint32 moduleId, uint32 clkId, uint64 ParentId)
Pointer to Callback function.
Definition: Mcu_Cfg.h:516
uint8 Mcu_ResetMode
Definition: Mcu.h:360
uint8 Mcu_ClockType
This type specifies the identification (ID) for a ClockType status used by Mcu_InitClock()
Definition: Mcu.h:286
Mcu_RamStateType
Enumeration of ranstate queried by Mcu_GetRamState()
Definition: Mcu_Cfg.h:470
uint8 Mcu_ModeType
This type specifies the identification (ID) for a MCU mode used in Mcu_SetMode()
Definition: Mcu.h:313
Structure for module clock setting.
Definition: Mcu.h:325
Mcu_DomainType
Definition: Mcu_Cfg.h:271
Mcu_RamStateType Mcu_GetRamState(void)
This service provides the actual status of the microcontroller Ram. (if supported)
Mcu_ClkModuleIdType Mcu_ClockModuleId
Definition: Mcu.h:327
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:337
void Mcu_Init(const Mcu_ConfigType *ConfigPtr)
This service initializes the MCU driver.
Mcu_CBKFunctionPtrType Mcu_CBK_Function
Definition: Mcu.h:366
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:304
Mcu_DomainType Domain
Definition: Mcu.h:333
void Mcu_GetVersionInfo(Std_VersionInfoType *versioninfo)
This service returns the version information of this module.
boolean Mcu_InitCfg
Definition: Mcu.h:335
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:358
Mcu_PllStatusType
This is a status value returned by the function Mcu_GetPllStatus() of the MCU module.
Definition: Mcu_Cfg.h:432
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:295
Mcu_ClockConfigPtrType Mcu_ClockConfig
Definition: Mcu.h:362
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:331