Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1378048ybt; Thu, 18 Jun 2020 07:22:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyS63HA3WuKe9b8x52dIFmbTeh6U1LtkUbI6P/lsHehs5p5cUZPl5fiBefTLoJkiBANSNr2 X-Received: by 2002:a17:906:e115:: with SMTP id gj21mr4002505ejb.528.1592490174134; Thu, 18 Jun 2020 07:22:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592490174; cv=none; d=google.com; s=arc-20160816; b=IH3F52s6S+kcIAA/NDLB1aztfamMuxS36AZCf2/FN9j94b6ob/y9fI2fq1gUs3s7JE ayAd1pd8X3ivTOSa0ufGD77O4Mb4F08CGd/zB2UesDhsPt0nl0k9UR2JPCqmsZLdRL2z wM8f25zO6gzIOQY8TuXOIQE/POV8N7iEhdUdxfN/8p7lnw68oxMSZjWY3jGxNpO9kP98 L7SYdy7z3MSbIGW3Id3Qwvm7rJjv2wcb9f9uuBfdkEM3gWB7M6qcw9rBRGOaP4MbaQ6l EQyz6kZN9ZxA0eSO56TuiJ/EeaK0G2/4Y5bjlsdoffasWWllR08y0heyvSPe7hpg5W6D uhdA== 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=FnyQWFYwQEhyGnl7bxcUepwC4LMLHEiY5vCao4rYSiE=; b=YS4N4QtBbDydZbrA960u161gBRPMwHohZlaS04PVOxjbwz5RYOhfVhPBGIwzU9ZVBH Mynk4xmoZqmRQEa1PcY/EQDYRS59w44GsogUWaedbNEPcXZ/AuICumicRzsp5VbXI9Ri 9h3Tn2Ln9n6LjDHmjcklSGV/I75EhWMaDmu0f7O6OKVMV/BbbSmOXLzdOpjX7ihMDjn7 QbWWEWs682SZ5a2N5fXfWx2n8OAsaL4Zb4ROfwW1qOrLQAZfXKomeVMqPaXp9oRDSFmD Ro8ofFD7u6rZO2KVMeLnJ1e2hgU+YwR+56+dbxUy01PjaqEHPwsf0GzImhDQRICZtPQc Ojpw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g8si2099965edy.450.2020.06.18.07.22.32; Thu, 18 Jun 2020 07:22:54 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730597AbgFROUc (ORCPT + 99 others); Thu, 18 Jun 2020 10:20:32 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:50647 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727078AbgFROUb (ORCPT ); Thu, 18 Jun 2020 10:20:31 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 49nkcB0N7kz9v22D; Thu, 18 Jun 2020 16:20:26 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id VHSpRGwXAHDS; Thu, 18 Jun 2020 16:20:25 +0200 (CEST) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 49nkc96PXvz9v22C; Thu, 18 Jun 2020 16:20:25 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id BD2528B84D; Thu, 18 Jun 2020 16:20:27 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id wQxPvpp23FIb; Thu, 18 Jun 2020 16:20:27 +0200 (CEST) Received: from [10.25.210.22] (po15451.idsi0.si.c-s.fr [10.25.210.22]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 84C4C8B849; Thu, 18 Jun 2020 16:20:27 +0200 (CEST) Subject: Re: [PATCH 3/3] powerpc/8xx: Provide ptep_get() with 16k pages To: Michael Ellerman , Peter Zijlstra Cc: Benjamin Herrenschmidt , Paul Mackerras , Will Deacon , Andrew Morton , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-mm@kvack.org References: <341688399c1b102756046d19ea6ce39db1ae4742.1592225558.git.christophe.leroy@csgroup.eu> <20200615132244.GR2531@hirez.programming.kicks-ass.net> <87wo45db8d.fsf@mpe.ellerman.id.au> <20200617143826.GJ2531@hirez.programming.kicks-ass.net> <0bb024ce-11aa-80dc-c7d8-d5acc5329f25@csgroup.eu> <87o8phchnu.fsf@mpe.ellerman.id.au> From: Christophe Leroy Message-ID: Date: Thu, 18 Jun 2020 16:19:33 +0200 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 In-Reply-To: <87o8phchnu.fsf@mpe.ellerman.id.au> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 18/06/2020 à 03:00, Michael Ellerman a écrit : > Christophe Leroy writes: >> Le 17/06/2020 à 16:38, Peter Zijlstra a écrit : >>> On Thu, Jun 18, 2020 at 12:21:22AM +1000, Michael Ellerman wrote: >>>> Peter Zijlstra writes: >>>>> On Mon, Jun 15, 2020 at 12:57:59PM +0000, Christophe Leroy wrote: >>> >>>>>> +#if defined(CONFIG_PPC_8xx) && defined(CONFIG_PPC_16K_PAGES) >>>>>> +#define __HAVE_ARCH_PTEP_GET >>>>>> +static inline pte_t ptep_get(pte_t *ptep) >>>>>> +{ >>>>>> + pte_t pte = {READ_ONCE(ptep->pte), 0, 0, 0}; >>>>>> + >>>>>> + return pte; >>>>>> +} >>>>>> +#endif >>>>> >>>>> Would it make sense to have a comment with this magic? The casual reader >>>>> might wonder WTH just happened when he stumbles on this :-) >>>> >>>> I tried writing a helpful comment but it's too late for my brain to form >>>> sensible sentences. >>>> >>>> Christophe can you send a follow-up with a comment explaining it? In >>>> particular the zero entries stand out, it's kind of subtle that those >>>> entries are only populated with the right value when we write to the >>>> page table. >>> >>> static inline pte_t ptep_get(pte_t *ptep) >>> { >>> unsigned long val = READ_ONCE(ptep->pte); >>> /* 16K pages have 4 identical value 4K entries */ >>> pte_t pte = {val, val, val, val); >>> return pte; >>> } >>> >>> Maybe something like that? >> >> This should work as well. Indeed nobody cares about what's in the other >> three. They are only there to ensure that ptep++ increases the ptep >> pointer by 16 bytes. Only the HW require 4 identical values, that's >> taken care of in set_pte_at() and pte_update(). > > Right, but it seems less error-prone to have the in-memory > representation match what we have in the page table (well that's > in-memory too but you know what I mean). > >> So we should use the most efficient. Thinking once more, maybe what you >> propose is the most efficient as there is no need to load another >> register with value 0 in order to write it in the stack. > > On 64-bit I'd say it makes zero difference, the only thing that's going > to matter is the load from ptep->pte. I don't know whether that's true > on the 8xx cores though. On 8xx core, loading a register with value 0 will take one cycle unless there is some bubble left by another instruction (like a load from memory or a taken branch). But that's in the noise. Christophe