forked from luck/tmp_suning_uos_patched
rtc: Remove BKL from efirtc
BKL locking came to efirtc via the big BKL push down, but the access to the efi functions is protected by efi_rtc_lock already. Remove it. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> LKML-Reference: <20091010153350.046644063@linutronix.de>
This commit is contained in:
parent
d2d2355985
commit
a5ee6dc9eb
@ -27,8 +27,6 @@
|
||||
* - Add module support
|
||||
*/
|
||||
|
||||
|
||||
#include <linux/smp_lock.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/errno.h>
|
||||
#include <linux/miscdevice.h>
|
||||
@ -174,13 +172,12 @@ static long efi_rtc_ioctl(struct file *file, unsigned int cmd,
|
||||
return -EINVAL;
|
||||
|
||||
case RTC_RD_TIME:
|
||||
lock_kernel();
|
||||
spin_lock_irqsave(&efi_rtc_lock, flags);
|
||||
|
||||
status = efi.get_time(&eft, &cap);
|
||||
|
||||
spin_unlock_irqrestore(&efi_rtc_lock,flags);
|
||||
unlock_kernel();
|
||||
|
||||
if (status != EFI_SUCCESS) {
|
||||
/* should never happen */
|
||||
printk(KERN_ERR "efitime: can't read time\n");
|
||||
@ -202,13 +199,11 @@ static long efi_rtc_ioctl(struct file *file, unsigned int cmd,
|
||||
|
||||
convert_to_efi_time(&wtime, &eft);
|
||||
|
||||
lock_kernel();
|
||||
spin_lock_irqsave(&efi_rtc_lock, flags);
|
||||
|
||||
status = efi.set_time(&eft);
|
||||
|
||||
spin_unlock_irqrestore(&efi_rtc_lock,flags);
|
||||
unlock_kernel();
|
||||
|
||||
return status == EFI_SUCCESS ? 0 : -EINVAL;
|
||||
|
||||
@ -224,7 +219,6 @@ static long efi_rtc_ioctl(struct file *file, unsigned int cmd,
|
||||
|
||||
convert_to_efi_time(&wtime, &eft);
|
||||
|
||||
lock_kernel();
|
||||
spin_lock_irqsave(&efi_rtc_lock, flags);
|
||||
/*
|
||||
* XXX Fixme:
|
||||
@ -235,19 +229,16 @@ static long efi_rtc_ioctl(struct file *file, unsigned int cmd,
|
||||
status = efi.set_wakeup_time((efi_bool_t)enabled, &eft);
|
||||
|
||||
spin_unlock_irqrestore(&efi_rtc_lock,flags);
|
||||
unlock_kernel();
|
||||
|
||||
return status == EFI_SUCCESS ? 0 : -EINVAL;
|
||||
|
||||
case RTC_WKALM_RD:
|
||||
|
||||
lock_kernel();
|
||||
spin_lock_irqsave(&efi_rtc_lock, flags);
|
||||
|
||||
status = efi.get_wakeup_time((efi_bool_t *)&enabled, (efi_bool_t *)&pending, &eft);
|
||||
|
||||
spin_unlock_irqrestore(&efi_rtc_lock,flags);
|
||||
unlock_kernel();
|
||||
|
||||
if (status != EFI_SUCCESS) return -EINVAL;
|
||||
|
||||
@ -277,7 +268,6 @@ static int efi_rtc_open(struct inode *inode, struct file *file)
|
||||
* We do accept multiple open files at the same time as we
|
||||
* synchronize on the per call operation.
|
||||
*/
|
||||
cycle_kernel_lock();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user