Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp702838ybh; Sat, 3 Aug 2019 08:04:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqxvrOjdV5sU3v9W74I8PDg7Sh9/x1VhrRzvQTPJVVLuUDvUODL8WDN2rTzg5kEagTxabE07 X-Received: by 2002:a17:902:7b98:: with SMTP id w24mr2750540pll.163.1564844697843; Sat, 03 Aug 2019 08:04:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564844697; cv=none; d=google.com; s=arc-20160816; b=XcGsL/YkMvtQ7qZWvbOqIZYCJm8sm/zYmP9al+M4DAxis39xR5l4M2d5vxxg2/43KU nWENsWkFiwSK/I7FG9KNjvm/Qe0F1lk7gUuBcnPG9X8VHh5rtM16CO/OMJx/m+y4m+wL hjU95Q6pIGaLWzlpZkdLeKaESwJGL5e1MAC2tWRp0/clQUZQWp7ZlqIeim3mdtXoQAiW bmD8TroyMMialWRe6PCogcZ6yjtwK8QJg8XVFkcmHc112OPhP1q4lN2GGHd3XM4w+Ix3 2WF8um+A/0s0AQMPS+g94ZYY2v909psKrWzZg4NnjZmGYGn703C4A9VmKFl/oTAqbbA9 hDfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:subject:cc:to:from:date; bh=d42AwuvrC/EXSlLFrSsDGBLDwczSd1C/3A+eUy9jH4o=; b=CGSiRkG1zSfcQs/TF3qIb04qGP0AmCzIggoaXo2avJnY5y6l1dllEc0fNhkotiuGlN I8PwsYsBgxJszVCuX9uKbLuC7WqdZZEf8vCf7+Gu0QnB0NTlI7/izQzJ/nPS2A3eyexc Q+0fXfI/kBNkG9xHWytl4oX3PUfUmKvFaICgmZm7hGWlBrwk9yVqHtRKuTmiDCTBEWb/ wCHgNDiFDOXUtJUvQYKcNl7w/aqWEih7njIVllN1nT66Vwx4+kj8DWkTAi3CxvezJkPY 68IVud1eX0EQWvPPnNNscrblpRSKyTrhXYE+fdXAndMkJzvrXxVMPDOr87qGf5xSmBGL R9Rg== 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 g129si41622253pfb.1.2019.08.03.08.04.42; Sat, 03 Aug 2019 08:04:57 -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 S2389533AbfHBQJ0 (ORCPT + 99 others); Fri, 2 Aug 2019 12:09:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:46572 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729142AbfHBQJX (ORCPT ); Fri, 2 Aug 2019 12:09:23 -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 AEDEE21783; Fri, 2 Aug 2019 16:09:21 +0000 (UTC) Date: Fri, 2 Aug 2019 12:09:20 -0400 From: Steven Rostedt To: Jiping Ma Cc: , , , , , Subject: Re: [PATCH v3] tracing: Function stack size and its name mismatch in arm64 Message-ID: <20190802120920.3b1f4351@gandalf.local.home> In-Reply-To: <20190802112259.0530a648@gandalf.local.home> References: <20190802094103.163576-1-jiping.ma2@windriver.com> <20190802112259.0530a648@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: multipart/mixed; boundary="MP_/H_zswQr7OwRjASX6FA341vN" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --MP_/H_zswQr7OwRjASX6FA341vN Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Content-Disposition: inline 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? -- 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)) { --MP_/H_zswQr7OwRjASX6FA341vN Content-Type: text/x-patch Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename=f.patch 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)) { --MP_/H_zswQr7OwRjASX6FA341vN--