Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp5810220ybf; Thu, 5 Mar 2020 07:26:16 -0800 (PST) X-Google-Smtp-Source: ADFU+vv59UkZQirikJKL18K9ZSeO8hOBaoOS3YTdOXJpoIlKekqgadRPqvfGEluXTfz0ARTNf6D7 X-Received: by 2002:a9d:69cd:: with SMTP id v13mr563826oto.134.1583421976470; Thu, 05 Mar 2020 07:26:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583421976; cv=none; d=google.com; s=arc-20160816; b=TEf8DiBunE8V6DqwallRqvp1lK9M7sj5JneofCA+abr8CGWCygaml9GhXdoJtDIBri 6XAOcmF623q8eq7S0DUq28H++9fcCrEjLWF4k60CIB8Rfp0N/EzmiBA74ttw4srdOLn6 EMYuqJGrtVBqQ3J1369OWSS6DQscU9l0LExYXKZzU6AGoBSkLpy6OUcw/1aTkHGF1E7W NgH3Rq+R3O3aGWjr8uDtZPzYXtkbjqg/6+Hb4PPMzr9mHN7M4Og5AJpF7C8bQE93d2A4 dkfF/2AmrwdzlEHApGje8S0Pbh0cNAJQAkpNioig5wCo/SVhMtqg625/m8GniRONoRuP hAqw== 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:dkim-signature; bh=vy5/EiEAp0wCHefyZwq4zlhiKyPciLoRoXRp/gwmNyU=; b=UNQ9X8B04r9496csoilikhLRYlkiPUvBpT0FH1SCz6Gfv9/Tp+ktigbXWDwVqA8xOb n1t3HHXKW5wMzUeOTBem2LzNnwTW9mm/DavWxvW7neflnh+083nmUgnUfUUfBFqKYpN7 XVbBBd1XSbz2Upburs/0LyBrGy4zTJ3jZlKRBcP8sB4BtsXHVYaYQxw9y5pLMUGqqxwn r2Io1qBlBm2IJ3g5LzsUA2ZUhNgSfu1DuSaNCoWHTHq+C0NK9q8EwSEZcnYqXim6g8XP mx43ETlAv/UEZl58Z5CDgsMMqVl7LiNYNsVq97YjBbZXV2fEI3tuBnJtyrg5v85e4glW 1V5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=EoSBPE60; 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=pass (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 c6si733709otk.233.2020.03.05.07.26.04; Thu, 05 Mar 2020 07:26:16 -0800 (PST) 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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=EoSBPE60; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726282AbgCEPZf (ORCPT + 99 others); Thu, 5 Mar 2020 10:25:35 -0500 Received: from us-smtp-delivery-1.mimecast.com ([205.139.110.120]:29221 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726007AbgCEPZf (ORCPT ); Thu, 5 Mar 2020 10:25:35 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1583421934; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=vy5/EiEAp0wCHefyZwq4zlhiKyPciLoRoXRp/gwmNyU=; b=EoSBPE60EHTHhlER1CGVK2DyLC+5cIWigUvnFwr4a+73FCaXge0jw5rYZT28O/4EUQVMJp eFtGq0urvyKvHHHPuojHxLpBHpr+sEeNjf0PyNKRQNogPrjzc+G+OqokK7lMBgL2yNAGTG Yd4H5Arg3IFMvGVI1WHT2Ih41DvY078= Received: from mail-wr1-f72.google.com (mail-wr1-f72.google.com [209.85.221.72]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-82-spDHu0AFOxyaJm-nauE8SQ-1; Thu, 05 Mar 2020 10:25:32 -0500 X-MC-Unique: spDHu0AFOxyaJm-nauE8SQ-1 Received: by mail-wr1-f72.google.com with SMTP id u18so2423438wrn.11 for ; Thu, 05 Mar 2020 07:25:32 -0800 (PST) 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=vy5/EiEAp0wCHefyZwq4zlhiKyPciLoRoXRp/gwmNyU=; b=jpCdo+SMRr/52Q8E6GUlZ7ug72J+kawqlNt3qcNaIv1Tk6rIQpUrNfryhZvNTsehZY uk6WSlOgaIw/vrcBrtBsRUi8NYGfZSAEKtL1zavpsURjDDNpiOGLkgQhYngmIjl/iP7+ 8JHZBK7vqmtqd/RLXbzeTgPlcoR7qXbtyuG+mVFMYNQzLvIK28e97OLj8gHzrfBWpLG5 eUurTx2G53OI/C1Ss9NLBrNVQq5bMIUv7AjRuO44C/BxJe04aqJPLmmfZAF8TzGj4yaK xWdbxPONSU1D2aeQlaIL/qN8sAQ3Rx0ySg1njjIrYW5cr6mzCpiGAn2OAfCN73IDQfeX 3sHA== X-Gm-Message-State: ANhLgQ2uZo17CBp0vVR1fpMmLmXN9sg0Au9U+PCqBVRTZ1GUguxvrYfr m22Ifbx6nfuod/5P/C9MGYfK443kSvLzdD1AgyEfmJ72t93StxQcGHSjQheD2wUgzjqXMaLDIkR 4rDefp7nGSLyC+yNRUF07xwNs X-Received: by 2002:a7b:cb46:: with SMTP id v6mr10012835wmj.0.1583421931390; Thu, 05 Mar 2020 07:25:31 -0800 (PST) X-Received: by 2002:a7b:cb46:: with SMTP id v6mr10012811wmj.0.1583421931138; Thu, 05 Mar 2020 07:25:31 -0800 (PST) Received: from ?IPv6:2001:b07:6468:f312:9def:34a0:b68d:9993? ([2001:b07:6468:f312:9def:34a0:b68d:9993]) by smtp.gmail.com with ESMTPSA id b24sm9503524wmj.13.2020.03.05.07.25.27 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 05 Mar 2020 07:25:30 -0800 (PST) Subject: Re: [PATCH] KVM: x86: small optimization for is_mtrr_mask calculation To: David Laight , linmiaohe , "rkrcmar@redhat.com" , "sean.j.christopherson@intel.com" , "vkuznets@redhat.com" , "jmattson@google.com" , "joro@8bytes.org" , "tglx@linutronix.de" , "mingo@redhat.com" , "bp@alien8.de" , "hpa@zytor.com" Cc: "kvm@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "x86@kernel.org" References: <1583376535-27255-1-git-send-email-linmiaohe@huawei.com> <2b678644-fcc0-e853-a53c-2651c1f6a327@redhat.com> From: Paolo Bonzini Message-ID: <2129995e-3441-f362-aed1-7c247189c136@redhat.com> Date: Thu, 5 Mar 2020 16:25:20 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 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 05/03/20 16:10, David Laight wrote: >>> index = (msr - 0x200) / 2; >>> - is_mtrr_mask = msr - 0x200 - 2 * index; >>> + is_mtrr_mask = (msr - 0x200) % 2; >>> cur = &mtrr_state->var_ranges[index]; >>> >>> /* remove the entry if it's in the list. */ >>> @@ -424,7 +424,7 @@ int kvm_mtrr_get_msr(struct kvm_vcpu *vcpu, u32 msr, u64 *pdata) >>> int is_mtrr_mask; >>> >>> index = (msr - 0x200) / 2; >>> - is_mtrr_mask = msr - 0x200 - 2 * index; >>> + is_mtrr_mask = (msr - 0x200) % 2; >>> if (!is_mtrr_mask) >>> *pdata = vcpu->arch.mtrr_state.var_ranges[index].base; >>> else >>> >> If you're going to do that, might as well use ">> 1" for index instead >> of "/ 2", and "msr & 1" for is_mtrr_mask. > Provided the variables are unsigned it makes little difference > whether you use / % or >> &. > At least with / % the two values are the same. Yes, I'm old-fashioned, but also I prefer ">>" and "&" for both signed and unsigned, because if ever I need to switch from unsigned to signed I will get floor-division instead of round-to-zero division (most likely the code doesn't expect negative remainders if it was using unsigned). (That perhaps also reflects on me working a lot with Smalltalk long before switching to the kernel...). Paolo