[memory] Make sure size is properly aligned in FreePages.

- Adds a DCHECK to FreePages that size is a multiple of allocation
  granularity.
- Makes VirtualMemory::Free conform to this.

This is to conform more closely to Chromium's page allocator API.

Bug:chromium:756050

Change-Id: I673e1c225b8bd1009775de1597b575120bd06f8e
Reviewed-on: https://chromium-review.googlesource.com/898008
Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
Commit-Queue: Bill Budge <bbudge@chromium.org>
Cr-Commit-Position: refs/heads/master@{#51064}
This commit is contained in:
Bill Budge 2018-02-01 14:05:05 -08:00 committed by Commit Bot
parent c462ddc80b
commit a231fed8bf
2 changed files with 5 additions and 3 deletions

View File

@ -160,6 +160,7 @@ void* AllocatePages(void* address, size_t size, size_t alignment,
} }
bool FreePages(void* address, const size_t size) { bool FreePages(void* address, const size_t size) {
DCHECK_EQ(0UL, size & (GetPageAllocator()->AllocatePageSize() - 1));
bool result = GetPageAllocator()->FreePages(address, size); bool result = GetPageAllocator()->FreePages(address, size);
#if defined(LEAK_SANITIZER) #if defined(LEAK_SANITIZER)
if (result) { if (result) {
@ -260,7 +261,9 @@ void VirtualMemory::Free() {
size_t size = size_; size_t size = size_;
CHECK(InVM(address, size)); CHECK(InVM(address, size));
Reset(); Reset();
CHECK(FreePages(address, size)); // FreePages expects size to be aligned to allocation granularity. Trimming
// may leave size at only commit granularity. Align it here.
CHECK(FreePages(address, RoundUp(size, AllocatePageSize())));
} }
void VirtualMemory::TakeControl(VirtualMemory* from) { void VirtualMemory::TakeControl(VirtualMemory* from) {

View File

@ -836,8 +836,7 @@ void* OS::Allocate(void* address, size_t size, size_t alignment,
// static // static
bool OS::Free(void* address, const size_t size) { bool OS::Free(void* address, const size_t size) {
DCHECK_EQ(0, reinterpret_cast<uintptr_t>(address) % AllocatePageSize()); DCHECK_EQ(0, reinterpret_cast<uintptr_t>(address) % AllocatePageSize());
// TODO(bbudge) Add DCHECK_EQ(0, size % AllocatePageSize()) when callers DCHECK_EQ(0, size % AllocatePageSize());
// pass the correct size on Windows.
USE(size); USE(size);
return VirtualFree(address, 0, MEM_RELEASE) != 0; return VirtualFree(address, 0, MEM_RELEASE) != 0;
} }