| /* Copyright (c) 2012-2017, The Linux Foundation. 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 version 2 and |
| * only version 2 as published by the Free Software Foundation. |
| * |
| * 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. |
| */ |
| |
| #ifndef __MDSS_HDMI_PLL_H |
| #define __MDSS_HDMI_PLL_H |
| |
| struct hdmi_pll_cfg { |
| unsigned long vco_rate; |
| u32 reg; |
| }; |
| |
| struct hdmi_pll_vco_clk { |
| unsigned long rate; /* current vco rate */ |
| unsigned long min_rate; /* min vco rate */ |
| unsigned long max_rate; /* max vco rate */ |
| bool rate_set; |
| struct hdmi_pll_cfg *ip_seti; |
| struct hdmi_pll_cfg *cp_seti; |
| struct hdmi_pll_cfg *ip_setp; |
| struct hdmi_pll_cfg *cp_setp; |
| struct hdmi_pll_cfg *crctrl; |
| void *priv; |
| |
| struct clk c; |
| }; |
| |
| static inline struct hdmi_pll_vco_clk *to_hdmi_vco_clk(struct clk *clk) |
| { |
| return container_of(clk, struct hdmi_pll_vco_clk, c); |
| } |
| |
| int hdmi_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_20nm_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_8996_v1_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_8996_v2_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_8996_v3_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_8996_v3_1p8_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| |
| int hdmi_8998_pll_clock_register(struct platform_device *pdev, |
| struct mdss_pll_resources *pll_res); |
| #endif |