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: <adad44tj090.fsf@cisco.com>
Date:	Sun, 11 Oct 2009 10:42:19 -0700
From:	Roland Dreier <rdreier@...co.com>
To:	Thomas Gleixner <tglx@...utronix.de>
Cc:	LKML <linux-kernel@...r.kernel.org>, linux-rdma@...r.kernel.org,
	Ralph Campbell <infinipath@...gic.com>
Subject: Re: infiniband BKL leftovers

[Adding a few CCs]

 > I'm looking into removing cycle_kernel_lock() from
 > drivers/infiniband/hw/ipath/ipath_file_ops.c .
 > 
 > cycle_kernel_lock() was pushed down into open functions to "emulate"
 > the previous BKL protected semantics by "serializing" the open
 > function against driver init in progress. Nobody knows how effective
 > this "serialization" was in reality. :)
 > 
 > This protection is not necessary when everything what might be needed
 > by write/aio_write/poll/mmap should be in place before
 > ipath_user_add() creates the device node.
 > 
 > But looking at the callsite ipath_init_one() I'm not so sure about that.
 > 
 > At the end of ipath_init_one() I see:
 > 
 >         ipath_device_create_group(&pdev->dev, dd);
 >         ipathfs_add_device(dd);
 >         ipath_user_add(dd);
 >         ipath_diag_add(dd);
 >         ipath_register_ib_device(dd);
 > 
 > ipath_user_add() is called before ipath_register_ib_device() which
 > registers the device with the infiniband core. That makes me wonder
 > whether the device node is really ready to use right after it is
 > created.
 > 
 > Aside of that I noticed that all the functions above have elaborate
 > error pathes, but non of the return values of these functions is ever
 > checked. Intersting approach :)

I guess you guys are getting serious about BKL removal.  I think I made
about as much progress on the ipath driver when the BKL pushdown first
happened: I looked at the code with an eye to getting rid of the BKL and
got too confused and scared to proceed.

I'm not sure what the best way to handle this is; as far as I know the
ipath code is abandoned by Qlogic (they have a new driver that also
supports newer hw that they have not tried to get upstream yet) and BKL
issues aside the code looks racy, eg

	if (atomic_inc_return(&user_count) == 1) {
		ret = user_init();

makes sure that only one thread does user_init() but it doesn't make
sure that user_init() finishes before another thread proceeds.

So I guess if the BKL stuff is blocking you in any way, we can just drop
it from ipath and leave it as yet another race condition in a rotting
old driver.

 - R.
--
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