diff options
| author | Ingo Molnar <mingo@elte.hu> | 2010-08-31 03:45:21 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-08-31 03:45:46 -0400 |
| commit | daab7fc734a53fdeaf844b7c03053118ad1769da (patch) | |
| tree | 575deb3cdcc6dda562acaed6f7c29bc81ae01cf2 /drivers/rtc/rtc-pxa.c | |
| parent | 774ea0bcb27f57b6fd521b3b6c43237782fed4b9 (diff) | |
| parent | 2bfc96a127bc1cc94d26bfaa40159966064f9c8c (diff) | |
Merge commit 'v2.6.36-rc3' into x86/memblock
Conflicts:
arch/x86/kernel/trampoline.c
mm/memblock.c
Merge reason: Resolve the conflicts, update to latest upstream.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'drivers/rtc/rtc-pxa.c')
| -rw-r--r-- | drivers/rtc/rtc-pxa.c | 42 |
1 files changed, 22 insertions, 20 deletions
diff --git a/drivers/rtc/rtc-pxa.c b/drivers/rtc/rtc-pxa.c index e9c6fa035989..29e867a1aaa8 100644 --- a/drivers/rtc/rtc-pxa.c +++ b/drivers/rtc/rtc-pxa.c | |||
| @@ -87,7 +87,6 @@ struct pxa_rtc { | |||
| 87 | int irq_Alrm; | 87 | int irq_Alrm; |
| 88 | struct rtc_device *rtc; | 88 | struct rtc_device *rtc; |
| 89 | spinlock_t lock; /* Protects this structure */ | 89 | spinlock_t lock; /* Protects this structure */ |
| 90 | struct rtc_time rtc_alarm; | ||
| 91 | }; | 90 | }; |
| 92 | 91 | ||
| 93 | static u32 ryxr_calc(struct rtc_time *tm) | 92 | static u32 ryxr_calc(struct rtc_time *tm) |
| @@ -236,32 +235,34 @@ static int pxa_periodic_irq_set_state(struct device *dev, int enabled) | |||
| 236 | return 0; | 235 | return 0; |
| 237 | } | 236 | } |
| 238 | 237 | ||
| 239 | static int pxa_rtc_ioctl(struct device *dev, unsigned int cmd, | 238 | static int pxa_alarm_irq_enable(struct device *dev, unsigned int enabled) |
| 240 | unsigned long arg) | ||
| 241 | { | 239 | { |
| 242 | struct pxa_rtc *pxa_rtc = dev_get_drvdata(dev); | 240 | struct pxa_rtc *pxa_rtc = dev_get_drvdata(dev); |
| 243 | int ret = 0; | ||
| 244 | 241 | ||
| 245 | spin_lock_irq(&pxa_rtc->lock); | 242 | spin_lock_irq(&pxa_rtc->lock); |
| 246 | switch (cmd) { | 243 | |
| 247 | case RTC_AIE_OFF: | 244 | if (enabled) |
| 248 | rtsr_clear_bits(pxa_rtc, RTSR_RDALE1); | ||
| 249 | break; | ||
| 250 | case RTC_AIE_ON: | ||
| 251 | rtsr_set_bits(pxa_rtc, RTSR_RDALE1); | 245 | rtsr_set_bits(pxa_rtc, RTSR_RDALE1); |
| 252 | break; | 246 | else |
| 253 | case RTC_UIE_OFF: | 247 | rtsr_clear_bits(pxa_rtc, RTSR_RDALE1); |
| 254 | rtsr_clear_bits(pxa_rtc, RTSR_HZE); | 248 | |
| 255 | break; | 249 | spin_unlock_irq(&pxa_rtc->lock); |
| 256 | case RTC_UIE_ON: | 250 | return 0; |
| 251 | } | ||
| 252 | |||
| 253 | static int pxa_update_irq_enable(struct device *dev, unsigned int enabled) | ||
| 254 | { | ||
| 255 | struct pxa_rtc *pxa_rtc = dev_get_drvdata(dev); | ||
| 256 | |||
| 257 | spin_lock_irq(&pxa_rtc->lock); | ||
| 258 | |||
| 259 | if (enabled) | ||
| 257 | rtsr_set_bits(pxa_rtc, RTSR_HZE); | 260 | rtsr_set_bits(pxa_rtc, RTSR_HZE); |
| 258 | break; | 261 | else |
| 259 | default: | 262 | rtsr_clear_bits(pxa_rtc, RTSR_HZE); |
| 260 | ret = -ENOIOCTLCMD; | ||
| 261 | } | ||
| 262 | 263 | ||
| 263 | spin_unlock_irq(&pxa_rtc->lock); | 264 | spin_unlock_irq(&pxa_rtc->lock); |
| 264 | return ret; | 265 | return 0; |
| 265 | } | 266 | } |
| 266 | 267 | ||
| 267 | static int pxa_rtc_read_time(struct device *dev, struct rtc_time *tm) | 268 | static int pxa_rtc_read_time(struct device *dev, struct rtc_time *tm) |
| @@ -340,11 +341,12 @@ static int pxa_rtc_proc(struct device *dev, struct seq_file *seq) | |||
| 340 | static const struct rtc_class_ops pxa_rtc_ops = { | 341 | static const struct rtc_class_ops pxa_rtc_ops = { |
| 341 | .open = pxa_rtc_open, | 342 | .open = pxa_rtc_open, |
| 342 | .release = pxa_rtc_release, | 343 | .release = pxa_rtc_release, |
| 343 | .ioctl = pxa_rtc_ioctl, | ||
| 344 | .read_time = pxa_rtc_read_time, | 344 | .read_time = pxa_rtc_read_time, |
| 345 | .set_time = pxa_rtc_set_time, | 345 | .set_time = pxa_rtc_set_time, |
| 346 | .read_alarm = pxa_rtc_read_alarm, | 346 | .read_alarm = pxa_rtc_read_alarm, |
| 347 | .set_alarm = pxa_rtc_set_alarm, | 347 | .set_alarm = pxa_rtc_set_alarm, |
| 348 | .alarm_irq_enable = pxa_alarm_irq_enable, | ||
| 349 | .update_irq_enable = pxa_update_irq_enable, | ||
| 348 | .proc = pxa_rtc_proc, | 350 | .proc = pxa_rtc_proc, |
| 349 | .irq_set_state = pxa_periodic_irq_set_state, | 351 | .irq_set_state = pxa_periodic_irq_set_state, |
| 350 | .irq_set_freq = pxa_periodic_irq_set_freq, | 352 | .irq_set_freq = pxa_periodic_irq_set_freq, |
