mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-04-03 04:52:54 +00:00
Backed out changeset 4f7c6bf2b8fe (Bug 1057393) for bustage on a CLOSED TREE
--HG-- extra : rebase_source : 9d12fbd474eaff04fe52bad48c1afda7bb9288b8
This commit is contained in:
parent
e96abc463e
commit
e849322dc3
@ -2769,7 +2769,7 @@ ArenaLists::refillFreeListInGC(Zone *zone, AllocKind thingKind)
|
||||
|
||||
Allocator &allocator = zone->allocator;
|
||||
JS_ASSERT(allocator.arenas.freeLists[thingKind].isEmpty());
|
||||
mozilla::DebugOnly<JSRuntime *> rt = zone->runtimeFromMainThread();
|
||||
JSRuntime *rt = zone->runtimeFromMainThread();
|
||||
JS_ASSERT(rt->isHeapMajorCollecting());
|
||||
JS_ASSERT(!rt->gc.isBackgroundSweeping());
|
||||
|
||||
|
@ -59,8 +59,17 @@ struct MallocProvider
|
||||
|
||||
template <class T>
|
||||
T *pod_malloc(size_t numElems) {
|
||||
MOZ_ASSERT(numElems > 0);
|
||||
return pod_malloc_with_extra<T, T>(numElems - 1);
|
||||
T *p = js_pod_malloc<T>(numElems);
|
||||
if (MOZ_LIKELY(p)) {
|
||||
client()->updateMallocCounter(numElems * sizeof(T));
|
||||
return p;
|
||||
}
|
||||
if (numElems & mozilla::tl::MulOverflowMask<sizeof(T)>::value) {
|
||||
client()->reportAllocationOverflow();
|
||||
return nullptr;
|
||||
}
|
||||
client()->onOutOfMemory(nullptr, numElems * sizeof(T));
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
template <class T, class U>
|
||||
@ -74,7 +83,7 @@ struct MallocProvider
|
||||
client()->reportAllocationOverflow();
|
||||
return nullptr;
|
||||
}
|
||||
T *p = reinterpret_cast<T *>(js_pod_malloc<uint8_t>(bytes));
|
||||
T *p = (T *)js_pod_malloc<uint8_t>(bytes);
|
||||
if (MOZ_LIKELY(p)) {
|
||||
client()->updateMallocCounter(bytes);
|
||||
return p;
|
||||
@ -95,29 +104,23 @@ struct MallocProvider
|
||||
}
|
||||
|
||||
template <class T>
|
||||
T *pod_calloc(size_t numElems) {
|
||||
MOZ_ASSERT(numElems > 0);
|
||||
return pod_calloc_with_extra<T, T>(numElems - 1);
|
||||
T *
|
||||
pod_calloc(size_t numElems) {
|
||||
T *p = pod_malloc<T>(numElems);
|
||||
if (MOZ_UNLIKELY(!p))
|
||||
return nullptr;
|
||||
memset(p, 0, numElems * sizeof(T));
|
||||
return p;
|
||||
}
|
||||
|
||||
template <class T, class U>
|
||||
T *pod_calloc_with_extra(size_t numExtra) {
|
||||
if (numExtra & mozilla::tl::MulOverflowMask<sizeof(U)>::value) {
|
||||
client()->reportAllocationOverflow();
|
||||
T *
|
||||
pod_calloc_with_extra(size_t numExtra) {
|
||||
T *p = pod_malloc_with_extra<T, U>(numExtra);
|
||||
if (MOZ_UNLIKELY(!p))
|
||||
return nullptr;
|
||||
}
|
||||
size_t bytes = sizeof(T) + numExtra * sizeof(U);
|
||||
if (bytes < sizeof(T)) {
|
||||
client()->reportAllocationOverflow();
|
||||
return nullptr;
|
||||
}
|
||||
T *p = reinterpret_cast<T *>(js_pod_calloc<uint8_t>(bytes));
|
||||
if (MOZ_LIKELY(p)) {
|
||||
client()->updateMallocCounter(bytes);
|
||||
return p;
|
||||
}
|
||||
client()->onOutOfMemory(nullptr, bytes);
|
||||
return nullptr;
|
||||
memset(p, 0, sizeof(T) + numExtra * sizeof(U));
|
||||
return p;
|
||||
}
|
||||
|
||||
template <class T>
|
||||
|
Loading…
x
Reference in New Issue
Block a user