summaryrefslogtreecommitdiff
path: root/drivers/clk
diff options
context:
space:
mode:
authorSylwester Nawrocki <s.nawrocki@samsung.com>2013-08-23 13:04:33 +0200
committerChanho Park <chanho61.park@samsung.com>2014-11-18 11:44:26 +0900
commitdc58da84f2f7b90f8663f17ef57c819e74428423 (patch)
treed6008325bacb6fe2d133c1dacdd5e9dc44a44717 /drivers/clk
parent5a283447e07161a639c97463a40c903b454cbf80 (diff)
downloadlinux-3.10-dc58da84f2f7b90f8663f17ef57c819e74428423.tar.gz
linux-3.10-dc58da84f2f7b90f8663f17ef57c819e74428423.tar.bz2
linux-3.10-dc58da84f2f7b90f8663f17ef57c819e74428423.zip
clk: Assign module owner of a clock being registered
Use dev->driver->owner as the owner module of a clock, it ensures reference on the module is taken in the __clk_get(), __clk_put() helpers. Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com> Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com> --- Changes since v5: - none.
Diffstat (limited to 'drivers/clk')
-rw-r--r--drivers/clk/clk.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
index 05a60cf6e27..0fadfe5e0f5 100644
--- a/drivers/clk/clk.c
+++ b/drivers/clk/clk.c
@@ -1697,6 +1697,10 @@ struct clk *__clk_register(struct device *dev, struct clk_hw *hw)
clk->flags = hw->init->flags;
clk->parent_names = hw->init->parent_names;
clk->num_parents = hw->init->num_parents;
+ if (dev && dev->driver)
+ clk->owner = dev->driver->owner;
+ else
+ clk->owner = NULL;
ret = __clk_init(dev, clk);
if (ret)
@@ -1717,6 +1721,8 @@ static int _clk_register(struct device *dev, struct clk_hw *hw, struct clk *clk)
goto fail_name;
}
clk->ops = hw->init->ops;
+ if (dev && dev->driver)
+ clk->owner = dev->driver->owner;
clk->hw = hw;
clk->flags = hw->init->flags;
clk->num_parents = hw->init->num_parents;