longjmp, siglongjmp — non-local jump to a saved stack context
#include <setjmp.h>
| void
            longjmp( | jmp_buf | env, | 
| int | val ); | 
| void
            siglongjmp( | sigjmp_buf | env, | 
| int | val ); | 
| ![[Note]](../stylesheet/note.png) | Note | ||
|---|---|---|---|
| 
 | 
longjmp() and setjmp(3) are useful for
      dealing with errors and interrupts encountered in a low-level
      subroutine of a program. longjmp() restores the environment saved by
      the last call of setjmp(3) with the
      corresponding env
      argument. After longjmp() is
      completed, program execution continues as if the
      corresponding call of setjmp(3) had just returned
      the value val.
      longjmp() cannot cause 0 to be
      returned. If longjmp() is
      invoked with a second argument of 0, 1 will be returned
      instead.
siglongjmp() is similar to
      longjmp() except for the type
      of its env argument.
      If the sigsetjmp(3) call that set
      this env used a
      non-zero savesigs
      flag, siglongjmp() also
      restores the set of blocked signals.
POSIX does not specify whether longjmp() will restore the signal context.
      If you want to save and restore signal masks, use
      siglongjmp().
The values of automatic variables are unspecified after a
      call to longjmp() if they meet
      all the following criteria:
Analogous remarks apply for siglongjmp().
longjmp() and siglongjmp() make programs hard to
      understand and maintain. If possible an alternative should be
      used.
This page is part of release 3.16 of the Linux man-pages project. A
      description of the project, and information about reporting
      bugs, can be found at
      http://www.kernel.org/doc/man-pages/.
| Written by Michael Haardt, Fri Nov 25 14:51:42 MET 1994 This is free documentation; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. The GNU General Public License's references to "object code" and "executables" are to be interpreted as the output of any document formatting or typesetting system, including intermediate and printed output. This manual is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this manual; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA. Added siglongjmp, Sun Mar 2 22:03:05 EST 1997, jrvvanzandt.mv.com Modifications, Sun Feb 26 14:39:45 1995, faithcs.unc.edu " |