Re: [PATCH] locking/pvqspinlock: Add lock holder CPU argument to pv_wait()

From: Waiman Long
Date: Wed Apr 13 2016 - 21:59:38 EST


On 04/13/2016 08:21 PM, Peter Zijlstra wrote:
On Wed, Apr 13, 2016 at 04:59:20PM -0400, Waiman Long wrote:
Pan Xinhui was asking for a lock holder cpu argument in pv_wait()
to help the porting of pvqspinlock to PPC. The new argument will can
potentially help hypervisor expediate the execution of the critical
section so that the lock holder vCPU can release the lock sooner.

This patch does just that by storing the previous node vCPU number.
In pv_wait_head_or_lock(), pv_wait() will be called with that vCPU
number as it is likely to be the lock holder. In pv_wait_node(),
-1 will be passed to pv_wait() instead to indicate that it doesn't
know what the current lock holder is.
Without knowing why he needs this, it is very hard to tell if this will
suffice.

Xinhui, what do you need the extra argument for?

I have some other people asking me if pvqspinlock was able to pass in information about which CPU was the lock holder before as he cited the PPC code has this capability to somehow kick up the vCPU that has the lock. That can be potentially useful in x86 too.

Cheers,
Longman