manual: setjmp: fix typos/grammar

Should hopefully be all obvious stuff.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
This commit is contained in:
Mike Frysinger 2013-12-31 04:43:43 -05:00
parent 0b7c7473b9
commit 6349768c8b
2 changed files with 13 additions and 9 deletions

View File

@ -1,3 +1,7 @@
2014-02-08 Mike Frysinger <vapier@gentoo.org>
* manual/setjmp.texi: Fix typos/grammar errors.
2014-02-08 Mike Frysinger <vapier@gentoo.org> 2014-02-08 Mike Frysinger <vapier@gentoo.org>
* debug/tst-backtrace4.c (handle_signal): Add NUM_FUNCTIONS to output. * debug/tst-backtrace4.c (handle_signal): Add NUM_FUNCTIONS to output.

View File

@ -262,7 +262,7 @@ declared respectively in the @file{ucontext.h} header file.
@comment SVID @comment SVID
@deftp {Data Type} ucontext_t @deftp {Data Type} ucontext_t
The @code{ucontext_t} type is defined as a structure with as least the The @code{ucontext_t} type is defined as a structure with at least the
following elements: following elements:
@table @code @table @code
@ -309,14 +309,14 @@ The function returns @code{0} if successful. Otherwise it returns
The @code{getcontext} function is similar to @code{setjmp} but it does The @code{getcontext} function is similar to @code{setjmp} but it does
not provide an indication of whether the function returns for the first not provide an indication of whether the function returns for the first
time or whether the initialized context was used and the execution is time or whether the initialized context was used and the execution is
resumed at just that point. If this is necessary the user has to take resumed at just that point. If this is necessary the user has to
determine this herself. This must be done carefully since the context determine this herself. This must be done carefully since the context
contains registers which might contain register variables. This is a contains registers which might contain register variables. This is a
good situation to define variables with @code{volatile}. good situation to define variables with @code{volatile}.
Once the context variable is initialized it can be used as is or it can Once the context variable is initialized it can be used as is or it can
be modified. The latter is normally done to implement co-routines or be modified. The latter is normally done to implement co-routines or
similar constructs. The @code{makecontext} function is what has to be similar constructs. The @code{makecontext} function has to be
used to do that. used to do that.
@comment ucontext.h @comment ucontext.h
@ -327,7 +327,7 @@ used to do that.
The @var{ucp} parameter passed to the @code{makecontext} shall be The @var{ucp} parameter passed to the @code{makecontext} shall be
initialized by a call to @code{getcontext}. The context will be initialized by a call to @code{getcontext}. The context will be
modified to in a way so that if the context is resumed it will start by modified in a way such that if the context is resumed it will start by
calling the function @code{func} which gets @var{argc} integer arguments calling the function @code{func} which gets @var{argc} integer arguments
passed. The integer arguments which are to be passed should follow the passed. The integer arguments which are to be passed should follow the
@var{argc} parameter in the call to @code{makecontext}. @var{argc} parameter in the call to @code{makecontext}.
@ -347,7 +347,7 @@ information about the exact use.
While allocating the memory for the stack one has to be careful. Most While allocating the memory for the stack one has to be careful. Most
modern processors keep track of whether a certain memory region is modern processors keep track of whether a certain memory region is
allowed to contain code which is executed or not. Data segments and allowed to contain code which is executed or not. Data segments and
heap memory is normally not tagged to allow this. The result is that heap memory are normally not tagged to allow this. The result is that
programs would fail. Examples for such code include the calling programs would fail. Examples for such code include the calling
sequences the GNU C compiler generates for calls to nested functions. sequences the GNU C compiler generates for calls to nested functions.
Safe ways to allocate stacks correctly include using memory on the Safe ways to allocate stacks correctly include using memory on the
@ -363,7 +363,7 @@ the @code{uc_stack} element to point to the base of the memory region
allocated for the stack and the size of the memory region is stored in allocated for the stack and the size of the memory region is stored in
@code{ss_size}. There are implements out there which require @code{ss_size}. There are implements out there which require
@code{ss_sp} to be set to the value the stack pointer will have (which @code{ss_sp} to be set to the value the stack pointer will have (which
can depending on the direction the stack grows be different). This can, depending on the direction the stack grows, be different). This
difference makes the @code{makecontext} function hard to use and it difference makes the @code{makecontext} function hard to use and it
requires detection of the platform at compile time. requires detection of the platform at compile time.
@ -429,7 +429,7 @@ installed and execution continues as described in this context.
If @code{swapcontext} succeeds the function does not return unless the If @code{swapcontext} succeeds the function does not return unless the
context @var{oucp} is used without prior modification by context @var{oucp} is used without prior modification by
@code{makecontext}. The return value in this case is @code{0}. If the @code{makecontext}. The return value in this case is @code{0}. If the
function fails it returns @code{-1} and set @var{errno} accordingly. function fails it returns @code{-1} and sets @var{errno} accordingly.
@end deftypefun @end deftypefun
@heading Example for SVID Context Handling @heading Example for SVID Context Handling
@ -437,7 +437,7 @@ function fails it returns @code{-1} and set @var{errno} accordingly.
The easiest way to use the context handling functions is as a The easiest way to use the context handling functions is as a
replacement for @code{setjmp} and @code{longjmp}. The context contains replacement for @code{setjmp} and @code{longjmp}. The context contains
on most platforms more information which might lead to less surprises on most platforms more information which might lead to less surprises
but this also means using these functions is more expensive (beside but this also means using these functions is more expensive (besides
being less portable). being less portable).
@smallexample @smallexample
@ -488,7 +488,7 @@ different context. It is not allowed to do the context switching from
the signal handler directly since neither @code{setcontext} nor the signal handler directly since neither @code{setcontext} nor
@code{swapcontext} are functions which can be called from a signal @code{swapcontext} are functions which can be called from a signal
handler. But setting a variable in the signal handler and checking it handler. But setting a variable in the signal handler and checking it
in the body of the functions which are executed. Since in the body of the functions which are executed is OK. Since
@code{swapcontext} is saving the current context it is possible to have @code{swapcontext} is saving the current context it is possible to have
multiple different scheduling points in the code. Execution will always multiple different scheduling points in the code. Execution will always
resume where it was left. resume where it was left.