Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp6448482pxv; Thu, 29 Jul 2021 15:10:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwYoYCcqzBjCeKEphdB5a7o9V8WFKch2T8xlcaN51oPRtOcw59+4tDVj3wuXqtwmDtxN+WN X-Received: by 2002:a6b:b2d7:: with SMTP id b206mr5870886iof.155.1627596630796; Thu, 29 Jul 2021 15:10:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627596630; cv=none; d=google.com; s=arc-20160816; b=XOoIXWoVdG6XZW07e1ZmmYNTDwHEjpp4k2RBeFMzYFbibj5u1w2SX07rtHQCpqM/68 1381DoIH60GzG5B8c3iaWtH+HYgnjSfT6Egq0rXAcYYQH9eboGYoY3QnSlxuTCrhXNSr D7JMnzaAkLqCDoZbC18tQ6y8sHrIl5Lz+mjUE0ZmC8z0aE2795cAjqzNDEqGs40wYeBv 7xXXuDSs37sweIwiXBmpbbyxf/vvaBxOwjV+gLISkOonkyig3ntkjkLzrEacjp2J4Gk1 mbR8Y1ECooDLDVeO8Vxg3EgUqL239eyioY0CuWaSBEtz9ythQGgjrVsg6vhcZr2zj4Rc roJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=quVRBmXT16c8/+OvPaemt4sih+vYkJfmbVpHJfXSYSE=; b=mHi6tR486u2cNkknC42Lr5YshbKA+eDkdxhdY74gY/ldoGvH4xsNLGTlYKy8Tyk7kC O2FbphBWYjwBWF8NfXTiot0sHTPBJj3WV6jP9zo2XgxJvsHfGwLCO9o8X1KDdus74nEl bVl6fxuQD/gJnzxR/eENMHEwY+OmFlVV2ZOgwX67JvDnbxvAsAILnnXqpej9ykwgQ/ef v/FUVYi/aCwe+ljeTHqaQ6BJXBCO1CavYsiTx6RyKcd9VLhfU4Kf0kDoOZwAEPpSx28d OVPOUUpnhx1fsFUI29BxgcJKsecsOHx5KEL99j38ULRURe26Xj/GoKQcNC9zsVPH+Gi3 81pw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=ugW9I6GN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r4si4187321ioh.93.2021.07.29.15.10.18; Thu, 29 Jul 2021 15:10:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=ugW9I6GN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234510AbhG2WJh (ORCPT + 99 others); Thu, 29 Jul 2021 18:09:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60028 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234299AbhG2WJa (ORCPT ); Thu, 29 Jul 2021 18:09:30 -0400 Received: from mail-oo1-xc49.google.com (mail-oo1-xc49.google.com [IPv6:2607:f8b0:4864:20::c49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 18B6EC0613C1 for ; Thu, 29 Jul 2021 15:09:27 -0700 (PDT) Received: by mail-oo1-xc49.google.com with SMTP id b7-20020a0568200247b02902691c6a5defso3093095ooe.15 for ; Thu, 29 Jul 2021 15:09:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=quVRBmXT16c8/+OvPaemt4sih+vYkJfmbVpHJfXSYSE=; b=ugW9I6GN7pWL34ADNzvmolXeBcl8BcWkp42bUMTI1HufksQY7hkq6QIre1ssegbcDK 1HingL2dULatPpmnK4uTzlDTe5eHq4aIvslbmDd+0FZDk9o/YhXmqlRUHTKClJqtjIRx lO9lAb7lc0X/0//6WYsoJanHg5bq1N/NKju+D9SXdR0TnkG7bI2ZtwBRiaEWf6bOkRAb 98/5vkebBq7V5Nz4THlbYao4dA+pzlZ/gHl/QwtbvjtosU+04rXIX/8S9Log9/7k7tkG h+Dzno/lXwqxLsTSydVwT48EpccvW4FnKhbvPPd1heziD9Z5v6dkZjVLzssvROFfgMNZ 1Y1Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=quVRBmXT16c8/+OvPaemt4sih+vYkJfmbVpHJfXSYSE=; b=kYW2WyR8FJV9wuEgVjyyRTw1qpCIIxdBlNs4q4llFN8akDMQ1xf2tDh2KraCSC+P8k 2TVo6Hd5Iacmp7S5fgqMVIsOTbHOgnRyIQYqNhCP/QYvKc14CtLcp+McJ/P9NRYGPGF9 a5twAUDNpeC6fGQ/YePmHR3bGa/qqB8265DqnEWURA+CIoPw+TWhb63FAy2vvpcaJL2s GMkffOQ/w15aCDGdqx1i5Iwu+7wtXKoOUkQNjlPga0DeeB201bgbLxq1mbJM4R8B/CTG MTkiHTl4iGcjeMasNfy2BIJ2WG2OY5TmWQZkpxMoFEY3tl7mJOuxNMQDdXFbm8LMc7uR I3gg== X-Gm-Message-State: AOAM532wcVDxIq7+1wvr/FaoM5YGRYQXHDTKaU8P6bkVpRWc9pK084ay WRmPWazqLz5jFnKgHNvvYIDXKJfZs+g= X-Received: from oupton.c.googlers.com ([fda3:e722:ac3:cc00:2b:ff92:c0a8:404]) (user=oupton job=sendgmr) by 2002:aca:bf84:: with SMTP id p126mr4508603oif.154.1627596566328; Thu, 29 Jul 2021 15:09:26 -0700 (PDT) Date: Thu, 29 Jul 2021 22:09:14 +0000 In-Reply-To: <20210729220916.1672875-1-oupton@google.com> Message-Id: <20210729220916.1672875-2-oupton@google.com> Mime-Version: 1.0 References: <20210729220916.1672875-1-oupton@google.com> X-Mailer: git-send-email 2.32.0.554.ge1b32706d8-goog Subject: [PATCH v2 1/3] KVM: arm64: Record number of signal exits as a vCPU stat From: Oliver Upton To: kvmarm@lists.cs.columbia.edu Cc: kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Paolo Bonzini , Marc Zyngier , James Morse , Alexandru Elisei , Suzuki K Poulose , Catalin Marinas , Will Deacon , Thomas Gleixner , Peter Zijlstra , Andy Lutomirski , linux-arm-kernel@lists.infradead.org, Peter Shier , Shakeel Butt , Guangyu Shi , Oliver Upton , Jing Zhang Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Most other architectures that implement KVM record a statistic indicating the number of times a vCPU has exited due to a pending signal. Add support for that stat to arm64. Reviewed-by: Jing Zhang Signed-off-by: Oliver Upton --- arch/arm64/include/asm/kvm_host.h | 1 + arch/arm64/kvm/arm.c | 1 + arch/arm64/kvm/guest.c | 1 + 3 files changed, 3 insertions(+) diff --git a/arch/arm64/include/asm/kvm_host.h b/arch/arm64/include/asm/kvm_host.h index 41911585ae0c..70e129f2b574 100644 --- a/arch/arm64/include/asm/kvm_host.h +++ b/arch/arm64/include/asm/kvm_host.h @@ -576,6 +576,7 @@ struct kvm_vcpu_stat { u64 wfi_exit_stat; u64 mmio_exit_user; u64 mmio_exit_kernel; + u64 signal_exits; u64 exits; }; diff --git a/arch/arm64/kvm/arm.c b/arch/arm64/kvm/arm.c index e9a2b8f27792..60d0a546d7fd 100644 --- a/arch/arm64/kvm/arm.c +++ b/arch/arm64/kvm/arm.c @@ -783,6 +783,7 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu) if (signal_pending(current)) { ret = -EINTR; run->exit_reason = KVM_EXIT_INTR; + ++vcpu->stat.signal_exits; } /* diff --git a/arch/arm64/kvm/guest.c b/arch/arm64/kvm/guest.c index 1dfb83578277..853d1e8d2e73 100644 --- a/arch/arm64/kvm/guest.c +++ b/arch/arm64/kvm/guest.c @@ -50,6 +50,7 @@ const struct _kvm_stats_desc kvm_vcpu_stats_desc[] = { STATS_DESC_COUNTER(VCPU, wfi_exit_stat), STATS_DESC_COUNTER(VCPU, mmio_exit_user), STATS_DESC_COUNTER(VCPU, mmio_exit_kernel), + STATS_DESC_COUNTER(VCPU, signal_exits), STATS_DESC_COUNTER(VCPU, exits) }; static_assert(ARRAY_SIZE(kvm_vcpu_stats_desc) == -- 2.32.0.554.ge1b32706d8-goog