Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp2277340imn; Mon, 1 Aug 2022 18:40:07 -0700 (PDT) X-Google-Smtp-Source: AGRyM1taH6V20Z/w3LUBCpPvii4uisj0PLF007RzvvdQiwYk6hCpfswkIPYk6JJHJ7aSie4y7z5n X-Received: by 2002:a17:907:2ccb:b0:72b:52bb:fd51 with SMTP id hg11-20020a1709072ccb00b0072b52bbfd51mr14468450ejc.118.1659404407632; Mon, 01 Aug 2022 18:40:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659404407; cv=none; d=google.com; s=arc-20160816; b=hdzDkjPfnZrXUjZ2upbU+2eopSwfaQPVrcWOhtxavNGmUcJKM65Z1ooIsCXugXM4FP AFhuscsEQGy4C7IwjYx60M0KsBtWv7kJobARgKVxp5TwPL3KDFA2rAZRj6dNyYBJRRyq VXIcyuZ4PWN8BJpcaAUVQ5bNqhwTarphGCBAt7vQA3Gx4brq1AGSst/aEhVdHV8Iijyh oAWbG5vFqdmBTDXQbmemQ1NVWI4BcsXGcUJ3qKTB6dzNxYpyHbAxJFMxnoTlPAAULELD DmfHtHgNF77ppMs4npOtAWNUn+iQBcT/vMSM2rgXlQigzomEMX3Vfvr3Wv9kD18NXllw NWOw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=d/7MNWfDtxB3tcSNCsKCZ1dwxYxDWaiH8NVQVEJg0G0=; b=yUtv6uMXKZI1LsztcMeJGW3mES0Oz1+/YfC9WgG0/PiqrM0zL2NuY9k74QAUOP0Wsz mc3aGZnyPsD73JUQadrq8tuAzGjMT1qshUyja3iiH5Eh+GHKU8n0BlDv+JQKsnuNnCBu 2CXrJ29yXLsxGxglATTJED7zoIBlKrzN7CRlUsXD1Snz+Bjpl59BAA8GoQCnFDpKLCHH Shtzbf1qikRUiFGWCmYn9cmhTOa6dBe/t64v/uNuZeV9Rkwqbp+kYxSVuCpI3MtNeDpH bVSvHZCp1oe7hWvQRLV5ddlS2GXjTC2b/mYZ9ZALqOSptwMrO78a78m6SOFynBjfVE+X KT5w== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i2-20020a05640242c200b0043c30f0f4a6si13456853edc.107.2022.08.01.18.39.42; Mon, 01 Aug 2022 18:40:07 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233932AbiHBBUI (ORCPT + 99 others); Mon, 1 Aug 2022 21:20:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48368 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231653AbiHBBUE (ORCPT ); Mon, 1 Aug 2022 21:20:04 -0400 Received: from loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id E76801B79D for ; Mon, 1 Aug 2022 18:20:02 -0700 (PDT) Received: from [10.130.0.63] (unknown [113.200.148.30]) by mail.loongson.cn (Coremail) with SMTP id AQAAf9BxHOS6e+hiV+EAAA--.4933S3; Tue, 02 Aug 2022 09:19:55 +0800 (CST) Subject: Re: [PATCH 3/4] LoongArch: Add stacktrace support To: Huacai Chen Cc: WANG Xuerui , loongarch@lists.linux.dev, LKML , Jiaxun Yang , Jinyang He References: <20220801121726.9681-1-zhangqing@loongson.cn> <20220801121726.9681-4-zhangqing@loongson.cn> From: zhangqing Message-ID: <3cc6aebc-87e7-f0d0-2a88-e7e742e1e5ee@loongson.cn> Date: Tue, 2 Aug 2022 09:19:54 +0800 User-Agent: Mozilla/5.0 (X11; Linux mips64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-CM-TRANSID: AQAAf9BxHOS6e+hiV+EAAA--.4933S3 X-Coremail-Antispam: 1UD129KBjvJXoWxurWUZrWfuFy5Zr1kGr48JFb_yoW5WF1xpF ykArsxGF4kCr1fCFyav345uFyrJwn7Gr12qF9rKa45CrnFvF1aqr1kGF1DuFWjqan8J3yI 9FyfWr9Iga1UXw7anT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUvm14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26ryj6F1UM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26r4j 6F4UM28EF7xvwVC2z280aVAFwI0_Cr0_Gr1UM28EF7xvwVC2z280aVCY1x0267AKxVW8Jr 0_Cr1UM2AIxVAIcxkEcVAq07x20xvEncxIr21l5I8CrVACY4xI64kE6c02F40Ex7xfMcIj 6xIIjxv20xvE14v26r1j6r18McIj6I8E87Iv67AKxVWUJVW8JwAm72CE4IkC6x0Yz7v_Jr 0_Gr1lF7xvr2IY64vIr41lF7I21c0EjII2zVCS5cI20VAGYxC7Mxk0xIA0c2IEe2xFo4CE bIxvr21lc2xSY4AK67AK6w4l42xK82IYc2Ij64vIr41l4I8I3I0E4IkC6x0Yz7v_Jr0_Gr 1lx2IqxVAqx4xG67AKxVWUJVWUGwC20s026x8GjcxK67AKxVWUGVWUWwC2zVAF1VAY17CE 14v26r126r1DMIIYrxkI7VAKI48JMIIF0xvE2Ix0cI8IcVAFwI0_Jr0_JF4lIxAIcVC0I7 IYx2IY6xkF7I0E14v26r1j6r4UMIIF0xvE42xK8VAvwI8IcIk0rVWrZr1j6s0DMIIF0xvE x4A2jsIE14v26r1j6r4UMIIF0xvEx4A2jsIEc7CjxVAFwI0_Jr0_GrUvcSsGvfC2KfnxnU UI43ZEXa7VUbLiSPUUUUU== X-CM-SenderInfo: x2kd0wptlqwqxorr0wxvrqhubq/ X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_PASS,SPF_PASS 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 On 2022/8/1 下午11:30, Huacai Chen wrote: > Hi, Qing, > > On Mon, Aug 1, 2022 at 8:17 PM Qing Zhang wrote: >> >> Use common arch_stack_walk infrastructure to avoid duplicated code and >> avoid taking care of the stack storage and filtering. >> Add sra (means __schedule return address) and scfa (means __schedule call >> frame address) to thread_info and store it in switch_to(). >> >> Now we can print the process stack by cat /proc/*/stack and can better >> support ftrace. >> >> Signed-off-by: Qing Zhang >> --- >> arch/loongarch/Kconfig | 5 ++++ >> arch/loongarch/include/asm/processor.h | 9 +++++++ >> arch/loongarch/include/asm/switch_to.h | 14 ++++++---- >> arch/loongarch/include/asm/uaccess.h | 4 +-- >> arch/loongarch/kernel/Makefile | 1 + >> arch/loongarch/kernel/asm-offsets.c | 2 ++ >> arch/loongarch/kernel/process.c | 3 +++ >> arch/loongarch/kernel/stacktrace.c | 37 ++++++++++++++++++++++++++ >> arch/loongarch/kernel/switch.S | 2 ++ >> 9 files changed, 70 insertions(+), 7 deletions(-) >> create mode 100644 arch/loongarch/kernel/stacktrace.c >> >> diff --git a/arch/loongarch/include/asm/uaccess.h b/arch/loongarch/include/asm/uaccess.h >> index 2b44edc604a2..a8ae2af4025a 100644 >> --- a/arch/loongarch/include/asm/uaccess.h >> +++ b/arch/loongarch/include/asm/uaccess.h >> @@ -229,13 +229,13 @@ extern unsigned long __copy_user(void *to, const void *from, __kernel_size_t n); >> static inline unsigned long __must_check >> raw_copy_from_user(void *to, const void __user *from, unsigned long n) >> { >> - return __copy_user(to, from, n); >> + return __copy_user(to, (__force const void *)from, n); >> } >> >> static inline unsigned long __must_check >> raw_copy_to_user(void __user *to, const void *from, unsigned long n) >> { >> - return __copy_user(to, from, n); >> + return __copy_user((__force void *)to, from, n); > Why this? Does it have something to do with stacktrace? > > Huacai Hi, huacai This is kernel test robot report sparse warnings: I reproduced locally and found that other architectures calling __copy_user also use __force conversion, Is this modification appropriate? kernel/trace/trace_events_user.c: note: in included file (through include/linux/uaccess.h, include/linux/sched/task.h, include/linux/sched/signal.h, ...): arch/loongarch/include/asm/uaccess.h:232:32: sparse: sparse: incorrect type in argument 2 (different address spaces) @@ expected void const *from @@ got void const [noderef] __user *from @@ arch/loongarch/include/asm/uaccess.h:232:32: sparse: expected void const *from arch/loongarch/include/asm/uaccess.h:232:32: sparse: got void const [noderef] __user *from Thanks, -Qing