Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp710499ybh; Sat, 3 Aug 2019 08:12:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqwY2Au5aDSl059qxrfkilJmF8KF5DAgUujFCktJT8e8ryya+DX24T7lDnIuff4kv/pwndJ2 X-Received: by 2002:a17:90a:5207:: with SMTP id v7mr9246282pjh.127.1564845123101; Sat, 03 Aug 2019 08:12:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564845123; cv=none; d=google.com; s=arc-20160816; b=Tc6u83FhS67vwpDYFs6gpHho5POIXBbr3X/s9DPiuZ+5efryungpoWsgmA3FZtP4ub rxwFETG4uj6OwTBtnqOwKeOZjx/xWLYrrtV/TK2WLV0rp02+5GGyyFY63sgikRuHTyNZ XqTszO/ZoA8Y+z7WCmEvG/yPxJka5elk9RP7GZe3ks4ngIpWZY/DRGP9kDZLOSSlb91u bPaQR2EuPu30e0NYDvHSq2+B4pqWqhoen/6tNcZE92ybzzhkj5IVimq91Y8HZkvrTIb9 K4Wbgx/J6rUzGZAE2rr2w+rkRpIXXNPA439gyC7HGjN9gtRDWnSLD01wbGI7r+hUtM/k lNZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=tvtO2hlxVczZAtRWYhC7akUjdbyuRScnh74Lefr2I5Y=; b=O4nkCthb7OXq/i/rHba2mDvUy0npHstNu0fbzJkv/+5xRTJ86kOJGq8QYS4sfRPwlU d6u4RnFnHrMI8jSUxNfmM0S9BWrRoHXvQQvgjjJj9oUHNNiP+AzHEtNTqo0CBRxoECbO 6S8mivQkh5Vv4/FViJHLEWcPHgfEGt/UxSg3Y35hvbBt8lSEp2EUijl0fgG8tfEXxNnq kn9BVAIge2SbGmqa8AiGA+UAiGi7EETRCIojTUgHlu0MhnIwwDNgyQcwL408GeHaQUmY VufQ8S5wwZRtOibE4angQvT85fq77tXdhTGu1VZz32b3NgcHhLmK+9K8yhRbHTkM9JQs Ub3A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v136si40447737pfc.9.2019.08.03.08.11.48; Sat, 03 Aug 2019 08:12:03 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390231AbfHBQL2 (ORCPT + 99 others); Fri, 2 Aug 2019 12:11:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:48184 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732543AbfHBQL1 (ORCPT ); Fri, 2 Aug 2019 12:11:27 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0F61120449; Fri, 2 Aug 2019 16:11:25 +0000 (UTC) Date: Fri, 2 Aug 2019 12:11:24 -0400 From: Steven Rostedt To: Jiping Ma Cc: , , , , , Subject: Re: [PATCH v3] tracing: Function stack size and its name mismatch in arm64 Message-ID: <20190802121124.6b41f26a@gandalf.local.home> In-Reply-To: <20190802120920.3b1f4351@gandalf.local.home> References: <20190802094103.163576-1-jiping.ma2@windriver.com> <20190802112259.0530a648@gandalf.local.home> <20190802120920.3b1f4351@gandalf.local.home> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 2 Aug 2019 12:09:20 -0400 Steven Rostedt wrote: > On Fri, 2 Aug 2019 11:22:59 -0400 > Steven Rostedt wrote: > > > I think you are not explaining the issue correctly. From looking at the > > document, I think what you want to say is that the LR is saved *after* > > the data for the function. Is that correct? If so, then yes, it would > > cause the stack tracing algorithm to be incorrect. > > > > [..] > > > Can someone confirm that this is the real issue? > > Does this patch fix your issue? > Bah, I hit "attach" instead of "insert" (I wondered why it didn't insert). Here's the patch without the attachment. -- Steve diff --git a/arch/arm64/include/asm/ftrace.h b/arch/arm64/include/asm/ftrace.h index 5ab5200b2bdc..13a4832cfb00 100644 --- a/arch/arm64/include/asm/ftrace.h +++ b/arch/arm64/include/asm/ftrace.h @@ -13,6 +13,7 @@ #define HAVE_FUNCTION_GRAPH_FP_TEST #define MCOUNT_ADDR ((unsigned long)_mcount) #define MCOUNT_INSN_SIZE AARCH64_INSN_SIZE +#define ARCH_RET_ADDR_AFTER_LOCAL_VARS 1 #ifndef __ASSEMBLY__ #include diff --git a/kernel/trace/trace_stack.c b/kernel/trace/trace_stack.c index 5d16f73898db..050c6bd9beac 100644 --- a/kernel/trace/trace_stack.c +++ b/kernel/trace/trace_stack.c @@ -158,6 +158,18 @@ static void check_stack(unsigned long ip, unsigned long *stack) i++; } +#ifdef ARCH_RET_ADDR_AFTER_LOCAL_VARS + /* + * Most archs store the return address before storing the + * function's local variables. But some archs do this backwards. + */ + if (x > 1) { + memmove(&stack_trace_index[0], &stack_trace_index[1], + sizeof(stack_trace_index[0]) * (x - 1)); + x--; + } +#endif + stack_trace_nr_entries = x; if (task_stack_end_corrupted(current)) {