Commit 405844b5 authored by ishell's avatar ishell Committed by Commit bot

Fixed memory-leak in d8. It did not clean evaluation context used for executing shell commands.

BUG=chromium:493284
LOG=N

Review URL: https://codereview.chromium.org/1147343004

Cr-Commit-Position: refs/heads/master@{#28790}
parent 994eb59d
...@@ -1339,19 +1339,7 @@ void SourceGroup::ExecuteInThread() { ...@@ -1339,19 +1339,7 @@ void SourceGroup::ExecuteInThread() {
Execute(isolate); Execute(isolate);
} }
} }
if (Shell::options.send_idle_notification) { Shell::CollectGarbage(isolate);
const double kLongIdlePauseInSeconds = 1.0;
isolate->ContextDisposedNotification();
isolate->IdleNotificationDeadline(
g_platform->MonotonicallyIncreasingTime() +
kLongIdlePauseInSeconds);
}
if (Shell::options.invoke_weak_callbacks) {
// By sending a low memory notifications, we will try hard to collect
// all garbage and will therefore also invoke all weak callbacks of
// actually unreachable persistent handles.
isolate->LowMemoryNotification();
}
} }
done_semaphore_.Signal(); done_semaphore_.Signal();
} while (!Shell::options.last_run); } while (!Shell::options.last_run);
...@@ -1413,6 +1401,10 @@ bool Shell::SetOptions(int argc, char* argv[]) { ...@@ -1413,6 +1401,10 @@ bool Shell::SetOptions(int argc, char* argv[]) {
} else if (strcmp(argv[i], "--test") == 0) { } else if (strcmp(argv[i], "--test") == 0) {
options.test_shell = true; options.test_shell = true;
argv[i] = NULL; argv[i] = NULL;
} else if (strcmp(argv[i], "--notest") == 0 ||
strcmp(argv[i], "--no-test") == 0) {
options.test_shell = false;
argv[i] = NULL;
} else if (strcmp(argv[i], "--send-idle-notification") == 0) { } else if (strcmp(argv[i], "--send-idle-notification") == 0) {
options.send_idle_notification = true; options.send_idle_notification = true;
argv[i] = NULL; argv[i] = NULL;
...@@ -1542,6 +1534,17 @@ int Shell::RunMain(Isolate* isolate, int argc, char* argv[]) { ...@@ -1542,6 +1534,17 @@ int Shell::RunMain(Isolate* isolate, int argc, char* argv[]) {
options.isolate_sources[0].Execute(isolate); options.isolate_sources[0].Execute(isolate);
} }
} }
CollectGarbage(isolate);
#ifndef V8_SHARED
for (int i = 1; i < options.num_isolates; ++i) {
options.isolate_sources[i].WaitForThread();
}
#endif // !V8_SHARED
return 0;
}
void Shell::CollectGarbage(Isolate* isolate) {
if (options.send_idle_notification) { if (options.send_idle_notification) {
const double kLongIdlePauseInSeconds = 1.0; const double kLongIdlePauseInSeconds = 1.0;
isolate->ContextDisposedNotification(); isolate->ContextDisposedNotification();
...@@ -1554,13 +1557,6 @@ int Shell::RunMain(Isolate* isolate, int argc, char* argv[]) { ...@@ -1554,13 +1557,6 @@ int Shell::RunMain(Isolate* isolate, int argc, char* argv[]) {
// unreachable persistent handles. // unreachable persistent handles.
isolate->LowMemoryNotification(); isolate->LowMemoryNotification();
} }
#ifndef V8_SHARED
for (int i = 1; i < options.num_isolates; ++i) {
options.isolate_sources[i].WaitForThread();
}
#endif // !V8_SHARED
return 0;
} }
...@@ -1729,6 +1725,13 @@ int Shell::Main(int argc, char* argv[]) { ...@@ -1729,6 +1725,13 @@ int Shell::Main(int argc, char* argv[]) {
#endif // !V8_SHARED #endif // !V8_SHARED
RunShell(isolate); RunShell(isolate);
} }
// Shut down contexts and collect garbage.
evaluation_context_.Reset();
#ifndef V8_SHARED
utility_context_.Reset();
#endif // !V8_SHARED
CollectGarbage(isolate);
} }
OnExit(isolate); OnExit(isolate);
#ifndef V8_SHARED #ifndef V8_SHARED
......
...@@ -264,6 +264,7 @@ class Shell : public i::AllStatic { ...@@ -264,6 +264,7 @@ class Shell : public i::AllStatic {
static int Main(int argc, char* argv[]); static int Main(int argc, char* argv[]);
static void Exit(int exit_code); static void Exit(int exit_code);
static void OnExit(Isolate* isolate); static void OnExit(Isolate* isolate);
static void CollectGarbage(Isolate* isolate);
#ifndef V8_SHARED #ifndef V8_SHARED
static Handle<Array> GetCompletions(Isolate* isolate, static Handle<Array> GetCompletions(Isolate* isolate,
......
// Copyright 2015 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --invoke-weak-callbacks --omit-quit --no-test
var coll = new Intl.Collator();
assertEquals(-1, coll.compare('a', 'c'));
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