4beb51c52f
Fix incomplete reset cause to be reported for NXP MIMXRT1062-evkb. In the event of a reset due to core lockup or software reset request on a 1062 board, the current NXP hwinfo driver reports an incomplete reset cause (only Ipp reset pin). This is happening because the 1062 uses a combined CPU lockup and system reset request register bit that should be checked, whereas the current driver only checks for the existence of a lockup-only status bit. This commit adds a check on the flag FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ already present in MIMXRT1062_features.h, to report such a reset cause should it occur. Signed-off-by: Casper Egholm Jørgensen <cjo@trackman.com>
145 lines
3.9 KiB
C
145 lines
3.9 KiB
C
/*
|
|
* Copyright (c) 2021 Basalte bv
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#define DT_DRV_COMPAT nxp_imx_src
|
|
|
|
#include <soc.h>
|
|
#include <zephyr/drivers/hwinfo.h>
|
|
#include <string.h>
|
|
#include <zephyr/sys/byteorder.h>
|
|
|
|
#include <fsl_src.h>
|
|
|
|
BUILD_ASSERT(DT_NUM_INST_STATUS_OKAY(DT_DRV_COMPAT) == 1, "No nxp,imx-src compatible device found");
|
|
|
|
int z_impl_hwinfo_get_reset_cause(uint32_t *cause)
|
|
{
|
|
uint32_t flags = 0;
|
|
|
|
uint32_t reason = SRC_GetResetStatusFlags((SRC_Type *)DT_INST_REG_ADDR(0));
|
|
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_IPP_RESET_B) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_IPP_RESET_B)
|
|
if (reason & kSRC_IppResetPinFlag) {
|
|
flags |= RESET_PIN;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_POR) && FSL_FEATURE_SRC_HAS_SRSR_POR)
|
|
if (reason & kSRC_PowerOnResetFlag) {
|
|
flags |= RESET_POR;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_LOCKUP) && FSL_FEATURE_SRC_HAS_SRSR_LOCKUP)
|
|
if (reason & kSRC_CoreLockupResetFlag) {
|
|
flags |= RESET_CPU_LOCKUP;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ)
|
|
if (reason & kSRC_LockupSysResetFlag) {
|
|
flags |= RESET_CPU_LOCKUP | RESET_SOFTWARE;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_CSU_RESET_B) && FSL_FEATURE_SRC_HAS_SRSR_CSU_RESET_B)
|
|
if (reason & kSRC_CsuResetFlag) {
|
|
flags |= RESET_SECURITY;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_SNVS) && FSL_FEATURE_SRC_HAS_SRSR_SNVS)
|
|
if (reason & kSRC_SNVSFailResetFlag) {
|
|
flags |= RESET_HARDWARE;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_IPP_USER_RESET_B) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_IPP_USER_RESET_B)
|
|
if (reason & kSRC_IppUserResetFlag) {
|
|
flags |= RESET_USER;
|
|
}
|
|
#endif
|
|
if (reason & kSRC_WatchdogResetFlag) {
|
|
flags |= RESET_WATCHDOG;
|
|
}
|
|
if (reason & kSRC_JTAGGeneratedResetFlag) {
|
|
flags |= RESET_DEBUG;
|
|
}
|
|
if (reason & kSRC_JTAGSoftwareResetFlag) {
|
|
flags |= RESET_DEBUG;
|
|
}
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_JTAG_SW_RST) && FSL_FEATURE_SRC_HAS_SRSR_JTAG_SW_RST)
|
|
if (reason & kSRC_JTAGSystemResetFlag) {
|
|
flags |= RESET_DEBUG;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_SW) && FSL_FEATURE_SRC_HAS_SRSR_SW)
|
|
if (reason & kSRC_SoftwareResetFlag) {
|
|
flags |= RESET_SOFTWARE;
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_WDOG3_RST_B) && FSL_FEATURE_SRC_HAS_SRSR_WDOG3_RST_B)
|
|
if (reason & kSRC_Wdog3ResetFlag) {
|
|
flags |= RESET_WATCHDOG;
|
|
}
|
|
#endif
|
|
if (reason & kSRC_TemperatureSensorResetFlag) {
|
|
flags |= RESET_TEMPERATURE;
|
|
}
|
|
#if !(defined(FSL_FEATURE_SRC_HAS_NO_SRSR_WBI) && FSL_FEATURE_SRC_HAS_NO_SRSR_WBI)
|
|
if (reason & kSRC_WarmBootIndicationFlag) {
|
|
flags |= RESET_SOFTWARE;
|
|
}
|
|
#endif
|
|
|
|
*cause = flags;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int z_impl_hwinfo_clear_reset_cause(void)
|
|
{
|
|
uint32_t reason = -1;
|
|
|
|
SRC_ClearResetStatusFlags((SRC_Type *)DT_INST_REG_ADDR(0), reason);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int z_impl_hwinfo_get_supported_reset_cause(uint32_t *supported)
|
|
{
|
|
*supported = (RESET_WATCHDOG
|
|
| RESET_DEBUG
|
|
| RESET_TEMPERATURE
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_IPP_RESET_B) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_IPP_RESET_B)
|
|
| RESET_PIN
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_POR) && FSL_FEATURE_SRC_HAS_SRSR_POR)
|
|
| RESET_POR
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SCR_LOCKUP_RST) && FSL_FEATURE_SRC_HAS_SCR_LOCKUP_RST)
|
|
| RESET_CPU_LOCKUP
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ)
|
|
| RESET_CPU_LOCKUP | RESET_SOFTWARE
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_CSU_RESET_B) && FSL_FEATURE_SRC_HAS_SRSR_CSU_RESET_B)
|
|
| RESET_SECURITY
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_SNVS) && FSL_FEATURE_SRC_HAS_SRSR_SNVS)
|
|
| RESET_HARDWARE
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_IPP_USER_RESET_B) && \
|
|
FSL_FEATURE_SRC_HAS_SRSR_IPP_USER_RESET_B)
|
|
| RESET_USER
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SRC_HAS_SRSR_SW) && FSL_FEATURE_SRC_HAS_SRSR_SW)
|
|
| RESET_SOFTWARE
|
|
#endif
|
|
);
|
|
|
|
return 0;
|
|
}
|