Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp2020506ybi; Thu, 18 Jul 2019 02:07:48 -0700 (PDT) X-Google-Smtp-Source: APXvYqy5m3z9jehHWH2SDQuqIhuJB+P9EqwNkGYOCwuQXgdPZPzrDGimkGZxzw76LFd8v/6KvX/E X-Received: by 2002:a65:5cca:: with SMTP id b10mr47569364pgt.365.1563440868495; Thu, 18 Jul 2019 02:07:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563440868; cv=none; d=google.com; s=arc-20160816; b=K7jCAGRVhgyHmr3XWnrxlpzgHgl5U98ahmzIFJzpKbGHdFTLLmfshnrWVOmP/Ls3m6 tGZITC9TRb47sCnZUKHyUXlB/KDZxAhEv8n8Nrevw7EKSyMHLm53AuGriGk7/sSGkrVl qxAYosgYcu57SxK3wmiF8+PRebupIyox1WTZg9LQQYduMvquECF6qba6i2Yr90OjBl2j EfrhyCY+QX+y0d91eQlM8SdCvnaG2kkaKr9IjE7Xf9sUA8dKAcgj64pKNhei4YpCRt8h 2hVN3iSW3URMhXSAoYTTUW2QR2uKckyRdFd2zcjhB3RDInd3sTj5ZdsLP7NCWyvYc7Qx exug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:openpgp:from:references:cc:to:subject; bh=o9/78Nh53njXX6v0c2aPrfA34ngPUQ0RdFKx5mOyEAk=; b=gLmB4Tj9vg5ztGEgAluZqbo1cnBNZeznvefzQRQ7/2sAC38xIUXCy3qLUPN2guGnxk 4gT88r2T2hl14qWO4Nb/Jn4oqLm9ddzSSe1DN777V8hDj+1TTVFgM6x8iUKMd+AIJ3pb HTkwcg2aVaTxHWbb4luLakV+YANVZXRbyApbvfgpakLaSmKFWuyR27wqMsFlVNtP6Yop 0Q3txS8/7pHZTOxGWsVROwkr5Rv5ZbPEe+ICVGOQYekgCMwgajWvx6don/B903RxW+yR Q0vq+SfsRb+qRUfJ8dphmdFw2uoS48ytAhvFQZ8u3P3XlyFWIHgYfqTKbormSsi78UI3 oU7Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k22si1078111pfk.90.2019.07.18.02.07.31; Thu, 18 Jul 2019 02:07:48 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389638AbfGRJHH (ORCPT + 99 others); Thu, 18 Jul 2019 05:07:07 -0400 Received: from mail-wr1-f67.google.com ([209.85.221.67]:45802 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389453AbfGRJHH (ORCPT ); Thu, 18 Jul 2019 05:07:07 -0400 Received: by mail-wr1-f67.google.com with SMTP id f9so27766580wre.12 for ; Thu, 18 Jul 2019 02:07:06 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:openpgp:message-id :date:user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=o9/78Nh53njXX6v0c2aPrfA34ngPUQ0RdFKx5mOyEAk=; b=N81zupP+HqVgSu0MHuGlLIYQ+w+fw1v0p0/+LCQi2iibrGfZ5d5Dg9s1m5M0kcC96s E72TbhrHvBkzYKhxD4HTEa2q3o3bGiPXUeOjsCFBtK3VLyKQU/2F956ZNuwdZ/FXllaw p3ofULqlvnrkKiCeEQ0+8N/BPXdy8Or7hKgKejN0Uo9boAml4oNs/z3QZ+EGM5YgocO9 SP5KD3ZAWoVFjOrkfTVn+YS4SOFcfQLhUJvk3BVn3emX+pUI2FpiNGWCkJrvXUNShaUk w/B1Bmc1KBzejI96T06aquFEs3f6cOeUoJtGx+afMArgxBTEL+kCpz8zUj54b19VAwfP RcZQ== X-Gm-Message-State: APjAAAV9x84Q2Ip19mpvN6JA+iT9jtU9+qePJgqjdoLvNHoEVYHtCSjk pHDVd00UIK5wsAj62o10imSZwQ== X-Received: by 2002:adf:db50:: with SMTP id f16mr35132159wrj.214.1563440825128; Thu, 18 Jul 2019 02:07:05 -0700 (PDT) Received: from ?IPv6:2001:b07:6468:f312:e427:3beb:1110:dda2? ([2001:b07:6468:f312:e427:3beb:1110:dda2]) by smtp.gmail.com with ESMTPSA id y6sm20665974wrp.12.2019.07.18.02.07.04 (version=TLS1_3 cipher=AEAD-AES128-GCM-SHA256 bits=128/128); Thu, 18 Jul 2019 02:07:04 -0700 (PDT) Subject: Re: [PATCH RESEND] KVM: Boosting vCPUs that are delivering interrupts To: Wanpeng Li Cc: Christian Borntraeger , LKML , kvm , =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= References: <1562915730-9490-1-git-send-email-wanpengli@tencent.com> From: Paolo Bonzini Openpgp: preference=signencrypt Message-ID: Date: Thu, 18 Jul 2019 11:07:03 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.2 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 18/07/19 10:43, Wanpeng Li wrote: >>> Isnt that done by the sched_in handler? >> >> I am a bit confused because, if it is done by the sched_in later, I >> don't understand why the sched_out handler hasn't set vcpu->preempted >> already. >> >> The s390 commit message is not very clear, but it talks about "a former >> sleeping cpu" that "gave up the cpu voluntarily". Does "voluntarily" >> that mean it is in kvm_vcpu_block? But then at least for x86 it would > > see the prepare_to_swait_exlusive() in kvm_vcpu_block(), the task will > be set in TASK_INTERRUPTIBLE state, kvm_sched_out will set > vcpu->preempted to true iff current->state == TASK_RUNNING. Ok, I was totally blind to that "if" around vcpu->preempted = true, it's obvious now. I think we need two flags then, for example vcpu->preempted and vcpu->ready: - kvm_sched_out sets both of them to true iff current->state == TASK_RUNNING - kvm_vcpu_kick sets vcpu->ready to true - kvm_sched_in clears both of them This way, vmx_vcpu_pi_load can keep looking at preempted only (it handles voluntary preemption in pi_pre_block/pi_post_block). Also, kvm_s390_vcpu_wakeup can be changed to use kvm_vcpu_wake_up, which is nice. Paolo