arch: cxd56xx: Add function to control GNSS RAM clock

Add function to enable and disable GNSS RAM clock.
This commit is contained in:
SPRESENSE 2024-02-05 19:06:45 +09:00 committed by Xiang Xiao
parent 3ff9432975
commit fc5ae43dda
3 changed files with 58 additions and 0 deletions

View File

@ -69,6 +69,8 @@
#define PDID_SCU 0 #define PDID_SCU 0
#define PDID_APP_DSP 9 #define PDID_APP_DSP 9
#define PDID_APP_SUB 10 #define PDID_APP_SUB 10
#define PDID_GNSS_ITP 12
#define PDID_GNSS 13
#define PDID_APP_AUD 14 #define PDID_APP_AUD 14
/* For enable_apwd, disable_apwd (analog domain) */ /* For enable_apwd, disable_apwd (analog domain) */
@ -2602,6 +2604,41 @@ int cxd56_hostseq_clock_disable(void)
return ret; return ret;
} }
int cxd56_gnssram_clock_enable(void)
{
uint32_t stat;
stat = getreg32(CXD56_TOPREG_PWD_STAT);
if ((stat & (1u << PDID_GNSS)) && (stat & (1u << PDID_GNSS_ITP)))
{
/* Already power on */
return OK;
}
/* Enable all of GNSS RAM memory power. */
putreg32(0xff00ffff, CXD56_TOPREG_GNSS_RAMMODE_SEL);
enable_pwd(PDID_GNSS_ITP);
enable_pwd(PDID_GNSS);
putreg32(0x143, CXD56_TOPREG_GNSDSP_CKEN);
busy_wait(10);
putreg32(0x103, CXD56_TOPREG_GNSDSP_CKEN);
putreg32(0x10000, CXD56_TOPREG_SWRESET_GNSDSP);
putreg32(0x153, CXD56_TOPREG_GNSDSP_CKEN);
return OK;
}
int cxd56_gnssram_clock_disable(void)
{
putreg32(0x0, CXD56_TOPREG_GNSDSP_CKEN);
putreg32(0x0, CXD56_TOPREG_SWRESET_GNSDSP);
putreg32(0xff000000, CXD56_TOPREG_GNSS_RAMMODE_SEL);
disable_pwd(PDID_GNSS);
disable_pwd(PDID_GNSS_ITP);
return OK;
}
int up_pmramctrl(int cmd, uintptr_t addr, size_t size) int up_pmramctrl(int cmd, uintptr_t addr, size_t size)
{ {
int startidx; int startidx;

View File

@ -724,6 +724,26 @@ int cxd56_hostseq_clock_enable(void);
int cxd56_hostseq_clock_disable(void); int cxd56_hostseq_clock_disable(void);
/****************************************************************************
* Name: cxd56_gnssram_clock_enable
*
* Description:
* Enable clock of the GNSS RAM
*
****************************************************************************/
int cxd56_gnssram_clock_enable(void);
/****************************************************************************
* Name: cxd56_gnssram_clock_disable
*
* Description:
* Disable clock of the GNSS RAM
*
****************************************************************************/
int cxd56_gnssram_clock_disable(void);
#undef EXTERN #undef EXTERN
#if defined(__cplusplus) #if defined(__cplusplus)
} }

View File

@ -241,6 +241,7 @@
#define CXD56_TOPREG_FUSEWRAD (CXD56_TOPREG_BASE + 0x0a04) #define CXD56_TOPREG_FUSEWRAD (CXD56_TOPREG_BASE + 0x0a04)
#define CXD56_TOPREG_FUSEWRDT (CXD56_TOPREG_BASE + 0x0a08) #define CXD56_TOPREG_FUSEWRDT (CXD56_TOPREG_BASE + 0x0a08)
#define CXD56_TOPREG_FUSEWRPG (CXD56_TOPREG_BASE + 0x0a0c) #define CXD56_TOPREG_FUSEWRPG (CXD56_TOPREG_BASE + 0x0a0c)
#define CXD56_TOPREG_GNSS_RAMMODE_SEL (CXD56_TOPREG_BASE + 0x0c00)
#define CXD56_TOPREG_ADSP1_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1010) #define CXD56_TOPREG_ADSP1_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1010)
#define CXD56_TOPREG_ADSP2_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1014) #define CXD56_TOPREG_ADSP2_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1014)
#define CXD56_TOPREG_ADSP3_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1018) #define CXD56_TOPREG_ADSP3_BOOT_ENTRY_POINT (CXD56_TOPREG_BASE + 0x1018)