Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp5849130ybg; Tue, 22 Oct 2019 09:14:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqwJ0TL3BRNrbS/umH0mkukPxPTp7h82fPNfpjojESk19hYhYxh2T14Sbxt7V6u0w8AisZXu X-Received: by 2002:a17:906:4806:: with SMTP id w6mr29165291ejq.44.1571760874913; Tue, 22 Oct 2019 09:14:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571760874; cv=none; d=google.com; s=arc-20160816; b=XrgVZYilHuW/iNZVhjHUTMpFXQhn9Ou5UiJWF23DSWFGhA5a/KRTbQTEOdmlnBRppF 1Q5oM73Nl1YwX1nKq1Oq3NHj/yc0gPYgcl0ebjL3Q2PiQRe6cEEcPWW7IHfdweFvPGps JmiDhhC2pJFYtRhYLIX8rWA/KWCQv/dV/NlcobDGuqxysF8f2SO2rC+k7HuuR+uiK0re g8Miv78VGcvrAvHn9luuiLFBbKLuDzfPBQ+h8DJLaP3lYudy+k2BKoiMBZhVxeGZ7jon lQY5xyNSzkROjVQpVPOZXUeAdZKq7MIv/jK1KGNTKLG3DytnWgXNwYyfUnAfrjAEFMt7 pvAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:user-agent:in-reply-to :content-disposition:mime-version:references:subject:cc:to:from:date; bh=DGcdHF8iojmyyJ6+BBgjuSpOoBUqIonfj2D0q0/y9qo=; b=M6DIZs96TDNUqGkirwoQrOaLWQZn9TXfAu+GXHFjSS2an94Hd+0JZvEY7KuWulOHux AdEBWDF6ARLvV/8iqiRHEq1Rh0qPPBOzMkG385rs7naTHaUfh+bmsHnZ3Ch4k8LVYIs9 pEZT9b03k7u7UykqDsiBZDDgINYvolNALPwqk/K57SD7G8E6xKYJbE7t/NNx4twVrEhr 7ZZCaUUo3EcpYMlh1UZF7VeZZV9gDFm0L98RX9xGXtnGz0jqnLpwfKaLSZngEl/xfDEf ZtvUm8WPjrfWkgYSaqFasJv3Of1QiaAg+7B1tDeb78geEJk5nbqU5XYibN5ea7qRgXqp FlaA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b2si1080375eja.89.2019.10.22.09.14.10; Tue, 22 Oct 2019 09:14:34 -0700 (PDT) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731781AbfJVPYN (ORCPT + 99 others); Tue, 22 Oct 2019 11:24:13 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:56246 "EHLO mx0b-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731521AbfJVPYM (ORCPT ); Tue, 22 Oct 2019 11:24:12 -0400 Received: from pps.filterd (m0127361.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.27/8.16.0.27) with SMTP id x9MFN8Z9061028 for ; Tue, 22 Oct 2019 11:24:11 -0400 Received: from e06smtp07.uk.ibm.com (e06smtp07.uk.ibm.com [195.75.94.103]) by mx0a-001b2d01.pphosted.com with ESMTP id 2vt3kgskjs-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Tue, 22 Oct 2019 11:24:08 -0400 Received: from localhost by e06smtp07.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Tue, 22 Oct 2019 16:24:00 +0100 Received: from b06cxnps4074.portsmouth.uk.ibm.com (9.149.109.196) by e06smtp07.uk.ibm.com (192.168.101.137) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; (version=TLSv1/SSLv3 cipher=AES256-GCM-SHA384 bits=256/256) Tue, 22 Oct 2019 16:23:58 +0100 Received: from d06av21.portsmouth.uk.ibm.com (d06av21.portsmouth.uk.ibm.com [9.149.105.232]) by b06cxnps4074.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id x9MFNvFd7798892 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 22 Oct 2019 15:23:57 GMT Received: from d06av21.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id F38DC52069; Tue, 22 Oct 2019 15:23:56 +0000 (GMT) Received: from linux.ibm.com (unknown [9.148.8.185]) by d06av21.portsmouth.uk.ibm.com (Postfix) with ESMTPS id 88AFF52057; Tue, 22 Oct 2019 15:23:56 +0000 (GMT) Date: Tue, 22 Oct 2019 18:23:54 +0300 From: Mike Rapoport To: Vineet Gupta Cc: linux-snps-arc@lists.infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, "Kirill A . Shutemov" Subject: Re: [PATCH v3] ARC: mm: remove __ARCH_USE_5LEVEL_HACK References: <20191009184350.18323-1-vgupta@synopsys.com> <20191009185731.25814-1-vgupta@synopsys.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191009185731.25814-1-vgupta@synopsys.com> User-Agent: Mutt/1.5.24 (2015-08-30) X-TM-AS-GCONF: 00 x-cbid: 19102215-0028-0000-0000-000003AD901C X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 19102215-0029-0000-0000-0000246FBB73 Message-Id: <20191022152354.GC14440@linux.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2019-10-22_03:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=2 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1908290000 definitions=main-1910220135 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Oct 09, 2019 at 11:57:31AM -0700, Vineet Gupta wrote: > Add the intermediate p4d accessors to make it 5 level compliant. > > This is a non-functional change anyways since ARC has software page walker > with 2 lookup levels (pgd -> pte) > > There is slight code bloat due to pulling in needless p*d_free_tlb() > macros which needs to be addressed seperately. > > | bloat-o-meter2 vmlinux-with-5LEVEL_HACK vmlinux-patched > | add/remove: 0/0 grow/shrink: 2/0 up/down: 128/0 (128) > | function old new delta > | free_pgd_range 546 656 +110 > | p4d_clear_bad 2 20 +18 > | Total: Before=4137148, After=4137276, chg 0.000000% > > Cc: Kirill A. Shutemov > Signed-off-by: Vineet Gupta Acked-by: Mike Rapoport > --- > v3 <- v2 > - fix highmem build error > > v2 <- v1 > - fix highmem code > --- > arch/arc/include/asm/pgtable.h | 1 - > arch/arc/mm/fault.c | 10 ++++++++-- > arch/arc/mm/highmem.c | 4 +++- > 3 files changed, 11 insertions(+), 4 deletions(-) > > diff --git a/arch/arc/include/asm/pgtable.h b/arch/arc/include/asm/pgtable.h > index 976b5931372e..902d45428cea 100644 > --- a/arch/arc/include/asm/pgtable.h > +++ b/arch/arc/include/asm/pgtable.h > @@ -33,7 +33,6 @@ > #define _ASM_ARC_PGTABLE_H > > #include > -#define __ARCH_USE_5LEVEL_HACK > #include > #include > #include /* to propagate CONFIG_ARC_MMU_VER */ > diff --git a/arch/arc/mm/fault.c b/arch/arc/mm/fault.c > index 3861543b66a0..fb86bc3e9b35 100644 > --- a/arch/arc/mm/fault.c > +++ b/arch/arc/mm/fault.c > @@ -30,6 +30,7 @@ noinline static int handle_kernel_vaddr_fault(unsigned long address) > * with the 'reference' page table. > */ > pgd_t *pgd, *pgd_k; > + p4d_t *p4d, *p4d_k; > pud_t *pud, *pud_k; > pmd_t *pmd, *pmd_k; > > @@ -39,8 +40,13 @@ noinline static int handle_kernel_vaddr_fault(unsigned long address) > if (!pgd_present(*pgd_k)) > goto bad_area; > > - pud = pud_offset(pgd, address); > - pud_k = pud_offset(pgd_k, address); > + p4d = p4d_offset(pgd, address); > + p4d_k = p4d_offset(pgd_k, address); > + if (!p4d_present(*p4d_k)) > + goto bad_area; > + > + pud = pud_offset(p4d, address); > + pud_k = pud_offset(p4d_k, address); > if (!pud_present(*pud_k)) > goto bad_area; > > diff --git a/arch/arc/mm/highmem.c b/arch/arc/mm/highmem.c > index a4856bfaedf3..fc8849e4f72e 100644 > --- a/arch/arc/mm/highmem.c > +++ b/arch/arc/mm/highmem.c > @@ -111,12 +111,14 @@ EXPORT_SYMBOL(__kunmap_atomic); > static noinline pte_t * __init alloc_kmap_pgtable(unsigned long kvaddr) > { > pgd_t *pgd_k; > + p4d_t *p4d_k; > pud_t *pud_k; > pmd_t *pmd_k; > pte_t *pte_k; > > pgd_k = pgd_offset_k(kvaddr); > - pud_k = pud_offset(pgd_k, kvaddr); > + p4d_k = p4d_offset(pgd_k, kvaddr); > + pud_k = pud_offset(p4d_k, kvaddr); > pmd_k = pmd_offset(pud_k, kvaddr); > > pte_k = (pte_t *)memblock_alloc_low(PAGE_SIZE, PAGE_SIZE); > -- > 2.20.1 > > -- Sincerely yours, Mike.