-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[ARM] 5613/1: implement CALLER_ADDRESSx
From: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> As __builtin_return_address(n) doesn't work for ARM with n > 0, the kernel needs its own implementation. This fixes many warnings saying: warning: unsupported argument to '__builtin_return_address' The new methods and walk_stackframe must not be instrumented because CALLER_ADDRESSx is used in the various tracers and tracing the tracer is a bad idea. What's currently missing is an implementation using unwind tables. This is not fatal though, it's just that the tracers don't get enough information to be really useful. Note that if both ARM_UNWIND and FRAME_POINTER are enabled, walk_stackframe uses unwind information. So in this case the same implementation is used as when FRAME_POINTER is disabled. Cc: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
- Loading branch information
Uwe Kleine-König
authored and
Russell King
committed
Jul 21, 2009
1 parent
6a00cde
commit 4bf1fa5
Showing
4 changed files
with
110 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
/* | ||
* arch/arm/kernel/return_address.c | ||
* | ||
* Copyright (C) 2009 Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
* for Pengutronix | ||
* | ||
* This program is free software; you can redistribute it and/or modify it | ||
* under the terms of the GNU General Public License version 2 as published by | ||
* the Free Software Foundation. | ||
*/ | ||
#include <linux/module.h> | ||
|
||
#if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) | ||
#include <linux/sched.h> | ||
|
||
#include <asm/stacktrace.h> | ||
|
||
struct return_address_data { | ||
unsigned int level; | ||
void *addr; | ||
}; | ||
|
||
static int save_return_addr(struct stackframe *frame, void *d) | ||
{ | ||
struct return_address_data *data = d; | ||
|
||
if (!data->level) { | ||
data->addr = (void *)frame->lr; | ||
|
||
return 1; | ||
} else { | ||
--data->level; | ||
return 0; | ||
} | ||
} | ||
|
||
void *return_address(unsigned int level) | ||
{ | ||
struct return_address_data data; | ||
struct stackframe frame; | ||
register unsigned long current_sp asm ("sp"); | ||
|
||
data.level = level + 1; | ||
|
||
frame.fp = (unsigned long)__builtin_frame_address(0); | ||
frame.sp = current_sp; | ||
frame.lr = (unsigned long)__builtin_return_address(0); | ||
frame.pc = (unsigned long)return_address; | ||
|
||
walk_stackframe(&frame, save_return_addr, &data); | ||
|
||
if (!data.level) | ||
return data.addr; | ||
else | ||
return NULL; | ||
} | ||
|
||
#else /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) */ | ||
|
||
#if defined(CONFIG_ARM_UNWIND) | ||
#warning "TODO: return_address should use unwind tables" | ||
#endif | ||
|
||
void *return_address(unsigned int level) | ||
{ | ||
return NULL; | ||
} | ||
|
||
#endif /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) / else */ | ||
|
||
EXPORT_SYMBOL_GPL(return_address); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters