Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp2297512pxp; Mon, 21 Mar 2022 16:12:43 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzyIZvMcUUyYFAchxWlJh9y0TJL4KF6bcIBWuAT3oD4lq5tU/tzJAVidVLApIJg36VXDag/ X-Received: by 2002:a17:90a:2ec2:b0:1bc:8bdd:8cfc with SMTP id h2-20020a17090a2ec200b001bc8bdd8cfcmr1546058pjs.237.1647904362967; Mon, 21 Mar 2022 16:12:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647904362; cv=none; d=google.com; s=arc-20160816; b=t72LufVcE21r54Ek1m2E/JRH5UjQYqfXnf0efT/XlueJ2c1i3OHmOvAM9k7o6xqdYo c+kLmfWVmN70bQn/3GoRpb4RrR51uOVAQ1Jt4As5Wr95diKDRgau318xXXO9Euz/bw35 KmcA4nyeoqZDCbTucqYYV5ul9vQG1oEvVz09mwxRsB9P+tBjDQvFYQjMXTErQjAMbX9H Et+vFhVyLwC3iHzbcfE7vzB9jdqcFQ9f20qtJOOTXDBXCvR5+I01duT0YzQIxvxlpp8n fiqFaNcQdI3EozWLulkpFZH50/GOek5T9a6eFn/S4vBrt7+yb+pznEDUedLrbSQbh1u+ NfKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=QVzcwu8qz1XYgxmLoJxa+vdcGix4flozGTYJ6RDn/as=; b=yV4p6z+S9xoX1zT1so2e90EddW7bNaRI+xEC+MrMDnhwFS0Iy0PpFsKcJxvmEZVA4D 14+2w3i9MoDyr4w8q1RFrqK/35Wn8HMBZea1shHZG5GfxIxHOTmjtxGfluGLgVrO4efo R4Wr5pxpuqPUQMXKypDlDMyVq6wcTPCqpX/GFuBrPN1atPR91qdmcBAD/nP5Wq4TGDS+ D9muaMsuVhxlFrexsL6axzN6mP0QK66aIHwkrPbwJMd7QpbqLGafWoExfRsS1tx9DQ0t lUmx0TEgCpXQM3p1ysLCBnQQdibt2ZP8gM2rrqGJJwK19EbDzRMl89DJ92d/rDgJMddY A0iw== ARC-Authentication-Results: i=1; mx.google.com; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id p8-20020a170902a40800b00153b2d16664si11253358plq.620.2022.03.21.16.12.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 21 Mar 2022 16:12:42 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8AE4E36A9F1; Mon, 21 Mar 2022 15:11:17 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350511AbiCUPrV (ORCPT + 99 others); Mon, 21 Mar 2022 11:47:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56176 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350505AbiCUPrQ (ORCPT ); Mon, 21 Mar 2022 11:47:16 -0400 Received: from pegase2.c-s.fr (pegase2.c-s.fr [93.17.235.10]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CAB3D5D5D5 for ; Mon, 21 Mar 2022 08:44:58 -0700 (PDT) Received: from localhost (mailhub3.si.c-s.fr [172.26.127.67]) by localhost (Postfix) with ESMTP id 4KMf7s3SVGz9sTR; Mon, 21 Mar 2022 16:44:57 +0100 (CET) X-Virus-Scanned: amavisd-new at c-s.fr Received: from pegase2.c-s.fr ([172.26.127.65]) by localhost (pegase2.c-s.fr [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id GTON49PSekrA; Mon, 21 Mar 2022 16:44:57 +0100 (CET) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase2.c-s.fr (Postfix) with ESMTP id 4KMf7s2jxKz9sTJ; Mon, 21 Mar 2022 16:44:57 +0100 (CET) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 4ADA28B76C; Mon, 21 Mar 2022 16:44:57 +0100 (CET) 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 WHfqW7FVGiGT; Mon, 21 Mar 2022 16:44:57 +0100 (CET) Received: from PO20335.IDSI0.si.c-s.fr (unknown [172.25.230.108]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 353D58B763; Mon, 21 Mar 2022 16:44:57 +0100 (CET) Received: from PO20335.IDSI0.si.c-s.fr (localhost [127.0.0.1]) by PO20335.IDSI0.si.c-s.fr (8.17.1/8.16.1) with ESMTPS id 22LFimKO961652 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NOT); Mon, 21 Mar 2022 16:44:48 +0100 Received: (from chleroy@localhost) by PO20335.IDSI0.si.c-s.fr (8.17.1/8.17.1/Submit) id 22LFilCw961651; Mon, 21 Mar 2022 16:44:47 +0100 X-Authentication-Warning: PO20335.IDSI0.si.c-s.fr: chleroy set sender to christophe.leroy@csgroup.eu using -f From: Christophe Leroy To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: Christophe Leroy , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: [PATCH] powerpc: align address to page boundary in change_page_attr() Date: Mon, 21 Mar 2022 16:44:45 +0100 Message-Id: <6bb118fb2ee89fa3c1f9cf90ed19f88220002cb0.1647877467.git.christophe.leroy@csgroup.eu> X-Mailer: git-send-email 2.35.1 MIME-Version: 1.0 X-Developer-Signature: v=1; a=ed25519-sha256; t=1647877483; l=1785; s=20211009; h=from:subject:message-id; bh=XD7Tck9OiYXR05COoXx5aqfW6pqO+VH6BD8lG/u3XEg=; b=TmSNUn02E3l15lu/1NK8vuqd8N+RO1fZ2rCnCFpIHKhiTQJDbao2uLhkrJ/7Wqtz9t4sFpp3SV9r c2QRt9ypCsWedDYifJx8yhAvx96L7TGbx/9tGCsL0xhs5oLyBx4V X-Developer-Key: i=christophe.leroy@csgroup.eu; a=ed25519; pk=HIzTzUj91asvincQGOFx6+ZF5AoUuP9GdOtQChs7Mm0= Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Aligning address to page boundary allows flush_tlb_kernel_range() to know it's a single page flush and use tlbie instead of tlbia. On 603 we now have the following code in first leg of change_page_attr(): 2c: 55 29 00 3c rlwinm r9,r9,0,0,30 30: 91 23 00 00 stw r9,0(r3) 34: 7c 00 22 64 tlbie r4,r0 38: 7c 00 04 ac hwsync 3c: 38 60 00 00 li r3,0 40: 4e 80 00 20 blr Before we had: 28: 55 29 00 3c rlwinm r9,r9,0,0,30 2c: 91 23 00 00 stw r9,0(r3) 30: 54 89 00 26 rlwinm r9,r4,0,0,19 34: 38 84 10 00 addi r4,r4,4096 38: 7c 89 20 50 subf r4,r9,r4 3c: 28 04 10 00 cmplwi r4,4096 40: 41 81 00 30 bgt 70 44: 7c 00 4a 64 tlbie r9,r0 48: 7c 00 04 ac hwsync 4c: 38 60 00 00 li r3,0 50: 4e 80 00 20 blr ... 70: 94 21 ff f0 stwu r1,-16(r1) 74: 7c 08 02 a6 mflr r0 78: 90 01 00 14 stw r0,20(r1) 7c: 48 00 00 01 bl 7c 7c: R_PPC_REL24 _tlbia 80: 80 01 00 14 lwz r0,20(r1) 84: 38 60 00 00 li r3,0 88: 7c 08 03 a6 mtlr r0 8c: 38 21 00 10 addi r1,r1,16 90: 4e 80 00 20 blr Signed-off-by: Christophe Leroy --- arch/powerpc/mm/pageattr.c | 1 + 1 file changed, 1 insertion(+) diff --git a/arch/powerpc/mm/pageattr.c b/arch/powerpc/mm/pageattr.c index 85753e32a4de..6163e484bc6d 100644 --- a/arch/powerpc/mm/pageattr.c +++ b/arch/powerpc/mm/pageattr.c @@ -31,6 +31,7 @@ static int change_page_attr(pte_t *ptep, unsigned long addr, void *data) { long action = (long)data; + addr &= PAGE_MASK; /* modify the PTE bits as desired */ switch (action) { case SET_MEMORY_RO: -- 2.35.1