Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp393782rwi; Wed, 26 Oct 2022 02:15:26 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4qsJObQeHnTlQjiXKlh6tl1CA3JMf03xrgvAsvHiJTO+CsCSm2lRu9ohKoZF+g73rDW6IA X-Received: by 2002:a63:8243:0:b0:463:10d9:f150 with SMTP id w64-20020a638243000000b0046310d9f150mr35835204pgd.242.1666775726439; Wed, 26 Oct 2022 02:15:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666775726; cv=none; d=google.com; s=arc-20160816; b=cO55dfpj2d66NljhGKzEeGeV43dluRub8vqSHSVHxbdTCfC3s3qkEBv5l3jprcuEJP PS+YiY+qulz2Cr5W7B1J/bEhmNqt6QpGBMrFFF7Jx+PrjD1k5I6ZkqM0h20QW7hH9fY2 24YWwerq8T7m5SUIJpJcW2Yzwx3rKjY5Y6XmuOQsQsfB7c+OE7crzWv7A20Rk/Xc3Da4 xgTFmNb9mbi/TKJ1Zx2ryE8+QnqVByJpC0xFsv5YSMkPwYlk2nhpcZ9fisGCzMwe7+LE trKqCNVisBUlhSh1BGmv0Wp3KWMu7V1v1ABth2gXBFn/dYPFvGM7wrTsqolJQtPCDRZQ 7CsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:references :cc:to:from:subject:user-agent:mime-version:date:message-id; bh=2j0eLGBArYBwTJhyPXbrtZgcwtaMt1MzDzls0S0h9hs=; b=KcjV7hOwzJ0Yg18QQEFJqz3e++9/gNozII6QZFlRW/lbKixxxNPGWzsCyiDdfE45KO +W4GIfHMAjy8+ULpbYEKDTm1GqNoQrv5ftpMR7apSH5OhOAgrDs84PuPJF4cGkSA8/E0 MZf3FEiltbSbmtc6XNi5YWBIzqh5+QO6PH41dGsWc5j+j0wCq5TeZqKM/+E0NexpfwNM JXf8Is7h9bx03nkr0zeFdlvCk4nMQG6BoID4mn0uPeFZsUAzWijh+G3YT5Tm05EWhaFt 6ycsugkA945ssdi5NLceYDCk1gfWVceKvhWg5KSDB2ytxJrK+yyWnK2uRgWaW6HrLiKn 5WdA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m20-20020a056a00081400b00545c1d801d7si345647pfk.364.2022.10.26.02.15.15; Wed, 26 Oct 2022 02:15:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233111AbiJZJIY (ORCPT + 99 others); Wed, 26 Oct 2022 05:08:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49336 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232488AbiJZJIV (ORCPT ); Wed, 26 Oct 2022 05:08:21 -0400 Received: from out30-132.freemail.mail.aliyun.com (out30-132.freemail.mail.aliyun.com [115.124.30.132]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E40449B851; Wed, 26 Oct 2022 02:08:18 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046050;MF=xianting.tian@linux.alibaba.com;NM=1;PH=DS;RN=24;SR=0;TI=SMTPD_---0VT6dyvZ_1666775291; Received: from 30.221.97.58(mailfrom:xianting.tian@linux.alibaba.com fp:SMTPD_---0VT6dyvZ_1666775291) by smtp.aliyun-inc.com; Wed, 26 Oct 2022 17:08:13 +0800 Message-ID: <5df30e57-88ae-0a3b-2c1a-b962363d8670@linux.alibaba.com> Date: Wed, 26 Oct 2022 17:08:11 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:91.0) Gecko/20100101 Thunderbird/91.12.0 Subject: Re: [PATCH V4 1/2] RISC-V: Add arch_crash_save_vmcoreinfo support From: Xianting Tian To: Baoquan He , Palmer Dabbelt , Conor Dooley Cc: paul.walmsley@sifive.com, aou@eecs.berkeley.edu, anup@brainfault.org, heiko@sntech.de, guoren@kernel.org, mick@ics.forth.gr, alexandre.ghiti@canonical.com, vgoyal@redhat.com, dyoung@redhat.com, corbet@lwn.net, bagasdotme@gmail.com, k-hagio-ab@nec.com, lijiang@redhat.com, kexec@lists.infradead.org, linux-doc@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, crash-utility@redhat.com, heinrich.schuchardt@canonical.com, hschauhan@nulltrace.org, yixun.lan@gmail.com References: <20221019103623.7008-1-xianting.tian@linux.alibaba.com> <20221019103623.7008-2-xianting.tian@linux.alibaba.com> <30621b3b-47ba-d612-cfb0-583d779691a3@linux.alibaba.com> <6af05838-fa58-8197-f3ce-ca95457077a7@linux.alibaba.com> In-Reply-To: <6af05838-fa58-8197-f3ce-ca95457077a7@linux.alibaba.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY, USER_IN_DEF_SPF_WL autolearn=ham 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 Hi Palmer, Conor Is this version OK for you? Do you plan to apply this patch set? thanks 在 2022/10/20 下午12:40, Xianting Tian 写道: > > 在 2022/10/20 上午11:05, Baoquan He 写道: >> On 10/20/22 at 10:17am, Xianting Tian wrote: >>> 在 2022/10/20 上午10:08, Baoquan He 写道: >>>> On 10/19/22 at 06:36pm, Xianting Tian wrote: >>>>> Add arch_crash_save_vmcoreinfo(), which exports VM layout(MODULES, >>>>> VMALLOC, >>>>> VMEMMAP ranges and KERNEL_LINK_ADDR), va bits and ram base for >>>>> vmcore. >>>>> >>>>> Default pagetable levels and PAGE_OFFSET aren't same for different >>>>> kernel >>>>> version as below. For pagetable levels, it sets sv57 by default >>>>> and falls >>>>> back to setting sv48 at boot time if sv57 is not supported by the >>>>> hardware. >>>>> >>>>> For ram base, the default value is 0x80200000 for qemu riscv64 env >>>>> and, >>>>> for example, is 0x200000 on the XuanTie 910 CPU. >>>>> >>>>>    * Linux Kernel 5.18 ~ >>>>>    *      PGTABLE_LEVELS = 5 >>>>>    *      PAGE_OFFSET = 0xff60000000000000 >>>>>    * Linux Kernel 5.17 ~ >>>>>    *      PGTABLE_LEVELS = 4 >>>>>    *      PAGE_OFFSET = 0xffffaf8000000000 >>>>>    * Linux Kernel 4.19 ~ >>>>>    *      PGTABLE_LEVELS = 3 >>>>>    *      PAGE_OFFSET = 0xffffffe000000000 >>>>> >>>>> Since these configurations change from time to time and version to >>>>> version, >>>>> it is preferable to export them via vmcoreinfo than to change the >>>>> crash's >>>>> code frequently, it can simplify the development of crash tool. >>>>> >>>>> Signed-off-by: Xianting Tian >>>>> --- >>>>>    arch/riscv/kernel/Makefile     |  1 + >>>>>    arch/riscv/kernel/crash_core.c | 23 +++++++++++++++++++++++ >>>>>    2 files changed, 24 insertions(+) >>>>>    create mode 100644 arch/riscv/kernel/crash_core.c >>>>> >>>>> diff --git a/arch/riscv/kernel/Makefile b/arch/riscv/kernel/Makefile >>>>> index db6e4b1294ba..4cf303a779ab 100644 >>>>> --- a/arch/riscv/kernel/Makefile >>>>> +++ b/arch/riscv/kernel/Makefile >>>>> @@ -81,6 +81,7 @@ obj-$(CONFIG_KGDB)        += kgdb.o >>>>>    obj-$(CONFIG_KEXEC_CORE)    += kexec_relocate.o >>>>> crash_save_regs.o machine_kexec.o >>>>>    obj-$(CONFIG_KEXEC_FILE)    += elf_kexec.o machine_kexec_file.o >>>>>    obj-$(CONFIG_CRASH_DUMP)    += crash_dump.o >>>>> +obj-$(CONFIG_CRASH_CORE)    += crash_core.o >>>>>    obj-$(CONFIG_JUMP_LABEL)    += jump_label.o >>>>> diff --git a/arch/riscv/kernel/crash_core.c >>>>> b/arch/riscv/kernel/crash_core.c >>>>> new file mode 100644 >>>>> index 000000000000..3e889d0ed7bd >>>>> --- /dev/null >>>>> +++ b/arch/riscv/kernel/crash_core.c >>>>> @@ -0,0 +1,23 @@ >>>>> +// SPDX-License-Identifier: GPL-2.0-only >>>>> + >>>>> +#include >>>>> +#include >>>>> + >>>>> +void arch_crash_save_vmcoreinfo(void) >>>>> +{ >>>>> +    VMCOREINFO_NUMBER(VA_BITS); >>>>> +    VMCOREINFO_NUMBER(phys_ram_base); >>>>> + >>>>> +    vmcoreinfo_append_str("NUMBER(PAGE_OFFSET)=0x%lx\n", >>>>> PAGE_OFFSET); >>>>> + vmcoreinfo_append_str("NUMBER(VMALLOC_START)=0x%lx\n", >>>>> VMALLOC_START); >>>>> +    vmcoreinfo_append_str("NUMBER(VMALLOC_END)=0x%lx\n", >>>>> VMALLOC_END); >>>>> + vmcoreinfo_append_str("NUMBER(VMEMMAP_START)=0x%lx\n", >>>>> VMEMMAP_START); >>>>> +    vmcoreinfo_append_str("NUMBER(VMEMMAP_END)=0x%lx\n", >>>>> VMEMMAP_END); >>>>> +#ifdef CONFIG_64BIT >>>>> + vmcoreinfo_append_str("NUMBER(MODULES_VADDR)=0x%lx\n", >>>>> MODULES_VADDR); >>>>> +    vmcoreinfo_append_str("NUMBER(MODULES_END)=0x%lx\n", >>>>> MODULES_END); >>>>> +#endif >>>>> + >>>>> +    if (IS_ENABLED(CONFIG_64BIT)) >>>>> + vmcoreinfo_append_str("NUMBER(KERNEL_LINK_ADDR)=0x%lx\n", >>>>> KERNEL_LINK_ADDR); >>>> Wondering why you don't put KERNEL_LINK_ADDR exporting into the above >>>> ifdeffery scope, with that you can save one line of >>>> "IS_ENABLED(CONFIG_64BIT)". >>> I followed the rule in print_vm_layout() of arch/riscv/mm/init.c, >>> which used >>> IS_ENABLED when print the value of KERNEL_LINK_ADDR. >>> >> I see. There's PAGE_OFFSET in the middle. Thanks. >> >>          print_ml("lowmem", (unsigned long)PAGE_OFFSET, >>                  (unsigned long)high_memory) >> >> So now, do you think if it's necessary to have another >> IS_ENABLED(CONFIG_64BIT) in the current arch_crash_save_vmcoreinfo()? > > For which MACRO?  I think current code for PAGE_OFFSET is OK. >