mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
clk: sophgo: Add clock support for CV1810 SoC
Add clock definition and init code for CV1810 SoC.
Signed-off-by: Inochi Amaoto <inochiama@outlook.com>
Link: 6f4e9b8ecb/duo/datasheet/CV180X-Clock-v1.xlsx
Link: https://lore.kernel.org/r/IA1PR20MB495357FB5EEA1623DAB08C94BB262@IA1PR20MB4953.namprd20.prod.outlook.com
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
This commit is contained in:
parent
80fd61ec46
commit
3b8d204212
@ -631,6 +631,10 @@ static const struct clk_parent_data clk_vip_sys_parents[] = {
|
||||
{ .hw = &clk_disppll.common.hw },
|
||||
{ .hw = &clk_fpll.common.hw },
|
||||
};
|
||||
static const struct clk_parent_data clk_disp_vip_parents[] = {
|
||||
{ .index = 0 },
|
||||
{ .hw = &clk_disppll.common.hw },
|
||||
};
|
||||
|
||||
static CV1800_BYPASS_DIV(clk_dsi_esc, clk_bypass_axi6_bus_parents,
|
||||
REG_CLK_EN_2, 3,
|
||||
@ -660,6 +664,11 @@ static CV1800_BYPASS_MUX(clk_src_vip_sys_1, clk_vip_sys_parents,
|
||||
REG_DIV_CLK_SRC_VIP_SYS_1, 8, 2,
|
||||
REG_CLK_BYP_0, 24,
|
||||
0);
|
||||
static CV1800_BYPASS_DIV(clk_disp_src_vip, clk_disp_vip_parents,
|
||||
REG_CLK_EN_2, 7,
|
||||
REG_DIV_CLK_DISP_SRC_VIP, 16, 4, 8, CV1800_DIV_FLAG,
|
||||
REG_CLK_BYP_0, 25,
|
||||
0);
|
||||
static CV1800_BYPASS_MUX(clk_src_vip_sys_2, clk_vip_sys_parents,
|
||||
REG_CLK_EN_3, 29,
|
||||
REG_DIV_CLK_SRC_VIP_SYS_2, 16, 4, 2, CV1800_DIV_FLAG,
|
||||
@ -1243,6 +1252,191 @@ static const struct cv1800_clk_desc cv1800_desc = {
|
||||
.pre_init = cv1800_pre_init,
|
||||
};
|
||||
|
||||
static struct clk_hw_onecell_data cv1810_hw_clks = {
|
||||
.num = CV1810_CLK_MAX,
|
||||
.hws = {
|
||||
[CLK_MPLL] = &clk_mpll.common.hw,
|
||||
[CLK_TPLL] = &clk_tpll.common.hw,
|
||||
[CLK_FPLL] = &clk_fpll.common.hw,
|
||||
[CLK_MIPIMPLL] = &clk_mipimpll.common.hw,
|
||||
[CLK_A0PLL] = &clk_a0pll.common.hw,
|
||||
[CLK_DISPPLL] = &clk_disppll.common.hw,
|
||||
[CLK_CAM0PLL] = &clk_cam0pll.common.hw,
|
||||
[CLK_CAM1PLL] = &clk_cam1pll.common.hw,
|
||||
|
||||
[CLK_MIPIMPLL_D3] = &clk_mipimpll_d3.common.hw,
|
||||
[CLK_CAM0PLL_D2] = &clk_cam0pll_d2.common.hw,
|
||||
[CLK_CAM0PLL_D3] = &clk_cam0pll_d3.common.hw,
|
||||
|
||||
[CLK_TPU] = &clk_tpu.mux.common.hw,
|
||||
[CLK_TPU_FAB] = &clk_tpu_fab.common.hw,
|
||||
[CLK_AHB_ROM] = &clk_ahb_rom.common.hw,
|
||||
[CLK_DDR_AXI_REG] = &clk_ddr_axi_reg.common.hw,
|
||||
[CLK_RTC_25M] = &clk_rtc_25m.common.hw,
|
||||
[CLK_SRC_RTC_SYS_0] = &clk_src_rtc_sys_0.div.common.hw,
|
||||
[CLK_TEMPSEN] = &clk_tempsen.common.hw,
|
||||
[CLK_SARADC] = &clk_saradc.common.hw,
|
||||
[CLK_EFUSE] = &clk_efuse.common.hw,
|
||||
[CLK_APB_EFUSE] = &clk_apb_efuse.common.hw,
|
||||
[CLK_DEBUG] = &clk_debug.common.hw,
|
||||
[CLK_AP_DEBUG] = &clk_ap_debug.div.common.hw,
|
||||
[CLK_XTAL_MISC] = &clk_xtal_misc.common.hw,
|
||||
[CLK_AXI4_EMMC] = &clk_axi4_emmc.common.hw,
|
||||
[CLK_EMMC] = &clk_emmc.mux.common.hw,
|
||||
[CLK_EMMC_100K] = &clk_emmc_100k.common.hw,
|
||||
[CLK_AXI4_SD0] = &clk_axi4_sd0.common.hw,
|
||||
[CLK_SD0] = &clk_sd0.mux.common.hw,
|
||||
[CLK_SD0_100K] = &clk_sd0_100k.common.hw,
|
||||
[CLK_AXI4_SD1] = &clk_axi4_sd1.common.hw,
|
||||
[CLK_SD1] = &clk_sd1.mux.common.hw,
|
||||
[CLK_SD1_100K] = &clk_sd1_100k.common.hw,
|
||||
[CLK_SPI_NAND] = &clk_spi_nand.mux.common.hw,
|
||||
[CLK_ETH0_500M] = &clk_eth0_500m.div.common.hw,
|
||||
[CLK_AXI4_ETH0] = &clk_axi4_eth0.common.hw,
|
||||
[CLK_ETH1_500M] = &clk_eth1_500m.div.common.hw,
|
||||
[CLK_AXI4_ETH1] = &clk_axi4_eth1.common.hw,
|
||||
[CLK_APB_GPIO] = &clk_apb_gpio.common.hw,
|
||||
[CLK_APB_GPIO_INTR] = &clk_apb_gpio_intr.common.hw,
|
||||
[CLK_GPIO_DB] = &clk_gpio_db.common.hw,
|
||||
[CLK_AHB_SF] = &clk_ahb_sf.common.hw,
|
||||
[CLK_AHB_SF1] = &clk_ahb_sf1.common.hw,
|
||||
[CLK_A24M] = &clk_a24m.common.hw,
|
||||
[CLK_AUDSRC] = &clk_audsrc.mux.common.hw,
|
||||
[CLK_APB_AUDSRC] = &clk_apb_audsrc.common.hw,
|
||||
[CLK_SDMA_AXI] = &clk_sdma_axi.common.hw,
|
||||
[CLK_SDMA_AUD0] = &clk_sdma_aud0.mux.common.hw,
|
||||
[CLK_SDMA_AUD1] = &clk_sdma_aud1.mux.common.hw,
|
||||
[CLK_SDMA_AUD2] = &clk_sdma_aud2.mux.common.hw,
|
||||
[CLK_SDMA_AUD3] = &clk_sdma_aud3.mux.common.hw,
|
||||
[CLK_I2C] = &clk_i2c.div.common.hw,
|
||||
[CLK_APB_I2C] = &clk_apb_i2c.common.hw,
|
||||
[CLK_APB_I2C0] = &clk_apb_i2c0.common.hw,
|
||||
[CLK_APB_I2C1] = &clk_apb_i2c1.common.hw,
|
||||
[CLK_APB_I2C2] = &clk_apb_i2c2.common.hw,
|
||||
[CLK_APB_I2C3] = &clk_apb_i2c3.common.hw,
|
||||
[CLK_APB_I2C4] = &clk_apb_i2c4.common.hw,
|
||||
[CLK_APB_WDT] = &clk_apb_wdt.common.hw,
|
||||
[CLK_PWM_SRC] = &clk_pwm_src.mux.common.hw,
|
||||
[CLK_PWM] = &clk_pwm.common.hw,
|
||||
[CLK_SPI] = &clk_spi.div.common.hw,
|
||||
[CLK_APB_SPI0] = &clk_apb_spi0.common.hw,
|
||||
[CLK_APB_SPI1] = &clk_apb_spi1.common.hw,
|
||||
[CLK_APB_SPI2] = &clk_apb_spi2.common.hw,
|
||||
[CLK_APB_SPI3] = &clk_apb_spi3.common.hw,
|
||||
[CLK_1M] = &clk_1m.common.hw,
|
||||
[CLK_CAM0_200] = &clk_cam0_200.mux.common.hw,
|
||||
[CLK_PM] = &clk_pm.common.hw,
|
||||
[CLK_TIMER0] = &clk_timer0.common.hw,
|
||||
[CLK_TIMER1] = &clk_timer1.common.hw,
|
||||
[CLK_TIMER2] = &clk_timer2.common.hw,
|
||||
[CLK_TIMER3] = &clk_timer3.common.hw,
|
||||
[CLK_TIMER4] = &clk_timer4.common.hw,
|
||||
[CLK_TIMER5] = &clk_timer5.common.hw,
|
||||
[CLK_TIMER6] = &clk_timer6.common.hw,
|
||||
[CLK_TIMER7] = &clk_timer7.common.hw,
|
||||
[CLK_UART0] = &clk_uart0.common.hw,
|
||||
[CLK_APB_UART0] = &clk_apb_uart0.common.hw,
|
||||
[CLK_UART1] = &clk_uart1.common.hw,
|
||||
[CLK_APB_UART1] = &clk_apb_uart1.common.hw,
|
||||
[CLK_UART2] = &clk_uart2.common.hw,
|
||||
[CLK_APB_UART2] = &clk_apb_uart2.common.hw,
|
||||
[CLK_UART3] = &clk_uart3.common.hw,
|
||||
[CLK_APB_UART3] = &clk_apb_uart3.common.hw,
|
||||
[CLK_UART4] = &clk_uart4.common.hw,
|
||||
[CLK_APB_UART4] = &clk_apb_uart4.common.hw,
|
||||
[CLK_APB_I2S0] = &clk_apb_i2s0.common.hw,
|
||||
[CLK_APB_I2S1] = &clk_apb_i2s1.common.hw,
|
||||
[CLK_APB_I2S2] = &clk_apb_i2s2.common.hw,
|
||||
[CLK_APB_I2S3] = &clk_apb_i2s3.common.hw,
|
||||
[CLK_AXI4_USB] = &clk_axi4_usb.common.hw,
|
||||
[CLK_APB_USB] = &clk_apb_usb.common.hw,
|
||||
[CLK_USB_125M] = &clk_usb_125m.div.common.hw,
|
||||
[CLK_USB_33K] = &clk_usb_33k.common.hw,
|
||||
[CLK_USB_12M] = &clk_usb_12m.div.common.hw,
|
||||
[CLK_AXI4] = &clk_axi4.mux.common.hw,
|
||||
[CLK_AXI6] = &clk_axi6.div.common.hw,
|
||||
[CLK_DSI_ESC] = &clk_dsi_esc.div.common.hw,
|
||||
[CLK_AXI_VIP] = &clk_axi_vip.mux.common.hw,
|
||||
[CLK_SRC_VIP_SYS_0] = &clk_src_vip_sys_0.mux.common.hw,
|
||||
[CLK_SRC_VIP_SYS_1] = &clk_src_vip_sys_1.mux.common.hw,
|
||||
[CLK_SRC_VIP_SYS_2] = &clk_src_vip_sys_2.mux.common.hw,
|
||||
[CLK_SRC_VIP_SYS_3] = &clk_src_vip_sys_3.mux.common.hw,
|
||||
[CLK_SRC_VIP_SYS_4] = &clk_src_vip_sys_4.mux.common.hw,
|
||||
[CLK_CSI_BE_VIP] = &clk_csi_be_vip.common.hw,
|
||||
[CLK_CSI_MAC0_VIP] = &clk_csi_mac0_vip.common.hw,
|
||||
[CLK_CSI_MAC1_VIP] = &clk_csi_mac1_vip.common.hw,
|
||||
[CLK_CSI_MAC2_VIP] = &clk_csi_mac2_vip.common.hw,
|
||||
[CLK_CSI0_RX_VIP] = &clk_csi0_rx_vip.common.hw,
|
||||
[CLK_CSI1_RX_VIP] = &clk_csi1_rx_vip.common.hw,
|
||||
[CLK_ISP_TOP_VIP] = &clk_isp_top_vip.common.hw,
|
||||
[CLK_IMG_D_VIP] = &clk_img_d_vip.common.hw,
|
||||
[CLK_IMG_V_VIP] = &clk_img_v_vip.common.hw,
|
||||
[CLK_SC_TOP_VIP] = &clk_sc_top_vip.common.hw,
|
||||
[CLK_SC_D_VIP] = &clk_sc_d_vip.common.hw,
|
||||
[CLK_SC_V1_VIP] = &clk_sc_v1_vip.common.hw,
|
||||
[CLK_SC_V2_VIP] = &clk_sc_v2_vip.common.hw,
|
||||
[CLK_SC_V3_VIP] = &clk_sc_v3_vip.common.hw,
|
||||
[CLK_DWA_VIP] = &clk_dwa_vip.common.hw,
|
||||
[CLK_BT_VIP] = &clk_bt_vip.common.hw,
|
||||
[CLK_DISP_VIP] = &clk_disp_vip.common.hw,
|
||||
[CLK_DSI_MAC_VIP] = &clk_dsi_mac_vip.common.hw,
|
||||
[CLK_LVDS0_VIP] = &clk_lvds0_vip.common.hw,
|
||||
[CLK_LVDS1_VIP] = &clk_lvds1_vip.common.hw,
|
||||
[CLK_PAD_VI_VIP] = &clk_pad_vi_vip.common.hw,
|
||||
[CLK_PAD_VI1_VIP] = &clk_pad_vi1_vip.common.hw,
|
||||
[CLK_PAD_VI2_VIP] = &clk_pad_vi2_vip.common.hw,
|
||||
[CLK_CFG_REG_VIP] = &clk_cfg_reg_vip.common.hw,
|
||||
[CLK_VIP_IP0] = &clk_vip_ip0.common.hw,
|
||||
[CLK_VIP_IP1] = &clk_vip_ip1.common.hw,
|
||||
[CLK_VIP_IP2] = &clk_vip_ip2.common.hw,
|
||||
[CLK_VIP_IP3] = &clk_vip_ip3.common.hw,
|
||||
[CLK_IVE_VIP] = &clk_ive_vip.common.hw,
|
||||
[CLK_RAW_VIP] = &clk_raw_vip.common.hw,
|
||||
[CLK_OSDC_VIP] = &clk_osdc_vip.common.hw,
|
||||
[CLK_CAM0_VIP] = &clk_cam0_vip.common.hw,
|
||||
[CLK_AXI_VIDEO_CODEC] = &clk_axi_video_codec.mux.common.hw,
|
||||
[CLK_VC_SRC0] = &clk_vc_src0.mux.common.hw,
|
||||
[CLK_VC_SRC1] = &clk_vc_src1.div.common.hw,
|
||||
[CLK_VC_SRC2] = &clk_vc_src2.div.common.hw,
|
||||
[CLK_H264C] = &clk_h264c.common.hw,
|
||||
[CLK_APB_H264C] = &clk_apb_h264c.common.hw,
|
||||
[CLK_H265C] = &clk_h265c.common.hw,
|
||||
[CLK_APB_H265C] = &clk_apb_h265c.common.hw,
|
||||
[CLK_JPEG] = &clk_jpeg.common.hw,
|
||||
[CLK_APB_JPEG] = &clk_apb_jpeg.common.hw,
|
||||
[CLK_CAM0] = &clk_cam0.common.hw,
|
||||
[CLK_CAM1] = &clk_cam1.common.hw,
|
||||
[CLK_WGN] = &clk_wgn.common.hw,
|
||||
[CLK_WGN0] = &clk_wgn0.common.hw,
|
||||
[CLK_WGN1] = &clk_wgn1.common.hw,
|
||||
[CLK_WGN2] = &clk_wgn2.common.hw,
|
||||
[CLK_KEYSCAN] = &clk_keyscan.common.hw,
|
||||
[CLK_CFG_REG_VC] = &clk_cfg_reg_vc.common.hw,
|
||||
[CLK_C906_0] = &clk_c906_0.common.hw,
|
||||
[CLK_C906_1] = &clk_c906_1.common.hw,
|
||||
[CLK_A53] = &clk_a53.common.hw,
|
||||
[CLK_CPU_AXI0] = &clk_cpu_axi0.div.common.hw,
|
||||
[CLK_CPU_GIC] = &clk_cpu_gic.div.common.hw,
|
||||
[CLK_XTAL_AP] = &clk_xtal_ap.common.hw,
|
||||
[CLK_DISP_SRC_VIP] = &clk_disp_src_vip.div.common.hw,
|
||||
},
|
||||
};
|
||||
|
||||
static int cv1810_pre_init(struct device *dev, void __iomem *base,
|
||||
struct cv1800_clk_ctrl *ctrl,
|
||||
const struct cv1800_clk_desc *desc)
|
||||
{
|
||||
cv18xx_clk_disable_a53(base);
|
||||
cv18xx_clk_disable_auto_pd(base);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct cv1800_clk_desc cv1810_desc = {
|
||||
.clks_data = &cv1810_hw_clks,
|
||||
.pre_init = cv1810_pre_init,
|
||||
};
|
||||
|
||||
static int cv1800_clk_init_ctrl(struct device *dev, void __iomem *reg,
|
||||
struct cv1800_clk_ctrl *ctrl,
|
||||
const struct cv1800_clk_desc *desc)
|
||||
@ -1311,6 +1505,7 @@ static int cv1800_clk_probe(struct platform_device *pdev)
|
||||
|
||||
static const struct of_device_id cv1800_clk_ids[] = {
|
||||
{ .compatible = "sophgo,cv1800-clk", .data = &cv1800_desc },
|
||||
{ .compatible = "sophgo,cv1810-clk", .data = &cv1810_desc },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(of, cv1800_clk_ids);
|
||||
|
@ -9,6 +9,7 @@
|
||||
#include <dt-bindings/clock/sophgo,cv1800.h>
|
||||
|
||||
#define CV1800_CLK_MAX (CLK_XTAL_AP + 1)
|
||||
#define CV1810_CLK_MAX (CLK_DISP_SRC_VIP + 1)
|
||||
|
||||
#define REG_PLL_G2_CTRL 0x800
|
||||
#define REG_PLL_G2_STATUS 0x804
|
||||
|
Loading…
Reference in New Issue
Block a user