dwww Home | Manual pages | Find package

UNW_INIT_LOCAL(3)            Programming Library             UNW_INIT_LOCAL(3)

NAME
       unw_init_local -- initialize cursor for local unwinding

SYNOPSIS
       #include <libunwind.h>

       int unw_init_local(unw_cursor_t *c, unw_context_t *ctxt);
       int unw_init_local2(unw_cursor_t *c, unw_context_t *ctxt, int flag);

DESCRIPTION
       The  unw_init_local()  routine initializes the unwind cursor pointed to
       by c with the machine-state in the  context  structure  pointed  to  by
       ctxt.   As  such,  the  machine-state pointed to by ctxt identifies the
       initial stack frame at which unwinding starts. The machine-state is ex-
       pected to be one provided by a call to unw_getcontext; as such, the in-
       struction pointer may point to the instruction after the last  instruc-
       tion  of a function, and libunwind will back-up the instruction pointer
       before beginning a walk up the call stack. The machine-state  must  re-
       main valid for the duration for which the cursor c is in use.

       The  unw_init_local() routine can be used only for unwinding in the ad-
       dress space of the current process (i.e., for  local  unwinding).   For
       all  other cases, unw_init_remote() must be used instead.  However, un-
       wind performance may be  better  when  using  unw_init_local().   Also,
       unw_init_local() is available even when UNW_LOCAL_ONLY has been defined
       before including <libunwind.h>, whereas unw_init_remote() is not.

       If the unw_context_t is known to be a  signal  frame  (i.e.,  from  the
       third  argument  in  a  sigaction  handler on linux), unw_init_local2()
       should be used for correct initialization on  some  platforms,  passing
       the UNW_INIT_SIGNAL_FRAME flag.

RETURN VALUE
       On  successful  completion,  unw_init_local() returns 0.  Otherwise the
       negative value of one of the error-codes below is returned.

THREAD AND SIGNAL SAFETY
       unw_init_local() is thread-safe as well as safe to use  from  a  signal
       handler.

ERRORS
       UNW_EINVAL
               unw_init_local()  was  called  in  a version of libunwind which
              supports remote unwinding only (this normally happens when call-
              ing unw_init_local() for a cross-platform version of libunwind).

       UNW_EUNSPEC
               An unspecified error occurred.

       UNW_EBADREG
               A register needed by unw_init_local() wasn't accessible.

SEE ALSO
       libunwind(3), unw_init_remote(3)

AUTHOR
       David Mosberger-Tang
       Email: dmosberger@gmail.com
       WWW: http://www.nongnu.org/libunwind/.

Programming Library             16 August 2017               UNW_INIT_LOCAL(3)

Generated by dwww version 1.14 on Fri Jan 24 06:13:24 CET 2025.