oleavr-rgl-a500-mini-linux-.../drivers/soc/allwinner/pm/mem_ccu-sun8iw10.c
Ole André Vadla Ravnås 169c65d57e Initial commit
2022-05-07 01:01:45 +02:00

193 lines
7.6 KiB
C

/*
* Copyright (c) 2011-2020 yanggq.young@allwinnertech.com
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 as published by
* the Free Software Foundation.
*/
#include "pm_types.h"
#include "pm_i.h"
/*
*********************************************************************************************************
* MEM CCU INITIALISE
*
* Description: mem interrupt initialise.
*
* Arguments : none.
*
* Returns : 0/-1;
*********************************************************************************************************
*/
__s32 mem_ccu_save(struct ccm_state *ccm_reg)
{
ccm_reg->ccm_reg = (__ccmu_reg_list_t *) IO_ADDRESS(AW_CCM_BASE);
/*bias: */
ccm_reg->ccm_reg_backup.PllAudioBias = ccm_reg->ccm_reg->PllAudioBias;
ccm_reg->ccm_reg_backup.PllDeBias = ccm_reg->ccm_reg->PllDeBias;
ccm_reg->ccm_reg_backup.PllVideo0Bias = ccm_reg->ccm_reg->PllVideo0Bias;
ccm_reg->ccm_reg_backup.PllVideo1Bias = ccm_reg->ccm_reg->PllVideo1Bias;
/*tune & pattern: */
ccm_reg->ccm_reg_backup.PllAudioPattern =
ccm_reg->ccm_reg->PllAudioPattern;
/*cfg: */
ccm_reg->ccm_reg_backup.Pll1Ctl = ccm_reg->ccm_reg->Pll1Ctl;
ccm_reg->ccm_reg_backup.Pll2Ctl = ccm_reg->ccm_reg->Pll2Ctl;
ccm_reg->ccm_reg_backup.Pll9Ctl = ccm_reg->ccm_reg->Pll9Ctl;
ccm_reg->ccm_reg_backup.Pll10Ctl = ccm_reg->ccm_reg->Pll10Ctl;
/*notice: be care to cpu, axi restore sequence!. */
ccm_reg->ccm_reg_backup.SysClkDiv = ccm_reg->ccm_reg->SysClkDiv;
ccm_reg->ccm_reg_backup.Ahb1Div = ccm_reg->ccm_reg->Ahb1Div;
ccm_reg->ccm_reg_backup.Apb2Div = ccm_reg->ccm_reg->Apb2Div;
/*actually, the gating & reset ctrl reg
** should not affect corresponding module's recovery.
*/
ccm_reg->ccm_reg_backup.AhbGate0 = ccm_reg->ccm_reg->AhbGate0;
ccm_reg->ccm_reg_backup.AhbGate1 = ccm_reg->ccm_reg->AhbGate1;
ccm_reg->ccm_reg_backup.Apb1Gate = ccm_reg->ccm_reg->Apb1Gate;
ccm_reg->ccm_reg_backup.Apb2Gate0 = ccm_reg->ccm_reg->Apb2Gate0;
ccm_reg->ccm_reg_backup.Apb2Gate1 = ccm_reg->ccm_reg->Apb2Gate1;
ccm_reg->ccm_reg_backup.Nand0 = ccm_reg->ccm_reg->Nand0;
ccm_reg->ccm_reg_backup.Sd0 = ccm_reg->ccm_reg->Sd0;
ccm_reg->ccm_reg_backup.Sd1 = ccm_reg->ccm_reg->Sd1;
ccm_reg->ccm_reg_backup.Sd2 = ccm_reg->ccm_reg->Sd2;
ccm_reg->ccm_reg_backup.Sd3 = ccm_reg->ccm_reg->Sd3;
ccm_reg->ccm_reg_backup.Spi0 = ccm_reg->ccm_reg->Spi0;
ccm_reg->ccm_reg_backup.Spi1 = ccm_reg->ccm_reg->Spi1;
ccm_reg->ccm_reg_backup.Spi2 = ccm_reg->ccm_reg->Spi2;
ccm_reg->ccm_reg_backup.I2s0 = ccm_reg->ccm_reg->I2s0;
ccm_reg->ccm_reg_backup.I2s1 = ccm_reg->ccm_reg->I2s1;
ccm_reg->ccm_reg_backup.SpdifClk = ccm_reg->ccm_reg->SpdifClk;
ccm_reg->ccm_reg_backup.Usb = ccm_reg->ccm_reg->Usb;
/* do not touch dram related config. */
/* ccm_reg->ccm_reg_backup.PllDdrCfg = ccm_reg->ccm_reg->PllDdrCfg; */
/* ccm_reg->ccm_reg_backup.MbusResetReg = ccm_reg->ccm_reg->MbusResetReg; */
/* ccm_reg->ccm_reg_backup.DramCfg = ccm_reg->ccm_reg->DramCfg; */
/* ccm_reg->ccm_reg_backup.DramGate = ccm_reg->ccm_reg->DramGate; */
ccm_reg->ccm_reg_backup.De0 = ccm_reg->ccm_reg->De0;
ccm_reg->ccm_reg_backup.Ee0 = ccm_reg->ccm_reg->Ee0;
ccm_reg->ccm_reg_backup.Edma = ccm_reg->ccm_reg->Edma;
ccm_reg->ccm_reg_backup.Lcd0Ch0 = ccm_reg->ccm_reg->Lcd0Ch0;
ccm_reg->ccm_reg_backup.CsiMisc = ccm_reg->ccm_reg->CsiMisc;
ccm_reg->ccm_reg_backup.Csi0 = ccm_reg->ccm_reg->Csi0;
/*mbus? function? */
/*ccm_reg->ccm_reg_backup.MBus0 = ccm_reg->ccm_reg->MBus0; */
ccm_reg->ccm_reg_backup.PllLock = ccm_reg->ccm_reg->PllLock;
ccm_reg->ccm_reg_backup.Pll1Lock = ccm_reg->ccm_reg->Pll1Lock;
ccm_reg->ccm_reg_backup.AhbReset0 = ccm_reg->ccm_reg->AhbReset0;
ccm_reg->ccm_reg_backup.AhbReset1 = ccm_reg->ccm_reg->AhbReset1;
ccm_reg->ccm_reg_backup.Apb1Reset = ccm_reg->ccm_reg->Apb1Reset;
ccm_reg->ccm_reg_backup.Apb2Reset = ccm_reg->ccm_reg->Apb2Reset;
ccm_reg->ccm_reg_backup.PsCtrl = ccm_reg->ccm_reg->PsCtrl;
ccm_reg->ccm_reg_backup.PsCnt = ccm_reg->ccm_reg->PsCnt;
ccm_reg->ccm_reg_backup.PllLockCtrl = ccm_reg->ccm_reg->PllLockCtrl;
ccm_reg->ccm_reg_backup.DcxoCtrl0 = ccm_reg->ccm_reg->DcxoCtrl0;
ccm_reg->ccm_reg_backup.DcxoCtrl1 = ccm_reg->ccm_reg->DcxoCtrl1;
return 0;
}
__s32 mem_ccu_restore(struct ccm_state *ccm_reg)
{
/*bias: */
ccm_reg->ccm_reg->PllAudioBias = ccm_reg->ccm_reg_backup.PllAudioBias;
ccm_reg->ccm_reg->PllDeBias = ccm_reg->ccm_reg_backup.PllDeBias;
ccm_reg->ccm_reg->PllVideo1Bias = ccm_reg->ccm_reg_backup.PllVideo1Bias;
/*tune & pattern: */
ccm_reg->ccm_reg->PllAudioPattern =
ccm_reg->ccm_reg_backup.PllAudioPattern;
/*cfg */
ccm_reg->ccm_reg->Pll2Ctl = ccm_reg->ccm_reg_backup.Pll2Ctl;
ccm_reg->ccm_reg->Pll9Ctl = ccm_reg->ccm_reg_backup.Pll9Ctl;
ccm_reg->ccm_reg->Pll10Ctl = ccm_reg->ccm_reg_backup.Pll10Ctl;
change_runtime_env();
delay_us(10);
ccm_reg->ccm_reg->Pll1Ctl = ccm_reg->ccm_reg_backup.Pll1Ctl;
change_runtime_env();
delay_us(1000);
/*notice: be care to cpu, axi restore sequence!. */
ccm_reg->ccm_reg->SysClkDiv = ccm_reg->ccm_reg_backup.SysClkDiv;
ccm_reg->ccm_reg->Ahb1Div = ccm_reg->ccm_reg_backup.Ahb1Div;
delay_us(1);
ccm_reg->ccm_reg->Apb2Div = ccm_reg->ccm_reg_backup.Apb2Div;
/*actually, the gating & reset ctrl reg
** should not affect corresponding module's recovery.
*/
/*first, reset, then, gating. */
ccm_reg->ccm_reg->AhbReset0 = ccm_reg->ccm_reg_backup.AhbReset0;
ccm_reg->ccm_reg->AhbReset1 = ccm_reg->ccm_reg_backup.AhbReset1;
ccm_reg->ccm_reg->Apb1Reset = ccm_reg->ccm_reg_backup.Apb1Reset;
ccm_reg->ccm_reg->Apb2Reset = ccm_reg->ccm_reg_backup.Apb2Reset;
ccm_reg->ccm_reg->Nand0 = ccm_reg->ccm_reg_backup.Nand0;
ccm_reg->ccm_reg->Sd0 = ccm_reg->ccm_reg_backup.Sd0;
ccm_reg->ccm_reg->Sd1 = ccm_reg->ccm_reg_backup.Sd1;
ccm_reg->ccm_reg->Sd2 = ccm_reg->ccm_reg_backup.Sd2;
ccm_reg->ccm_reg->Spi0 = ccm_reg->ccm_reg_backup.Spi0;
ccm_reg->ccm_reg->Spi1 = ccm_reg->ccm_reg_backup.Spi1;
ccm_reg->ccm_reg->I2s0 = ccm_reg->ccm_reg_backup.I2s0;
ccm_reg->ccm_reg->I2s1 = ccm_reg->ccm_reg_backup.I2s1;
ccm_reg->ccm_reg->SpdifClk = ccm_reg->ccm_reg_backup.SpdifClk;
ccm_reg->ccm_reg->Usb = ccm_reg->ccm_reg_backup.Usb;
#if 0
ccm_reg->ccm_reg->DramCfg = ccm_reg->ccm_reg_backup.DramCfg;
ccm_reg->ccm_reg_backup.PllDdrCfg = ccm_reg->ccm_reg->PllDdrCfg;
ccm_reg->ccm_reg_backup.MbusResetReg = ccm_reg->ccm_reg->MbusResetReg;
ccm_reg->ccm_reg->DramGate = ccm_reg->ccm_reg_backup.DramGate;
#endif
ccm_reg->ccm_reg->De0 = ccm_reg->ccm_reg_backup.De0;
ccm_reg->ccm_reg->Ee0 = ccm_reg->ccm_reg_backup.Ee0;
ccm_reg->ccm_reg->Edma = ccm_reg->ccm_reg_backup.Edma;
ccm_reg->ccm_reg->Lcd0Ch0 = ccm_reg->ccm_reg_backup.Lcd0Ch0;
ccm_reg->ccm_reg->Csi0 = ccm_reg->ccm_reg_backup.Csi0;
/*ccm_reg->ccm_reg->MBus0 = ccm_reg->ccm_reg_backup.MBus0; */
ccm_reg->ccm_reg->PllLock = ccm_reg->ccm_reg_backup.PllLock;
ccm_reg->ccm_reg->Pll1Lock = ccm_reg->ccm_reg_backup.Pll1Lock;
ccm_reg->ccm_reg->PsCtrl = ccm_reg->ccm_reg_backup.PsCtrl;
ccm_reg->ccm_reg->PsCnt = ccm_reg->ccm_reg_backup.PsCnt;
ccm_reg->ccm_reg->PllLockCtrl = ccm_reg->ccm_reg_backup.PllLockCtrl;
ccm_reg->ccm_reg->DcxoCtrl0 = ccm_reg->ccm_reg_backup.DcxoCtrl0;
ccm_reg->ccm_reg->DcxoCtrl1 = ccm_reg->ccm_reg_backup.DcxoCtrl1;
change_runtime_env();
delay_us(1);
ccm_reg->ccm_reg->AhbGate0 = ccm_reg->ccm_reg_backup.AhbGate0;
ccm_reg->ccm_reg->AhbGate1 = ccm_reg->ccm_reg_backup.AhbGate1;
ccm_reg->ccm_reg->Apb1Gate = ccm_reg->ccm_reg_backup.Apb1Gate;
ccm_reg->ccm_reg->Apb2Gate0 = ccm_reg->ccm_reg_backup.Apb2Gate0;
ccm_reg->ccm_reg->Apb2Gate1 = ccm_reg->ccm_reg_backup.Apb2Gate1;
delay_us(10);
return 0;
}