Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp6724033ybi; Wed, 5 Jun 2019 05:33:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqzCUu8tT9okS33kwdr2sc6s3YB9I/zKuNh84U0uJyM8CHlAU3U2zqNKNYa7CSxOXOjqCkZu X-Received: by 2002:a17:902:b110:: with SMTP id q16mr35385611plr.218.1559737983723; Wed, 05 Jun 2019 05:33:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559737983; cv=none; d=google.com; s=arc-20160816; b=yUkcpfMD8kxNHjG88yXgxAirN77Lxoi3KkcdO8/n3WvQq2Ds5gQU5mn2v2Ug6/ISPc S55l43WO7uD5OOm1yQg10rT9szdoKc1GrJbRJu+AL0+ClBFzAkycjMf23GoYhBYS2jjI nC9ahNt6V7F3rMyAMWKvtt1fhPNK/t73RBCFQwByrX8aFgbxJBBgB7Vj3GvCava4Ck58 rfZzARl8vJsv+Ypri1VCSvZFF+hzn0sVl3vk1+fVRICIAa/BRzO+9nwFjSZUaoPnmw2/ RFq7jUGyCZtKiFanoEO28cggVdYjE2kR3ei1wEwin0fXwVuF9GZmo9aYLs+0AUaMmTjF 4Ohw== 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:from:references:cc:to:subject; bh=LbP+4Vhj30bq0+PmaAtLxhYGOHZkRbouhUMM/rlGAio=; b=QCMucJiA9O74tMVdX0VwUDuA2reI1sVE5ssf43nx0LK5T3i0wYe7LEcFZiJmFrCSXW WYbWgxkmQYI9WG6crZdacnQb4CIKRZl1VSUOhIOKg28o/lGVvc3RKqzNT/UF0LEqk7W1 RWZoXKTMn7+TDqKHOcmLiuRh7yHAd5bTnNnfOkx2l2P/s449qvksdZ+bQaRSE/86BUub /b93DfmP7gRb7IcK0vjmMOnRvbfqnv8ag5qoEv55pGnx7JZKIutemgUMHP0pEOe0DjCW ZaeQrNVrCH4AvH/IWFT7W1NMqfvD2cCtaZAaxVs7kJpFKNDXuL3ve1aMaSdXBXXZMFpF ah4A== 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 n28si4297786pgl.23.2019.06.05.05.32.44; Wed, 05 Jun 2019 05:33:03 -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 S1727705AbfFEMay (ORCPT + 99 others); Wed, 5 Jun 2019 08:30:54 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:41893 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727273AbfFEMay (ORCPT ); Wed, 5 Jun 2019 08:30:54 -0400 Received: by mail-wr1-f66.google.com with SMTP id c2so19283587wrm.8 for ; Wed, 05 Jun 2019 05:30:53 -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:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=LbP+4Vhj30bq0+PmaAtLxhYGOHZkRbouhUMM/rlGAio=; b=NSSYdLPc2VNUD7/+/Nc7sL1uD4BtfPNOdogzKmKEpKHJ01lJ3MX+yu9ploDrbJhsCg VUUUGBh+7CT9TLnD76Pfcq6cN2vZcDzoUFEqzY/gYE6QM2IqNjIdCXrt5oHQbWmoPVZn pNF2nzSpX1KxhuclCEOZGOxco3ONirkGpf8a7l7oHJLgIkRfURnjU6wTEdzntpLRsEtH 4YhiZ88yvbILNFNSV6v6s2pNN9DXkG7sLg0aV7EyYH9l7986kHzKlVlTUzdKsDOUvekm nQsF4SJmvzkCjX3zcNWsWTCaqbiks8I3Ah/JypCaoEPqwasIPdqVi8dfk8sCEcgdoRdr 7+rg== X-Gm-Message-State: APjAAAV73/uuj8CBjSiB7ObUmKCo5VGqG+J70PuD0i87/OUKpsUtLjj7 LkZzt8toJXcjlzdCPQCu6WUnbGqIDJ4= X-Received: by 2002:adf:a18a:: with SMTP id u10mr2661650wru.351.1559737853018; Wed, 05 Jun 2019 05:30:53 -0700 (PDT) Received: from ?IPv6:2001:b07:6468:f312:657f:501:149f:5617? ([2001:b07:6468:f312:657f:501:149f:5617]) by smtp.gmail.com with ESMTPSA id j15sm10149112wrn.50.2019.06.05.05.30.52 (version=TLS1_3 cipher=AEAD-AES128-GCM-SHA256 bits=128/128); Wed, 05 Jun 2019 05:30:52 -0700 (PDT) Subject: Re: [PATCH 2/3] KVM: LAPIC: lapic timer is injected by posted interrupt To: Wanpeng Li , linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= References: <1559729351-20244-1-git-send-email-wanpengli@tencent.com> <1559729351-20244-3-git-send-email-wanpengli@tencent.com> From: Paolo Bonzini Message-ID: <16c54182-7198-f476-080b-5876cd871e42@redhat.com> Date: Wed, 5 Jun 2019 14:30:51 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <1559729351-20244-3-git-send-email-wanpengli@tencent.com> 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 05/06/19 12:09, Wanpeng Li wrote: > +static void apic_timer_expired_pi(struct kvm_lapic *apic) > +{ > + struct kvm_timer *ktimer = &apic->lapic_timer; > + > + kvm_apic_local_deliver(apic, APIC_LVTT); > + if (apic_lvtt_tscdeadline(apic)) > + ktimer->tscdeadline = 0; > + if (apic_lvtt_oneshot(apic)) { > + ktimer->tscdeadline = 0; > + ktimer->target_expiration = 0; > + } > +} Please rename this function to kvm_apic_inject_pending_timer_irqs and call it from kvm_inject_apic_timer_irqs. Then apic_timer_expired can just do if (atomic_read(&apic->lapic_timer.pending)) return; + if (unlikely(posted_interrupt_inject_timer(apic->vcpu))) { + kvm_apic_inject_pending_timer_irqs(apic); + return; + } etc. Paolo