diff options
author | Tony Lindgren <tony@atomide.com> | 2009-06-03 12:43:14 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-06-04 12:45:43 -0400 |
commit | c0683039207226afcffbe0fbf6a1caaee77a37b0 (patch) | |
tree | d91295ea184722929a12c772839c3d6f502ad95b /arch/arm/common/clkdev.c | |
parent | 5926a295bb78272b3f648f62febecd19a1b6a6ca (diff) |
[ARM] 5536/1: Move clk_add_alias() to arch/arm/common/clkdev.c
This can be used for other arm platforms too as discussed
on the linux-arm-kernel list.
Also check the return value with IS_ERR and return PTR_ERR
as suggested by Russell King.
Signed-off-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/common/clkdev.c')
-rw-r--r-- | arch/arm/common/clkdev.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/arch/arm/common/clkdev.c b/arch/arm/common/clkdev.c index 5589444ff437..f37afd9422f3 100644 --- a/arch/arm/common/clkdev.c +++ b/arch/arm/common/clkdev.c | |||
@@ -135,6 +135,24 @@ struct clk_lookup *clkdev_alloc(struct clk *clk, const char *con_id, | |||
135 | } | 135 | } |
136 | EXPORT_SYMBOL(clkdev_alloc); | 136 | EXPORT_SYMBOL(clkdev_alloc); |
137 | 137 | ||
138 | int clk_add_alias(const char *alias, const char *alias_dev_name, char *id, | ||
139 | struct device *dev) | ||
140 | { | ||
141 | struct clk *r = clk_get(dev, id); | ||
142 | struct clk_lookup *l; | ||
143 | |||
144 | if (IS_ERR(r)) | ||
145 | return PTR_ERR(r); | ||
146 | |||
147 | l = clkdev_alloc(r, alias, alias_dev_name); | ||
148 | clk_put(r); | ||
149 | if (!l) | ||
150 | return -ENODEV; | ||
151 | clkdev_add(l); | ||
152 | return 0; | ||
153 | } | ||
154 | EXPORT_SYMBOL(clk_add_alias); | ||
155 | |||
138 | /* | 156 | /* |
139 | * clkdev_drop - remove a clock dynamically allocated | 157 | * clkdev_drop - remove a clock dynamically allocated |
140 | */ | 158 | */ |