From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Wed, 06 Jul 2016 12:58:11 +0800 From: xinhui MIME-Version: 1.0 Subject: Re: [PATCH v2 2/4] powerpc/spinlock: support vcpu preempted check References: <1467124991-13164-1-git-send-email-xinhui.pan@linux.vnet.ibm.com> <1467124991-13164-3-git-send-email-xinhui.pan@linux.vnet.ibm.com> In-Reply-To: Content-Type: text/plain; charset="utf-8"; format="flowed" Message-Id: <577C8FE3.3010208@linux.vnet.ibm.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , List-Archive: To: Wanpeng Li Cc: "linux-kernel@vger.kernel.org" , linuxppc-dev@lists.ozlabs.org, virtualization@lists.linux-foundation.org, linux-s390 , Peter Zijlstra , Ingo Molnar , mpe@ellerman.id.au, Paul Mackerras , benh@kernel.crashing.org, Paul McKenney , Waiman Long , will.deacon@arm.com, boqun.feng@gmail.com, Davidlohr Bueso , schwidefsky@de.ibm.com List-ID: Content-Transfer-Encoding: 8bit Hi, wanpeng On 2016年07月05日 17:57, Wanpeng Li wrote: > Hi Xinhui, > 2016-06-28 22:43 GMT+08:00 Pan Xinhui : >> This is to fix some lock holder preemption issues. Some other locks >> implementation do a spin loop before acquiring the lock itself. Currently >> kernel has an interface of bool vcpu_is_preempted(int cpu). It take the cpu >> as parameter and return true if the cpu is preempted. Then kernel can break >> the spin loops upon on the retval of vcpu_is_preempted. >> >> As kernel has used this interface, So lets support it. >> >> Only pSeries need supoort it. And the fact is powerNV are built into same >> kernel image with pSeries. So we need return false if we are runnig as >> powerNV. The another fact is that lppaca->yiled_count keeps zero on >> powerNV. So we can just skip the machine type. > > Lock holder vCPU preemption can be detected by hardware pSeries or > paravirt method? > There is one shard struct between kernel and powerVM/KVM. And we read the yield_count of this struct to detect if one vcpu is running or not. SO it's easy for ppc to implement such interface. Note that yield_count is set by powerVM/KVM. and only pSeries can run a guest for now. :) I also review x86 related code, looks like we need add one hyer-call to get such vcpu preemption info? thanks xinui > Regards, > Wanpeng Li >