From patchwork Fri Dec 24 11:07:40 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christophe Leroy X-Patchwork-Id: 528010 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 71F3DC433F5 for ; Fri, 24 Dec 2021 11:07:44 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229513AbhLXLHn convert rfc822-to-8bit (ORCPT ); Fri, 24 Dec 2021 06:07:43 -0500 Received: from mail-eopbgr90074.outbound.protection.outlook.com ([40.107.9.74]:8074 "EHLO FRA01-MR2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1344029AbhLXLHn (ORCPT ); Fri, 24 Dec 2021 06:07:43 -0500 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=C5QPRqd95sXgtZAsXBxL/t/QhjC37VHeqDHanbqS4PjR3h2GNNIsv/Q/6wlRvhAujimnJPBmPoVgExQa8JOtsdCrgo3L0Xm0fKugw03cbW7u/jNtdavyObf2o5AaJMh4Itjn9YPN8JBWfrOFC7g+7b/zmkDH34fakd0Ae9+B6uk11N8Gx2sQUFq0rhxwZUAI5ERJT/sVrOpypExQTuddQGAjEH22ZiMMoKP4oL1kqhXbdBKoFyzN86ke/7/kq7bBbkHSIrhiOKPJIYX2Phi6wHMQVPSEBwIKhfKo4CCAq59IvFeCUiEhK3BAnFGoF+w+1K1aAOo7SHE6bX+Ns0UUng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=cIMKLbEc1X7ojhyPl/Wd/bkJLWi83d+e8lOVZJrwAGY=; b=YRWS0pBp0zBQDEJscZqaD7eZlaxgpVhXP1JTe9H7hq/iKUyWWHCnY+y4AgL92wqpLZP2Yk9r1Wt5EBvQXatuGFfsqfFMoMaoSwUnWMxoyf0cVh5kGe0jv1gdFYRtHJSk8nXb7nN5l6UtgDSnnrRGF5mHvcUYPtQY1gAyOnpVeiYE0QFgfgDlimL8JZxepv5K8l8dUmV4qeJyXLGmpzaUbVHagqxKgQBLibfcoEBH5JMsqbHDJDY96RKrpX09HAK8dNE6FPfoYX78e5zfSHEzjkiEFsOJmZKlY8OtD2x7btX4+iEwBm0N6dEwjRzLwLYE9I7DM7m1x/reKLWbLi1KBw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=csgroup.eu; dmarc=pass action=none header.from=csgroup.eu; dkim=pass header.d=csgroup.eu; arc=none Received: from MRZP264MB2988.FRAP264.PROD.OUTLOOK.COM (2603:10a6:501:31::15) by MRXP264MB0005.FRAP264.PROD.OUTLOOK.COM (2603:10a6:500:25::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4801.20; Fri, 24 Dec 2021 11:07:41 +0000 Received: from MRZP264MB2988.FRAP264.PROD.OUTLOOK.COM ([fe80::f0ef:856d:b0de:e85d]) by MRZP264MB2988.FRAP264.PROD.OUTLOOK.COM ([fe80::f0ef:856d:b0de:e85d%7]) with mapi id 15.20.4823.021; Fri, 24 Dec 2021 11:07:41 +0000 From: Christophe Leroy To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman CC: Christophe Leroy , "linux-kernel@vger.kernel.org" , "linuxppc-dev@lists.ozlabs.org" , Maxime Bizon , "stable@vger.kernel.org" , Russell Currey Subject: [PATCH v3 2/2] powerpc: Add set_memory_{p/np}() and remove set_memory_attr() Thread-Topic: [PATCH v3 2/2] powerpc: Add set_memory_{p/np}() and remove set_memory_attr() Thread-Index: AQHX+LZ3pRpnIABVV0eAi8LQLOkMHw== Date: Fri, 24 Dec 2021 11:07:40 +0000 Message-ID: References: <43c3c76a1175ae6dc1a3d3b5c3f7ecb48f683eea.1640344012.git.christophe.leroy@csgroup.eu> In-Reply-To: <43c3c76a1175ae6dc1a3d3b5c3f7ecb48f683eea.1640344012.git.christophe.leroy@csgroup.eu> Accept-Language: fr-FR, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=csgroup.eu; x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: aba06c92-3e17-470b-c780-08d9c6cd9a5c x-ms-traffictypediagnostic: MRXP264MB0005:EE_ x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:551; x-ms-exchange-senderadcheck: 1 x-ms-exchange-antispam-relay: 0 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: w3IMcNUJC4LHwXm6ZEWHflyt6AP8qzMGEDKQeo7RjtDwdqB4ZnTv+d+gpkFdduzPnFwhIB59ABOBhrUpGl6iTFZ7rGRfxzs27NtGRRHmY2Im7Qz44cvmfFl7oxjOrxVCm8GQ13JeY8BtnkNKI+qthsM3wKUHo1/syejB1uPDlvdUKV1PZ5lHTJqBCQpahy6apOjPS+M23zJDN8jRlYky6dOjJ11DjmTJDuehl/5ELvz2ud/RlpuQIyj8uJv3sdZn9HH1sMBC4C1EtNOy25wJehM/Ab3G5S9pT6KuUUM9YtNpIT8cLH7sbfT9xlpZU6+rlgvEWl0OQWeSq4DPTyGpLbVVllTu/6jc5NMZYMLcXZC84FetWuwQOWT5YA3N6ECJnjg1GlFIECSDBWurg8cc/uIVpQSobJRFIhFvZy/Kxy3UZWVdoTYum2p6myVDqeAv0FFD2lQ4vkRwCkSjenBrKYRUEFQdL3Dulm+5+NDGbMlRmx+cfKH+H/kuZnF19vo21qpwz9TaxLMaaY9nmeUsFOJII1yflS0QSamtEEgJlSKF9hZslL6OoWna+X27Kfe7UIcW5+gmk2UaMfuN6+iWX4hBRolLUPMEEqjXp3J72j3pe2QU2Nwl+z5qeNRoAr/nHVWQ9h1keM9qxweqygCfkoy4yQgwWrIrUClHUs4yjLB0w7SxHfsJ6Bw6Y9Pe7trai2BVzloiT1wAUVwnAi6J4g== x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:MRZP264MB2988.FRAP264.PROD.OUTLOOK.COM; PTR:; CAT:NONE; SFS:(4636009)(366004)(54906003)(110136005)(2906002)(4326008)(2616005)(44832011)(64756008)(508600001)(5660300002)(66556008)(66446008)(66476007)(6506007)(91956017)(76116006)(66946007)(8676002)(71200400001)(8936002)(26005)(38070700005)(316002)(186003)(36756003)(38100700002)(122000001)(83380400001)(6486002)(6512007)(86362001); DIR:OUT; SFP:1101; x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?iso-8859-1?q?akAsGyhJd1k1h0d6j5m7jAG?= =?iso-8859-1?q?wVmErJjHNh70pcKb2qQRy7/9XoUiRLT/2f9O3wo9tNLZ5ruOFLO6iOh9DVwt?= =?iso-8859-1?q?PKfC950wd0dQZx0rhTgnzZSMxWIGk1uhsz49JC+EoUUsD78V0J9Qs9ZYW+fA?= =?iso-8859-1?q?D3n1eeAov/xgK2yddBT6NWI9FUhSNVuqFIHc+mF6VHkXqO4/h8sZQ05rfRiG?= =?iso-8859-1?q?smlr2pVIRuUaFq9pEoqzaa6vpagPu7/YNC5Q5iHXcAYHeWiSZV7v2JDxetij?= =?iso-8859-1?q?oefx0Y+V5rGaZWOaKdN8tEhc8ROaLrLDC6wLN28faLfbvbr0Epw5UqLgwhgU?= =?iso-8859-1?q?Lcx/G294hoNaJgR5XeZpiVGeJRXVcG4T0WP+pRYBiw+bF4kdY7fwPoITJkjN?= =?iso-8859-1?q?h3XYJNKzUgbUDwSZutGCnrUc66TN8fXIuRIH4u36BGbcO0WQYp2rQC+Ike51?= =?iso-8859-1?q?VfA3lh9Kc7CTMjgwTVvj2M3Q3OYvUglxPDbyrs2iSZFMRB7XT1D7Yp+obhlM?= =?iso-8859-1?q?LMxNtntXJIDjR8cdirTclBd0j74tnq/R9D65rCaUMElzrh+/qRcwsxHI/Nkr?= =?iso-8859-1?q?FeRRAzl71CjpeB69GC7VxtOX0Htssmvp4uehsBKdaweqshxJb9BtxEYJkNtx?= =?iso-8859-1?q?SVXjVpOJ+uqNKeszrr/5Ce9xeNuDPBOzHka+fpGr7xMr+pA3jui+aMom5rBe?= =?iso-8859-1?q?aw8pfEFW1ydKwpm/PLvejLR/IwqFxbJK2rCtHApLrAX8vstFqVXOdWrRMUw6?= =?iso-8859-1?q?5nyx3HF5ahRutNgwS8g9HTO+J6hoJGt1oosl8+gHn7MmW1zThQIM+tdboufT?= =?iso-8859-1?q?M4NsYjO8+SjWu4L3Vovo3r/5a8/pS0/o4ttzUunmoZJuv1Bucuv22JiWTEv4?= =?iso-8859-1?q?9xw7xMKNWp+a0lugKQiWMfqBKD8OMPsiiMrrRPyxYWA/I/s9zVhT1wLGT/B4?= =?iso-8859-1?q?wI/YwZra6xNdRwUQgaKej4YcxWM/0J2+f+gF7+iHupb47qpUMkFBN0Qd+w/J?= =?iso-8859-1?q?SKyeTsupDt1viycxaSzhmEH6NhcPVybbv7vYFwx01h6UXPsIVmTeZJHZItES?= =?iso-8859-1?q?n8vtyUpZWXI/8O54mW2R162RT+U5N2ejECYP45aMVg9Ib651snNiVeYeq/ts?= =?iso-8859-1?q?ZwtVCNyDtaUWeXtptF/92ttSsyoI9aWfxJUcVYmm0nvTNz6bc9n+DLgXF3pn?= =?iso-8859-1?q?/PZmX+9rnBJhz1x6LSi5dUdXNrWrIfelruyzqQqHbCpCTbdyzG3Nbbn5juM0?= =?iso-8859-1?q?kDeT7Qub8vuNAxzYWCNLtRiFAG6oXo+wG2qeUN1lyuVRZlLItq0ViqpK67IE?= =?iso-8859-1?q?Vb1N4Mkrps+hKky4Em9amqbZA5rq2NURLkQAt3gawcuAFaH+GmekxM3bqdQr?= =?iso-8859-1?q?q2WNm+kuPsquZXtNBAKCyqdK00W63klLSmmrNHZI5inmxbwI8e3go334OyTx?= =?iso-8859-1?q?wMMHPpPGAeBGTkp6AEaXXm2A/UFoJ9AJT+WaoW3JhTG8r4a/fMTR9LMKopVS?= =?iso-8859-1?q?vi5gh1Je5z6a1iSgKg9ZGnLW8mF1dMcgFi0zyTSuBjSUKkpZiX3axYEBF8L5?= =?iso-8859-1?q?lKqZLalP6I3W7FDhX28WO0rOh4aZVhxHw0e/EPfwfp6zkAMaijVBoNt/DJkM?= =?iso-8859-1?q?BDyc34R9RlCfCqkD/+0XzMYV7FVsLjlE9aD1Mc7QZIcd8xYgRwbU6h85ntMX?= =?iso-8859-1?q?qSg/w2V/cwvDfX0GrVVsluUjU9FL2WJ04caPB7F1MufVBEFG/uEw0Xe32yMx?= =?iso-8859-1?q?lSfg=3D?= MIME-Version: 1.0 X-OriginatorOrg: csgroup.eu X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: MRZP264MB2988.FRAP264.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-Network-Message-Id: aba06c92-3e17-470b-c780-08d9c6cd9a5c X-MS-Exchange-CrossTenant-originalarrivaltime: 24 Dec 2021 11:07:40.9221 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 9914def7-b676-4fda-8815-5d49fb3b45c8 X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: UhFtoMtJwRZTfizeR9Qs9ErbLB6SNnaq3m2wagiu1tctGBdLXRkyB/A8tq3BlteSirjiKEYBMj7/PXuMQmowXRGLqC3rCozA2+9pK7VjZQ8= X-MS-Exchange-Transport-CrossTenantHeadersStamped: MRXP264MB0005 Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org set_memory_attr() was implemented by commit 4d1755b6a762 ("powerpc/mm: implement set_memory_attr()") because the set_memory_xx() couldn't be used at that time to modify memory "on the fly" as explained it the commit. But set_memory_attr() uses set_pte_at() which leads to warnings when CONFIG_DEBUG_VM is selected, because set_pte_at() is unexpected for updating existing page table entries. The check could be bypassed by using __set_pte_at() instead, as it was the case before commit c988cfd38e48 ("powerpc/32: use set_memory_attr()") but since commit 9f7853d7609d ("powerpc/mm: Fix set_memory_*() against concurrent accesses") it is now possible to use set_memory_xx() functions to update page table entries "on the fly" because the update is now atomic. For DEBUG_PAGEALLOC we need to clear and set back _PAGE_PRESENT. Add set_memory_np() and set_memory_p() for that. Replace all uses of set_memory_attr() by the relevant set_memory_xx() and remove set_memory_attr(). Reported-by: Maxime Bizon Fixes: c988cfd38e48 ("powerpc/32: use set_memory_attr()") Cc: stable@vger.kernel.org Depends-on: 9f7853d7609d ("powerpc/mm: Fix set_memory_*() against concurrent accesses") Signed-off-by: Christophe Leroy Reviewed-by: Russell Currey Tested-by: Maxime Bizon --- v3: Use _PAGE_PRESENT directly as all platforms have the bit v2: Add comment to SET_MEMORY_P and SET_MEMORY_NP --- arch/powerpc/include/asm/set_memory.h | 12 ++++++++- arch/powerpc/mm/pageattr.c | 39 +++++---------------------- arch/powerpc/mm/pgtable_32.c | 24 ++++++++--------- 3 files changed, 28 insertions(+), 47 deletions(-) diff --git a/arch/powerpc/include/asm/set_memory.h b/arch/powerpc/include/asm/set_memory.h index b040094f7920..7ebc807aa8cc 100644 --- a/arch/powerpc/include/asm/set_memory.h +++ b/arch/powerpc/include/asm/set_memory.h @@ -6,6 +6,8 @@ #define SET_MEMORY_RW 1 #define SET_MEMORY_NX 2 #define SET_MEMORY_X 3 +#define SET_MEMORY_NP 4 /* Set memory non present */ +#define SET_MEMORY_P 5 /* Set memory present */ int change_memory_attr(unsigned long addr, int numpages, long action); @@ -29,6 +31,14 @@ static inline int set_memory_x(unsigned long addr, int numpages) return change_memory_attr(addr, numpages, SET_MEMORY_X); } -int set_memory_attr(unsigned long addr, int numpages, pgprot_t prot); +static inline int set_memory_np(unsigned long addr, int numpages) +{ + return change_memory_attr(addr, numpages, SET_MEMORY_NP); +} + +static inline int set_memory_p(unsigned long addr, int numpages) +{ + return change_memory_attr(addr, numpages, SET_MEMORY_P); +} #endif diff --git a/arch/powerpc/mm/pageattr.c b/arch/powerpc/mm/pageattr.c index 8812454e70ff..85753e32a4de 100644 --- a/arch/powerpc/mm/pageattr.c +++ b/arch/powerpc/mm/pageattr.c @@ -46,6 +46,12 @@ static int change_page_attr(pte_t *ptep, unsigned long addr, void *data) case SET_MEMORY_X: pte_update_delta(ptep, addr, _PAGE_KERNEL_RO, _PAGE_KERNEL_ROX); break; + case SET_MEMORY_NP: + pte_update(&init_mm, addr, ptep, _PAGE_PRESENT, 0, 0); + break; + case SET_MEMORY_P: + pte_update(&init_mm, addr, ptep, 0, _PAGE_PRESENT, 0); + break; default: WARN_ON_ONCE(1); break; @@ -90,36 +96,3 @@ int change_memory_attr(unsigned long addr, int numpages, long action) return apply_to_existing_page_range(&init_mm, start, size, change_page_attr, (void *)action); } - -/* - * Set the attributes of a page: - * - * This function is used by PPC32 at the end of init to set final kernel memory - * protection. It includes changing the maping of the page it is executing from - * and data pages it is using. - */ -static int set_page_attr(pte_t *ptep, unsigned long addr, void *data) -{ - pgprot_t prot = __pgprot((unsigned long)data); - - spin_lock(&init_mm.page_table_lock); - - set_pte_at(&init_mm, addr, ptep, pte_modify(*ptep, prot)); - flush_tlb_kernel_range(addr, addr + PAGE_SIZE); - - spin_unlock(&init_mm.page_table_lock); - - return 0; -} - -int set_memory_attr(unsigned long addr, int numpages, pgprot_t prot) -{ - unsigned long start = ALIGN_DOWN(addr, PAGE_SIZE); - unsigned long sz = numpages * PAGE_SIZE; - - if (numpages <= 0) - return 0; - - return apply_to_existing_page_range(&init_mm, start, sz, set_page_attr, - (void *)pgprot_val(prot)); -} diff --git a/arch/powerpc/mm/pgtable_32.c b/arch/powerpc/mm/pgtable_32.c index 906e4e4328b2..f71ededdc02a 100644 --- a/arch/powerpc/mm/pgtable_32.c +++ b/arch/powerpc/mm/pgtable_32.c @@ -135,10 +135,12 @@ void mark_initmem_nx(void) unsigned long numpages = PFN_UP((unsigned long)_einittext) - PFN_DOWN((unsigned long)_sinittext); - if (v_block_mapped((unsigned long)_sinittext)) + if (v_block_mapped((unsigned long)_sinittext)) { mmu_mark_initmem_nx(); - else - set_memory_attr((unsigned long)_sinittext, numpages, PAGE_KERNEL); + } else { + set_memory_nx((unsigned long)_sinittext, numpages); + set_memory_rw((unsigned long)_sinittext, numpages); + } } #ifdef CONFIG_STRICT_KERNEL_RWX @@ -152,18 +154,14 @@ void mark_rodata_ro(void) return; } - numpages = PFN_UP((unsigned long)_etext) - - PFN_DOWN((unsigned long)_stext); - - set_memory_attr((unsigned long)_stext, numpages, PAGE_KERNEL_ROX); /* - * mark .rodata as read only. Use __init_begin rather than __end_rodata - * to cover NOTES and EXCEPTION_TABLE. + * mark .text and .rodata as read only. Use __init_begin rather than + * __end_rodata to cover NOTES and EXCEPTION_TABLE. */ numpages = PFN_UP((unsigned long)__init_begin) - - PFN_DOWN((unsigned long)__start_rodata); + PFN_DOWN((unsigned long)_stext); - set_memory_attr((unsigned long)__start_rodata, numpages, PAGE_KERNEL_RO); + set_memory_ro((unsigned long)_stext, numpages); // mark_initmem_nx() should have already run by now ptdump_check_wx(); @@ -179,8 +177,8 @@ void __kernel_map_pages(struct page *page, int numpages, int enable) return; if (enable) - set_memory_attr(addr, numpages, PAGE_KERNEL); + set_memory_p(addr, numpages); else - set_memory_attr(addr, numpages, __pgprot(0)); + set_memory_np(addr, numpages); } #endif /* CONFIG_DEBUG_PAGEALLOC */