Re: infiniband BKL leftovers

From: Roland Dreier
Date: Sun Oct 11 2009 - 13:43:47 EST


[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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/