mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
rtc: remove BKL for ioctl()
Remove implicit use of BKL in ioctl() from the RTC framework. Instead, the rtc->ops_lock is used. That's the same lock that already protects the RTC operations when they're issued through the exported rtc_*() calls in drivers/rtc/interface.c ... making this a bugfix, not just a cleanup, since both ioctl calls and set_alarm() need to update IRQ enable flags and that implies a common lock (which RTC drivers as a rule do not provide on their own). A new comment at the declaration of "struct rtc_class_ops" summarizes current locking rules. It's not clear to me that the exceptions listed there should exist ... if not, those are pre-existing problems which can be fixed in a patch that doesn't relate to BKL removal. Signed-off-by: David Brownell <dbrownell@users.sourceforge.net> Cc: Alan Cox <alan@lxorguk.ukuu.org.uk> Cc: Jonathan Corbet <corbet@lwn.net> Acked-by: Alessandro Zummo <a.zummo@towertech.it> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
53f1b1433d
commit
5ad31a5751
2 changed files with 55 additions and 20 deletions
|
@ -115,6 +115,23 @@ extern void rtc_time_to_tm(unsigned long time, struct rtc_time *tm);
|
|||
|
||||
extern struct class *rtc_class;
|
||||
|
||||
/*
|
||||
* For these RTC methods the device parameter is the physical device
|
||||
* on whatever bus holds the hardware (I2C, Platform, SPI, etc), which
|
||||
* was passed to rtc_device_register(). Its driver_data normally holds
|
||||
* device state, including the rtc_device pointer for the RTC.
|
||||
*
|
||||
* Most of these methods are called with rtc_device.ops_lock held,
|
||||
* through the rtc_*(struct rtc_device *, ...) calls.
|
||||
*
|
||||
* The (current) exceptions are mostly filesystem hooks:
|
||||
* - the proc() hook for procfs
|
||||
* - non-ioctl() chardev hooks: open(), release(), read_callback()
|
||||
* - periodic irq calls: irq_set_state(), irq_set_freq()
|
||||
*
|
||||
* REVISIT those periodic irq calls *do* have ops_lock when they're
|
||||
* issued through ioctl() ...
|
||||
*/
|
||||
struct rtc_class_ops {
|
||||
int (*open)(struct device *);
|
||||
void (*release)(struct device *);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue