dm: clk: Add support for of-platdata

Add support for this feature in the core clock code.

Signed-off-by: Simon Glass <sjg@chromium.org>
master
Simon Glass 9 years ago
parent f24770d812
commit 7423daa60e
  1. 22
      drivers/clk/clk-uclass.c
  2. 2
      drivers/clk/clk_fixed_rate.c
  3. 4
      include/clk.h

@ -10,6 +10,7 @@
#include <clk.h> #include <clk.h>
#include <clk-uclass.h> #include <clk-uclass.h>
#include <dm.h> #include <dm.h>
#include <dt-structs.h>
#include <errno.h> #include <errno.h>
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
@ -21,6 +22,22 @@ static inline struct clk_ops *clk_dev_ops(struct udevice *dev)
#if CONFIG_IS_ENABLED(OF_CONTROL) #if CONFIG_IS_ENABLED(OF_CONTROL)
#ifdef CONFIG_SPL_BUILD #ifdef CONFIG_SPL_BUILD
# if CONFIG_IS_ENABLED(OF_PLATDATA)
int clk_get_by_index_platdata(struct udevice *dev, int index,
struct phandle_2_cell *cells, struct clk *clk)
{
int ret;
if (index != 0)
return -ENOSYS;
ret = uclass_get_device(UCLASS_CLK, 0, &clk->dev);
if (ret)
return ret;
clk->id = cells[0].id;
return 0;
}
# else
int clk_get_by_index(struct udevice *dev, int index, struct clk *clk) int clk_get_by_index(struct udevice *dev, int index, struct clk *clk)
{ {
int ret; int ret;
@ -39,6 +56,7 @@ int clk_get_by_index(struct udevice *dev, int index, struct clk *clk)
clk->id = cell[1]; clk->id = cell[1];
return 0; return 0;
} }
# endif /* OF_PLATDATA */
int clk_get_by_name(struct udevice *dev, const char *name, struct clk *clk) int clk_get_by_name(struct udevice *dev, const char *name, struct clk *clk)
{ {
@ -117,8 +135,8 @@ int clk_get_by_name(struct udevice *dev, const char *name, struct clk *clk)
return clk_get_by_index(dev, index, clk); return clk_get_by_index(dev, index, clk);
} }
#endif #endif /* CONFIG_SPL_BUILD */
#endif #endif /* OF_CONTROL */
int clk_request(struct udevice *dev, struct clk *clk) int clk_request(struct udevice *dev, struct clk *clk)
{ {

@ -30,9 +30,11 @@ const struct clk_ops clk_fixed_rate_ops = {
static int clk_fixed_rate_ofdata_to_platdata(struct udevice *dev) static int clk_fixed_rate_ofdata_to_platdata(struct udevice *dev)
{ {
#if !CONFIG_IS_ENABLED(OF_PLATDATA)
to_clk_fixed_rate(dev)->fixed_rate = to_clk_fixed_rate(dev)->fixed_rate =
fdtdec_get_int(gd->fdt_blob, dev->of_offset, fdtdec_get_int(gd->fdt_blob, dev->of_offset,
"clock-frequency", 0); "clock-frequency", 0);
#endif
return 0; return 0;
} }

@ -60,6 +60,10 @@ struct clk {
}; };
#if CONFIG_IS_ENABLED(OF_CONTROL) #if CONFIG_IS_ENABLED(OF_CONTROL)
struct phandle_2_cell;
int clk_get_by_index_platdata(struct udevice *dev, int index,
struct phandle_2_cell *cells, struct clk *clk);
/** /**
* clock_get_by_index - Get/request a clock by integer index. * clock_get_by_index - Get/request a clock by integer index.
* *

Loading…
Cancel
Save