Thread (15 messages) 15 messages, 3 authors, 2017-08-28

[PATCH v2 2/3] rtc: Add Realtek RTD1295

From: afaerber@suse.de (Andreas Färber)
Date: 2017-08-27 02:30:13
Also in: linux-rtc, lkml

Am 27.08.2017 um 04:05 schrieb Andrew Lunn:
n Sun, Aug 27, 2017 at 02:33:27AM +0200, Andreas F?rber wrote:
quoted
+struct rtd119x_rtc {
+	void __iomem *base;
+	struct clk *clk;
+	struct rtc_device *rtcdev;
+	unsigned base_year;
+	spinlock_t lock;
Where is this lock initialised? I would expect a call to
spin_lock_init() somewhere.
Hm, the spinlock in my irq mux series doesn't have that call either; my
reset driver did have it. The zero initialization appears to work OK,
but you're probably right that it should be there.
I also wonder what this lock is protecting, which rtc->ops_lock does
not protect?
By that same argument we could ask why so many drivers (and mine, too)
are calling rtc_valid_tm() when __rtc_read_time() calls it again...

The downstream code is locking inside individual functions such as
check_acr or set_enabled; I adopted it for whole operations only, but
you're right that so far it matches the RTC class ops granularity, so I
can drop it again. The latching discussion had reminded me of locking.

Cheers,
Andreas

-- 
SUSE Linux GmbH, Maxfeldstr. 5, 90409 N?rnberg, Germany
GF: Felix Imend?rffer, Jane Smithard, Graham Norton
HRB 21284 (AG N?rnberg)
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help