diff options
author | Daniel Lezcano <daniel.lezcano@linaro.org> | 2016-06-01 02:55:46 -0400 |
---|---|---|
committer | Daniel Lezcano <daniel.lezcano@linaro.org> | 2016-06-28 04:19:19 -0400 |
commit | 2e1773f8caef47037486814989e689ff9eacc155 (patch) | |
tree | 9e4b600fc116cfe0784e968259148df1ed728c57 /drivers/clocksource | |
parent | 84309e0abdd76517b7b0d72e2f8373194fcffeb2 (diff) |
clocksource/drivers/dw_apb_timer: Convert init function to return error
The init functions do not return any error. They behave as the following:
- panic, thus leading to a kernel crash while another timer may work and
make the system boot up correctly
or
- print an error and let the caller unaware if the state of the system
Change that by converting the init functions to return an error conforming
to the CLOCKSOURCE_OF_RET prototype.
Proper error handling (rollback, errno value) will be changed later case
by case, thus this change just return back an error or success in the init
function.
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Diffstat (limited to 'drivers/clocksource')
-rw-r--r-- | drivers/clocksource/dw_apb_timer_of.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/clocksource/dw_apb_timer_of.c b/drivers/clocksource/dw_apb_timer_of.c index 860843cef572..4985a2cadad9 100644 --- a/drivers/clocksource/dw_apb_timer_of.c +++ b/drivers/clocksource/dw_apb_timer_of.c | |||
@@ -143,7 +143,7 @@ static struct delay_timer dw_apb_delay_timer = { | |||
143 | #endif | 143 | #endif |
144 | 144 | ||
145 | static int num_called; | 145 | static int num_called; |
146 | static void __init dw_apb_timer_init(struct device_node *timer) | 146 | static int __init dw_apb_timer_init(struct device_node *timer) |
147 | { | 147 | { |
148 | switch (num_called) { | 148 | switch (num_called) { |
149 | case 0: | 149 | case 0: |
@@ -164,8 +164,10 @@ static void __init dw_apb_timer_init(struct device_node *timer) | |||
164 | } | 164 | } |
165 | 165 | ||
166 | num_called++; | 166 | num_called++; |
167 | |||
168 | return 0; | ||
167 | } | 169 | } |
168 | CLOCKSOURCE_OF_DECLARE(pc3x2_timer, "picochip,pc3x2-timer", dw_apb_timer_init); | 170 | CLOCKSOURCE_OF_DECLARE_RET(pc3x2_timer, "picochip,pc3x2-timer", dw_apb_timer_init); |
169 | CLOCKSOURCE_OF_DECLARE(apb_timer_osc, "snps,dw-apb-timer-osc", dw_apb_timer_init); | 171 | CLOCKSOURCE_OF_DECLARE_RET(apb_timer_osc, "snps,dw-apb-timer-osc", dw_apb_timer_init); |
170 | CLOCKSOURCE_OF_DECLARE(apb_timer_sp, "snps,dw-apb-timer-sp", dw_apb_timer_init); | 172 | CLOCKSOURCE_OF_DECLARE_RET(apb_timer_sp, "snps,dw-apb-timer-sp", dw_apb_timer_init); |
171 | CLOCKSOURCE_OF_DECLARE(apb_timer, "snps,dw-apb-timer", dw_apb_timer_init); | 173 | CLOCKSOURCE_OF_DECLARE_RET(apb_timer, "snps,dw-apb-timer", dw_apb_timer_init); |