diff options
author | primiano@chromium.org <primiano@chromium.org> | 2014-10-21 08:30:28 +0000 |
---|---|---|
committer | primiano@chromium.org <primiano@chromium.org> | 2014-10-21 08:30:28 +0000 |
commit | a1d7ad0c79e373fde08fcf8f4a9201569c45bbc0 (patch) | |
tree | 0861beace75d06e468f1d21aeb9344da14cfdf28 /src/common/android/include/sys/user.h | |
parent | Fixing the Mac Inspector build by adding the launch_report dependency to the ... (diff) | |
download | breakpad-a1d7ad0c79e373fde08fcf8f4a9201569c45bbc0.tar.xz |
Remove unecessary headers following NDK r10c update.
BUG=chromium:358831
R=primiano@chromium.org, rmcilroy@chromium.org
Review URL: https://breakpad.appspot.com/10694002
git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@1394 4c0a9323-5329-0410-9bdc-e9ce6186880e
Diffstat (limited to 'src/common/android/include/sys/user.h')
-rw-r--r-- | src/common/android/include/sys/user.h | 229 |
1 files changed, 0 insertions, 229 deletions
diff --git a/src/common/android/include/sys/user.h b/src/common/android/include/sys/user.h deleted file mode 100644 index f7b67062..00000000 --- a/src/common/android/include/sys/user.h +++ /dev/null @@ -1,229 +0,0 @@ -// Copyright (c) 2012, Google Inc. -// 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. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// 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 GOOGLE_BREAKPAD_COMMON_ANDROID_INCLUDE_SYS_USER_H -#define GOOGLE_BREAKPAD_COMMON_ANDROID_INCLUDE_SYS_USER_H - -#ifdef __cplusplus -extern "C" { -#endif // __cplusplus - -// These types are used with ptrace(), more specifically with -// PTRACE_GETREGS, PTRACE_GETFPREGS and PTRACE_GETVFPREGS respectively. -// -// They are also defined, sometimes with different names, in <asm/user.h> -// - -#if defined(__arm__) - -#define _ARM_USER_H 1 // Prevent <asm/user.h> conflicts - -// Note: on ARM, GLibc uses user_regs instead of user_regs_struct. -struct user_regs { - // Note: Entries 0-15 match r0..r15 - // Entry 16 is used to store the CPSR register. - // Entry 17 is used to store the "orig_r0" value. - unsigned long int uregs[18]; -}; - -// Same here: user_fpregs instead of user_fpregs_struct. -struct user_fpregs { - struct fp_reg { - unsigned int sign1:1; - unsigned int unused:15; - unsigned int sign2:1; - unsigned int exponent:14; - unsigned int j:1; - unsigned int mantissa1:31; - unsigned int mantissa0:32; - } fpregs[8]; - unsigned int fpsr:32; - unsigned int fpcr:32; - unsigned char ftype[8]; - unsigned int init_flag; -}; - -// GLibc doesn't define this one in <sys/user.h> though. -struct user_vfpregs { - unsigned long long fpregs[32]; - unsigned long fpscr; -}; - -#elif defined(__aarch64__) - -// aarch64 does not have user_regs definitions in <asm/user.h>, instead -// use the definitions in <asm/ptrace.h>, which we don't need to redefine here. - -#elif defined(__i386__) - -#define _I386_USER_H 1 // Prevent <asm/user.h> conflicts - -// GLibc-compatible definitions -struct user_regs_struct { - long ebx, ecx, edx, esi, edi, ebp, eax; - long xds, xes, xfs, xgs, orig_eax; - long eip, xcs, eflags, esp, xss; -}; - -struct user_fpregs_struct { - long cwd, swd, twd, fip, fcs, foo, fos; - long st_space[20]; -}; - -struct user_fpxregs_struct { - unsigned short cwd, swd, twd, fop; - long fip, fcs, foo, fos, mxcsr, reserved; - long st_space[32]; - long xmm_space[32]; - long padding[56]; -}; - -struct user { - struct user_regs_struct regs; - int u_fpvalid; - struct user_fpregs_struct i387; - unsigned long u_tsize; - unsigned long u_dsize; - unsigned long u_ssize; - unsigned long start_code; - unsigned long start_stack; - long signal; - int reserved; - struct user_regs_struct* u_ar0; - struct user_fpregs_struct* u_fpstate; - unsigned long magic; - char u_comm [32]; - int u_debugreg [8]; -}; - - -#elif defined(__mips__) - -#define _ASM_USER_H 1 // Prevent <asm/user.h> conflicts - -#define EF_REG0 6 -#define EF_REG1 7 -#define EF_REG2 8 -#define EF_REG3 9 -#define EF_REG4 10 -#define EF_REG5 11 -#define EF_REG6 12 -#define EF_REG7 13 -#define EF_REG8 14 -#define EF_REG9 15 -#define EF_REG10 16 -#define EF_REG11 17 -#define EF_REG12 18 -#define EF_REG13 19 -#define EF_REG14 20 -#define EF_REG15 21 -#define EF_REG16 22 -#define EF_REG17 23 -#define EF_REG18 24 -#define EF_REG19 25 -#define EF_REG20 26 -#define EF_REG21 27 -#define EF_REG22 28 -#define EF_REG23 29 -#define EF_REG24 30 -#define EF_REG25 31 - -/* - * k0/k1 unsaved - */ -#define EF_REG26 32 -#define EF_REG27 33 - -#define EF_REG28 34 -#define EF_REG29 35 -#define EF_REG30 36 -#define EF_REG31 37 - -/* - * Saved special registers - */ -#define EF_LO 38 -#define EF_HI 39 -#define EF_CP0_EPC 40 -#define EF_CP0_BADVADDR 41 -#define EF_CP0_STATUS 42 -#define EF_CP0_CAUSE 43 - -struct user_regs_struct { - unsigned long long regs[32]; - unsigned long long lo; - unsigned long long hi; - unsigned long long epc; - unsigned long long badvaddr; - unsigned long long status; - unsigned long long cause; -}; - -struct user_fpregs_struct { - unsigned long long regs[32]; - unsigned int fpcsr; - unsigned int fir; -}; - -#elif defined(__x86_64__) - -// Bionic's user_fpregs_struct calls the tag word twd instead of ftw. To avoid -// changing lots of Bionic, use an ugly macro renaming trick with -// #include_next. -// TODO(rmcilroy): Remove when NDK headers are fixed. -#define user_fpregs_struct __bionic_user_fpregs_struct -#include_next <sys/user.h> -#undef user_fpregs_struct - -// This struct is the same as user_fpregs_struct in Bionic's sys/user.h -// except that the struct name and individual field names are chosen here -// to match the ones used in breakpad for other x86_64 platforms. -struct user_fpregs_struct { - __u16 cwd; - __u16 swd; - __u16 ftw; - __u16 fop; - __u64 rip; - __u64 rdp; - __u32 mxcsr; - __u32 mxcr_mask; - __u32 st_space[32]; /* 8*16 bytes for each FP-reg = 128 bytes */ - __u32 xmm_space[64]; /* 16*16 bytes for each XMM-reg = 256 bytes */ - __u32 padding[24]; -}; - -#else -# error "Unsupported Android CPU ABI" -#endif - -#ifdef __cplusplus -} // extern "C" -#endif // __cplusplus - -#endif // GOOGLE_BREAKPAD_COMMON_ANDROID_INCLUDE_SYS_USER_H |