193 lines
7.6 KiB
C
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;
|
|
}
|