diff options
author | Shiraz Hashim <shiraz.hashim@st.com> | 2012-03-23 18:02:29 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-23 19:58:38 -0400 |
commit | 131f8b75f1c00a5a822ff2103db588466e942490 (patch) | |
tree | 5d2f0476e3ceacbcecd4af0850fa4fc959819e15 /drivers/rtc | |
parent | cd0e08a8c9fb9c50d182d20e3bc52452c1ce1bfb (diff) |
rtc/spear: fix for RTC_AIE_ON and RTC_AIE_OFF ioctl errors
Define API for '.alarm_irq_enable' to enable and disable alarm irq. This
is required by the framework else RTC_AIE_ON and RTC_AIE_OFF ioctls
return errors.
Signed-off-by: Shiraz Hashim <shiraz.hashim@st.com>
Signed-off-by: Viresh Kumar <viresh.kumar@st.com>
Cc: Deepak Sikri <deepak.sikri@st.com>
Acked-by: Rajeev Kumar <rajeev-dlh.kumar@st.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/rtc')
-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) |