MCUSW
Loading...
Searching...
No Matches
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
90extern "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 (10U)
111#define MCU_SW_MINOR_VERSION (0U)
113#define MCU_SW_PATCH_VERSION (0U)
114/* @} */
115
123#define MCU_AR_RELEASE_MAJOR_VERSION (4U)
125#define MCU_AR_RELEASE_MINOR_VERSION (3U)
127#define MCU_AR_RELEASE_REVISION_VERSION (1U)
128/* @} */
129
135#define MCU_VENDOR_ID ((uint16) 44U)
137#define MCU_MODULE_ID ((uint16) 101U)
139#define MCU_INSTANCE_ID ((uint8) 0U)
140/* @} */
141
149 /*
150 * Design: MCAL-8507,MCAL-8489
151 */
152 #ifndef MCU_E_PARAM_CONFIG
154 #define MCU_E_PARAM_CONFIG (0x0AU)
155 #endif
156
157
158 /*
159 * Design: MCAL-8507
160 */
161
162#ifndef MCU_E_PARAM_CLOCK
164#define MCU_E_PARAM_CLOCK (0x0BU)
165#endif
166
167/*
168 * Design: MCAL-8507
169 */
170#ifndef MCU_E_PARAM_MODE
172#define MCU_E_PARAM_MODE (0x0CU)
173#endif
174
175/*
176 * Design: MCAL-8507
177 */
178#ifndef MCU_E_PARAM_RAMSECTION
180#define MCU_E_PARAM_RAMSECTION (0x0DU)
181#endif
182
183/*
184 * Design: MCAL-8507
185 */
186#ifndef MCU_E_PLL_NOT_LOCKED
188#define MCU_E_PLL_NOT_LOCKED (0x0EU)
189#endif
190
191/*
192 * Design: MCAL-8507
193 */
194#ifndef MCU_E_UNINIT
196#define MCU_E_UNINIT (0x0FU)
197#endif
198
199/*
200 * Design: MCAL-8507
201 */
202#ifndef MCU_E_PARAM_POINTER
204#define MCU_E_PARAM_POINTER (0x10U)
205#endif
206
207/*
208 * Design: MCAL-8507
209 */
210#ifndef MCU_E_INIT_FAILED
212#define MCU_E_INIT_FAILED (0x11U)
213#endif
214
221 /*
222 * Design: MCAL-8507
223 */
225#define MCU_STATUS_UNINIT ((uint8)(0U))
227#define MCU_STATUS_INIT ((uint8)(1U))
228
238#define MCU_SID_INIT (0x00U)
240#define MCU_SID_INIT_RAM_SECTION (0x01U)
242#define MCU_SID_INIT_CLOCK (0x02U)
244#define MCU_SID_DISTRIBUTE_PLL_CLOCK (0x03U)
246#define MCU_SID_GET_PLL_STATUS (0x04U)
248#define MCU_SID_GET_RESET_REASON (0x05U)
250#define MCU_SID_GET_RESET_RAW_VALUE (0x06U)
252#define MCU_SID_PERFORM_RESET (0x07U)
254#define MCU_SID_SETMODE (0x08U)
256#define MCU_SID_GET_VERSION_INFO (0x09U)
258#define MCU_SID_GET_RAM_STATE (0x0AU)
259/* @} */
260
261#if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4) || defined (SOC_J742S2)
269#define MCU_PERFORM_RESET_MODE_COLD ((uint8) 0U)
270#endif
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 */
286typedef uint8 Mcu_ClockType;
287
288/*
289 * Design: MCAL-8491,MCAL-8471
290 */
295typedef uint32 Mcu_RawResetType;
296
297/*
298 * Design: MCAL-8406,MCAL-8421
299 */
304typedef uint8 Mcu_RamSectionType;
305
306/*
307 * Design: MCAL-8490,MCAL-8418
308 */
313typedef uint8 Mcu_ModeType;
314
315/* ========================================================================== */
316/* Structures and Enums */
317/* ========================================================================== */
318
319/*
320 * Design: MCAL-8438
321 */
340
341
342
346typedef P2CONST (Mcu_ClockConfigType, AUTOMATIC, MCU_PBCFG)
348
349/*
350* Design: MCAL-8439,MCAL-8424,MCAL-8405,MCAL-8438,MCAL-8457
351*/
369
370
372extern const struct Mcu_ConfigType_s McuModuleConfiguration_0;
373
374
375
376
377/* @} */
378
379/* ========================================================================== */
380/* Function Declarations */
381/* ========================================================================== */
382
399FUNC(void, MCU_CODE) Mcu_Init(
400 P2CONST(Mcu_ConfigType, AUTOMATIC, MCU_PBCFG) ConfigPtr);
401
402
403#if (STD_ON == MCU_INIT_CLOCK_API)
424FUNC(Std_ReturnType, MCU_CODE) Mcu_InitClock(Mcu_ClockType ClockSetting);
425#endif /* MCU_INIT_CLOCK_API */
426
444#if(STD_OFF == MCU_NO_PLL)
445FUNC(Std_ReturnType, MCU_CODE) Mcu_DistributePllClock(void);
446
447#endif /* STD_OFF == MCU_NO_PLL */
448
449#if (STD_ON == MCU_PERFORM_RESET_API)
466FUNC(void, MCU_CODE) Mcu_PerformReset(void);
467
468#endif /* MCU_PERFORM_RESET_API */
469
470#if (STD_ON == MCU_INIT_RAM_API)
492FUNC(Std_ReturnType, MCU_CODE) Mcu_InitRamSection(
493 Mcu_RamSectionType RamSection);
494#endif /* MCU_INIT_RAM_API */
495
496
497/* Design: MCAL-8391 */
498
499/* This is a Dummy API */
500
518
536FUNC(Mcu_ResetType, MCU_CODE) Mcu_GetResetReason(void);
537
557
558#if defined (SOC_J721E) || defined (SOC_J7200) || defined (SOC_J721S2) || defined (SOC_J784S4) || defined (SOC_J742S2)
576FUNC(void, MCU_CODE) Mcu_ClearResetReason(void);
577#endif
578
579#if (STD_ON == MCU_GET_RAM_STATE_API)
580
581/* This is a Dummy API
582*/
601FUNC(Mcu_RamStateType, MCU_CODE) Mcu_GetRamState(void);
602#endif /* MCU_GET_RAM_STATE_API */
603
604#if (STD_ON == MCU_GET_VERSION_INFO_API)
628FUNC(void, MCU_CODE) Mcu_GetVersionInfo(
629 P2VAR(Std_VersionInfoType, AUTOMATIC, MCU_APPL_DATA) versioninfo);
630#endif /* MCU_GET_VERSION_INFO_API */
631
632
633
651 FUNC(void, MCU_CODE) Mcu_SetMode(Mcu_ModeType McuMode);
652
653
654
655#ifdef __cplusplus
656}
657#endif
658
659#endif /* #ifndef MCU_H_ */
660
661/* @} */
This file contains generated pre compile configuration file for MCU MCAL driver.
void Mcu_GetVersionInfo(Std_VersionInfoType *versioninfo)
This service returns the version information of this module.
uint8 Mcu_RamSectionType
This type specifies the identification (ID) for a RAM section used in Mcu_InitRamSection()
Definition Mcu.h:304
Mcu_CBKFunctionPtrType Mcu_CBK_Function
Definition Mcu.h:366
uint8 Mcu_ResetMode
Definition Mcu.h:360
Std_ReturnType Mcu_InitClock(Mcu_ClockType ClockSetting)
This service initializes the PLL and other MCU specific clock options.
Mcu_ModuleName ModuleName
Definition Mcu.h:331
Mcu_ClkSourceIdType Mcu_ClockSourceId
Definition Mcu.h:329
void Mcu_Init(const Mcu_ConfigType *ConfigPtr)
This service initializes the MCU driver.
Std_ReturnType Mcu_InitRamSection(Mcu_RamSectionType RamSection)
This service initializes the RAM section wise.
Mcu_ResetType Mcu_GetResetReason(void)
The service reads the reset type from the hardware, if supported.
uint32 Mcu_RawResetType
This type specifies the identification (ID) for a RAW MCU reset status returned by Mcu_GetResetRawVal...
Definition Mcu.h:295
Mcu_RamStateType Mcu_GetRamState(void)
This service provides the actual status of the microcontroller Ram. (if supported)
Mcu_RawResetType Mcu_GetResetRawValue(void)
The service reads the reset type from the hardware register, if supported.
Mcu_ModeType Mcu_Mode
Definition Mcu.h:358
uint8 Mcu_ClockType
This type specifies the identification (ID) for a ClockType status used by Mcu_InitClock()
Definition Mcu.h:286
void Mcu_SetMode(Mcu_ModeType McuMode)
This service activates the MCU power modes.
Mcu_ClkModuleIdType Mcu_ClockModuleId
Definition Mcu.h:327
void Mcu_ClearResetReason(void)
Clear the Mcu Reset reason by clearing the reset reason register.
uint8 Mcu_ModeType
This type specifies the identification (ID) for a MCU mode used in Mcu_SetMode()
Definition Mcu.h:313
const struct Mcu_ConfigType_s McuModuleConfiguration_0
MCU Configuration struct declaration.
Std_ReturnType Mcu_DistributePllClock(void)
This service activates the PLL clock to the MCU clock distribution.
boolean Mcu_InitCfg
Definition Mcu.h:335
Mcu_ClockConfigPtrType Mcu_ClockConfig
Definition Mcu.h:362
uint64 Mcu_ClockFrequency
Definition Mcu.h:337
Mcu_DomainType Domain
Definition Mcu.h:333
void Mcu_PerformReset(void)
The service performs a microcontroller reset.
uint8 Mcu_NumberOfClockConfig
Definition Mcu.h:364
Mcu_PllStatusType Mcu_GetPllStatus(void)
This service provides the lock status of the PLL.
Mcu_RamStateType
Enumeration of ranstate queried by Mcu_GetRamState()
Definition Mcu_Cfg.h:471
Mcu_ModuleName
Definition Mcu_Cfg.h:283
Mcu_PllStatusType
This is a status value returned by the function Mcu_GetPllStatus() of the MCU module.
Definition Mcu_Cfg.h:433
Mcu_ClkSourceIdType
This is the type of the clock source in clock tree that is selectable for peripheral....
Definition Mcu_Cfg.h:415
Mcu_DomainType
Definition Mcu_Cfg.h:272
Std_ReturnType(* Mcu_CBKFunctionPtrType)(uint32 moduleId, uint32 clkId, uint64 ParentId)
Pointer to Callback function.
Definition Mcu_Cfg.h:516
Mcu_ClkModuleIdType
Clock source config modules id enum.
Definition Mcu_Cfg.h:314
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:258
Structure for module clock setting.
Definition Mcu.h:326
MCU CONFIG ROOT structure.
Definition Mcu.h:357