zephyr/boards/nxp/rd_rw612_bga/init.c

76 lines
2 KiB
C
Raw Normal View History

/*
* Copyright 2022, 2024-25 NXP
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/pm/pm.h>
#include <fsl_power.h>
#include <fsl_common.h>
static void rdrw61x_power_init_config(void)
{
power_init_config_t initCfg = {
/* VCORE AVDD18 supplied from iBuck on RD board. */
.iBuck = true,
/* CAU_SOC_SLP_REF_CLK is needed for LPOSC. */
.gateCauRefClk = false,
};
POWER_InitPowerConfig(&initCfg);
}
#if CONFIG_PM
static void rdrw61x_pm_state_exit(enum pm_state state)
{
switch (state) {
case PM_STATE_STANDBY:
rdrw61x_power_init_config();
break;
default:
break;
}
}
#endif
void board_early_init_hook(void)
{
rdrw61x_power_init_config();
#if CONFIG_PM
static struct pm_notifier rdrw61x_pm_notifier = {
.state_exit = rdrw61x_pm_state_exit,
};
pm_notifier_register(&rdrw61x_pm_notifier);
#endif
#ifdef CONFIG_I2S_TEST_SEPARATE_DEVICES
/*
* Eventually this code should not be here
* but should be configured by some SYSCTL node
*/
/* Set shared signal set 0 SCK, WS from Transmit I2S - Flexcomm1 */
SYSCTL1->SHAREDCTRLSET[0] = SYSCTL1_SHAREDCTRLSET_SHAREDSCKSEL(1) |
SYSCTL1_SHAREDCTRLSET_SHAREDWSSEL(1);
/* Select Data in from Transmit I2S - Flexcomm 1 */
SYSCTL1->SHAREDCTRLSET[0] |= SYSCTL1_SHAREDCTRLSET_SHAREDDATASEL(1);
/* Enable Transmit I2S - Flexcomm 1 for Shared Data Out */
SYSCTL1->SHAREDCTRLSET[0] |= SYSCTL1_SHAREDCTRLSET_FC1DATAOUTEN(1);
/* Set Receive I2S - Flexcomm 0 SCK, WS from shared signal set 0 */
SYSCTL1->FCCTRLSEL[0] = SYSCTL1_FCCTRLSEL_SCKINSEL(1) |
SYSCTL1_FCCTRLSEL_WSINSEL(1);
/* Set Transmit I2S - Flexcomm 1 SCK, WS from shared signal set 0 */
SYSCTL1->FCCTRLSEL[1] = SYSCTL1_FCCTRLSEL_SCKINSEL(1) |
SYSCTL1_FCCTRLSEL_WSINSEL(1);
/* Select Receive I2S - Flexcomm 0 Data in from shared signal set 0 */
SYSCTL1->FCCTRLSEL[0] |= SYSCTL1_FCCTRLSEL_DATAINSEL(1);
/* Select Transmit I2S - Flexcomm 1 Data out to shared signal set 0 */
SYSCTL1->FCCTRLSEL[1] |= SYSCTL1_FCCTRLSEL_DATAOUTSEL(1);
#endif /* CONFIG_I2S_TEST_SEPARATE_DEVICES */
}