Commit 1ad30f0b authored by Clemens Hammacher's avatar Clemens Hammacher Committed by Commit Bot

[wasm] Fix committing memory on win32

This code is rarely used, but it makes invalid assumptions. The
reversations in {owned_code_space_} might not actually be sorted, so we
cannot assume that whenever there is an overlap this will be at the end
of the to-be-committed range.

Minor drive-by improvements: Use iterator, remove redundant DCHECK.

R=mstarzinger@chromium.org

Change-Id: I56bca4298c89e97395de71f9d9be404a7b2bf621
Reviewed-on: https://chromium-review.googlesource.com/1245770Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#56263}
parent 88a444ba
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include <iomanip> #include <iomanip>
#include "src/assembler-inl.h" #include "src/assembler-inl.h"
#include "src/base/adapters.h"
#include "src/base/macros.h" #include "src/base/macros.h"
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/codegen.h" #include "src/codegen.h"
...@@ -680,9 +681,9 @@ Vector<byte> NativeModule::AllocateForCode(size_t size) { ...@@ -680,9 +681,9 @@ Vector<byte> NativeModule::AllocateForCode(size_t size) {
mem = free_code_space_.Allocate(size); mem = free_code_space_.Allocate(size);
DCHECK(!mem.is_empty()); DCHECK(!mem.is_empty());
} }
Address commit_start = const Address page_size = page_allocator->AllocatePageSize();
RoundUp(mem.begin(), page_allocator->AllocatePageSize()); Address commit_start = RoundUp(mem.begin(), page_size);
Address commit_end = RoundUp(mem.end(), page_allocator->AllocatePageSize()); Address commit_end = RoundUp(mem.end(), page_size);
// {commit_start} will be either mem.start or the start of the next page. // {commit_start} will be either mem.start or the start of the next page.
// {commit_end} will be the start of the page after the one in which // {commit_end} will be the start of the page after the one in which
// the allocation ends. // the allocation ends.
...@@ -698,23 +699,24 @@ Vector<byte> NativeModule::AllocateForCode(size_t size) { ...@@ -698,23 +699,24 @@ Vector<byte> NativeModule::AllocateForCode(size_t size) {
// we need more memory, we append that memory at the end of the // we need more memory, we append that memory at the end of the
// owned_code_space_ list, we traverse that list in reverse order to find // owned_code_space_ list, we traverse that list in reverse order to find
// the reservation(s) that guide how to chunk the region to commit. // the reservation(s) that guide how to chunk the region to commit.
for (auto it = owned_code_space_.crbegin(), for (auto& vmem : base::Reversed(owned_code_space_)) {
rend = owned_code_space_.crend(); if (commit_end <= vmem.address() || vmem.end() <= commit_start) continue;
it != rend && commit_start < commit_end; ++it) { Address start = std::max(commit_start, vmem.address());
if (commit_end > it->end() || it->address() >= commit_end) continue; Address end = std::min(commit_end, vmem.end());
Address start = std::max(commit_start, it->address()); size_t commit_size = static_cast<size_t>(end - start);
size_t commit_size = static_cast<size_t>(commit_end - start);
DCHECK(IsAligned(commit_size, page_allocator->AllocatePageSize()));
if (!wasm_code_manager_->Commit(start, commit_size)) { if (!wasm_code_manager_->Commit(start, commit_size)) {
V8::FatalProcessOutOfMemory(nullptr, V8::FatalProcessOutOfMemory(nullptr,
"NativeModule::AllocateForCode commit"); "NativeModule::AllocateForCode commit");
UNREACHABLE(); UNREACHABLE();
} }
commit_end = start; // Opportunistically reduce the commit range. This might terminate the
// loop early.
if (commit_start == start) commit_start = end;
if (commit_end == end) commit_end = start;
if (commit_start >= commit_end) break;
} }
#else #else
size_t commit_size = static_cast<size_t>(commit_end - commit_start); size_t commit_size = static_cast<size_t>(commit_end - commit_start);
DCHECK(IsAligned(commit_size, page_allocator->AllocatePageSize()));
if (!wasm_code_manager_->Commit(commit_start, commit_size)) { if (!wasm_code_manager_->Commit(commit_start, commit_size)) {
V8::FatalProcessOutOfMemory(nullptr, V8::FatalProcessOutOfMemory(nullptr,
"NativeModule::AllocateForCode commit"); "NativeModule::AllocateForCode commit");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment