OSHW-DEIMOS/SOFTWARE/A64-TERES/linux-a64/drivers/soc/allwinner/pm/mem_sram.c
Dimitar Gamishev f9b0e7a283 linux
2017-10-13 14:07:04 +03:00

75 lines
1.8 KiB
C

#include "pm_types.h"
#include "pm_i.h"
static void *sram_pbase;
/*
*********************************************************************************************************
* MEM SRAM INIT
*
* Description: mem sram init.
*
* Arguments : none.
*
* Returns : 0/-1;
*********************************************************************************************************
*/
__s32 mem_sram_init(void)
{
#ifdef CONFIG_FPGA_V4_PLATFORM
sram_pbase = (void *)AW_SRAMCTRL_BASE;
#else
u32 *base = 0;
u32 sram_len = 0;
pm_get_dev_info("sram_ctrl", 0, &base, &sram_len);
sram_pbase = base;
#endif
return 0;
}
/*
*********************************************************************************************************
* MEM SRAM SAVE
*
* Description: mem sram save.
*
* Arguments : none.
*
* Returns : 0/-1;
*********************************************************************************************************
*/
__s32 mem_sram_save(struct sram_state *psram_state)
{
int i=0;
/*save all the sram reg*/
for(i=0; i<(SRAM_REG_LENGTH); i++){
psram_state->sram_reg_back[i] = *(volatile __u32 *)(IO_ADDRESS(sram_pbase) + i*0x04);
}
return 0;
}
/*
*********************************************************************************************************
* MEM sram restore
*
* Description: mem sram restore.
*
* Arguments : none.
*
* Returns : 0/-1;
*********************************************************************************************************
*/
__s32 mem_sram_restore(struct sram_state *psram_state)
{
int i=0;
/*restore all the sram reg*/
for(i=0; i<(SRAM_REG_LENGTH); i++){
*(volatile __u32 *)(IO_ADDRESS(sram_pbase) + i*0x04) = psram_state->sram_reg_back[i];
}
return 0;
}