提交 93366489 编写于 作者: V Vipul Kumar Samar 提交者: Dmitry Torokhov

Input: spear-keyboard - add clk_{un}prepare() support

clk_{un}prepare is mandatory for platforms using common clock framework.
Because for SPEAr we don't do anything in clk_{un}prepare() calls, just
call them once in probe/remove.
Signed-off-by: NVipul Kumar Samar <vipulkumar.samar@st.com>
Signed-off-by: NViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: NDmitry Torokhov <dmitry.torokhov@gmail.com>
上级 92aab960
...@@ -267,9 +267,14 @@ static int spear_kbd_probe(struct platform_device *pdev) ...@@ -267,9 +267,14 @@ static int spear_kbd_probe(struct platform_device *pdev)
return error; return error;
} }
error = clk_prepare(kbd->clk);
if (error)
return error;
error = input_register_device(input_dev); error = input_register_device(input_dev);
if (error) { if (error) {
dev_err(&pdev->dev, "Unable to register keyboard device\n"); dev_err(&pdev->dev, "Unable to register keyboard device\n");
clk_unprepare(kbd->clk);
return error; return error;
} }
...@@ -281,6 +286,11 @@ static int spear_kbd_probe(struct platform_device *pdev) ...@@ -281,6 +286,11 @@ static int spear_kbd_probe(struct platform_device *pdev)
static int spear_kbd_remove(struct platform_device *pdev) static int spear_kbd_remove(struct platform_device *pdev)
{ {
struct spear_kbd *kbd = platform_get_drvdata(pdev);
input_unregister_device(kbd->input);
clk_unprepare(kbd->clk);
device_init_wakeup(&pdev->dev, 0); device_init_wakeup(&pdev->dev, 0);
platform_set_drvdata(pdev, NULL); platform_set_drvdata(pdev, NULL);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册