From 51d479427777dff694320df855b591e0474d8388 Mon Sep 17 00:00:00 2001 From: Pavel Chupin Date: Mon, 20 Aug 2012 10:21:24 +0400 Subject: [PATCH] Replace link.h for mips with new version for all platforms Update from bionic/libc/include/link.h For details see https://android-review.googlesource.com/#/c/41705 Change-Id: Ib9e658aa0606584b148e951ad199dc12c2f563c2 Signed-off-by: Pavel Chupin --- ndk/platforms/android-3/include/link.h | 55 +++++++++++++++++++ .../android-9/arch-mips/include/link.h | 26 --------- 2 files changed, 55 insertions(+), 26 deletions(-) create mode 100644 ndk/platforms/android-3/include/link.h delete mode 100644 ndk/platforms/android-9/arch-mips/include/link.h diff --git a/ndk/platforms/android-3/include/link.h b/ndk/platforms/android-3/include/link.h new file mode 100644 index 000000000..842b4483d --- /dev/null +++ b/ndk/platforms/android-3/include/link.h @@ -0,0 +1,55 @@ +/* + * 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 _LINK_H_ +#define _LINK_H_ + +#include +#include + +__BEGIN_DECLS + +/* bionic is currently only 32-bit. */ +#define ElfW(type) Elf32_##type + +struct dl_phdr_info { + ElfW(Addr) dlpi_addr; + const char* dlpi_name; + const ElfW(Phdr)* dlpi_phdr; + ElfW(Half) dlpi_phnum; +}; + +#ifdef __arm__ +typedef long unsigned int* _Unwind_Ptr; +_Unwind_Ptr dl_unwind_find_exidx(_Unwind_Ptr pc, int* pcount); +#else +int dl_iterate_phdr(int (*cb)(struct dl_phdr_info*, size_t, void*), void*); +#endif + +__END_DECLS + +#endif /* _LINK_H_ */ diff --git a/ndk/platforms/android-9/arch-mips/include/link.h b/ndk/platforms/android-9/arch-mips/include/link.h deleted file mode 100644 index 1c009c6d6..000000000 --- a/ndk/platforms/android-9/arch-mips/include/link.h +++ /dev/null @@ -1,26 +0,0 @@ -/* - For building unwind-dw2-fde-glibc.c for MIPS frame unwinding, - we need to have that defines struct dl_phdr_info, - ELFW(type), and dl_iterate_phdr(). -*/ - -#include -#include - -struct dl_phdr_info -{ - Elf32_Addr dlpi_addr; - const char *dlpi_name; - const Elf32_Phdr *dlpi_phdr; - Elf32_Half dlpi_phnum; -}; - -#if _MIPS_SZPTR == 32 -#define ElfW(type) Elf32_##type -#elif _MIPS_SZPTR == 64 -#define ElfW(type) Elf64_##type -#endif - -int -dl_iterate_phdr(int (*cb)(struct dl_phdr_info *info, size_t size, void *data), - void *data);