On Friday 19 August 2016 09:37 AM, David Miller wrote: > From: Pavel Andrianov <andria...@ispras.ru> > Date: Tue, 16 Aug 2016 16:39:06 +0300 > >> smc_reset may be executed in parallel with timer function media_check. >> To avoid data race in smc_set_xcvr a spinlock was added. >> >> Found by Linux Driver Verification project (linuxtesting.org). >> >> Signed-off-by: Pavel Andrianov <andria...@ispras.ru> > > This is not sufficient. > > You have to block basically the entire function, because both > smc_reset and media_check program the bank selection so could > corrupt eachother's register accesses.
Hmm, but then there is a use of udelay as well. Would it be still fine to acquire a spinlock on whole function? > -- Vaishali