Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2881085pxk; Mon, 28 Sep 2020 02:35:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwn8EvMBf1pNCmgUeYR0nFcVJCvQ3tPs3PfBJ7+j2A5oOD+LJAJ5UvqV/LzVhd5JuP6I+tO X-Received: by 2002:a17:906:1185:: with SMTP id n5mr756408eja.495.1601285748250; Mon, 28 Sep 2020 02:35:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601285748; cv=none; d=google.com; s=arc-20160816; b=EJwl+NjXodv/84lTd8HYY8Q85qCkR1QCMckyLMPtw1ZAA4iNQC5Zch0RmY/Jsmj9P6 uu0PBxPuAEDyFboEyta+CWO7niZLBi45pRX7Q0OeltsLVFw52oCpzmwjT7AtQ2UyMtLm pzMhK5dC96Z63AqvbUhNvJ68UMLSkQwBcxNPSbKLsVlqa3ynJddkjk7uUf4YDrhdEQP9 LIxXgXmQTTuldhXuacbdlGgXD7hbRyjplFm0n4F47fejOvhFCHTjYqVx6EeLzaqwnbGe bqMm+QAjg7od+RfBJpeWAgZyCzvGWwa09iJo4vfR9Oce/BDSRrrl7bAUFtd05Mp12WVk ZA4Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date; bh=MNxV8g67U5HpO/b48nG/vLcSIUtqcbyOoRC7xrgCL+Y=; b=YhuOqZKVdih5Ietv9aJ8JA8E0xCZDLxCOxVUnuKsJiou81Nxr8Boa5CQx8UNV0H5BV mcMqnOcXNOp+9I5oZfnLEjicRW3G7PlRUMZE7R2JVf8sck1jj9Ltrkqc09IvzjG4eVBe DnexhK5Sg0iTOgYnxB5h/tMD5A/uO1WbGCSFGo9UA0+CoM6GcCAj3vkCqK8ha3Jfwn7/ rf6L5corQScnk4ZGGRFMAgamYmG7jJ1ShL1IwzQDvbq1nEyK5MJ/TckXZromknY7fgRb fg5yULnbDdhZ67jAwO5UmzT/XMn6eO/0fupwco8sj6IjiuBCX9nYwqJiDypxGeadgm0s POdw== 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 a8si254588ejs.101.2020.09.28.02.35.25; Mon, 28 Sep 2020 02:35:48 -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 S1726600AbgI1JcK (ORCPT + 99 others); Mon, 28 Sep 2020 05:32:10 -0400 Received: from smtp2207-205.mail.aliyun.com ([121.197.207.205]:47816 "EHLO smtp2207-205.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726559AbgI1JcJ (ORCPT ); Mon, 28 Sep 2020 05:32:09 -0400 X-Alimail-AntiSpam: AC=CONTINUE;BC=0.08003213|-1;CH=green;DM=|CONTINUE|false|;DS=CONTINUE|ham_system_inform|0.012899-0.00117961-0.985921;FP=0|0|0|0|0|-1|-1|-1;HT=ay29a033018047209;MF=fuyao@allwinnertech.com;NM=1;PH=DS;RN=13;RT=13;SR=0;TI=SMTPD_---.IdDp-2p_1601285523; Received: from localhost(mailfrom:fuyao@allwinnertech.com fp:SMTPD_---.IdDp-2p_1601285523) by smtp.aliyun-inc.com(10.147.41.231); Mon, 28 Sep 2020 17:32:04 +0800 Date: Mon, 28 Sep 2020 17:31:58 +0800 From: fuyao To: =?utf-8?B?5YiY6YK15Y2OQlRE?= Cc: Christoph Hellwig , "paul.walmsley" , palmer , aou , akpm , peterx , walken , "daniel.m.jordan" , vbabka , rppt , linux-riscv , linux-kernel Subject: Re: =?utf-8?B?5Zue5aSN77yaW1BBVENI?= =?utf-8?Q?=5D?= riscv: fix pfn_to_virt err in do_page_fault(). Message-ID: <20200928093158.GC4756@g8Exdroid64> Mail-Followup-To: =?utf-8?B?5YiY6YK15Y2OQlRE?= , Christoph Hellwig , "paul.walmsley" , palmer , aou , akpm , peterx , walken , "daniel.m.jordan" , vbabka , rppt , linux-riscv , linux-kernel References: <1600327549-3995-1-git-send-email-liush@allwinnertech.com> <20200917152518.GA8930@infradead.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.12.1 (2019-06-15) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Sep 18, 2020 at 03:43:39PM +0800, 刘邵华BTD wrote: > Hi Christoph, > > On Thu, Sep 17, 2020 at 03:25:49PM +0800, liush wrote: > > > The argument to pfn_to_virt() should be pfn not the value of CSR_SATP. > > > > > > Signed-off-by: liush > > > --- > > > arch/riscv/mm/fault.c | 2 +- > > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > > > diff --git a/arch/riscv/mm/fault.c b/arch/riscv/mm/fault.c > > > index 716d64e..9b4e088 100644 > > > --- a/arch/riscv/mm/fault.c > > > +++ b/arch/riscv/mm/fault.c > > > @@ -212,7 +212,7 @@ asmlinkage void do_page_fault(struct pt_regs *regs) > > > * of a task switch. > > > */ > > > index = pgd_index(addr); > > > - pgd = (pgd_t *)pfn_to_virt(csr_read(CSR_SATP)) + index; > > > + pgd = (pgd_t *)pfn_to_virt(csr_read(CSR_SATP) & SATP_PPN) + index; > > > This adds a crazy long line. One nice way to clean this up would be to > > add a local pfn variable, as it would also make the code more readable. > > Thanks, i'll modify it in next revision Tested-by: fuayo@allwinnertech.com -- Allwinnertech Technology