clk: bcm: rpi: Add clock id to data
The driver has really only supported one clock so far and has hardcoded the ID used in communications with the firmware in all the functions implementing the clock framework hooks. Let's store that in the clock data structure so that we can support more clocks later on. Cc: Michael Turquette <mturquette@baylibre.com> Cc: linux-clk@vger.kernel.org Acked-by: Nicolas Saenz Julienne <nsaenzjulienne@suse.de> Reviewed-by: Stephen Boyd <sboyd@kernel.org> Tested-by: Nicolas Saenz Julienne <nsaenzjulienne@suse.de> Signed-off-by: Maxime Ripard <maxime@cerno.tech> Link: https://lore.kernel.org/r/e23c37961b97b027e21efa3b818578970f88527a.1592210452.git-series.maxime@cerno.tech Signed-off-by: Stephen Boyd <sboyd@kernel.org>
This commit is contained in:
parent
f922c560c9
commit
8a1f3ebc38
@ -39,6 +39,9 @@ struct raspberrypi_clk {
|
|||||||
|
|
||||||
struct raspberrypi_clk_data {
|
struct raspberrypi_clk_data {
|
||||||
struct clk_hw hw;
|
struct clk_hw hw;
|
||||||
|
|
||||||
|
unsigned int id;
|
||||||
|
|
||||||
struct raspberrypi_clk *rpi;
|
struct raspberrypi_clk *rpi;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -91,7 +94,7 @@ static int raspberrypi_fw_pll_is_on(struct clk_hw *hw)
|
|||||||
|
|
||||||
ret = raspberrypi_clock_property(rpi->firmware,
|
ret = raspberrypi_clock_property(rpi->firmware,
|
||||||
RPI_FIRMWARE_GET_CLOCK_STATE,
|
RPI_FIRMWARE_GET_CLOCK_STATE,
|
||||||
RPI_FIRMWARE_ARM_CLK_ID, &val);
|
data->id, &val);
|
||||||
if (ret)
|
if (ret)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -110,8 +113,7 @@ static unsigned long raspberrypi_fw_pll_get_rate(struct clk_hw *hw,
|
|||||||
|
|
||||||
ret = raspberrypi_clock_property(rpi->firmware,
|
ret = raspberrypi_clock_property(rpi->firmware,
|
||||||
RPI_FIRMWARE_GET_CLOCK_RATE,
|
RPI_FIRMWARE_GET_CLOCK_RATE,
|
||||||
RPI_FIRMWARE_ARM_CLK_ID,
|
data->id, &val);
|
||||||
&val);
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -129,8 +131,7 @@ static int raspberrypi_fw_pll_set_rate(struct clk_hw *hw, unsigned long rate,
|
|||||||
|
|
||||||
ret = raspberrypi_clock_property(rpi->firmware,
|
ret = raspberrypi_clock_property(rpi->firmware,
|
||||||
RPI_FIRMWARE_SET_CLOCK_RATE,
|
RPI_FIRMWARE_SET_CLOCK_RATE,
|
||||||
RPI_FIRMWARE_ARM_CLK_ID,
|
data->id, &new_rate);
|
||||||
&new_rate);
|
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err_ratelimited(rpi->dev, "Failed to change %s frequency: %d",
|
dev_err_ratelimited(rpi->dev, "Failed to change %s frequency: %d",
|
||||||
clk_hw_get_name(hw), ret);
|
clk_hw_get_name(hw), ret);
|
||||||
@ -183,6 +184,7 @@ static int raspberrypi_register_pllb(struct raspberrypi_clk *rpi)
|
|||||||
if (!data)
|
if (!data)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
data->rpi = rpi;
|
data->rpi = rpi;
|
||||||
|
data->id = RPI_FIRMWARE_ARM_CLK_ID;
|
||||||
|
|
||||||
/* All of the PLLs derive from the external oscillator. */
|
/* All of the PLLs derive from the external oscillator. */
|
||||||
init.parent_names = (const char *[]){ "osc" };
|
init.parent_names = (const char *[]){ "osc" };
|
||||||
@ -194,8 +196,7 @@ static int raspberrypi_register_pllb(struct raspberrypi_clk *rpi)
|
|||||||
/* Get min & max rates set by the firmware */
|
/* Get min & max rates set by the firmware */
|
||||||
ret = raspberrypi_clock_property(rpi->firmware,
|
ret = raspberrypi_clock_property(rpi->firmware,
|
||||||
RPI_FIRMWARE_GET_MIN_CLOCK_RATE,
|
RPI_FIRMWARE_GET_MIN_CLOCK_RATE,
|
||||||
RPI_FIRMWARE_ARM_CLK_ID,
|
data->id, &min_rate);
|
||||||
&min_rate);
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(rpi->dev, "Failed to get %s min freq: %d\n",
|
dev_err(rpi->dev, "Failed to get %s min freq: %d\n",
|
||||||
init.name, ret);
|
init.name, ret);
|
||||||
@ -204,8 +205,7 @@ static int raspberrypi_register_pllb(struct raspberrypi_clk *rpi)
|
|||||||
|
|
||||||
ret = raspberrypi_clock_property(rpi->firmware,
|
ret = raspberrypi_clock_property(rpi->firmware,
|
||||||
RPI_FIRMWARE_GET_MAX_CLOCK_RATE,
|
RPI_FIRMWARE_GET_MAX_CLOCK_RATE,
|
||||||
RPI_FIRMWARE_ARM_CLK_ID,
|
data->id, &max_rate);
|
||||||
&max_rate);
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(rpi->dev, "Failed to get %s max freq: %d\n",
|
dev_err(rpi->dev, "Failed to get %s max freq: %d\n",
|
||||||
init.name, ret);
|
init.name, ret);
|
||||||
|
Loading…
Reference in New Issue
Block a user