diff options
author | Ian Lance Taylor <iant@google.com> | 2007-12-22 01:53:39 +0000 |
---|---|---|
committer | Ian Lance Taylor <iant@google.com> | 2007-12-22 01:53:39 +0000 |
commit | cf88803ada9d053a8d6f48437bb117a6ca45e0db (patch) | |
tree | ba08ade182a8215bba06f0cfd6cbfbb710daa51e /gold | |
parent | 06a9731e8a3fa1bfd5f79be0f3c624046b75cc75 (diff) | |
download | gdb-cf88803ada9d053a8d6f48437bb117a6ca45e0db.zip gdb-cf88803ada9d053a8d6f48437bb117a6ca45e0db.tar.gz gdb-cf88803ada9d053a8d6f48437bb117a6ca45e0db.tar.bz2 |
Use a simpler hash function.
Diffstat (limited to 'gold')
-rw-r--r-- | gold/stringpool.cc | 30 |
1 files changed, 9 insertions, 21 deletions
diff --git a/gold/stringpool.cc b/gold/stringpool.cc index 0e92ec1..f569e52 100644 --- a/gold/stringpool.cc +++ b/gold/stringpool.cc @@ -151,28 +151,16 @@ size_t Stringpool_template<Stringpool_char>::string_hash(const Stringpool_char* s, size_t length) { - // Fowler/Noll/Vo (FNV) hash (type FNV-1a). + // This is the hash function used by the dynamic linker for + // DT_GNU_HASH entries. I compared this to a Fowler/Noll/Vo hash + // for a C++ program with 385,775 global symbols. This hash + // function was very slightly worse. However, it is much faster to + // compute. Overall wall clock time was a win. const unsigned char* p = reinterpret_cast<const unsigned char*>(s); - if (sizeof(size_t) > 4) - { - size_t result = static_cast<size_t>(14695981039346656037ULL); - for (size_t i = 0; i < length * sizeof(Stringpool_char); ++i) - { - result ^= static_cast<size_t>(*p++); - result *= 1099511628211ULL; - } - return result; - } - else - { - size_t result = 2166136261UL; - for (size_t i = 0; i < length * sizeof(Stringpool_char); ++i) - { - result ^= static_cast<size_t>(*p++); - result *= 16777619UL; - } - return result; - } + size_t h = 5381; + for (size_t i = 0; i < length * sizeof(Stringpool_char); ++i) + h = h * 33 + *p++; + return h; } // Add the string S to the list of canonical strings. Return a |