Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp3052089ybz; Mon, 27 Apr 2020 09:08:34 -0700 (PDT) X-Google-Smtp-Source: APiQypI9uVvTei4atnIJ52PD+lt547bYXvYM1rgpIvf/vkkJg6xsTGcd9wS8oBQF8kbKKylLLJD+ X-Received: by 2002:a17:906:4cd9:: with SMTP id q25mr20915724ejt.126.1588003714456; Mon, 27 Apr 2020 09:08:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588003714; cv=none; d=google.com; s=arc-20160816; b=d4InpeIyvH8VvFgdskVVSPkNjk5tihv6jBXEJVrkABgaMFmMSpCucyAWjQwMwwMQS/ OCpYa00TTcm9FguEfr1HleRoO/Qlx1+POfw0sgzKmu3qhAPFvDzlhU7zyKfbi+SkXGLf MyQp6jy6snYZO1ztcvZHcshD/8dLNCqqtilJIB1BAU0+GAuB6OFU+yV+sJFVbwb0C/iD Wc+d9rrr5MgTsAb5efAthSNZC8PosGz5/3qxw2co0PtLHZ/DGBz7u/v0snM+ylyN4nzx B6xPaOmp34oDW7+QBvLq7O+BAE7WfYFPdU6CYoQx763krKO9emRULdQE/Pq3hc8LSnrQ mR4w== 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:ironport-sdr:ironport-sdr; bh=goFKLAbNsaYtXQhYZEdXjmqSVwRl4LqLSnuAVtYNLek=; b=hJPSzc0IO1PTjl5MFFVanpQXS+JCe74H+/iokkjgD6AEWOowry+Xf2Y0gucmAJhF1H U0t8DP6bbiu2ooK4rvwmg6BNsTVoKGbbQOcPC+W2L5M9fgYz3By8SeessWRJryXkw5VX R2DsW56Dnv+zA2o2L4PcVNgzz87S6HdFRgHgoFwn10edwhiKtlT8nHwD2qOrkvFBaoeN Wi7dUgDmb1Y2cW5u+oqLE0O/bSicC6srg9A3BeykYWJ7lReFSeZBtu27h3vIsnsQdlyx 9ncnV0nBOAMrWL4N71wIJ7PKdVq6YtAH053AIsy6LAbHZHzbtmUAVqe9WQpI78zfDNzM wA4Q== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q7si11205ejz.377.2020.04.27.09.08.02; Mon, 27 Apr 2020 09:08:34 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728198AbgD0QGX (ORCPT + 99 others); Mon, 27 Apr 2020 12:06:23 -0400 Received: from mga05.intel.com ([192.55.52.43]:8556 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726185AbgD0QGX (ORCPT ); Mon, 27 Apr 2020 12:06:23 -0400 IronPort-SDR: z02/zrHjM/G6rUnKQoMtXt7HhW1CMfB5TQtKNfYYVFcCCzlZmv2c2Mjm+/uFfRC/vWojyvc/v1 lTXCJElIDurg== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 27 Apr 2020 09:06:22 -0700 IronPort-SDR: b01dvZ9KFoBL+qpbsGAzdTYnopKrQZ8+lhXmHHjPNgel+wtCMg/Bin2YPgQbRw4AGbXxJm9p/b QvKU9QwaQRWA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,324,1583222400"; d="scan'208";a="293579355" Received: from xiaoyaol-mobl.ccr.corp.intel.com (HELO [10.249.174.92]) ([10.249.174.92]) by orsmga008.jf.intel.com with ESMTP; 27 Apr 2020 09:06:20 -0700 Subject: Re: [RFC PATCH 1/3] kvm: x86: Rename KVM_DEBUGREG_RELOAD to KVM_DEBUGREG_NEED_RELOAD To: Peter Xu , Paolo Bonzini Cc: Sean Christopherson , kvm@vger.kernel.org, Nadav Amit , Vitaly Kuznetsov , linux-kernel@vger.kernel.org References: <20200416101509.73526-1-xiaoyao.li@intel.com> <20200416101509.73526-2-xiaoyao.li@intel.com> <20200423190941.GN17824@linux.intel.com> <20200424202103.GA48376@xz-x1> <20200427143732.GD48376@xz-x1> From: Xiaoyao Li Message-ID: <3cc6471b-13da-832f-18d8-6db840b5ac47@intel.com> Date: Tue, 28 Apr 2020 00:06:20 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200427143732.GD48376@xz-x1> Content-Type: text/plain; charset=utf-8; format=flowed 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 4/27/2020 10:37 PM, Peter Xu wrote: > On Sat, Apr 25, 2020 at 09:48:17AM +0200, Paolo Bonzini wrote: >> On 24/04/20 22:21, Peter Xu wrote: >>> But then shouldn't DIRTY be set as long as KVM_DEBUGREG_BP_ENABLED is set every >>> time before vmenter? Then it'll somehow go back to switch_db_regs, iiuc... >>> >>> IIUC RELOAD actually wants to say "reload only for this iteration", that's why >>> it's cleared after each reload. So maybe... RELOAD_ONCE? >>> >>> (Btw, do we have debug regs tests somewhere no matter inside guest or with >>> KVM_SET_GUEST_DEBUG?) >> >> What about KVM_DEBUGREG_EFF_DB_DIRTY? > > The problem is iiuc we always reload eff_db[] no matter which bit in > switch_db_regs is set, so this may still not clearly identify this bit from the > rest of the two bits... > > Actually I think eff_db[] is a bit confusing here in that it can be either the > host specified dbreg values or the guest specified depends on the dynamic value > of KVM_GUESTDBG_USE_HW_BP. > > I am thinking maybe it's clearer to have host_db[] and guest_db[], then only > until vmenter do we load either of them by: host_db[] is somewhat misleading, how about user_db[] (just like user_fpu) > if (KVM_GUESTDBG_USE_HW_BP) > load(host_db[]); > else > load(gueet_db[]); > > Then each db[] will be very clear on what's the data is about. And we don't > need to check KVM_GUESTDBG_USE_HW_BP every time when accessing eff_db[]. >