| |
| /* |
| * arch/arm/cpu/armv8/gxtvbb/gate_init.c |
| * |
| * Copyright (C) 2015 Amlogic, Inc. All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * |
| * This program is distributed in the hope that it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| * more details. |
| * |
| * You should have received a copy of the GNU General Public License along |
| * with this program; if not, write to the Free Software Foundation, Inc., |
| * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
| */ |
| |
| #include "power_gate.h" |
| #ifdef CONFIG_AML_LCD |
| #include <amlogic/aml_lcd.h> |
| #endif |
| |
| #define SECUREBOOT_FLAG_ADDR 0xc8100228 |
| |
| #ifdef CONFIG_AML_CVBS |
| extern unsigned int cvbs_mode; |
| #endif |
| |
| void ee_gate_off(void) |
| { |
| printf("ee_gate_off ...\n"); |
| |
| /* int secureboot = readl(SECUREBOOT_FLAG_ADDR)&(1<<5);*/ |
| |
| #ifdef CONFIG_AML_CVBS |
| unsigned int cvbs_opened = 0; |
| #endif |
| #ifdef CONFIG_AML_LCD |
| unsigned int lcd_status = 0; |
| struct aml_lcd_drv_s *lcd_drv = aml_lcd_get_driver(); |
| #endif |
| |
| #ifdef CONFIG_AML_CVBS |
| if ((cvbs_mode == 0) || (cvbs_mode == 1)) |
| cvbs_opened = 1; |
| #endif |
| #ifdef CONFIG_AML_LCD |
| if (lcd_drv) |
| lcd_status = lcd_drv->lcd_status; |
| #endif |
| |
| /* |
| //if close , audio maybe have noise |
| CLK_GATE_OFF(AUD); |
| CLK_GATE_OFF(AUD2); |
| CLK_GATE_OFF(AUD_CLK_2); |
| CLK_GATE_OFF(AUD_CLK_3); |
| */ |
| CLK_GATE_OFF(AUD_IN); |
| CLK_GATE_OFF(AIU_AUD_MIXER); |
| CLK_GATE_OFF(SANA); |
| |
| /*kernel will reopen */ |
| #ifdef CONFIG_AML_LCD |
| if (lcd_status == 0) |
| CLK_GATE_OFF(CTS_ENCL); |
| #else |
| CLK_GATE_OFF(CTS_ENCL); |
| #endif |
| /* CLK_GATE_OFF(CTS_ENCT); */ |
| #ifdef CONFIG_AML_CVBS |
| if (cvbs_opened == 0) |
| CLK_GATE_OFF(CTS_ENCI); |
| #else |
| CLK_GATE_OFF(CTS_ENCI); |
| #endif |
| /* CLK_GATE_OFF(CTS_ENCP); */ |
| |
| /*close cvbs clock*/ |
| #ifdef CONFIG_AML_CVBS |
| if (cvbs_opened == 0) { |
| CLK_GATE_OFF(DAC_CLK); |
| CLK_GATE_OFF(CTS_VDAC); |
| } |
| #else |
| CLK_GATE_OFF(DAC_CLK); |
| CLK_GATE_OFF(CTS_VDAC); |
| #endif |
| |
| /* usb clock close */ |
| CLK_GATE_OFF(USB0); |
| CLK_GATE_OFF(USB1); |
| CLK_GATE_OFF(USB_CLK); |
| CLK_GATE_OFF(MISC_USB0_TO_DDR); |
| CLK_GATE_OFF(MISC_USB1_TO_DDR); |
| |
| /* uarts close */ |
| CLK_GATE_OFF(UART0); |
| CLK_GATE_OFF(UART1); |
| CLK_GATE_OFF(UART2); |
| CLK_GATE_OFF(UART3); |
| |
| CLK_GATE_OFF(VCLK2_VENCP); |
| CLK_GATE_OFF(VCLK2_VENCT); |
| CLK_GATE_OFF(VCLK2_VENCT1); |
| CLK_GATE_OFF(VCLK2_OTHER); |
| #ifdef CONFIG_AML_CVBS |
| if (cvbs_opened == 0) { |
| CLK_GATE_OFF(VCLK2_VENCI); |
| CLK_GATE_OFF(VCLK2_VENCI1); |
| } |
| #else |
| CLK_GATE_OFF(VCLK2_VENCI); |
| CLK_GATE_OFF(VCLK2_VENCI1); |
| #endif |
| #ifdef CONFIG_AML_LCD |
| if (lcd_status == 0) |
| CLK_GATE_OFF(VCLK2_VENCL); |
| #else |
| CLK_GATE_OFF(VCLK2_VENCL); |
| #endif |
| CLK_GATE_OFF(VCLK2_OTHER1); |
| |
| #ifdef CONFIG_AML_CVBS |
| if (cvbs_opened == 0) |
| CLK_GATE_OFF(VCLK2_ENCI); |
| #else |
| CLK_GATE_OFF(VCLK2_ENCI); |
| #endif |
| #ifdef CONFIG_AML_LCD |
| if (lcd_status == 0) |
| CLK_GATE_OFF(VCLK2_ENCL); |
| #else |
| CLK_GATE_OFF(VCLK2_ENCL); |
| #endif |
| CLK_GATE_OFF(VCLK2_ENCT); |
| |
| CLK_GATE_OFF(VDEC_CLK_1); |
| CLK_GATE_OFF(VDEC_CLK_2); |
| CLK_GATE_OFF(VDEC2_CLK_1); |
| CLK_GATE_OFF(VDEC2_CLK_2); |
| CLK_GATE_OFF(HCODEC_CLK_1); |
| CLK_GATE_OFF(HCODEC_CLK_2); |
| /* CLK_GATE_OFF(HEVC_CLK_1 ); */ |
| /* CLK_GATE_OFF(HEVC_CLK_2 ); */ |
| |
| CLK_GATE_OFF(MMC_A_PCLK); |
| CLK_GATE_OFF(MMC_B_PCLK); |
| CLK_GATE_OFF(MMC_C_PCLK); |
| |
| CLK_GATE_OFF(LCD_AN_PHY2); |
| CLK_GATE_OFF(LCD_AN_PHY3); |
| |
| CLK_GATE_OFF(ETHERNET); |
| CLK_GATE_OFF(ETH_CLK); |
| |
| CLK_GATE_OFF(GE2D); |
| CLK_GATE_OFF(GEN_CLK); |
| CLK_GATE_OFF(PCM_MCLK); |
| CLK_GATE_OFF(PCM_SCLK); |
| |
| |
| CLK_GATE_OFF(HIU_PARSER_TOP); |
| |
| |
| /* can not off nand_clk */ |
| /* CLK_GATE_OFF(NAND_CLK); */ |
| /* |
| //HDMI no output |
| CLK_GATE_OFF(VCLK2_VENCP1); |
| CLK_GATE_OFF(VCLK2_ENCP); |
| */ |
| |
| /* |
| //if OFF, HDMI will report error! |
| CLK_GATE_OFF(HDMI_PCLK); |
| CLK_GATE_OFF(HDMI_PLL_CNTL); |
| CLK_GATE_OFF(HDMITX_CLK); |
| */ |
| |
| /* |
| //PWM B used for VCCK,PWM D used for VDDEE,ignoring |
| CLK_GATE_OFF(PWM_A_CLK); |
| CLK_GATE_OFF(PWM_B_CLK); |
| CLK_GATE_OFF(PWM_C_CLK); |
| CLK_GATE_OFF(PWM_D_CLK); |
| CLK_GATE_OFF(PWM_E_CLK); |
| CLK_GATE_OFF(PWM_F_CLK); |
| */ |
| |
| |
| /* can not close |
| CLK_GATE_OFF(VPU_CLK_1); |
| CLK_GATE_OFF(VPU_CLK_2); |
| CLK_GATE_OFF(VPU_CLKB); |
| CLK_GATE_OFF(MALI_CLK_1); |
| CLK_GATE_OFF(MALI_CLK_2); |
| CLK_GATE_OFF(ATV_DEMO_VDAC); |
| CLK_GATE_OFF(EMMC_A); |
| CLK_GATE_OFF(EMMC_B); |
| CLK_GATE_OFF(EMMC_C); |
| CLK_GATE_OFF(EMMC_A_CLK); |
| CLK_GATE_OFF(EMMC_B_CLK); |
| |
| CLK_GATE_OFF(MSR_CLK); |
| CLK_GATE_OFF(MSR_HS_CLK); |
| CLK_GATE_OFF(32K_CLK); |
| CLK_GATE_OFF(VAPB_CLK_1); |
| CLK_GATE_OFF(VAPB_CLK_2); |
| CLK_GATE_OFF(GIC); |
| CLK_GATE_OFF(I2C_AO); //no close for to use |
| CLK_GATE_OFF(AO_CPU); |
| CLK_GATE_OFF(ASSIST_MISC); |
| CLK_GATE_OFF(HIU_PARSER); |
| CLK_GATE_OFF(PERIPHS_TOP); |
| CLK_GATE_OFF(PL310_CBUS); |
| CLK_GATE_OFF(ISA); |
| CLK_GATE_OFF(SECURE_AHP_APB3); |
| CLK_GATE_OFF(VPU_INTR); |
| CLK_GATE_OFF(MMC_PCLK); //can not close |
| CLK_GATE_OFF(AIU_PCLK); |
| //can not connect pc |
| CLK_GATE_OFF(USB_GENERAL); |
| CLK_GATE_OFF(AHB_DATA_BUS); |
| CLK_GATE_OFF(AHB_CONTROL_BUS); |
| CLK_GATE_OFF(HDMI_INTR_SYNC); //should open |
| //can't suspend @ 2nd time |
| //CLK_GATE_OFF(RESET); |
| |
| // close rom |
| //disable this bit will make other cpu can not be booted. |
| //CLK_GATE_OFF(ROM_CLK); |
| |
| */ |
| /*************************/ |
| CLK_GATE_OFF(AHB_ARB0); |
| CLK_GATE_OFF(ASYNC_FIFO); |
| CLK_GATE_OFF(STREAM); |
| CLK_GATE_OFF(RANDOM_NUM_GEN); |
| CLK_GATE_OFF(RANDOM_NUM_GEN1); |
| CLK_GATE_OFF(SMART_CARD_MPEG_DOMAIN); |
| CLK_GATE_OFF(I2C); |
| CLK_GATE_OFF(SPI); |
| CLK_GATE_OFF(SPICC); |
| CLK_GATE_OFF(DOS); |
| CLK_GATE_OFF(SAR_ADC); |
| CLK_GATE_OFF(MISC_DVIN); |
| CLK_GATE_OFF(BT656); |
| CLK_GATE_OFF(BT656_2); |
| CLK_GATE_OFF(PDM); |
| |
| /* close AIU */ |
| CLK_GATE_OFF(AIU_IEC958); |
| CLK_GATE_OFF(AIU_ICE958_AMCLK); |
| |
| CLK_GATE_OFF(AIU_AMCLK_MEASURE); |
| CLK_GATE_OFF(AIU_AIFIFO2); |
| CLK_GATE_OFF(AIU_MIXER_REG); |
| CLK_GATE_OFF(AIU_ADC); |
| CLK_GATE_OFF(AIU_TOP_LEVEL); |
| CLK_GATE_OFF(AIU_AOCLK); |
| CLK_GATE_OFF(AIU_AI_TOP_GLUE); |
| CLK_GATE_OFF(AIU_I2S_OUT); |
| |
| CLK_GATE_OFF(ENC480P); |
| |
| CLK_GATE_OFF(DEMUX); |
| /* |
| * EFUSE/BLK_MOV clock gate must be on, |
| kernel storage ops depend on them. |
| it can be reference PD#112732 |
| */ |
| /* |
| if (secureboot) { |
| printf("secure boot ignore [ BLK_MOV, efuse ] clk gate\n"); |
| } else { |
| CLK_GATE_OFF(EFUSE); |
| CLK_GATE_OFF(BLK_MOV); |
| } |
| */ |
| } |
| |
| void ee_gate_on(void) |
| { |
| |
| printf("ee_gate_on ...\n"); |
| |
| /* |
| //if close , audio maybe have noise |
| CLK_GATE_ON(AUD); |
| CLK_GATE_ON(AUD2); |
| CLK_GATE_ON(AUD_CLK_2); |
| CLK_GATE_ON(AUD_CLK_3); |
| */ |
| CLK_GATE_ON(AUD_IN); |
| CLK_GATE_ON(AIU_AUD_MIXER); |
| CLK_GATE_ON(SANA); |
| |
| /*kernel will reopen */ |
| CLK_GATE_ON(CTS_ENCL); |
| /* CLK_GATE_ON(CTS_ENCT); */ |
| CLK_GATE_ON(CTS_ENCI); |
| /* CLK_GATE_ON(CTS_ENCP); */ |
| |
| /*close cvbs clock*/ |
| CLK_GATE_ON(DAC_CLK); |
| CLK_GATE_ON(CTS_VDAC); |
| |
| /* usb clock close */ |
| CLK_GATE_ON(USB0); |
| CLK_GATE_ON(USB1); |
| CLK_GATE_ON(USB_CLK); |
| CLK_GATE_ON(MISC_USB0_TO_DDR); |
| CLK_GATE_ON(MISC_USB1_TO_DDR); |
| |
| /* uarts close */ |
| CLK_GATE_ON(UART0); |
| CLK_GATE_ON(UART1); |
| CLK_GATE_ON(UART2); |
| CLK_GATE_ON(UART3); |
| |
| CLK_GATE_ON(VCLK2_VENCP); |
| CLK_GATE_ON(VCLK2_VENCT); |
| CLK_GATE_ON(VCLK2_VENCT1); |
| CLK_GATE_ON(VCLK2_OTHER); |
| CLK_GATE_ON(VCLK2_VENCI); |
| CLK_GATE_ON(VCLK2_VENCI1); |
| CLK_GATE_ON(VCLK2_VENCL); |
| CLK_GATE_ON(VCLK2_OTHER1); |
| |
| |
| CLK_GATE_ON(VCLK2_ENCI); |
| CLK_GATE_ON(VCLK2_ENCL); |
| CLK_GATE_ON(VCLK2_ENCT); |
| |
| CLK_GATE_ON(VDEC_CLK_1); |
| CLK_GATE_ON(VDEC_CLK_2); |
| CLK_GATE_ON(VDEC2_CLK_1); |
| CLK_GATE_ON(VDEC2_CLK_2); |
| CLK_GATE_ON(HCODEC_CLK_1); |
| CLK_GATE_ON(HCODEC_CLK_2); |
| /* CLK_GATE_ON(HEVC_CLK_1 ); */ |
| /* CLK_GATE_ON(HEVC_CLK_2 ); */ |
| |
| CLK_GATE_ON(MMC_A_PCLK); |
| CLK_GATE_ON(MMC_B_PCLK); |
| CLK_GATE_ON(MMC_C_PCLK); |
| |
| CLK_GATE_ON(LCD_AN_PHY2); |
| CLK_GATE_ON(LCD_AN_PHY3); |
| |
| CLK_GATE_ON(ETHERNET); |
| CLK_GATE_ON(ETH_CLK); |
| |
| CLK_GATE_ON(GE2D); |
| CLK_GATE_ON(GEN_CLK); |
| CLK_GATE_ON(PCM_MCLK); |
| CLK_GATE_ON(PCM_SCLK); |
| |
| |
| CLK_GATE_ON(HIU_PARSER_TOP); |
| |
| /*************************/ |
| CLK_GATE_ON(AHB_ARB0); |
| CLK_GATE_ON(ASYNC_FIFO); |
| CLK_GATE_ON(STREAM); |
| CLK_GATE_ON(RANDOM_NUM_GEN); |
| CLK_GATE_ON(RANDOM_NUM_GEN1); |
| CLK_GATE_ON(SMART_CARD_MPEG_DOMAIN); |
| CLK_GATE_ON(I2C); |
| CLK_GATE_ON(SPI); |
| CLK_GATE_ON(SPICC); |
| CLK_GATE_ON(DOS); |
| CLK_GATE_ON(SAR_ADC); |
| CLK_GATE_ON(MISC_DVIN); |
| CLK_GATE_ON(BT656); |
| CLK_GATE_ON(BT656_2); |
| CLK_GATE_ON(PDM); |
| |
| /* close AIU */ |
| CLK_GATE_ON(AIU_IEC958); |
| CLK_GATE_ON(AIU_ICE958_AMCLK); |
| |
| CLK_GATE_ON(AIU_AMCLK_MEASURE); |
| CLK_GATE_ON(AIU_AIFIFO2); |
| CLK_GATE_ON(AIU_MIXER_REG); |
| CLK_GATE_ON(AIU_ADC); |
| CLK_GATE_ON(AIU_TOP_LEVEL); |
| CLK_GATE_ON(AIU_AOCLK); |
| CLK_GATE_ON(AIU_AI_TOP_GLUE); |
| CLK_GATE_ON(AIU_I2S_OUT); |
| |
| CLK_GATE_ON(ENC480P); |
| |
| CLK_GATE_ON(DEMUX); |
| |
| CLK_GATE_ON(EFUSE); |
| CLK_GATE_ON(BLK_MOV); |
| } |
| |