18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Pistachio SoC clock controllers 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2014 Google, Inc. 68c2ecf20Sopenharmony_ci */ 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#include <linux/clk-provider.h> 98c2ecf20Sopenharmony_ci#include <linux/init.h> 108c2ecf20Sopenharmony_ci#include <linux/io.h> 118c2ecf20Sopenharmony_ci#include <linux/kernel.h> 128c2ecf20Sopenharmony_ci#include <linux/of.h> 138c2ecf20Sopenharmony_ci 148c2ecf20Sopenharmony_ci#include <dt-bindings/clock/pistachio-clk.h> 158c2ecf20Sopenharmony_ci 168c2ecf20Sopenharmony_ci#include "clk.h" 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_cistatic struct pistachio_gate pistachio_gates[] __initdata = { 198c2ecf20Sopenharmony_ci GATE(CLK_MIPS, "mips", "mips_div", 0x104, 0), 208c2ecf20Sopenharmony_ci GATE(CLK_AUDIO_IN, "audio_in", "audio_clk_in_gate", 0x104, 1), 218c2ecf20Sopenharmony_ci GATE(CLK_AUDIO, "audio", "audio_div", 0x104, 2), 228c2ecf20Sopenharmony_ci GATE(CLK_I2S, "i2s", "i2s_div", 0x104, 3), 238c2ecf20Sopenharmony_ci GATE(CLK_SPDIF, "spdif", "spdif_div", 0x104, 4), 248c2ecf20Sopenharmony_ci GATE(CLK_AUDIO_DAC, "audio_dac", "audio_dac_div", 0x104, 5), 258c2ecf20Sopenharmony_ci GATE(CLK_RPU_V, "rpu_v", "rpu_v_div", 0x104, 6), 268c2ecf20Sopenharmony_ci GATE(CLK_RPU_L, "rpu_l", "rpu_l_div", 0x104, 7), 278c2ecf20Sopenharmony_ci GATE(CLK_RPU_SLEEP, "rpu_sleep", "rpu_sleep_div", 0x104, 8), 288c2ecf20Sopenharmony_ci GATE(CLK_WIFI_PLL_GATE, "wifi_pll_gate", "wifi_pll_mux", 0x104, 9), 298c2ecf20Sopenharmony_ci GATE(CLK_RPU_CORE, "rpu_core", "rpu_core_div", 0x104, 10), 308c2ecf20Sopenharmony_ci GATE(CLK_WIFI_ADC, "wifi_adc", "wifi_div8_mux", 0x104, 11), 318c2ecf20Sopenharmony_ci GATE(CLK_WIFI_DAC, "wifi_dac", "wifi_div4_mux", 0x104, 12), 328c2ecf20Sopenharmony_ci GATE(CLK_USB_PHY, "usb_phy", "usb_phy_div", 0x104, 13), 338c2ecf20Sopenharmony_ci GATE(CLK_ENET_IN, "enet_in", "enet_clk_in_gate", 0x104, 14), 348c2ecf20Sopenharmony_ci GATE(CLK_ENET, "enet", "enet_div", 0x104, 15), 358c2ecf20Sopenharmony_ci GATE(CLK_UART0, "uart0", "uart0_div", 0x104, 16), 368c2ecf20Sopenharmony_ci GATE(CLK_UART1, "uart1", "uart1_div", 0x104, 17), 378c2ecf20Sopenharmony_ci GATE(CLK_PERIPH_SYS, "periph_sys", "sys_internal_div", 0x104, 18), 388c2ecf20Sopenharmony_ci GATE(CLK_SPI0, "spi0", "spi0_div", 0x104, 19), 398c2ecf20Sopenharmony_ci GATE(CLK_SPI1, "spi1", "spi1_div", 0x104, 20), 408c2ecf20Sopenharmony_ci GATE(CLK_EVENT_TIMER, "event_timer", "event_timer_div", 0x104, 21), 418c2ecf20Sopenharmony_ci GATE(CLK_AUX_ADC_INTERNAL, "aux_adc_internal", "sys_internal_div", 428c2ecf20Sopenharmony_ci 0x104, 22), 438c2ecf20Sopenharmony_ci GATE(CLK_AUX_ADC, "aux_adc", "aux_adc_div", 0x104, 23), 448c2ecf20Sopenharmony_ci GATE(CLK_SD_HOST, "sd_host", "sd_host_div", 0x104, 24), 458c2ecf20Sopenharmony_ci GATE(CLK_BT, "bt", "bt_div", 0x104, 25), 468c2ecf20Sopenharmony_ci GATE(CLK_BT_DIV4, "bt_div4", "bt_div4_div", 0x104, 26), 478c2ecf20Sopenharmony_ci GATE(CLK_BT_DIV8, "bt_div8", "bt_div8_div", 0x104, 27), 488c2ecf20Sopenharmony_ci GATE(CLK_BT_1MHZ, "bt_1mhz", "bt_1mhz_div", 0x104, 28), 498c2ecf20Sopenharmony_ci}; 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_cistatic struct pistachio_fixed_factor pistachio_ffs[] __initdata = { 528c2ecf20Sopenharmony_ci FIXED_FACTOR(CLK_WIFI_DIV4, "wifi_div4", "wifi_pll", 4), 538c2ecf20Sopenharmony_ci FIXED_FACTOR(CLK_WIFI_DIV8, "wifi_div8", "wifi_pll", 8), 548c2ecf20Sopenharmony_ci}; 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_cistatic struct pistachio_div pistachio_divs[] __initdata = { 578c2ecf20Sopenharmony_ci DIV(CLK_MIPS_INTERNAL_DIV, "mips_internal_div", "mips_pll_mux", 588c2ecf20Sopenharmony_ci 0x204, 2), 598c2ecf20Sopenharmony_ci DIV(CLK_MIPS_DIV, "mips_div", "mips_internal_div", 0x208, 8), 608c2ecf20Sopenharmony_ci DIV_F(CLK_AUDIO_DIV, "audio_div", "audio_mux", 618c2ecf20Sopenharmony_ci 0x20c, 8, CLK_DIVIDER_ROUND_CLOSEST), 628c2ecf20Sopenharmony_ci DIV_F(CLK_I2S_DIV, "i2s_div", "audio_pll_mux", 638c2ecf20Sopenharmony_ci 0x210, 8, CLK_DIVIDER_ROUND_CLOSEST), 648c2ecf20Sopenharmony_ci DIV_F(CLK_SPDIF_DIV, "spdif_div", "audio_pll_mux", 658c2ecf20Sopenharmony_ci 0x214, 8, CLK_DIVIDER_ROUND_CLOSEST), 668c2ecf20Sopenharmony_ci DIV_F(CLK_AUDIO_DAC_DIV, "audio_dac_div", "audio_pll_mux", 678c2ecf20Sopenharmony_ci 0x218, 8, CLK_DIVIDER_ROUND_CLOSEST), 688c2ecf20Sopenharmony_ci DIV(CLK_RPU_V_DIV, "rpu_v_div", "rpu_v_pll_mux", 0x21c, 2), 698c2ecf20Sopenharmony_ci DIV(CLK_RPU_L_DIV, "rpu_l_div", "rpu_l_mux", 0x220, 2), 708c2ecf20Sopenharmony_ci DIV(CLK_RPU_SLEEP_DIV, "rpu_sleep_div", "xtal", 0x224, 10), 718c2ecf20Sopenharmony_ci DIV(CLK_RPU_CORE_DIV, "rpu_core_div", "rpu_core_mux", 0x228, 3), 728c2ecf20Sopenharmony_ci DIV(CLK_USB_PHY_DIV, "usb_phy_div", "sys_internal_div", 0x22c, 6), 738c2ecf20Sopenharmony_ci DIV(CLK_ENET_DIV, "enet_div", "enet_mux", 0x230, 6), 748c2ecf20Sopenharmony_ci DIV_F(CLK_UART0_INTERNAL_DIV, "uart0_internal_div", "sys_pll_mux", 758c2ecf20Sopenharmony_ci 0x234, 3, CLK_DIVIDER_ROUND_CLOSEST), 768c2ecf20Sopenharmony_ci DIV_F(CLK_UART0_DIV, "uart0_div", "uart0_internal_div", 0x238, 10, 778c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 788c2ecf20Sopenharmony_ci DIV_F(CLK_UART1_INTERNAL_DIV, "uart1_internal_div", "sys_pll_mux", 798c2ecf20Sopenharmony_ci 0x23c, 3, CLK_DIVIDER_ROUND_CLOSEST), 808c2ecf20Sopenharmony_ci DIV_F(CLK_UART1_DIV, "uart1_div", "uart1_internal_div", 0x240, 10, 818c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 828c2ecf20Sopenharmony_ci DIV(CLK_SYS_INTERNAL_DIV, "sys_internal_div", "sys_pll_mux", 0x244, 3), 838c2ecf20Sopenharmony_ci DIV(CLK_SPI0_INTERNAL_DIV, "spi0_internal_div", "sys_pll_mux", 848c2ecf20Sopenharmony_ci 0x248, 3), 858c2ecf20Sopenharmony_ci DIV(CLK_SPI0_DIV, "spi0_div", "spi0_internal_div", 0x24c, 7), 868c2ecf20Sopenharmony_ci DIV(CLK_SPI1_INTERNAL_DIV, "spi1_internal_div", "sys_pll_mux", 878c2ecf20Sopenharmony_ci 0x250, 3), 888c2ecf20Sopenharmony_ci DIV(CLK_SPI1_DIV, "spi1_div", "spi1_internal_div", 0x254, 7), 898c2ecf20Sopenharmony_ci DIV(CLK_EVENT_TIMER_INTERNAL_DIV, "event_timer_internal_div", 908c2ecf20Sopenharmony_ci "event_timer_mux", 0x258, 3), 918c2ecf20Sopenharmony_ci DIV(CLK_EVENT_TIMER_DIV, "event_timer_div", "event_timer_internal_div", 928c2ecf20Sopenharmony_ci 0x25c, 12), 938c2ecf20Sopenharmony_ci DIV(CLK_AUX_ADC_INTERNAL_DIV, "aux_adc_internal_div", 948c2ecf20Sopenharmony_ci "aux_adc_internal", 0x260, 3), 958c2ecf20Sopenharmony_ci DIV(CLK_AUX_ADC_DIV, "aux_adc_div", "aux_adc_internal_div", 0x264, 10), 968c2ecf20Sopenharmony_ci DIV(CLK_SD_HOST_DIV, "sd_host_div", "sd_host_mux", 0x268, 6), 978c2ecf20Sopenharmony_ci DIV(CLK_BT_DIV, "bt_div", "bt_pll_mux", 0x26c, 6), 988c2ecf20Sopenharmony_ci DIV(CLK_BT_DIV4_DIV, "bt_div4_div", "bt_pll_mux", 0x270, 6), 998c2ecf20Sopenharmony_ci DIV(CLK_BT_DIV8_DIV, "bt_div8_div", "bt_pll_mux", 0x274, 6), 1008c2ecf20Sopenharmony_ci DIV(CLK_BT_1MHZ_INTERNAL_DIV, "bt_1mhz_internal_div", "bt_pll_mux", 1018c2ecf20Sopenharmony_ci 0x278, 3), 1028c2ecf20Sopenharmony_ci DIV(CLK_BT_1MHZ_DIV, "bt_1mhz_div", "bt_1mhz_internal_div", 0x27c, 10), 1038c2ecf20Sopenharmony_ci}; 1048c2ecf20Sopenharmony_ci 1058c2ecf20Sopenharmony_ciPNAME(mux_xtal_audio_refclk) = { "xtal", "audio_clk_in_gate" }; 1068c2ecf20Sopenharmony_ciPNAME(mux_xtal_mips) = { "xtal", "mips_pll" }; 1078c2ecf20Sopenharmony_ciPNAME(mux_xtal_audio) = { "xtal", "audio_pll", "audio_in" }; 1088c2ecf20Sopenharmony_ciPNAME(mux_audio_debug) = { "audio_pll_mux", "debug_mux" }; 1098c2ecf20Sopenharmony_ciPNAME(mux_xtal_rpu_v) = { "xtal", "rpu_v_pll" }; 1108c2ecf20Sopenharmony_ciPNAME(mux_xtal_rpu_l) = { "xtal", "rpu_l_pll" }; 1118c2ecf20Sopenharmony_ciPNAME(mux_rpu_l_mips) = { "rpu_l_pll_mux", "mips_pll_mux" }; 1128c2ecf20Sopenharmony_ciPNAME(mux_xtal_wifi) = { "xtal", "wifi_pll" }; 1138c2ecf20Sopenharmony_ciPNAME(mux_xtal_wifi_div4) = { "xtal", "wifi_div4" }; 1148c2ecf20Sopenharmony_ciPNAME(mux_xtal_wifi_div8) = { "xtal", "wifi_div8" }; 1158c2ecf20Sopenharmony_ciPNAME(mux_wifi_div4_rpu_l) = { "wifi_pll_gate", "wifi_div4_mux", 1168c2ecf20Sopenharmony_ci "rpu_l_pll_mux" }; 1178c2ecf20Sopenharmony_ciPNAME(mux_xtal_sys) = { "xtal", "sys_pll" }; 1188c2ecf20Sopenharmony_ciPNAME(mux_sys_enet) = { "sys_internal_div", "enet_in" }; 1198c2ecf20Sopenharmony_ciPNAME(mux_audio_sys) = { "audio_pll_mux", "sys_internal_div" }; 1208c2ecf20Sopenharmony_ciPNAME(mux_sys_bt) = { "sys_internal_div", "bt_pll_mux" }; 1218c2ecf20Sopenharmony_ciPNAME(mux_xtal_bt) = { "xtal", "bt_pll" }; 1228c2ecf20Sopenharmony_ci 1238c2ecf20Sopenharmony_cistatic struct pistachio_mux pistachio_muxes[] __initdata = { 1248c2ecf20Sopenharmony_ci MUX(CLK_AUDIO_REF_MUX, "audio_refclk_mux", mux_xtal_audio_refclk, 1258c2ecf20Sopenharmony_ci 0x200, 0), 1268c2ecf20Sopenharmony_ci MUX(CLK_MIPS_PLL_MUX, "mips_pll_mux", mux_xtal_mips, 0x200, 1), 1278c2ecf20Sopenharmony_ci MUX(CLK_AUDIO_PLL_MUX, "audio_pll_mux", mux_xtal_audio, 0x200, 2), 1288c2ecf20Sopenharmony_ci MUX(CLK_AUDIO_MUX, "audio_mux", mux_audio_debug, 0x200, 4), 1298c2ecf20Sopenharmony_ci MUX(CLK_RPU_V_PLL_MUX, "rpu_v_pll_mux", mux_xtal_rpu_v, 0x200, 5), 1308c2ecf20Sopenharmony_ci MUX(CLK_RPU_L_PLL_MUX, "rpu_l_pll_mux", mux_xtal_rpu_l, 0x200, 6), 1318c2ecf20Sopenharmony_ci MUX(CLK_RPU_L_MUX, "rpu_l_mux", mux_rpu_l_mips, 0x200, 7), 1328c2ecf20Sopenharmony_ci MUX(CLK_WIFI_PLL_MUX, "wifi_pll_mux", mux_xtal_wifi, 0x200, 8), 1338c2ecf20Sopenharmony_ci MUX(CLK_WIFI_DIV4_MUX, "wifi_div4_mux", mux_xtal_wifi_div4, 0x200, 9), 1348c2ecf20Sopenharmony_ci MUX(CLK_WIFI_DIV8_MUX, "wifi_div8_mux", mux_xtal_wifi_div8, 0x200, 10), 1358c2ecf20Sopenharmony_ci MUX(CLK_RPU_CORE_MUX, "rpu_core_mux", mux_wifi_div4_rpu_l, 0x200, 11), 1368c2ecf20Sopenharmony_ci MUX(CLK_SYS_PLL_MUX, "sys_pll_mux", mux_xtal_sys, 0x200, 13), 1378c2ecf20Sopenharmony_ci MUX(CLK_ENET_MUX, "enet_mux", mux_sys_enet, 0x200, 14), 1388c2ecf20Sopenharmony_ci MUX(CLK_EVENT_TIMER_MUX, "event_timer_mux", mux_audio_sys, 0x200, 15), 1398c2ecf20Sopenharmony_ci MUX(CLK_SD_HOST_MUX, "sd_host_mux", mux_sys_bt, 0x200, 16), 1408c2ecf20Sopenharmony_ci MUX(CLK_BT_PLL_MUX, "bt_pll_mux", mux_xtal_bt, 0x200, 17), 1418c2ecf20Sopenharmony_ci}; 1428c2ecf20Sopenharmony_ci 1438c2ecf20Sopenharmony_cistatic struct pistachio_pll pistachio_plls[] __initdata = { 1448c2ecf20Sopenharmony_ci PLL_FIXED(CLK_MIPS_PLL, "mips_pll", "xtal", PLL_GF40LP_LAINT, 0x0), 1458c2ecf20Sopenharmony_ci PLL_FIXED(CLK_AUDIO_PLL, "audio_pll", "audio_refclk_mux", 1468c2ecf20Sopenharmony_ci PLL_GF40LP_FRAC, 0xc), 1478c2ecf20Sopenharmony_ci PLL_FIXED(CLK_RPU_V_PLL, "rpu_v_pll", "xtal", PLL_GF40LP_LAINT, 0x20), 1488c2ecf20Sopenharmony_ci PLL_FIXED(CLK_RPU_L_PLL, "rpu_l_pll", "xtal", PLL_GF40LP_LAINT, 0x2c), 1498c2ecf20Sopenharmony_ci PLL_FIXED(CLK_SYS_PLL, "sys_pll", "xtal", PLL_GF40LP_FRAC, 0x38), 1508c2ecf20Sopenharmony_ci PLL_FIXED(CLK_WIFI_PLL, "wifi_pll", "xtal", PLL_GF40LP_FRAC, 0x4c), 1518c2ecf20Sopenharmony_ci PLL_FIXED(CLK_BT_PLL, "bt_pll", "xtal", PLL_GF40LP_LAINT, 0x60), 1528c2ecf20Sopenharmony_ci}; 1538c2ecf20Sopenharmony_ci 1548c2ecf20Sopenharmony_ciPNAME(mux_debug) = { "mips_pll_mux", "rpu_v_pll_mux", 1558c2ecf20Sopenharmony_ci "rpu_l_pll_mux", "sys_pll_mux", 1568c2ecf20Sopenharmony_ci "wifi_pll_mux", "bt_pll_mux" }; 1578c2ecf20Sopenharmony_cistatic u32 mux_debug_idx[] = { 0x0, 0x1, 0x2, 0x4, 0x8, 0x10 }; 1588c2ecf20Sopenharmony_ci 1598c2ecf20Sopenharmony_cistatic unsigned int pistachio_critical_clks_core[] __initdata = { 1608c2ecf20Sopenharmony_ci CLK_MIPS 1618c2ecf20Sopenharmony_ci}; 1628c2ecf20Sopenharmony_ci 1638c2ecf20Sopenharmony_cistatic unsigned int pistachio_critical_clks_sys[] __initdata = { 1648c2ecf20Sopenharmony_ci PERIPH_CLK_SYS, 1658c2ecf20Sopenharmony_ci PERIPH_CLK_SYS_BUS, 1668c2ecf20Sopenharmony_ci PERIPH_CLK_DDR, 1678c2ecf20Sopenharmony_ci PERIPH_CLK_ROM, 1688c2ecf20Sopenharmony_ci}; 1698c2ecf20Sopenharmony_ci 1708c2ecf20Sopenharmony_cistatic void __init pistachio_clk_init(struct device_node *np) 1718c2ecf20Sopenharmony_ci{ 1728c2ecf20Sopenharmony_ci struct pistachio_clk_provider *p; 1738c2ecf20Sopenharmony_ci struct clk *debug_clk; 1748c2ecf20Sopenharmony_ci 1758c2ecf20Sopenharmony_ci p = pistachio_clk_alloc_provider(np, CLK_NR_CLKS); 1768c2ecf20Sopenharmony_ci if (!p) 1778c2ecf20Sopenharmony_ci return; 1788c2ecf20Sopenharmony_ci 1798c2ecf20Sopenharmony_ci pistachio_clk_register_pll(p, pistachio_plls, 1808c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_plls)); 1818c2ecf20Sopenharmony_ci pistachio_clk_register_mux(p, pistachio_muxes, 1828c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_muxes)); 1838c2ecf20Sopenharmony_ci pistachio_clk_register_div(p, pistachio_divs, 1848c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_divs)); 1858c2ecf20Sopenharmony_ci pistachio_clk_register_fixed_factor(p, pistachio_ffs, 1868c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_ffs)); 1878c2ecf20Sopenharmony_ci pistachio_clk_register_gate(p, pistachio_gates, 1888c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_gates)); 1898c2ecf20Sopenharmony_ci 1908c2ecf20Sopenharmony_ci debug_clk = clk_register_mux_table(NULL, "debug_mux", mux_debug, 1918c2ecf20Sopenharmony_ci ARRAY_SIZE(mux_debug), 1928c2ecf20Sopenharmony_ci CLK_SET_RATE_NO_REPARENT, 1938c2ecf20Sopenharmony_ci p->base + 0x200, 18, 0x1f, 0, 1948c2ecf20Sopenharmony_ci mux_debug_idx, NULL); 1958c2ecf20Sopenharmony_ci p->clk_data.clks[CLK_DEBUG_MUX] = debug_clk; 1968c2ecf20Sopenharmony_ci 1978c2ecf20Sopenharmony_ci pistachio_clk_register_provider(p); 1988c2ecf20Sopenharmony_ci 1998c2ecf20Sopenharmony_ci pistachio_clk_force_enable(p, pistachio_critical_clks_core, 2008c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_critical_clks_core)); 2018c2ecf20Sopenharmony_ci} 2028c2ecf20Sopenharmony_ciCLK_OF_DECLARE(pistachio_clk, "img,pistachio-clk", pistachio_clk_init); 2038c2ecf20Sopenharmony_ci 2048c2ecf20Sopenharmony_cistatic struct pistachio_gate pistachio_periph_gates[] __initdata = { 2058c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_SYS, "sys", "periph_sys", 0x100, 0), 2068c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_SYS_BUS, "bus_sys", "periph_sys", 0x100, 1), 2078c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_DDR, "ddr", "periph_sys", 0x100, 2), 2088c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_ROM, "rom", "rom_div", 0x100, 3), 2098c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_COUNTER_FAST, "counter_fast", "counter_fast_div", 2108c2ecf20Sopenharmony_ci 0x100, 4), 2118c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_COUNTER_SLOW, "counter_slow", "counter_slow_div", 2128c2ecf20Sopenharmony_ci 0x100, 5), 2138c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_IR, "ir", "ir_div", 0x100, 6), 2148c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_WD, "wd", "wd_div", 0x100, 7), 2158c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_PDM, "pdm", "pdm_div", 0x100, 8), 2168c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_PWM, "pwm", "pwm_div", 0x100, 9), 2178c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_I2C0, "i2c0", "i2c0_div", 0x100, 10), 2188c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_I2C1, "i2c1", "i2c1_div", 0x100, 11), 2198c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_I2C2, "i2c2", "i2c2_div", 0x100, 12), 2208c2ecf20Sopenharmony_ci GATE(PERIPH_CLK_I2C3, "i2c3", "i2c3_div", 0x100, 13), 2218c2ecf20Sopenharmony_ci}; 2228c2ecf20Sopenharmony_ci 2238c2ecf20Sopenharmony_cistatic struct pistachio_div pistachio_periph_divs[] __initdata = { 2248c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_ROM_DIV, "rom_div", "periph_sys", 0x10c, 7), 2258c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_COUNTER_FAST_DIV, "counter_fast_div", "periph_sys", 2268c2ecf20Sopenharmony_ci 0x110, 7), 2278c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_COUNTER_SLOW_PRE_DIV, "counter_slow_pre_div", 2288c2ecf20Sopenharmony_ci "periph_sys", 0x114, 7), 2298c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_COUNTER_SLOW_DIV, "counter_slow_div", 2308c2ecf20Sopenharmony_ci "counter_slow_pre_div", 0x118, 7), 2318c2ecf20Sopenharmony_ci DIV_F(PERIPH_CLK_IR_PRE_DIV, "ir_pre_div", "periph_sys", 0x11c, 7, 2328c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 2338c2ecf20Sopenharmony_ci DIV_F(PERIPH_CLK_IR_DIV, "ir_div", "ir_pre_div", 0x120, 7, 2348c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 2358c2ecf20Sopenharmony_ci DIV_F(PERIPH_CLK_WD_PRE_DIV, "wd_pre_div", "periph_sys", 0x124, 7, 2368c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 2378c2ecf20Sopenharmony_ci DIV_F(PERIPH_CLK_WD_DIV, "wd_div", "wd_pre_div", 0x128, 7, 2388c2ecf20Sopenharmony_ci CLK_DIVIDER_ROUND_CLOSEST), 2398c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_PDM_PRE_DIV, "pdm_pre_div", "periph_sys", 0x12c, 7), 2408c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_PDM_DIV, "pdm_div", "pdm_pre_div", 0x130, 7), 2418c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_PWM_PRE_DIV, "pwm_pre_div", "periph_sys", 0x134, 7), 2428c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_PWM_DIV, "pwm_div", "pwm_pre_div", 0x138, 7), 2438c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C0_PRE_DIV, "i2c0_pre_div", "periph_sys", 0x13c, 7), 2448c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C0_DIV, "i2c0_div", "i2c0_pre_div", 0x140, 7), 2458c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C1_PRE_DIV, "i2c1_pre_div", "periph_sys", 0x144, 7), 2468c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C1_DIV, "i2c1_div", "i2c1_pre_div", 0x148, 7), 2478c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C2_PRE_DIV, "i2c2_pre_div", "periph_sys", 0x14c, 7), 2488c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C2_DIV, "i2c2_div", "i2c2_pre_div", 0x150, 7), 2498c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C3_PRE_DIV, "i2c3_pre_div", "periph_sys", 0x154, 7), 2508c2ecf20Sopenharmony_ci DIV(PERIPH_CLK_I2C3_DIV, "i2c3_div", "i2c3_pre_div", 0x158, 7), 2518c2ecf20Sopenharmony_ci}; 2528c2ecf20Sopenharmony_ci 2538c2ecf20Sopenharmony_cistatic void __init pistachio_clk_periph_init(struct device_node *np) 2548c2ecf20Sopenharmony_ci{ 2558c2ecf20Sopenharmony_ci struct pistachio_clk_provider *p; 2568c2ecf20Sopenharmony_ci 2578c2ecf20Sopenharmony_ci p = pistachio_clk_alloc_provider(np, PERIPH_CLK_NR_CLKS); 2588c2ecf20Sopenharmony_ci if (!p) 2598c2ecf20Sopenharmony_ci return; 2608c2ecf20Sopenharmony_ci 2618c2ecf20Sopenharmony_ci pistachio_clk_register_div(p, pistachio_periph_divs, 2628c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_periph_divs)); 2638c2ecf20Sopenharmony_ci pistachio_clk_register_gate(p, pistachio_periph_gates, 2648c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_periph_gates)); 2658c2ecf20Sopenharmony_ci 2668c2ecf20Sopenharmony_ci pistachio_clk_register_provider(p); 2678c2ecf20Sopenharmony_ci 2688c2ecf20Sopenharmony_ci pistachio_clk_force_enable(p, pistachio_critical_clks_sys, 2698c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_critical_clks_sys)); 2708c2ecf20Sopenharmony_ci} 2718c2ecf20Sopenharmony_ciCLK_OF_DECLARE(pistachio_clk_periph, "img,pistachio-clk-periph", 2728c2ecf20Sopenharmony_ci pistachio_clk_periph_init); 2738c2ecf20Sopenharmony_ci 2748c2ecf20Sopenharmony_cistatic struct pistachio_gate pistachio_sys_gates[] __initdata = { 2758c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2C0, "i2c0_sys", "sys", 0x8, 0), 2768c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2C1, "i2c1_sys", "sys", 0x8, 1), 2778c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2C2, "i2c2_sys", "sys", 0x8, 2), 2788c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2C3, "i2c3_sys", "sys", 0x8, 3), 2798c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2S_IN, "i2s_in_sys", "sys", 0x8, 4), 2808c2ecf20Sopenharmony_ci GATE(SYS_CLK_PAUD_OUT, "paud_out_sys", "sys", 0x8, 5), 2818c2ecf20Sopenharmony_ci GATE(SYS_CLK_SPDIF_OUT, "spdif_out_sys", "sys", 0x8, 6), 2828c2ecf20Sopenharmony_ci GATE(SYS_CLK_SPI0_MASTER, "spi0_master_sys", "sys", 0x8, 7), 2838c2ecf20Sopenharmony_ci GATE(SYS_CLK_SPI0_SLAVE, "spi0_slave_sys", "sys", 0x8, 8), 2848c2ecf20Sopenharmony_ci GATE(SYS_CLK_PWM, "pwm_sys", "sys", 0x8, 9), 2858c2ecf20Sopenharmony_ci GATE(SYS_CLK_UART0, "uart0_sys", "sys", 0x8, 10), 2868c2ecf20Sopenharmony_ci GATE(SYS_CLK_UART1, "uart1_sys", "sys", 0x8, 11), 2878c2ecf20Sopenharmony_ci GATE(SYS_CLK_SPI1, "spi1_sys", "sys", 0x8, 12), 2888c2ecf20Sopenharmony_ci GATE(SYS_CLK_MDC, "mdc_sys", "sys", 0x8, 13), 2898c2ecf20Sopenharmony_ci GATE(SYS_CLK_SD_HOST, "sd_host_sys", "sys", 0x8, 14), 2908c2ecf20Sopenharmony_ci GATE(SYS_CLK_ENET, "enet_sys", "sys", 0x8, 15), 2918c2ecf20Sopenharmony_ci GATE(SYS_CLK_IR, "ir_sys", "sys", 0x8, 16), 2928c2ecf20Sopenharmony_ci GATE(SYS_CLK_WD, "wd_sys", "sys", 0x8, 17), 2938c2ecf20Sopenharmony_ci GATE(SYS_CLK_TIMER, "timer_sys", "sys", 0x8, 18), 2948c2ecf20Sopenharmony_ci GATE(SYS_CLK_I2S_OUT, "i2s_out_sys", "sys", 0x8, 24), 2958c2ecf20Sopenharmony_ci GATE(SYS_CLK_SPDIF_IN, "spdif_in_sys", "sys", 0x8, 25), 2968c2ecf20Sopenharmony_ci GATE(SYS_CLK_EVENT_TIMER, "event_timer_sys", "sys", 0x8, 26), 2978c2ecf20Sopenharmony_ci GATE(SYS_CLK_HASH, "hash_sys", "sys", 0x8, 27), 2988c2ecf20Sopenharmony_ci}; 2998c2ecf20Sopenharmony_ci 3008c2ecf20Sopenharmony_cistatic void __init pistachio_cr_periph_init(struct device_node *np) 3018c2ecf20Sopenharmony_ci{ 3028c2ecf20Sopenharmony_ci struct pistachio_clk_provider *p; 3038c2ecf20Sopenharmony_ci 3048c2ecf20Sopenharmony_ci p = pistachio_clk_alloc_provider(np, SYS_CLK_NR_CLKS); 3058c2ecf20Sopenharmony_ci if (!p) 3068c2ecf20Sopenharmony_ci return; 3078c2ecf20Sopenharmony_ci 3088c2ecf20Sopenharmony_ci pistachio_clk_register_gate(p, pistachio_sys_gates, 3098c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_sys_gates)); 3108c2ecf20Sopenharmony_ci 3118c2ecf20Sopenharmony_ci pistachio_clk_register_provider(p); 3128c2ecf20Sopenharmony_ci} 3138c2ecf20Sopenharmony_ciCLK_OF_DECLARE(pistachio_cr_periph, "img,pistachio-cr-periph", 3148c2ecf20Sopenharmony_ci pistachio_cr_periph_init); 3158c2ecf20Sopenharmony_ci 3168c2ecf20Sopenharmony_cistatic struct pistachio_gate pistachio_ext_gates[] __initdata = { 3178c2ecf20Sopenharmony_ci GATE(EXT_CLK_ENET_IN, "enet_clk_in_gate", "enet_clk_in", 0x58, 5), 3188c2ecf20Sopenharmony_ci GATE(EXT_CLK_AUDIO_IN, "audio_clk_in_gate", "audio_clk_in", 0x58, 8) 3198c2ecf20Sopenharmony_ci}; 3208c2ecf20Sopenharmony_ci 3218c2ecf20Sopenharmony_cistatic void __init pistachio_cr_top_init(struct device_node *np) 3228c2ecf20Sopenharmony_ci{ 3238c2ecf20Sopenharmony_ci struct pistachio_clk_provider *p; 3248c2ecf20Sopenharmony_ci 3258c2ecf20Sopenharmony_ci p = pistachio_clk_alloc_provider(np, EXT_CLK_NR_CLKS); 3268c2ecf20Sopenharmony_ci if (!p) 3278c2ecf20Sopenharmony_ci return; 3288c2ecf20Sopenharmony_ci 3298c2ecf20Sopenharmony_ci pistachio_clk_register_gate(p, pistachio_ext_gates, 3308c2ecf20Sopenharmony_ci ARRAY_SIZE(pistachio_ext_gates)); 3318c2ecf20Sopenharmony_ci 3328c2ecf20Sopenharmony_ci pistachio_clk_register_provider(p); 3338c2ecf20Sopenharmony_ci} 3348c2ecf20Sopenharmony_ciCLK_OF_DECLARE(pistachio_cr_top, "img,pistachio-cr-top", 3358c2ecf20Sopenharmony_ci pistachio_cr_top_init); 336