On Fri, Feb 13, 2009 at 09:51:22PM -0800, Arve Hjønnevåg wrote: > On Fri, Feb 13, 2009 at 5:49 PM, Matthew Garrett <mjg59@xxxxxxxxxxxxx> wrote: > > Like I suggested before, just multiplex them through a single daemon in > > userspace. That lets you tie your policy into your platform specifics. > > You get to do things like keep the lock until whatever process restarts > > dead system components indicates that your input process is running > > again, for instance. > > OK, so you want a single daemon in userspace (init?) to handle process > restarting and wakelocks. That would be one way of doing it, but it would also be fine to have some sort of IPC between multiple daemons. > > The retry doesn't have to be immediate. Yes, this is something of a > > hypocritical argument given everything else I've had to say about > > timeouts, but working out why a driver's preventing a suspend is > > probably a Hard Problem. I don't think this single case is enough to add > > it to the entire API. > > It is not a single case. Having wakelocks with timeout support makes > it trivial to work around the problem. You're not describing these cases. So far we've got "We need timeouts because we haven't added locking everywhere that it's needed in the kernel" and "We need timeouts because we want to poll in the case of a failed suspend". I don't think these are convincing reasons - the first should be fixed before merging the code and the second is a hack to begin with. Getting -EBUSY and then setting a wakelock with a timeout to trigger a resuspend would be more cleanly implemented by scheduling a timeout to re-trigger the attempt. > > Remember that for things like IDE we probably need to have locks in the > > fast path. An atomic_inc is a lot cheaper than a spinlock protected > > list_add. > > The slow path for spinlocks and atomic operations are about the same. > On an smp arm v6 we have: On x86 an uncontended spin_lock()/spin_unlock() cycle appears to be an order of magnitude slower than an atomic_inc. How much this matters probably depends on how frequently you think these locks will be taken and what the probability of them being contended is. -- Matthew Garrett | mjg59@xxxxxxxxxxxxx _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm