src/runtime: prevent overflow when calculating hashmap growth limits
Этот коммит содержится в:
родитель
050d516264
коммит
93654544b3
1 изменённых файлов: 18 добавлений и 6 удалений
|
@ -109,15 +109,27 @@ func hashmapKeyHashAlg(alg hashmapAlgorithm) func(key unsafe.Pointer, n uintptr)
|
||||||
}
|
}
|
||||||
|
|
||||||
func hashmapShouldGrow(m *hashmap) bool {
|
func hashmapShouldGrow(m *hashmap) bool {
|
||||||
if m.bucketBits == 32 {
|
// with 29 bucket bits, we have potentially 8*(1 << 29) == 2^32 elements
|
||||||
// can't grow any more
|
if m.bucketBits <= 29 {
|
||||||
return false
|
// "maximum" number of elements is 0.75 * buckets * elements per bucket
|
||||||
|
// to avoid overflow, this is calculated as
|
||||||
|
// max = 3 * (1/4 * buckets * elements per bucket)
|
||||||
|
// = 3 * (buckets * (elements per bucket)/4)
|
||||||
|
// = 3 * (buckets * (8/4)
|
||||||
|
// = 3 * (buckets * 2)
|
||||||
|
// = 6 * buckets
|
||||||
|
max := (uintptr(6) << m.bucketBits)
|
||||||
|
return m.count > max
|
||||||
}
|
}
|
||||||
|
|
||||||
// "maximum" number of elements is 0.75 * buckets * elements per bucket
|
if m.bucketBits == 30 && m.count > uintptr(0xe0000000) {
|
||||||
max := uintptr((3 * ((1 << m.bucketBits) * 8)) / 4)
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
return m.count > max
|
// bucketBits == 32 will cause overflow problems on 32-bit platforms, so we limit it to 31.
|
||||||
|
// We're also likely to overflow the `int`-sized map length, causing other issues.
|
||||||
|
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the number of entries in this hashmap, called from the len builtin.
|
// Return the number of entries in this hashmap, called from the len builtin.
|
||||||
|
|
Загрузка…
Создание таблицы
Сослаться в новой задаче