linux/drivers/clk/starfive/clk-starfive-jh7110-sys.c

// SPDX-License-Identifier: GPL-2.0
/*
 * StarFive JH7110 System Clock Driver
 *
 * Copyright (C) 2022 Emil Renner Berthing <[email protected]>
 * Copyright (C) 2022 StarFive Technology Co., Ltd.
 */

#include <linux/auxiliary_bus.h>
#include <linux/clk.h>
#include <linux/clk-provider.h>
#include <linux/init.h>
#include <linux/io.h>
#include <linux/platform_device.h>
#include <linux/slab.h>

#include <soc/starfive/reset-starfive-jh71x0.h>

#include <dt-bindings/clock/starfive,jh7110-crg.h>

#include "clk-starfive-jh7110.h"

/* external clocks */
#define JH7110_SYSCLK_OSC
#define JH7110_SYSCLK_GMAC1_RMII_REFIN
#define JH7110_SYSCLK_GMAC1_RGMII_RXIN
#define JH7110_SYSCLK_I2STX_BCLK_EXT
#define JH7110_SYSCLK_I2STX_LRCK_EXT
#define JH7110_SYSCLK_I2SRX_BCLK_EXT
#define JH7110_SYSCLK_I2SRX_LRCK_EXT
#define JH7110_SYSCLK_TDM_EXT
#define JH7110_SYSCLK_MCLK_EXT
#define JH7110_SYSCLK_PLL0_OUT
#define JH7110_SYSCLK_PLL1_OUT
#define JH7110_SYSCLK_PLL2_OUT

static const struct jh71x0_clk_data jh7110_sysclk_data[] __initconst =;

static struct clk_hw *jh7110_sysclk_get(struct of_phandle_args *clkspec, void *data)
{}

static void jh7110_reset_unregister_adev(void *_adev)
{}

static void jh7110_reset_adev_release(struct device *dev)
{}

int jh7110_reset_controller_register(struct jh71x0_clk_priv *priv,
				     const char *adev_name,
				     u32 adev_id)
{}
EXPORT_SYMBOL_GPL();

/*
 * This clock notifier is called when the rate of PLL0 clock is to be changed.
 * The cpu_root clock should save the curent parent clock and switch its parent
 * clock to osc before PLL0 rate will be changed. Then switch its parent clock
 * back after the PLL0 rate is completed.
 */
static int jh7110_pll0_clk_notifier_cb(struct notifier_block *nb,
				       unsigned long action, void *data)
{}

static int __init jh7110_syscrg_probe(struct platform_device *pdev)
{}

static const struct of_device_id jh7110_syscrg_match[] =;

static struct platform_driver jh7110_syscrg_driver =;
builtin_platform_driver_probe();