diff options
-rw-r--r-- | drivers/rtc/rtc-spear.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/drivers/rtc/rtc-spear.c b/drivers/rtc/rtc-spear.c index 4f068e9ec0f8..646937473515 100644 --- a/drivers/rtc/rtc-spear.c +++ b/drivers/rtc/rtc-spear.c | |||
@@ -327,11 +327,39 @@ static int spear_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alm) | |||
327 | 327 | ||
328 | return 0; | 328 | return 0; |
329 | } | 329 | } |
330 | |||
331 | static int spear_alarm_irq_enable(struct device *dev, unsigned int enabled) | ||
332 | { | ||
333 | struct platform_device *pdev = to_platform_device(dev); | ||
334 | struct rtc_device *rtc = platform_get_drvdata(pdev); | ||
335 | struct spear_rtc_config *config = dev_get_drvdata(&rtc->dev); | ||
336 | int ret = 0; | ||
337 | |||
338 | spear_rtc_clear_interrupt(config); | ||
339 | |||
340 | switch (enabled) { | ||
341 | case 0: | ||
342 | /* alarm off */ | ||
343 | spear_rtc_disable_interrupt(config); | ||
344 | break; | ||
345 | case 1: | ||
346 | /* alarm on */ | ||
347 | spear_rtc_enable_interrupt(config); | ||
348 | break; | ||
349 | default: | ||
350 | ret = -EINVAL; | ||
351 | break; | ||
352 | } | ||
353 | |||
354 | return ret; | ||
355 | } | ||
356 | |||
330 | static struct rtc_class_ops spear_rtc_ops = { | 357 | static struct rtc_class_ops spear_rtc_ops = { |
331 | .read_time = spear_rtc_read_time, | 358 | .read_time = spear_rtc_read_time, |
332 | .set_time = spear_rtc_set_time, | 359 | .set_time = spear_rtc_set_time, |
333 | .read_alarm = spear_rtc_read_alarm, | 360 | .read_alarm = spear_rtc_read_alarm, |
334 | .set_alarm = spear_rtc_set_alarm, | 361 | .set_alarm = spear_rtc_set_alarm, |
362 | .alarm_irq_enable = spear_alarm_irq_enable, | ||
335 | }; | 363 | }; |
336 | 364 | ||
337 | static int __devinit spear_rtc_probe(struct platform_device *pdev) | 365 | static int __devinit spear_rtc_probe(struct platform_device *pdev) |