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: <20100427092530.GD11348@elte.hu>
Date:	Tue, 27 Apr 2010 11:25:30 +0200
From:	Ingo Molnar <mingo@...e.hu>
To:	Arnd Bergmann <arnd@...db.de>
Cc:	Frederic Weisbecker <fweisbec@...il.com>,
	Linus Torvalds <torvalds@...ux-foundation.org>,
	LKML <linux-kernel@...r.kernel.org>,
	Thomas Gleixner <tglx@...utronix.de>,
	Al Viro <viro@...iv.linux.org.uk>,
	Jan Blunck <jblunck@...e.de>, John Kacur <jkacur@...hat.com>
Subject: Re: [GIT PULL v2] Preparation for BKL'ed ioctl removal


* Arnd Bergmann <arnd@...db.de> wrote:

> On Monday 26 April 2010, Ingo Molnar wrote:
> > This could be done all automated for a hundred old drivers if need to be. 
> > There would be no bkl_ioctl's left.
> 
> I don't think it can be fully automated. [...]

Corner cases are not a problem as long as the risk of them going unnoticed is 
lower than the risk of a manual conversion introducing bugs.

> [...] For the majority of the modules, your approach would work fine, but 
> there are still the well-known pitfalls in corner cases:
> 
> - recursive uses in functions outside of ioctl (possibly none left
>   after the TTY layer is done, but who knows)

Not a problem even if there's any such usage left: lockdep will sort those out 
very quickly.

> - lock-order problems with other mutexes (see DRM)

This too will be mapped out very quickly via lockdep.

> - code that depends on autorelease to allow one ioctl while another
>   is sleeping. (a small number of drivers)

This is a real issue, and in fact it's an unknown: there may be an unknown 
number of random sleep points within BKL codepaths that is being relied on in 
creative ways.

Note that by introducing a mutex we (in most cases) make the locking 
_stricter_, so the biggest risk from that is a lockup - which will be 
debuggable via lockdep.

	Ingo
--
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