[PATCH 2/4] ARM: extract out insn generation code from ftrace
Dave Martin
dave.martin at linaro.org
Wed Nov 23 06:50:12 EST 2011
On Tue, Nov 22, 2011 at 11:55:49PM +0530, Rabin Vincent wrote:
> On Tue, Nov 22, 2011 at 19:26, Dave Martin <dave.martin at linaro.org> wrote:
> > On Tue, Nov 22, 2011 at 07:02:13PM +0530, Rabin Vincent wrote:
> >> It's not used on Thumb-2. This is only used by the function graph
> >> tracer and that depends on !THUMB2_KERNEL.
> >
> > I assume there's no special reason why this doesn't work with a Thumb-2
> > kernel, other than that it simply hasn't implemented yet?
>
> The function graph tracer expects to get a pointer to the saved return
> address of the function (on the stack). It changes this to its own
> return_hooker function where it records the exit from the function and
> jumps to the real return address.
>
> We do this for ARM (the instruction set) by building with frame pointers,
> and the function prologues always save the registers in the expected
> order and the epilogues restore them out from the saved locations.
>
> However, with Thumb-2, we don't get frame pointers even if we ask for
> them. So to support Thumb-2 we'd probably need a way to find and modify
> the LR without it being at a fixed location (MIPS does something similar
> IIRC). I haven't really looked into it.
The unwind tables contain the information required to find the link
register. This is how the backtracer works in Thumb-2 kernels or with
CONFIG_ARM_UNWIND. This adds some complexity, but it also has some
advantages such as elimiating the runtime stack and instruction overhead
associated with maintaining a framepointer chain.
Really, "find/change frame's stored return address" is a generic
operation which is closely related to stack unwinding, and would best
be implemented along with the unwinder code. Ideally, ftrace should
not need to know or care _how_ this is accomplished. Indeed, at this
level the operation isn't even arch-specific.
I will take a look at the ARM unwind/backtrace code and think about
whether this could be factored out or exposed in a helpful way.
Certainly we shouldn't implement a second unwind table parser in
ftrace...
Are there any other dependencies on framepointers, or is that the only
thing?
Cheers
---Dave
More information about the linux-arm-kernel
mailing list