 |
__builtin_frame_address |
void *__builtin_frame_address (int level);
This function is similar to __builtin_return_address, but it
returns the address of the function frame rather than the return address
of the function. Calling __builtin_frame_address with a value of
0 yields the frame address of the current function, a value of
1 yields the frame address of the caller of the current function,
and so forth.
The frame is the area on the stack which holds local variables and saved
registers. The frame address is normally the address of the first word
pushed on to the stack by the function. However, the exact definition
depends upon the processor and the calling convention. On the Motorola
68000, if the function has a frame,
then __builtin_frame_address will return the value of the frame
pointer register a6
if level is 0.
This function should be used with a nonzero argument only for debugging
purposes.