Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp266342pxx; Thu, 29 Oct 2020 02:00:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwLfbUSitnXhTnhNYdR+6J9sKD89LHcx196ifmFeEHzhWgj4/vytIm0VOPRNoGmu2VL2mDC X-Received: by 2002:a17:906:c293:: with SMTP id r19mr2899012ejz.63.1603962030398; Thu, 29 Oct 2020 02:00:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603962030; cv=none; d=google.com; s=arc-20160816; b=0PO4CUdzd4RVvaPn96LzBoSxndVziaYgarhc7pKt7Dw1yUnUk6kt9KszuMRc2lUYKQ qiaNw03koK6CIR29sOylNSe+KBVt+xdRc3A0fpIIKCHLRWKv6FsmFuBV1InOF+wa6LVh J3fFxhr+hOLlR/apCTUQnlwHZ4aJ8fjKNuBunVccvd7Nczn1xwVimF2rOBPVqup+etMX 7HDo0e1YtCecfYNlghRPqlx5y1iFG1xQ/3SNYuJosWHzttG/i/7VugzG3r8+IosQVaAO QNM40XUvMhxk96p7zITSzNVG2fxu8PjSZSlOp3fNzewWtutuHUg9jw3ESkpPlCnnGh+H vI0g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=YNtlQgloUeeFpFm/UYnd2QqHmCntydKiC9S5aRwY9pM=; b=LKQhkre5+KYg/fTiaGYsUqDH6U0N3ek2BzoxGZxiOkqpHPcE3hgmuB6k20MDU+3Ebl cZQ0k4x6JddP2cAD2zgahxuP1ZVS7vDxRwtWwEqOHjt4cga1Gx2fKfBgoHuBlJkr5osQ elTY1iUHtFmJ+l/A+N7+pLjxZ0QP2bfGzALQjg98TwlHV0CS385wgQ2IMRy0cv3jy535 NUl1TS58WX+xeV0iPdWIaXJTVhkB03HC2u2IYauf0bz+BfAx+3/IO2hZ8XD0lhJ3DDkS YkYsItmkJaRYS+YfvesfEGQGQQJUx7D1NUpT+BcqVe7bpLVAq4LLrnqXPY0bED3VJ/Iu 0rMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=C9kL2ZXn; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e12si1543725edy.188.2020.10.29.02.00.08; Thu, 29 Oct 2020 02:00: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=@redhat.com header.s=mimecast20190719 header.b=C9kL2ZXn; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726235AbgJ2HYI (ORCPT + 99 others); Thu, 29 Oct 2020 03:24:08 -0400 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:22955 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726101AbgJ2HYI (ORCPT ); Thu, 29 Oct 2020 03:24:08 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1603956247; 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=YNtlQgloUeeFpFm/UYnd2QqHmCntydKiC9S5aRwY9pM=; b=C9kL2ZXn6g9CuajaolZscrS57gR8yi8ZKmdC84JVfYEGwzYljmkDdYvtX/4pVBunuE9jm/ 1BpFuRipmJVb7rg8kR3oWrHudzqWgUDc6kkweDh7en1iWYMTaTomyT6W+muuImHv8/T9QT ME+XTY/AWhPdhD0kextch8BQgsqCpCE= Received: from mail-wm1-f70.google.com (mail-wm1-f70.google.com [209.85.128.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-579-7dp8NO8ePhiR7AgnbWQNVg-1; Thu, 29 Oct 2020 03:08:51 -0400 X-MC-Unique: 7dp8NO8ePhiR7AgnbWQNVg-1 Received: by mail-wm1-f70.google.com with SMTP id z62so315191wmb.1 for ; Thu, 29 Oct 2020 00:08:50 -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=YNtlQgloUeeFpFm/UYnd2QqHmCntydKiC9S5aRwY9pM=; b=lG+wmG8gYdJhWBwICd82DuEY/MxZokJS8WwINXqZtXIxMtdWCicGTRxEpEPXtueYaa m45Q/icCp4uBTdEH+eMchirNn5wAPzbjn5PQ7eiM/hS8kGs00gsyTN9schwmjY5MGPaP mvjsd+qqdM/AnfP3/Y0o3+dmNQ+/mSZ5g9jR+bQlsQHAfcaRo/LAIXhCAhIdR/b21UXT BZ4hsX+2O/sYU26T89CSnuIzrI6TLA0cnz5rKR/Rq3KzpDeZfflbTdBofJSxEuUrNsT6 GM0rIROeHsnbR2YjCVgaMfMphzpBuSzO6PcN7tjon3PqYikTkXXJyTcHnsI9MUTAb8vt yecA== X-Gm-Message-State: AOAM531Mtz1/cM+K/htdlEGYAqHtZ6bLWD+2bf4T9yUyPskPrzRqOiRI 89WWqisjsqKhIwJKeFyUGqcUUiTG8mo8jSEKWP3AyEJbCURpyiemyFvFnUzWNb2twscuCETp7VM tgkG/KXxyL/z50mdbh+2yAn03 X-Received: by 2002:adf:ffc7:: with SMTP id x7mr568876wrs.168.1603955329819; Thu, 29 Oct 2020 00:08:49 -0700 (PDT) X-Received: by 2002:adf:ffc7:: with SMTP id x7mr568856wrs.168.1603955329628; Thu, 29 Oct 2020 00:08:49 -0700 (PDT) Received: from ?IPv6:2001:b07:6468:f312:5e2c:eb9a:a8b6:fd3e? ([2001:b07:6468:f312:5e2c:eb9a:a8b6:fd3e]) by smtp.gmail.com with ESMTPSA id r18sm3462688wrj.50.2020.10.29.00.08.48 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 29 Oct 2020 00:08:49 -0700 (PDT) Subject: Re: [PATCH 0/3] KVM: x86/mmu: Add macro for hugepage GFN mask To: Sean Christopherson Cc: Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Ben Gardon References: <20201027214300.1342-1-sean.j.christopherson@intel.com> <80038ae1-d603-dc22-1997-1ad7da0a936d@redhat.com> <20201028152948.GA7584@linux.intel.com> From: Paolo Bonzini Message-ID: Date: Thu, 29 Oct 2020 08:08:48 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.3.1 MIME-Version: 1.0 In-Reply-To: <20201028152948.GA7584@linux.intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 28/10/20 16:29, Sean Christopherson wrote: > The naming and usage also aligns with the kernel, which defines PAGE, PMD and > PUD masks, and has near identical usage patterns. > > #define PAGE_SIZE (_AC(1,UL) << PAGE_SHIFT) > #define PAGE_MASK (~(PAGE_SIZE-1)) > > #define PMD_PAGE_SIZE (_AC(1, UL) << PMD_SHIFT) > #define PMD_PAGE_MASK (~(PMD_PAGE_SIZE-1)) > > #define PUD_PAGE_SIZE (_AC(1, UL) << PUD_SHIFT) > #define PUD_PAGE_MASK (~(PUD_PAGE_SIZE-1)) Well, PAGE_MASK is also one of my pet peeves for Linux. At least I am consistent. :) >> and of course if you're debugging it you have to >> look closer and check if it's really "x & -y" or "x & ~y", but at least >> in normal cursory code reading that's how it works for me. > > IMO, "x & -y" has a higher barrier to entry, especially when the kernel's page > masks uses "x & ~(y - 1))". But, my opinion is definitely colored by my > inability to read two's-complement on the fly. Fair enough. What about having instead #define KVM_HPAGE_GFN_BASE(gfn, level) \ (x & ~(KVM_PAGES_PER_HPAGE(gfn) - 1)) #define KVM_HPAGE_GFN_INDEX(gfn, level) \ (x & (KVM_PAGES_PER_HPAGE(gfn) - 1)) ? Paolo