#include <dt-bindings/clock/mt8173-clk.h>
#include <linux/of_address.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include "clk-fhctl.h"
#include "clk-mtk.h"
#include "clk-pll.h"
#include "clk-pllfh.h"
#define REGOFF_REF2USB …
#define REGOFF_HDMI_REF …
#define MT8173_PLL_FMAX …
#define CON0_MT8173_RST_BAR …
#define PLL_B(_id, _name, _reg, _pwr_reg, _en_mask, _flags, _pcwbits, \
_pd_reg, _pd_shift, _tuner_reg, _pcw_reg, \
_pcw_shift, _div_table) …
#define PLL(_id, _name, _reg, _pwr_reg, _en_mask, _flags, _pcwbits, \
_pd_reg, _pd_shift, _tuner_reg, _pcw_reg, \
_pcw_shift) …
static const struct mtk_pll_div_table mmpll_div_table[] = …;
static const struct mtk_pll_data plls[] = …;
enum fh_pll_id { … };
#define FH(_pllid, _fhid, _offset) …
static struct mtk_pllfh_data pllfhs[] = …;
static const struct of_device_id of_match_clk_mt8173_apmixed[] = …;
MODULE_DEVICE_TABLE(of, of_match_clk_mt8173_apmixed);
static int clk_mt8173_apmixed_probe(struct platform_device *pdev)
{ … }
static void clk_mt8173_apmixed_remove(struct platform_device *pdev)
{ … }
static struct platform_driver clk_mt8173_apmixed_drv = …;
module_platform_driver(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;