Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp733568ybh; Wed, 15 Jul 2020 13:48:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwtOdaeFStTtHFdKubiBhWGqj/nO9k3WedKWuD85ydtfym6Y/DVzuizYPHLrnbiqZiba/8d X-Received: by 2002:a05:6402:1a54:: with SMTP id bf20mr1419913edb.69.1594846087644; Wed, 15 Jul 2020 13:48:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594846087; cv=none; d=google.com; s=arc-20160816; b=QOHJFAOoluO4D756goQwG+1cb6PkVNqovySjhAKDZVmlYBSk6+bvTe4tuH2jYTtXUK nUPRa+PmejgrZoYL7R8cdYxgGEH5Sw+xlu0r+/RJeBahniUvIEITU61KJ7s1Fp7Or2/2 jPXANKqUflig4M7ttGSuUoqPjJkw7vO/7HwnXHCvWKKttefGFxvUveKbc+BohE4tk3tn RNHbXKb2p7IKPN9miAzjJGGSbvjjnBLcTPDBNDZ8PQOgoPHPUJ+1Aa5sHikrntB2UrHt eCSh3J4IytQq7IbJZO6g8yQ7Wk92SF8SzQXctxBRkXEC3zvCr4fzX70kxgNrfrMMxhWq xXZw== 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:date:subject:cc:to:from :dkim-signature; bh=lY/a7mtzZ/kDBh9cPH6vLSX7hTXPZl052GtqhdcIFzM=; b=VsZLEFZdUNC+xQMXX7nv+zRYlkIIF2dPrXqXsSn+E9RhwBSSpSbEpGtjyoRIi0ktDc KN6u9iOz8RnaUDEo+zvuaWjmmvDnsWOhp/O7ZwyuR+dbdzDiIYWatXu8V0ULaa0IcqBq plO6D2sY0/2C33JoBi0DhBfIyhO6KYq6Ys0UnpSL86schwqtgoRxxOcqzxrKHjwjdU5E x7q4w7sSFbFMPpibuLKYK71c4w26DTc0CR8wgT2WcEWbWX9tj2mpIml7u3Dx9rL5SGgm xiA7xwtnKvDAmT6sDCGKdLHKQ1qZGxdI6A49zJQBhrcX392gmJ83bZ7SKpXK9vY0PhMT cnSg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eVcCgpSp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w24si1738740ejv.691.2020.07.15.13.47.44; Wed, 15 Jul 2020 13:48:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eVcCgpSp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727886AbgGOUpI (ORCPT + 99 others); Wed, 15 Jul 2020 16:45:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:37774 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726670AbgGOUpC (ORCPT ); Wed, 15 Jul 2020 16:45:02 -0400 Received: from localhost (fw-tnat.cambridge.arm.com [217.140.96.140]) (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 4A73C2070E; Wed, 15 Jul 2020 20:45:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594845901; bh=82c0M4r2v9vmu+J3LNGEZvNsiX4xegCRnclRjTkc4/o=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eVcCgpSp6N8Lu8pYUkh2pzuDpoBZ9+aiIPRlmvsFhp1Bfd3YqxJUUDQFqM08p1mDW S5jMIbrSuBtCPF0Kar2gn5BtTdTQjI183TIUre92tq5Hq+QWM3a84jB3rYrAKu8eBM H3JGVGLCn+Wum99KL/beD+yTWX44f+lMRh/EJnhg= From: Mark Brown To: Catalin Marinas , Will Deacon , Heiko Carstens , Vasily Gorbik , Thomas Gleixner , Borislav Petkov , "H. Peter Anvin" Cc: Christian Borntraeger , Ingo Molnar , Jiri Slaby , x86@kernel.org, linux-arm-kernel@lists.infradead.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, Mark Brown Subject: [PATCH 2/3] arm64: stacktrace: Make stack walk callback consistent with generic code Date: Wed, 15 Jul 2020 21:28:20 +0100 Message-Id: <20200715202821.12220-3-broonie@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200715202821.12220-1-broonie@kernel.org> References: <20200715202821.12220-1-broonie@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As with the generic arch_stack_walk() code the arm64 stack walk code takes a callback that is called per stack frame. Currently the arm64 code always passes a struct stackframe to the callback and the generic code just passes the pc, however none of the users ever reference anything in the struct other than the pc value. The arm64 code also uses a return type of int while the generic code uses a return type of bool though in both cases the return value is a boolean value. In order to reduce code duplication when arm64 is converted to use arch_stack_walk() change the signature of the arm64 specific callback to match that of the generic code. Signed-off-by: Mark Brown --- arch/arm64/include/asm/stacktrace.h | 2 +- arch/arm64/kernel/perf_callchain.c | 6 +++--- arch/arm64/kernel/return_address.c | 8 ++++---- arch/arm64/kernel/stacktrace.c | 11 +++++------ 4 files changed, 13 insertions(+), 14 deletions(-) diff --git a/arch/arm64/include/asm/stacktrace.h b/arch/arm64/include/asm/stacktrace.h index fc7613023c19..eb29b1fe8255 100644 --- a/arch/arm64/include/asm/stacktrace.h +++ b/arch/arm64/include/asm/stacktrace.h @@ -63,7 +63,7 @@ struct stackframe { extern int unwind_frame(struct task_struct *tsk, struct stackframe *frame); extern void walk_stackframe(struct task_struct *tsk, struct stackframe *frame, - int (*fn)(struct stackframe *, void *), void *data); + bool (*fn)(void *, unsigned long), void *data); extern void dump_backtrace(struct pt_regs *regs, struct task_struct *tsk, const char *loglvl); diff --git a/arch/arm64/kernel/perf_callchain.c b/arch/arm64/kernel/perf_callchain.c index b0e03e052dd1..bd2a91bd9e9e 100644 --- a/arch/arm64/kernel/perf_callchain.c +++ b/arch/arm64/kernel/perf_callchain.c @@ -137,11 +137,11 @@ void perf_callchain_user(struct perf_callchain_entry_ctx *entry, * whist unwinding the stackframe and is like a subroutine return so we use * the PC. */ -static int callchain_trace(struct stackframe *frame, void *data) +static bool callchain_trace(void *data, unsigned long pc) { struct perf_callchain_entry_ctx *entry = data; - perf_callchain_store(entry, frame->pc); - return 0; + perf_callchain_store(entry, pc); + return false; } void perf_callchain_kernel(struct perf_callchain_entry_ctx *entry, diff --git a/arch/arm64/kernel/return_address.c b/arch/arm64/kernel/return_address.c index a5e8b3b9d798..6434427a827a 100644 --- a/arch/arm64/kernel/return_address.c +++ b/arch/arm64/kernel/return_address.c @@ -18,16 +18,16 @@ struct return_address_data { void *addr; }; -static int save_return_addr(struct stackframe *frame, void *d) +static bool save_return_addr(void *d, unsigned long pc) { struct return_address_data *data = d; if (!data->level) { - data->addr = (void *)frame->pc; - return 1; + data->addr = (void *)pc; + return true; } else { --data->level; - return 0; + return false; } } NOKPROBE_SYMBOL(save_return_addr); diff --git a/arch/arm64/kernel/stacktrace.c b/arch/arm64/kernel/stacktrace.c index 2dd8e3b8b94b..743cf11fbfca 100644 --- a/arch/arm64/kernel/stacktrace.c +++ b/arch/arm64/kernel/stacktrace.c @@ -118,12 +118,12 @@ int notrace unwind_frame(struct task_struct *tsk, struct stackframe *frame) NOKPROBE_SYMBOL(unwind_frame); void notrace walk_stackframe(struct task_struct *tsk, struct stackframe *frame, - int (*fn)(struct stackframe *, void *), void *data) + bool (*fn)(void *, unsigned long), void *data) { while (1) { int ret; - if (fn(frame, data)) + if (fn(data, frame->pc)) break; ret = unwind_frame(tsk, frame); if (ret < 0) @@ -139,17 +139,16 @@ struct stack_trace_data { unsigned int skip; }; -static int save_trace(struct stackframe *frame, void *d) +static bool save_trace(void *d, unsigned long addr) { struct stack_trace_data *data = d; struct stack_trace *trace = data->trace; - unsigned long addr = frame->pc; if (data->no_sched_functions && in_sched_functions(addr)) - return 0; + return false; if (data->skip) { data->skip--; - return 0; + return false; } trace->entries[trace->nr_entries++] = addr; -- 2.20.1