mirror of
https://github.com/tobast/libunwind-eh_elf.git
synced 2024-11-23 16:07:37 +01:00
37e20822f4
can be used in lieu of unw_getcontext() but not vice versa. (Logical change 1.196)
65 lines
1.9 KiB
TeX
65 lines
1.9 KiB
TeX
\documentclass{article}
|
|
\usepackage[fancyhdr,pdf]{latex2man}
|
|
|
|
\input{common.tex}
|
|
|
|
\begin{document}
|
|
|
|
\begin{Name}{3}{unw\_getcontext}{David Mosberger-Tang}{Programming Library}{unw\_getcontext}unw\_getcontext -- get initial machine-state
|
|
\end{Name}
|
|
|
|
\section{Synopsis}
|
|
|
|
\File{\#include $<$libunwind.h$>$}\\
|
|
|
|
\Type{int} \Func{unw\_getcontext}(\Type{unw\_context\_t~*}\Var{ucp});\\
|
|
|
|
\section{Description}
|
|
|
|
The \Func{unw\_getcontext}() routine initializes the context structure
|
|
pointed to by \Var{ucp} with the machine-state of the call-site. The
|
|
exact set of registers stored by \Func{unw\_getcontext}() is
|
|
platform-specific, but, in general, at least all preserved
|
|
(``callee-saved'') and all frame-related registers, such as the
|
|
stack-pointer, will be stored.
|
|
|
|
This routine is normally implemented as a macro and applications
|
|
should not attempt to take its address.
|
|
|
|
\section{Platform-specific Notes}
|
|
|
|
On IA-64, \Type{unw\_context\_t} has a layout that is compatible with
|
|
that of \Type{ucontext\_t} and such structures can be initialized with
|
|
\Func{getcontext}() instead of \Func{unw\_getcontext}(). However, the
|
|
reverse is \emph{not} true and it is \emph{not} safe to use structures
|
|
initialized by \Func{unw\_getcontext()} in places where a structure
|
|
initialized by \Func{getcontext()} is expected. The reason for this
|
|
asymmetry is that \Func{unw\_getcontext()} is optimized for maximum
|
|
performance and does not, for example, save the signal mask.
|
|
|
|
\section{Return Value}
|
|
|
|
On successful completion, \Func{unw\_getcontext}() returns 0.
|
|
Otherwise, a value of -1 is returned.
|
|
|
|
\section{Thread and Signal Safety}
|
|
|
|
\Func{unw\_getcontext}() is thread-safe as well as safe to use
|
|
from a signal handler.
|
|
|
|
\section{See Also}
|
|
|
|
\SeeAlso{libunwind(3)},
|
|
\SeeAlso{unw\_init\_local(3)}
|
|
|
|
\section{Author}
|
|
|
|
\noindent
|
|
David Mosberger-Tang\\
|
|
Hewlett-Packard Labs\\
|
|
Palo-Alto, CA 94304\\
|
|
Email: \Email{davidm@hpl.hp.com}\\
|
|
WWW: \URL{http://www.hpl.hp.com/research/linux/libunwind/}.
|
|
\LatexManEnd
|
|
|
|
\end{document}
|