diff options
author | Iliyan Malchev <malchev@google.com> | 2011-03-08 16:19:48 -0800 |
---|---|---|
committer | Iliyan Malchev <malchev@google.com> | 2011-03-12 14:59:46 -0800 |
commit | b375e71d306f2fd356b9b356b636e568c4581fa1 (patch) | |
tree | 0cb0325afabe55732edb092659793d39d51c4212 /tools/apriori/hash.c | |
parent | 0469678719a5e8d59b779c8ae8e87a317c5788f5 (diff) | |
download | build-b375e71d306f2fd356b9b356b636e568c4581fa1.zip build-b375e71d306f2fd356b9b356b636e568c4581fa1.tar.gz build-b375e71d306f2fd356b9b356b636e568c4581fa1.tar.bz2 |
build: remove prelinker build build system
This patch removes support for prelinking from the build system. By now, the
prelinker has outlived its usefulness for several reasons. Firstly, the
speedup that it afforded in the early days of Android is now nullified by the
speed of hardware, as well as by the presence of Zygote. Secondly, the space
savings that come with prelinking (measued at 17MB on a recent honeycomb
stingray build) are no longer important either. Thirdly, prelinking reduces
the effectiveness of Address-Space-Layout Randomization. Finally, since it is
not part of the gcc suite, the prelinker needs to be maintained separately.
The patch deletes apriori, soslim, lsd, isprelinked, and iself from the source
tree. It also removes the prelink map.
LOCAL_PRELINK_MODULE becomes a no-op. Individual Android.mk will get cleaned
separately. Support for prelinking will have to be removed from the recovery
code and from the dynamic loader as well.
Change-Id: I5839c9c25f7772d5183eedfe20ab924f2a7cd411
Diffstat (limited to 'tools/apriori/hash.c')
-rw-r--r-- | tools/apriori/hash.c | 27 |
1 files changed, 0 insertions, 27 deletions
diff --git a/tools/apriori/hash.c b/tools/apriori/hash.c deleted file mode 100644 index 9f1a614..0000000 --- a/tools/apriori/hash.c +++ /dev/null @@ -1,27 +0,0 @@ -#include <common.h> -#include <debug.h> -#include <libelf.h> -#include <hash.h> -#include <string.h> - -int hash_lookup(Elf *elf, - Elf_Data *hash, - Elf_Data *symtab, - Elf_Data *symstr, - const char *symname) { - Elf32_Word *hash_data = (Elf32_Word *)hash->d_buf; - Elf32_Word index; - Elf32_Word nbuckets = *hash_data++; - Elf32_Word *buckets = ++hash_data; - Elf32_Word *chains = hash_data + nbuckets; - - index = buckets[elf_hash(symname) % nbuckets]; - while (index != STN_UNDEF && - strcmp((char *)symstr->d_buf + - ((Elf32_Sym *)symtab->d_buf)[index].st_name, - symname)) { - index = chains[index]; - } - - return index; -} |