lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Thu, 18 Feb 2016 17:00:31 +0900 From: Byungchul Park <byungchul.park@....com> To: Ingo Molnar <mingo@...nel.org> Cc: willy@...ux.intel.com, akpm@...ux-foundation.org, linux-kernel@...r.kernel.org, akinobu.mita@...il.com, jack@...e.cz, sergey.senozhatsky.work@...il.com, peter@...leysoftware.com Subject: Re: [PATCH v3] lock/semaphore: Avoid an unnecessary deadlock within up() On Wed, Feb 17, 2016 at 10:28:29AM +0100, Ingo Molnar wrote: > > * Byungchul Park <byungchul.park@....com> wrote: > > > diff --git a/kernel/locking/semaphore.c b/kernel/locking/semaphore.c > > index b8120ab..6634b68 100644 > > --- a/kernel/locking/semaphore.c > > +++ b/kernel/locking/semaphore.c > > @@ -130,13 +130,14 @@ EXPORT_SYMBOL(down_killable); > > int down_trylock(struct semaphore *sem) > > { > > unsigned long flags; > > - int count; > > + int count = -1; > > > > - raw_spin_lock_irqsave(&sem->lock, flags); > > - count = sem->count - 1; > > - if (likely(count >= 0)) > > - sem->count = count; > > - raw_spin_unlock_irqrestore(&sem->lock, flags); > > + if (raw_spin_trylock_irqsave(&sem->lock, flags)) { > > + count = sem->count - 1; > > + if (likely(count >= 0)) > > + sem->count = count; > > + raw_spin_unlock_irqrestore(&sem->lock, flags); > > + } > > I still don't really like it: two parallel trylocks will cause one of them to fail > - while with the previous code they would both succeed. > > None of these changes are necessary with all the printk robustification > changes/enhancements we talked about, right? Right. I expect that Jan's patch which Sergey informed can make printk robuster. Actually I'm waiting for the patch done. And I thought that it's also a problem that a trylock implementation can make a system deadlock. Don't you think it need to make a trylock only either acquire or fail in any case? IMHO, waiting something within trylock is wrong. I'm just curious. Thanks, Byungchul > > Thanks, > > Ingo
Powered by blists - more mailing lists