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
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20091014071428.GA5318@core.coreip.homeip.net>
Date:	Wed, 14 Oct 2009 00:14:28 -0700
From:	Dmitry Torokhov <dmitry.torokhov@...il.com>
To:	Jiri Kosina <jkosina@...e.cz>
Cc:	iceberg <strakh@...ras.ru>, Vojtech Pavlik <vojtech@...e.cz>,
	Linux Kernlel Mailing List <linux-kernel@...r.kernel.org>,
	linux-input@...r.kernel.org
Subject: Re: [BUG] ati_remote2.c: possible mutex_lock without mutex_unlock

On Wed, Oct 14, 2009 at 09:11:06AM +0200, Jiri Kosina wrote:
> On Tue, 13 Oct 2009, Dmitry Torokhov wrote:
> 
> > Umm, I don't like assuming that EAGAIN can only mean that 
> > mutex_lock_interruptible() failed, seq_file core may theoretically 
> > return -EAGAIN too. In fact, looking through seq_file.c traverse() does 
> > return -EAGAIN in certain cases...
> 
> Damn, you are right -- I explicitly checked for this, but have completely 
> overlooked the "Eoveflow:" branch in traverse(), which returns EAGAIN. So 
> my previous patch is of course incorrect.
> 
> > Input: fix locking issue in /proc/bus/input/ handlers
> > 
> > From: Dmitry Torokhov <dmitry.torokhov@...il.com>
> > 
> > input_devices_seq_start() uses mutex_lock_interruptible() to acquire
> > the input_mutex, but doesn't properly handle the situation when the
> > call fails (for example due to interrupt). Instead of returning NULL
> > (which indicates that there is no more data) we should return
> > ERR_PTR()-encoded error.
> > 
> > We also need explicit flag indicating whether input_mutex was acquired
> > since input_devices_seq_stop() is called whether input_devices_seq_start()
> > was successful or not.
> > 
> > The same applies to input_handlers_seq_start().
> > 
> > Reported-by: iceberg <strakh@...ras.ru>
> > Signed-off-by: Dmitry Torokhov <dtor@...l.ru>
> 
> Yup, looks OK to me.
> 

Putting you as "Reviewed-by.." then, OK?

-- 
Dmitry
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ