diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-08-16 21:02:59 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-08-16 21:02:59 +0000 | 
| commit | 3ca95b020283db6244cab92ede73c969253b6a31 (patch) | |
| tree | d16e791e58694facd8f68d3e2797a1eaa8018afc /contrib/llvm/lib/Support/StringMap.cpp | |
| parent | 27067774dce3388702a4cf744d7096c6fb71b688 (diff) | |
| parent | c3aee98e721333f265a88d6bf348e6e468f027d4 (diff) | |
Notes
Diffstat (limited to 'contrib/llvm/lib/Support/StringMap.cpp')
| -rw-r--r-- | contrib/llvm/lib/Support/StringMap.cpp | 16 | 
1 files changed, 15 insertions, 1 deletions
| diff --git a/contrib/llvm/lib/Support/StringMap.cpp b/contrib/llvm/lib/Support/StringMap.cpp index 7be946642d90..7da9ccbd40c7 100644 --- a/contrib/llvm/lib/Support/StringMap.cpp +++ b/contrib/llvm/lib/Support/StringMap.cpp @@ -17,12 +17,26 @@  #include <cassert>  using namespace llvm; +/// Returns the number of buckets to allocate to ensure that the DenseMap can +/// accommodate \p NumEntries without need to grow(). +static unsigned getMinBucketToReserveForEntries(unsigned NumEntries) { +  // Ensure that "NumEntries * 4 < NumBuckets * 3" +  if (NumEntries == 0) +    return 0; +  // +1 is required because of the strict equality. +  // For example if NumEntries is 48, we need to return 401. +  return NextPowerOf2(NumEntries * 4 / 3 + 1); +} +  StringMapImpl::StringMapImpl(unsigned InitSize, unsigned itemSize) {    ItemSize = itemSize;    // If a size is specified, initialize the table with that many buckets.    if (InitSize) { -    init(InitSize); +    // The table will grow when the number of entries reach 3/4 of the number of +    // buckets. To guarantee that "InitSize" number of entries can be inserted +    // in the table without growing, we allocate just what is needed here. +    init(getMinBucketToReserveForEntries(InitSize));      return;    } | 
