Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp72158imn; Thu, 28 Jul 2022 23:13:45 -0700 (PDT) X-Google-Smtp-Source: AA6agR7/RFrht48wZTGXgBBzvYVie052trrGyaPkCFWOYRokpiYBphZghRXZWahYBex3AnZiEfmq X-Received: by 2002:a17:902:d4c5:b0:16d:65e3:7215 with SMTP id o5-20020a170902d4c500b0016d65e37215mr2379068plg.142.1659075225464; Thu, 28 Jul 2022 23:13:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659075225; cv=none; d=google.com; s=arc-20160816; b=edFTxT+se1G4SJBJYvX75HRXYPYNfLvuLqr4uVvF5eKeUQuo3ZhCtvzk8RbySMBLKD PkX0fbozTA6Ba5Ttl8DSJnyGHJ/tHNeEObDABKb2RDVqPCAw1WKPiCh2u3DN8+3DZoY9 3dEItEiaoSa+UYPmPEkdPJRJSW+Q5S0o3VMvS+HPnhBApEtQB6kauHX0uTirH2Cq19FZ NSh3YMFA1wyqsONqeHBTSQ6Wq3Pbv9pE4RHqsNLapKSpnKL6/V9AMGY6+2tEloyuBfGV NHkT6sjGzw8WKGtytXQvxH4oS46QSr5kvG6SXDSL55yCxF87Ck3XrtNis3iKiNl4GIHK U5AA== 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=vDnA804ka6CQHUHML1FEjP9qdF2IpRgg+Q16rkg0bgY=; b=yaZrTh3EIibMw/LmKpGobbOvJSGuVF2iHtiGs6ljdTf0lYwE/4chA0kpT/gHfI9u90 5/RFeKW+uFpVjuOE1Sj2XCUKjQGyPVEca/aRz8pT+OpxMDAROjihDldDO1NJMdPUhxaC nq4DY/4SXZDYO+S6Nw3oQ+nKhtsks2gI6F6em7M8KKj+j9i+kyAwaRXL9oTI+6b2+azr rGR4Wk41V2VbSp9ZoWQ/r2d1VccBF2F+knzuyamD2RYR3/cFv0cE9ehkNXgEMjSqaapq PUysO7lL2MDHe3K8sMmBJwEI0TmapGP8XGBiA5Lz35H1DKO9JxUbD88+vXi1jL4Vkrfb Yu8Q== 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 h11-20020a056a00230b00b0051896b51021si1850644pfh.299.2022.07.28.23.13.30; Thu, 28 Jul 2022 23:13:45 -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 S234334AbiG2Fi5 (ORCPT + 99 others); Fri, 29 Jul 2022 01:38:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36878 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229445AbiG2Fi4 (ORCPT ); Fri, 29 Jul 2022 01:38:56 -0400 Received: from loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 661CB1F62E for ; Thu, 28 Jul 2022 22:38:54 -0700 (PDT) Received: from [10.130.0.63] (unknown [113.200.148.30]) by mail.loongson.cn (Coremail) with SMTP id AQAAf9Dxz9JmcuNiJipBAA--.27572S3; Fri, 29 Jul 2022 13:38:47 +0800 (CST) Subject: Re: [PATCH 2/3] LoongArch: Add prologue unwinder support To: Youling Tang , Huacai Chen Cc: WANG Xuerui , loongarch@lists.linux.dev, linux-kernel@vger.kernel.org, Jiaxun Yang , hejinyang@loongson.cn References: <20220728140519.5420-1-zhangqing@loongson.cn> <20220728140519.5420-2-zhangqing@loongson.cn> From: zhangqing Message-ID: Date: Fri, 29 Jul 2022 13:38:46 +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: AQAAf9Dxz9JmcuNiJipBAA--.27572S3 X-Coremail-Antispam: 1UD129KBjvJXoW7tF4rXFy3Xr47CF4DWF1Dtrb_yoW8Zr1xpr 4ktFWDtFyDKrn3ur1UJr4kuF98ArWkGw1DtFZ5XF4UGr1DXw1Iqrya9w1v93Z7Jr4kGr18 Ar15Zr9ruF1DWFJanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUvm14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26r1I6r4UM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26r4j 6F4UM28EF7xvwVC2z280aVAFwI0_Cr1j6rxdM28EF7xvwVC2z280aVCY1x0267AKxVW0oV Cq3wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC0VAKzVAqx4xG6I80ewAv7VC0 I7IYx2IY67AKxVWUXVWUAwAv7VC2z280aVAFwI0_Gr0_Cr1lOx8S6xCaFVCjc4AY6r1j6r 4UM4x0Y48IcVAKI48JM4x0x7Aq67IIx4CEVc8vx2IErcIFxwCYjI0SjxkI62AI1cAE67vI Y487MxkIecxEwVAFwVW8WwCF04k20xvY0x0EwIxGrwCFx2IqxVCFs4IE7xkEbVWUJVW8Jw C20s026c02F40E14v26r1j6r18MI8I3I0E7480Y4vE14v26r106r1rMI8E67AF67kF1VAF wI0_JF0_Jw1lIxkGc2Ij64vIr41lIxAIcVC0I7IYx2IY67AKxVWUJVWUCwCI42IY6xIIjx v20xvEc7CjxVAFwI0_Jr0_Gr1lIxAIcVCF04k26cxKx2IYs7xG6rWUJVWrZr1UMIIF0xvE x4A2jsIE14v26r1j6r4UMIIF0xvEx4A2jsIEc7CjxVAFwI0_Jr0_GrUvcSsGvfC2KfnxnU UI43ZEXa7VUjivttUUUUU== 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/7/29 上午10:03, Youling Tang wrote: > > > On 07/28/2022 10:05 PM, Qing Zhang wrote: >> It unwind the stack frame based on prologue code analyze. >> CONFIG_KALLSYMS is needed, at least the address and length >> of each function. >> >> Three stages when we do unwind, >>   (1)unwind_start(), the prapare of unwinding, fill unwind_state. >>   (2)unwind_done(), judge whether the unwind process is finished or not. >>   (3)unwind_next_frame(), unwind the next frame. >> >> Dividing unwinder helps to add new unwinders in the future, eg: >> unwind_frame, unwind_orc .etc >> >> Signed-off-by: Qing Zhang >> >> + >> +    while (ip < ip_end) { >> +        if (is_ra_save_ins(ip)) { >> +            frame_ra = ip->reg2i12_format.immediate; > Because the immediate member in struct reg2i12_format is defined as an > unsigned type, the value obtained by frame_ra here can only be a > positive number. > >> +            break; >> +        } >> +        if (is_branch_insn(*ip)) >> +            break; >> +        ip++; >> +    } >> + >> +    if (frame_ra < 0) { > In addition to judging whether the initial value of frame_ra is > negative, we also want to judge whether the previously assigned > frame_ra is negative. > > Save the ra value to the stack in the prologue, offset must be a > positive number, so we can add another judgment to is_ra_save_ins, the > code is as follows: > +static inline bool is_ra_save_ins(union loongarch_instruction *ip) > +{ > +    /* st.d $ra, $sp, offset */ > +    return ip->reg2i12_format.opcode == std_op && > +        ip->reg2i12_format.rj == LOONGARCH_GPR_SP && > +        ip->reg2i12_format.rd == LOONGARCH_GPR_RA && > +        !(ip->reg2i12_format.immediate & (1 << 11)); > +} Hi, youling you are right and I will send v2. Thanks, Qing