123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265 |
- \documentclass{article}
- \usepackage[fancyhdr,pdf]{latex2man}
- \input{common.tex}
- \begin{document}
- \begin{Name}{3}{unw\_create\_addr\_space}{David Mosberger-Tang}{Programming Library}{unw\_create\_addr\_space}unw\_create\_addr\_space -- create address space for remote unwinding
- \end{Name}
- \section{Synopsis}
- \File{\#include $<$libunwind.h$>$}\\
- \Type{unw\_addr\_space\_t} \Func{unw\_create\_addr\_space}(\Type{unw\_accessors\_t~*}\Var{ap}, \Type{int} \Var{byteorder});\\
- \section{Description}
- The \Func{unw\_create\_addr\_space}() routine creates a new unwind
- address-space and initializes it based on the call-back routines
- passed via the \Var{ap} pointer and the specified \Var{byteorder}.
- The call-back routines are described in detail below. The
- \Var{byteorder} can be set to 0 to request the default byte-order of
- the unwind target. To request a particular byte-order,
- \Var{byteorder} can be set to any constant defined by
- \File{$<$endian.h$>$}. In particular, \Const{\_\_LITTLE\_ENDIAN} would
- request little-endian byte-order and \Const{\_\_BIG\_ENDIAN} would
- request big-endian byte-order. Whether or not a particular byte-order
- is supported depends on the target platform.
- \section{Call-back Routines}
- \Prog{Libunwind} uses a set of call-back routines to access the
- information it needs to unwind a chain of stack-frames. These
- routines are specified via the \Var{ap} argument, which points to a
- variable of type \Type{unw\_accessors\_t}. The contents of this
- variable is copied into the newly-created address space, so the
- variable must remain valid only for the duration of the call to
- \Func{unw\_create\_addr\_space}().
- The first argument to every call-back routine is an address-space
- identifier (\Var{as}) and the last argument is an arbitrary,
- application-specified void-pointer (\Var{arg}). When invoking a
- call-back routine, \Prog{libunwind} sets the \Var{as} argument to the
- address-space on whose behalf the invocation is made and the \Var{arg}
- argument to the value that was specified when
- \Func{unw\_init\_remote}(3) was called.
- The synopsis and a detailed description of every call-back routine
- follows below.
- \subsection{Call-back Routine Synopsis}
- \Type{int} \Func{find\_proc\_info}(\Type{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_word\_t} \Var{ip}, \Type{unw\_proc\_info\_t~*}\Var{pip},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{int} \Var{need\_unwind\_info}, \Type{void~*}arg);\\
- \Type{void} \Func{put\_unwind\_info}(\Type{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_proc\_info\_t~*}pip, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{get\_dyn\_info\_list\_addr}(\Type{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_word\_t~*}\Var{dilap}, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{access\_mem}(\Var{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_word\_t} \Var{addr}, \Type{unw\_word\_t~*}\Var{valp},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{int} \Var{write}, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{access\_reg}(\Var{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_regnum\_t} \Var{regnum}, \Type{unw\_word\_t~*}\Var{valp},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{int} \Var{write}, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{access\_fpreg}(\Var{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_regnum\_t} \Var{regnum}, \Type{unw\_fpreg\_t~*}\Var{fpvalp},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{int} \Var{write}, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{resume}(\Var{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_cursor\_t~*}\Var{cp}, \Type{void~*}\Var{arg});\\
- \Type{int} \Func{get\_proc\_name}(\Type{unw\_addr\_space\_t} \Var{as},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{unw\_word\_t} \Var{addr}, \Type{char~*}\Var{bufp},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{size\_t} \Var{buf\_len}, \Type{unw\_word\_t~*}\Var{offp},\\
- \SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\SP\Type{void~*}\Var{arg});\\
- \subsection{find\_proc\_info}
- \Prog{Libunwind} invokes the \Func{find\_proc\_info}() call-back to
- locate the information need to unwind a particular procedure. The
- \Var{ip} argument is an instruction-address inside the procedure whose
- information is needed. The \Var{pip} argument is a pointer to the
- variable used to return the desired information. The type of this
- variable is \Type{unw\_proc\_info\_t}. See
- \Func{unw\_get\_proc\_info(3)} for details. Argument
- \Var{need\_unwind\_info} is zero if the call-back does not need to
- provide values for the following members in the
- \Type{unw\_proc\_info\_t} structure: \Var{format},
- \Var{unwind\_info\_size}, and \Var{unwind\_info}. If
- \Var{need\_unwind\_info} is non-zero, valid values need to be returned
- in these members. Furthermore, the contents of the memory addressed
- by the \Var{unwind\_info} member must remain valid until the info is
- released via the \Func{put\_unwind\_info} call-back (see below).
- On successful completion, the \Func{find\_proc\_info}() call-back must
- return zero. Otherwise, the negative value of one of the
- \Type{unw\_error\_t} error-codes may be returned. In particular, this
- call-back may return -\Const{UNW\_ESTOPUNWIND} to signal the end of
- the frame-chain.
- \subsection{put\_unwind\_info}
- \Prog{Libunwind} invokes the \Func{put\_unwind\_info}() call-back to
- release the resources (such as memory) allocated by a previous call to
- \Func{find\_proc\_info}() with the \Var{need\_unwind\_info} argument
- set to a non-zero value. The \Var{pip} argument has the same value as
- the argument of the same name in the previous matching call to
- \Func{find\_proc\_info}(). Note that \Prog{libunwind} does \emph{not}
- invoke \Func{put\_unwind\_info} for calls to \Func{find\_proc\_info}()
- with a zero \Var{need\_unwind\_info} argument.
- \subsection{get\_dyn\_info\_list\_addr}
- \Prog{Libunwind} invokes the \Func{get\_dyn\_info\_list\_addr}()
- call-back to obtain the address of the head of the dynamic unwind-info
- registration list. The variable stored at the returned address must
- have a type of \Type{unw\_dyn\_info\_list\_t} (see
- \Func{\_U\_dyn\_register}(3)). The \Var{dliap} argument is a pointer
- to a variable of type \Type{unw\_word\_t} which is used to return the
- address of the dynamic unwind-info registration list. If no dynamic
- unwind-info registration list exist, the value pointed to by
- \Var{dliap} must be cleared to zero. \Prog{Libunwind} will cache the
- value returned by \Func{get\_dyn\_info\_list\_addr}() if caching is
- enabled for the given address-space. The cache can be cleared with a
- call to \Func{unw\_flush\_cache}().
- On successful completion, the \Func{get\_dyn\_info\_list\_addr}()
- call-back must return zero. Otherwise, the negative value of one of
- the \Type{unw\_error\_t} error-codes may be returned.
- \subsection{access\_mem}
- \Prog{Libunwind} invokes the \Func{access\_mem}() call-back to read
- from or write to a word of memory in the target address-space. The
- address of the word to be accessed is passed in argument \Var{addr}.
- To read memory, \Prog{libunwind} sets argument \Var{write} to zero and
- \Var{valp} to point to the word that receives the read value. To
- write memory, \Prog{libunwind} sets argument \Var{write} to a non-zero
- value and \Var{valp} to point to the word that contains the value to
- be written. The word that \Var{valp} points to is always in the
- byte-order of the host-platform, regardless of the byte-order of the
- target. In other words, it is the responsibility of the call-back
- routine to convert between the target's and the host's byte-order, if
- necessary.
- On successful completion, the \Func{access\_mem}()
- call-back must return zero. Otherwise, the negative value of one of
- the \Type{unw\_error\_t} error-codes may be returned.
- \subsection{access\_reg}
- \Prog{Libunwind} invokes the \Func{access\_reg}() call-back to read
- from or write to a scalar (non-floating-point) CPU register. The
- index of the register to be accessed is passed in argument
- \Var{regnum}. To read a register, \Prog{libunwind} sets argument
- \Var{write} to zero and \Var{valp} to point to the word that receives
- the read value. To write a register, \Prog{libunwind} sets argument
- \Var{write} to a non-zero value and \Var{valp} to point to the word
- that contains the value to be written. The word that \Var{valp}
- points to is always in the byte-order of the host-platform, regardless
- of the byte-order of the target. In other words, it is the
- responsibility of the call-back routine to convert between the
- target's and the host's byte-order, if necessary.
- On successful completion, the \Func{access\_reg}() call-back must
- return zero. Otherwise, the negative value of one of the
- \Type{unw\_error\_t} error-codes may be returned.
- \subsection{access\_fpreg}
- \Prog{Libunwind} invokes the \Func{access\_fpreg}() call-back to read
- from or write to a floating-point CPU register. The index of the
- register to be accessed is passed in argument \Var{regnum}. To read a
- register, \Prog{libunwind} sets argument \Var{write} to zero and
- \Var{fpvalp} to point to a variable of type \Type{unw\_fpreg\_t} that
- receives the read value. To write a register, \Prog{libunwind} sets
- argument \Var{write} to a non-zero value and \Var{fpvalp} to point to
- the variable of type \Type{unw\_fpreg\_t} that contains the value to
- be written. The word that \Var{fpvalp} points to is always in the
- byte-order of the host-platform, regardless of the byte-order of the
- target. In other words, it is the responsibility of the call-back
- routine to convert between the target's and the host's byte-order, if
- necessary.
- On successful completion, the \Func{access\_fpreg}() call-back must
- return zero. Otherwise, the negative value of one of the
- \Type{unw\_error\_t} error-codes may be returned.
- \subsection{resume}
- \Prog{Libunwind} invokes the \Func{resume}() call-back to resume
- execution in the target address space. Argument \Var{cp} is the
- unwind-cursor that identifies the stack-frame in which execution
- should resume. By the time \Prog{libunwind} invokes the \Func{resume}
- call-back, it has already established the desired machine- and
- memory-state via calls to the \Func{access\_reg}(),
- \Func{access\_fpreg}, and \Func{access\_mem}() call-backs. Thus, all
- the call-back needs to do is perform whatever action is needed to
- actually resume execution.
- The \Func{resume} call-back is invoked only in response to a call to
- \Func{unw\_resume}(3), so applications which never invoke
- \Func{unw\_resume}(3) need not define the \Func{resume} callback.
- On successful completion, the \Func{resume}() call-back must return
- zero. Otherwise, the negative value of one of the
- \Type{unw\_error\_t} error-codes may be returned. As a special case,
- when resuming execution in the local address space, the call-back will
- not return on success.
- \subsection{get\_proc\_name}
- \Prog{Libunwind} invokes the \Func{get\_proc\_name}() call-back to
- obtain the procedure-name of a static (not dynamically generated)
- procedure. Argument \Var{addr} is an instruction-address within the
- procedure whose name is to be obtained. The \Var{bufp} argument is a
- pointer to a character-buffer used to return the procedure name. The
- size of this buffer is specified in argument \Var{buf\_len}. The
- returned name must be terminated by a NUL character. If the
- procedure's name is longer than \Var{buf\_len} bytes, it must be
- truncated to \Var{buf\_len}\Prog{-1} bytes, with the last byte in the
- buffer set to the NUL character and -\Const{UNW\_ENOMEM} must be
- returned. Argument \Var{offp} is a pointer to a word which is used to
- return the byte-offset relative to the start of the procedure whose
- name is being returned. For example, if procedure \Func{foo}() starts
- at address 0x40003000, then invoking \Func{get\_proc\_name}() with
- \Var{addr} set to 0x40003080 should return a value of 0x80 in the word
- pointed to by \Var{offp} (assuming the procedure is at least 0x80
- bytes long).
- On successful completion, the \Func{get\_proc\_name}() call-back must
- return zero. Otherwise, the negative value of one of the
- \Type{unw\_error\_t} error-codes may be returned.
- \section{Return Value}
- On successful completion, \Func{unw\_create\_addr\_space}() returns a
- non-\Const{NULL} value that represents the newly created
- address-space. Otherwise, \Const{NULL} is returned.
- \section{Thread and Signal Safety}
- \Func{unw\_create\_addr\_space}() is thread-safe but \emph{not}
- safe to use from a signal handler.
- \section{See Also}
- \SeeAlso{\_U\_dyn\_register(3)},
- \SeeAlso{libunwind(3)},
- \SeeAlso{unw\_destroy\_addr\_space(3)},
- \SeeAlso{unw\_get\_proc\_info(3)},
- \SeeAlso{unw\_init\_remote(3)},
- \SeeAlso{unw\_resume(3)}
- \section{Author}
- \noindent
- David Mosberger-Tang\\
- Email: \Email{dmosberger@gmail.com}\\
- WWW: \URL{http://www.nongnu.org/libunwind/}.
- \LatexManEnd
- \end{document}
|