libc: Provide ucontext_t/mcontext_t/<sys/ucontext.h>

This patch updates the C library headers to provide ucontext_t
definitions for three architectures.

+ Fix <signal.h> to always define 'struct sigcontext'.

The new declarations are announced with new macros defined in
<sys/cdefs.h> in order to make it easier to adapt client code
that already defines its own, incompatible, versions of the
structures seen here.

http://code.google.com/p/android/issues/detail?id=34784

Change-Id: Ie78c48690a4ce61c50593f6c39639be7fead3596
This commit is contained in:
David 'Digit' Turner
2012-07-12 19:06:15 +02:00
parent a9944cfe9e
commit c124baaf29
14 changed files with 837 additions and 159 deletions

View File

@@ -29,29 +29,61 @@
#define _SIGNAL_H_
#include <sys/cdefs.h>
#include <limits.h> /* For LONG_BIT */
#include <string.h> /* For memset() */
#include <sys/types.h>
#include <asm/signal.h>
#include <machine/signal.h>
#include <machine/ucontext.h>
#define __ARCH_SI_UID_T __kernel_uid32_t
#include <asm/siginfo.h>
#undef __ARCH_SI_UID_T
#include <limits.h> /* For LONG_BIT */
#include <string.h> /* For memset() */
__BEGIN_DECLS
typedef int sig_atomic_t;
/* _NSIG is used by the SIGRTMAX definition under <asm/signal.h>, however
* its definition is part of a #if __KERNEL__ .. #endif block in the original
* kernel headers and is thus not part of our cleaned-up versions.
/* Previous versions of <signal.h> didn't define 'struct sigcontext'. This
* has led client code to redefine the structure, sometimes in a custom and
* incompatible way.
*
* Looking at the current kernel sources, it is defined as 64 for all
* architectures except for the 'mips' one which set it to 128.
* The __BIONIC_HAVE_STRUCT_SIGCONTEXT macro is defined in <sys/cdefs.h>
* to indicate that <signal.h> does indeed define the structure. For
* maximum source compatibility, client code should follow these guidelines:
*
* - If client code is guaranteed to build against a recent NDK/platform
* version, just include <signal.h> as usual, and use the
* 'struct sigcontext'.
*
* - If client code wants to build against older NDK/platform versions,
* and only uses 'struct sigcontext' without accessing _any_
* of its fields, just always include <asm/sigcontext.h> on Android
* to ensure maximum portability (i.e. to old platform/NDK releases).
* As in:
*
* #include <signal.h>
* #ifdef __BIONIC__
* #include <asm/sigcontext.h>
* #endif
*
* - Otherwise, if the client has a custom sigcontext definition and wants to
* keep it to minimize source changes, use a macro trick as below to avoid
* naming conflicts:
*
* #include <signal.h>
* #ifdef __BIONIC__
* # include <asm/sigcontext.h>
* # ifdef __BIONIC_HAVE_STRUCT_SIGCONTEXT
* # undef sigcontext
* # define sigcontext my_custom_sigcontext
* # endif
* #endif
*/
#ifndef _NSIG
# define _NSIG 64
#endif
/* Similarly, previous versions of the C library didn't define ucontext_t
* and mcontext_t in <signal.h>, or <sys/ucontext.h>. Client code can check
* against the macro __BIONIC_HAVE_UCONTEXT_T to determine if it does.
*
* Beware, that does _not_ mean that <ucontext.h> and related functions are
* available.
*/
typedef int sig_atomic_t;
extern const char * const sys_siglist[];
extern const char * const sys_signame[];

View File

@@ -510,4 +510,12 @@
#define __BIONIC_FORTIFY_UNKNOWN_SIZE ((size_t) -1)
#endif
/* Indicates to client code that <signal.h> now defines 'struct sigcontext'
* properly. See comments in <signal.h> */
#define __BIONIC_HAVE_STRUCT_SIGCONTEXT 1
/* Indicates to client code that <signal.h> now defines 'ucontext_t' */
/* NOTE: That does not mean that <ucontext.h> is available! */
#define __BIONIC_HAVE_UCONTEXT_T 1
#endif /* !_SYS_CDEFS_H_ */

View File

@@ -0,0 +1,43 @@
/*
* Copyright (C) 2012 The Android Open Source Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#ifndef _SYS_UCONTEXT_H_
#define _SYS_UCONTEXT_H_
/* While not standard, this header is typically provided by GLibc and the
* BSD C library to provide for the definition of ucontext_t and mcontext_t,
* without the declarations of the deprecated *context() functions in
* <ucontext.h>.
*
* Client code that directly includes this file exists. Note that
* the better, POSIX-compliant, way to get these declarations is to include
* <signal.h>.
*/
#include <machine/ucontext.h>
#endif /* _SYS_UCONTEXT_H_ */

View File

@@ -30,10 +30,7 @@
#include <sys/cdefs.h>
#include <sys/time.h>
#define __ARCH_SI_UID_T __kernel_uid32_t
#include <asm/siginfo.h>
#undef __ARCH_SI_UID_T
#include <machine/signal.h> /* for struct sigevent */
__BEGIN_DECLS