Re: [PATCH linux-2.6 04/04] brsem: convert cpucontrol to brsem

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




 Hello, Nathan & Nick.

Nick Piggin wrote:
Nathan Lynch wrote:

Nick Piggin wrote:


Note that I happen to also think the idea (brsems) have merit, and
that cpucontrol may be one of the places where a sane implementation
would actually be useful... but at least when you're introducing
this kind of complexity anywhere, you *really* need to be able to
back it up with numbers.


The only performance-related complaint with cpu hotplug of which I'm
aware -- that taking a cpu down on a large system can be painfully
slow -- resides in the "write side" of the code, which is not the case
that the brsem implementation optimizes.  I think this patch would
make that case even worse.  So I don't think it's appropriate to use a
brsem for cpu hotplug, especially without trying rwsem first.



Actually, a patch which converts cpucontrol to rwsem was once in -mm. I don't know what happened to it. I can't see it in 2.6.13-rc2-mm1.


I'm not sure that a brsem would make a noticable difference.

It isn't that cpu hotplug semaphore is a performance problem
now, but that it isn't being used in as many cases as it could
be due to its unscalable nature. For example, a while back I
wanted to use it in the fork() path in the scheduler but
couldn't.

I couldn't have put it better. As it currently stands, cpucontrol doesn't have any heavy readers. It's partly because it's not necessary but at least for some part it's because it cannot be used in such cases as the overhead is too big. The same is true for super->s_umount rwsem - read_down'ing per-fs rwsem on every write(2) will hurt performance on SMP machines. I think we'll have more and more of this class of synchronization problems as we add hotplug capability to subsystems.

Having spent a week on implementing something very ugly :-), I'm a bit embarrased here but I still want to point out that we need something to solve this problem.

Anyway, as I said, you need to be able to back it up with
numbers ;)

 Right, gotta benchmark before committing full implementation.

 Thanks.

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

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]
  Powered by Linux