mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-29 02:20:21 +08:00
72b6105518
When creating a split manual with one-node-per-page, the main index.html ends up getting clobbered by the page for the index() function because it uses "@node index" which, for html, also creates an index.html page. To remedy this, add "Function " to every function node so now we output "Function-index.html" and avoid clobbering. It also namespaces every other function and helps make sure we don't clobber anything else. Otherwise, there isn't really much rendering difference as @node text is mostly internal. Node title text comes from @section instead.
73 lines
1.9 KiB
TeX
73 lines
1.9 KiB
TeX
@node Xtensa
|
|
@chapter Functions for Xtensa Processors
|
|
|
|
This chapter describes machine-dependent functions that are included
|
|
in the C library when it is built for Xtensa processors.
|
|
|
|
@menu
|
|
* Function setjmp:: Save stack environment
|
|
* Function longjmp:: Non-local goto
|
|
@end menu
|
|
|
|
@page
|
|
@node Function setjmp
|
|
@section @code{setjmp}---save stack environment
|
|
@findex setjmp
|
|
@strong{Synopsis}
|
|
@example
|
|
#include <setjmp.h>
|
|
int setjmp(jmp_buf env);
|
|
|
|
@end example
|
|
@strong{Description}@*
|
|
@code{setjmp} and @code{longjmp} are useful for dealing with errors
|
|
and interrupts encountered in a low-level subroutine of a program.
|
|
@code{setjmp} saves the stack context/environment in @code{env} for
|
|
later use by @code{longjmp}. The stack context will be invalidated if
|
|
the function which called @code{setjmp} returns.
|
|
|
|
@*
|
|
@strong{Returns}@*
|
|
@code{setjmp} returns 0 if returning directly, and non-zero when
|
|
returning from @code{longjmp} using the saved context.
|
|
|
|
@*
|
|
@strong{Portability}@*
|
|
@code{setjmp} is ANSI C and POSIX.1.
|
|
|
|
setjmp requires no supporting OS subroutines.
|
|
|
|
@*
|
|
@page
|
|
@node Function longjmp
|
|
@section @code{longjmp}---non-local goto
|
|
@findex longjmp
|
|
@strong{Synopsis}
|
|
@example
|
|
#include <setjmp.h>
|
|
void longjmp(jmp_buf env, int val);
|
|
|
|
@end example
|
|
@strong{Description}@*
|
|
@code{longjmp} and @code{setjmp} are useful for dealing with errors
|
|
and interrupts encountered in a low-level subroutine of a program.
|
|
@code{longjmp} restores the environment saved by the last call of
|
|
@code{setjmp} with the corresponding @code{env} argument. After
|
|
@code{longjmp} is completed, program execution continues as if the
|
|
corresponding call of @code{setjmp} had just returned the value
|
|
@code{val}. @code{longjmp} cannot cause 0 to be returned. If
|
|
@code{longjmp} is invoked with a second argument of 0, 1 will be
|
|
returned instead.
|
|
|
|
@*
|
|
@strong{Returns}@*
|
|
This function never returns.
|
|
|
|
@*
|
|
@strong{Portability}@*
|
|
@code{longjmp} is ANSI C and POSIX.1.
|
|
|
|
longjmp requires no supporting OS subroutines.
|
|
|
|
@*
|