From ae464533ad3909ac5cd5f565b45da81592bf8b49 Mon Sep 17 00:00:00 2001
From: test262-automation <test262-automation@bocoup.com>
Date: Mon, 10 Dec 2018 19:18:21 +0000
Subject: [PATCH] [v8-test262-automation] Changes from
 https://github.com/v8/v8.git at sha 9583858e on Mon Dec 10 2018 19:17:52
 GMT+0000 (Coordinated Universal Time)

---
 .../v8/intl/break-iterator/default-locale.js  |   3 -
 .../wellformed-unsupported-locale.js          |  32 -
 .../v8/intl/collator/default-locale.js        |   4 -
 .../v8/intl/collator/options.js               |   4 -
 .../collator/wellformed-unsupported-locale.js |  32 -
 .../v8/intl/date-format/default-locale.js     |   3 -
 .../wellformed-unsupported-locale.js          |  32 -
 .../v8/intl/default_locale.js                 |  17 +
 .../v8/intl/intl.status                       |  13 +-
 .../v8/intl/number-format/default-locale.js   |   3 -
 .../wellformed-unsupported-locale.js          |  32 -
 .../v8/intl/regress-8414.js                   | 806 ------------------
 .../v8/intl/regress-8469.js                   |  87 ++
 .../v8/intl/regress-8525.js                   |  27 +
 .../v8/mjsunit/code-coverage-block.js         |   4 +-
 .../v8/mjsunit/compiler/regress-910838.js     |  20 +
 .../v8/mjsunit/es6/microtask-delivery.js      |   2 +-
 .../es8/async-arrow-lexical-arguments.js      |   2 +-
 .../es8/async-arrow-lexical-new.target.js     |   2 +-
 .../mjsunit/es8/async-arrow-lexical-super.js  |   2 +-
 .../mjsunit/es8/async-arrow-lexical-this.js   |   2 +-
 .../v8/mjsunit/es8/async-await-basic.js       |  30 +-
 .../mjsunit/es8/async-await-no-constructor.js |   2 +-
 .../v8/mjsunit/es8/async-await-species.js     |   2 +-
 .../v8/mjsunit/es8/async-destructuring.js     |   6 +-
 .../mjsunit/es8/async-function-try-finally.js |   4 +-
 .../harmony/async-from-sync-iterator.js       |   8 +-
 .../mjsunit/harmony/async-generators-basic.js |  34 +-
 .../v8/mjsunit/harmony/for-await-of.js        |   2 +-
 .../import-from-compilation-errored.js        |   2 +-
 .../harmony/import-from-evaluation-errored.js |   2 +-
 .../harmony/import-from-fetch-errored.js      |   2 +-
 .../import-from-instantiation-errored.js      |   2 +-
 .../v8/mjsunit/harmony/modules-import-1.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-10.js   |   2 +-
 .../v8/mjsunit/harmony/modules-import-11.js   |   2 +-
 .../v8/mjsunit/harmony/modules-import-12.js   |   2 +-
 .../v8/mjsunit/harmony/modules-import-13.js   |   4 +-
 .../v8/mjsunit/harmony/modules-import-14.js   |   2 +-
 .../v8/mjsunit/harmony/modules-import-15.js   |   6 +-
 .../v8/mjsunit/harmony/modules-import-16.js   |   6 +-
 .../v8/mjsunit/harmony/modules-import-17.js   |   2 +-
 .../v8/mjsunit/harmony/modules-import-2.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-3.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-5.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-6.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-7.js    |   2 +-
 .../v8/mjsunit/harmony/modules-import-8.js    |   6 +-
 .../v8/mjsunit/harmony/modules-import-9.js    |   2 +-
 ...leanupsome-dereffed-and-cleared-weakref.js |   4 +-
 .../weakrefs/cleanupsome-dereffed-weakref.js  |   6 +-
 .../harmony/weakrefs/cleanupsome-weakref.js   |   2 +-
 .../harmony/weakrefs/clear-after-deref.js     |   2 +-
 .../mjsunit/harmony/weakrefs/two-weakrefs.js  |   8 +-
 .../harmony/weakrefs/weakcell-and-weakref.js  |   4 +-
 .../weakrefs/weakref-creation-keeps-alive.js  |   4 +-
 .../weakrefs/weakref-deref-keeps-alive.js     |   8 +-
 .../v8/mjsunit/mjsunit.status                 |  10 +
 .../v8/mjsunit/regress/regress-5405.js        |   2 +-
 .../v8/mjsunit/regress/regress-5691.js        |   2 +-
 .../v8/mjsunit/regress/regress-682349.js      |   2 +-
 .../v8/mjsunit/regress/regress-740694.js      |   2 +-
 .../v8/mjsunit/regress/regress-797581.js      |   2 +-
 .../v8/mjsunit/regress/regress-800651.js      |   2 +-
 .../mjsunit/regress/regress-crbug-911416.js   |   5 +
 .../v8/mjsunit/regress/wasm/regress-8533.js   |  85 ++
 .../v8/mjsunit/test-async.js                  |   4 +-
 .../v8/test262/test262.status                 |  13 +-
 .../v8/test262/testcfg.py                     |   3 +-
 .../v8/wasm-js/wasm-js.status                 |   1 -
 70 files changed, 378 insertions(+), 1064 deletions(-)
 delete mode 100644 implementation-contributed/v8/intl/break-iterator/wellformed-unsupported-locale.js
 delete mode 100644 implementation-contributed/v8/intl/collator/wellformed-unsupported-locale.js
 delete mode 100644 implementation-contributed/v8/intl/date-format/wellformed-unsupported-locale.js
 create mode 100644 implementation-contributed/v8/intl/default_locale.js
 delete mode 100644 implementation-contributed/v8/intl/number-format/wellformed-unsupported-locale.js
 delete mode 100644 implementation-contributed/v8/intl/regress-8414.js
 create mode 100644 implementation-contributed/v8/intl/regress-8469.js
 create mode 100644 implementation-contributed/v8/intl/regress-8525.js
 create mode 100644 implementation-contributed/v8/mjsunit/compiler/regress-910838.js
 create mode 100644 implementation-contributed/v8/mjsunit/regress/regress-crbug-911416.js
 create mode 100644 implementation-contributed/v8/mjsunit/regress/wasm/regress-8533.js

diff --git a/implementation-contributed/v8/intl/break-iterator/default-locale.js b/implementation-contributed/v8/intl/break-iterator/default-locale.js
index e1a42a100a..fd379db1c8 100644
--- a/implementation-contributed/v8/intl/break-iterator/default-locale.js
+++ b/implementation-contributed/v8/intl/break-iterator/default-locale.js
@@ -37,9 +37,6 @@ assertFalse(options.locale === 'und');
 assertFalse(options.locale === '');
 assertFalse(options.locale === undefined);
 
-// Then check for legitimacy.
-assertLanguageTag(%GetDefaultICULocale(), options.locale);
-
 var iteratorNone = new Intl.v8BreakIterator();
 assertEquals(options.locale, iteratorNone.resolvedOptions().locale);
 
diff --git a/implementation-contributed/v8/intl/break-iterator/wellformed-unsupported-locale.js b/implementation-contributed/v8/intl/break-iterator/wellformed-unsupported-locale.js
deleted file mode 100644
index ffa44aef08..0000000000
--- a/implementation-contributed/v8/intl/break-iterator/wellformed-unsupported-locale.js
+++ /dev/null
@@ -1,32 +0,0 @@
-// Copyright 2013 the V8 project authors. All rights reserved.
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-//     * Redistributions of source code must retain the above copyright
-//       notice, this list of conditions and the following disclaimer.
-//     * Redistributions in binary form must reproduce the above
-//       copyright notice, this list of conditions and the following
-//       disclaimer in the documentation and/or other materials provided
-//       with the distribution.
-//     * Neither the name of Google Inc. nor the names of its
-//       contributors may be used to endorse or promote products derived
-//       from this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-// Passing a well formed but unsupported locale falls back to default.
-
-var iterator = Intl.v8BreakIterator(['xx']);
-
-assertLanguageTag(%GetDefaultICULocale(), iterator.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/collator/default-locale.js b/implementation-contributed/v8/intl/collator/default-locale.js
index fd964f0620..56435d147f 100644
--- a/implementation-contributed/v8/intl/collator/default-locale.js
+++ b/implementation-contributed/v8/intl/collator/default-locale.js
@@ -37,9 +37,6 @@ assertFalse(options.locale === 'und');
 assertFalse(options.locale === '');
 assertFalse(options.locale === undefined);
 
-// Then check for legitimacy.
-assertLanguageTag(%GetDefaultICULocale(), options.locale);
-
 var collatorNone = new Intl.Collator();
 assertEquals(options.locale, collatorNone.resolvedOptions().locale);
 
@@ -49,5 +46,4 @@ assertEquals(options.locale, collatorBraket.resolvedOptions().locale);
 
 var collatorWithOptions = new Intl.Collator(undefined, {usage: 'search'});
 var locale = collatorWithOptions.resolvedOptions().locale;
-assertLanguageTag(%GetDefaultICULocale(), locale);
 assertEquals(locale.indexOf('-co-search'), -1);
diff --git a/implementation-contributed/v8/intl/collator/options.js b/implementation-contributed/v8/intl/collator/options.js
index f03ff2cafc..126bfc0959 100644
--- a/implementation-contributed/v8/intl/collator/options.js
+++ b/implementation-contributed/v8/intl/collator/options.js
@@ -5,14 +5,12 @@
 // No locale
 var collatorWithOptions = new Intl.Collator(undefined);
 var { locale, usage, collation } = collatorWithOptions.resolvedOptions();
-assertLanguageTag(%GetDefaultICULocale(), locale);
 assertEquals('sort', usage);
 assertEquals('default', collation);
 assertEquals(locale.indexOf('-co-search'), -1);
 
 collatorWithOptions = new Intl.Collator(undefined, {usage: 'sort'});
 var { locale, usage, collation } = collatorWithOptions.resolvedOptions();
-assertLanguageTag(%GetDefaultICULocale(), locale);
 assertEquals('sort', usage);
 assertEquals('default', collation);
 assertEquals(locale.indexOf('-co-search'), -1);
@@ -21,12 +19,10 @@ collatorWithOptions = new Intl.Collator(undefined, {usage: 'search'});
 var { locale, usage, collation } = collatorWithOptions.resolvedOptions();
 assertEquals('search', usage);
 assertEquals('default', collation);
-assertLanguageTag(%GetDefaultICULocale(), locale);
 assertEquals(locale.indexOf('-co-search'), -1);
 
 collatorWithOptions = new Intl.Collator(locale);
 var { locale, usage, collation } = collatorWithOptions.resolvedOptions();
-assertLanguageTag(%GetDefaultICULocale(), locale);
 assertEquals('sort', usage);
 assertEquals('default', collation);
 assertEquals(locale.indexOf('-co-search'), -1);
diff --git a/implementation-contributed/v8/intl/collator/wellformed-unsupported-locale.js b/implementation-contributed/v8/intl/collator/wellformed-unsupported-locale.js
deleted file mode 100644
index ad89e3e220..0000000000
--- a/implementation-contributed/v8/intl/collator/wellformed-unsupported-locale.js
+++ /dev/null
@@ -1,32 +0,0 @@
-// Copyright 2013 the V8 project authors. All rights reserved.
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-//     * Redistributions of source code must retain the above copyright
-//       notice, this list of conditions and the following disclaimer.
-//     * Redistributions in binary form must reproduce the above
-//       copyright notice, this list of conditions and the following
-//       disclaimer in the documentation and/or other materials provided
-//       with the distribution.
-//     * Neither the name of Google Inc. nor the names of its
-//       contributors may be used to endorse or promote products derived
-//       from this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-// Passing a well formed but unsupported locale falls back to default.
-
-var collator = Intl.Collator(['xx']);
-
-assertLanguageTag(%GetDefaultICULocale(), collator.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/date-format/default-locale.js b/implementation-contributed/v8/intl/date-format/default-locale.js
index 2d79e895b5..ecc85da479 100644
--- a/implementation-contributed/v8/intl/date-format/default-locale.js
+++ b/implementation-contributed/v8/intl/date-format/default-locale.js
@@ -37,8 +37,5 @@ assertFalse(options.locale === 'und');
 assertFalse(options.locale === '');
 assertFalse(options.locale === undefined);
 
-// Then check for legitimacy.
-assertLanguageTag(%GetDefaultICULocale(), options.locale);
-
 var dtfNone = new Intl.DateTimeFormat();
 assertEquals(options.locale, dtfNone.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/date-format/wellformed-unsupported-locale.js b/implementation-contributed/v8/intl/date-format/wellformed-unsupported-locale.js
deleted file mode 100644
index b812164832..0000000000
--- a/implementation-contributed/v8/intl/date-format/wellformed-unsupported-locale.js
+++ /dev/null
@@ -1,32 +0,0 @@
-// Copyright 2013 the V8 project authors. All rights reserved.
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-//     * Redistributions of source code must retain the above copyright
-//       notice, this list of conditions and the following disclaimer.
-//     * Redistributions in binary form must reproduce the above
-//       copyright notice, this list of conditions and the following
-//       disclaimer in the documentation and/or other materials provided
-//       with the distribution.
-//     * Neither the name of Google Inc. nor the names of its
-//       contributors may be used to endorse or promote products derived
-//       from this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-// Passing a well formed but unsupported locale falls back to default.
-
-var dtf = Intl.DateTimeFormat(['xx']);
-
-assertLanguageTag(%GetDefaultICULocale(), dtf.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/default_locale.js b/implementation-contributed/v8/intl/default_locale.js
new file mode 100644
index 0000000000..453f5e66ed
--- /dev/null
+++ b/implementation-contributed/v8/intl/default_locale.js
@@ -0,0 +1,17 @@
+// Copyright 2018 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.
+
+// Environment Variables: LC_ALL=de
+
+assertEquals("de", (new Intl.Collator([])).resolvedOptions().locale);
+assertEquals("de", (new Intl.Collator(['xx'])).resolvedOptions().locale);
+assertEquals("de", (new Intl.Collator(undefined)).resolvedOptions().locale);
+assertEquals("de", (new Intl.Collator(undefined, {usage: 'sort'})).resolvedOptions().locale);
+assertEquals("de", (new Intl.Collator(undefined, {usage: 'search'})).resolvedOptions().locale);
+assertEquals("de", (new Intl.DateTimeFormat([])).resolvedOptions().locale);
+assertEquals("de", (new Intl.DateTimeFormat(['xx'])).resolvedOptions().locale);
+assertEquals("de", (new Intl.NumberFormat([])).resolvedOptions().locale);
+assertEquals("de", (new Intl.NumberFormat(['xx'])).resolvedOptions().locale);
+assertEquals("de", (new Intl.v8BreakIterator([])).resolvedOptions().locale);
+assertEquals("de", (new Intl.v8BreakIterator(['xx'])).resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/intl.status b/implementation-contributed/v8/intl/intl.status
index d70056f049..3841b287dc 100644
--- a/implementation-contributed/v8/intl/intl.status
+++ b/implementation-contributed/v8/intl/intl.status
@@ -29,6 +29,9 @@
 [ALWAYS, {
   # TODO(jochen): The following test is flaky.
   'overrides/caching': [PASS, FAIL],
+
+  # https://crbug.com/v8/8469
+  'regress-8469': [FAIL],
 }],  # ALWAYS
 
 ['variant == no_wasm_traps', {
@@ -39,14 +42,18 @@
   # noi18n cannot turn on ICU backend for Date
   'relative-time-format/default-locale-fr-CA': [SKIP],
   'relative-time-format/default-locale-pt-BR': [SKIP],
+
+  # Unable to change locale on Windows:
+  'default_locale': [SKIP],
 }],  # system == windows'
 
 ['system == android', {
   # Android's ICU data file does not have the Chinese/Japanese dictionary
   # required for the test to pass.
-  'break-iterator/zh-break': [FAIL],
+  'break-iterator/zh-break': [SKIP],
   # Unable to change locale on Android:
-  'relative-time-format/default-locale-fr-CA': [FAIL],
-  'relative-time-format/default-locale-pt-BR': [FAIL],
+  'relative-time-format/default-locale-fr-CA': [SKIP],
+  'relative-time-format/default-locale-pt-BR': [SKIP],
+  'default_locale': [SKIP],
 }],  # 'system == android'
 ]
diff --git a/implementation-contributed/v8/intl/number-format/default-locale.js b/implementation-contributed/v8/intl/number-format/default-locale.js
index a24aec2333..7e67176baf 100644
--- a/implementation-contributed/v8/intl/number-format/default-locale.js
+++ b/implementation-contributed/v8/intl/number-format/default-locale.js
@@ -37,8 +37,5 @@ assertFalse(options.locale === 'und');
 assertFalse(options.locale === '');
 assertFalse(options.locale === undefined);
 
-// Then check for legitimacy.
-assertLanguageTag(%GetDefaultICULocale(), options.locale);
-
 var nfNone = new Intl.NumberFormat();
 assertEquals(options.locale, nfNone.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/number-format/wellformed-unsupported-locale.js b/implementation-contributed/v8/intl/number-format/wellformed-unsupported-locale.js
deleted file mode 100644
index c51753928e..0000000000
--- a/implementation-contributed/v8/intl/number-format/wellformed-unsupported-locale.js
+++ /dev/null
@@ -1,32 +0,0 @@
-// Copyright 2013 the V8 project authors. All rights reserved.
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-//     * Redistributions of source code must retain the above copyright
-//       notice, this list of conditions and the following disclaimer.
-//     * Redistributions in binary form must reproduce the above
-//       copyright notice, this list of conditions and the following
-//       disclaimer in the documentation and/or other materials provided
-//       with the distribution.
-//     * Neither the name of Google Inc. nor the names of its
-//       contributors may be used to endorse or promote products derived
-//       from this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-// Passing a well formed but unsupported locale falls back to default.
-
-var nf = Intl.NumberFormat(['xx']);
-
-assertLanguageTag(%GetDefaultICULocale(), nf.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/intl/regress-8414.js b/implementation-contributed/v8/intl/regress-8414.js
deleted file mode 100644
index 3e34421636..0000000000
--- a/implementation-contributed/v8/intl/regress-8414.js
+++ /dev/null
@@ -1,806 +0,0 @@
-// Copyright 2018 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: --harmony-intl-segmenter --harmony-intl-list-format --harmony-locale
-
-let locales = [
-  "af-NA",
-  "af",
-  "af-ZA",
-  "agq-CM",
-  "agq",
-  "ak-GH",
-  "ak",
-  "am-ET",
-  "am",
-  "an",
-  "ar-001",
-  "ar-AE",
-  "ar-BH",
-  "ar-DJ",
-  "ar-DZ",
-  "ar-EG",
-  "ar-EH",
-  "ar-ER",
-  "ar-IL",
-  "ar-IQ",
-  "ar-JO",
-  "ar-KM",
-  "ar-KW",
-  "ar-LB",
-  "ar-LY",
-  "ar-MA",
-  "ar-MR",
-  "ar-OM",
-  "ar-PS",
-  "ar-QA",
-  "ar-SA",
-  "ar-SD",
-  "ar-SO",
-  "ar-SS",
-  "ars",
-  "ar-SY",
-  "ar-TD",
-  "ar-TN",
-  "ar",
-  "ar-YE",
-  "asa",
-  "asa-TZ",
-  "as-IN",
-  "ast-ES",
-  "ast",
-  "as",
-  "az-AZ",
-  "az-Cyrl-AZ",
-  "az-Cyrl",
-  "az-Latn-AZ",
-  "az-Latn",
-  "az",
-  "bas-CM",
-  "bas",
-  "be-BY",
-  "bem",
-  "bem-ZM",
-  "be",
-  "bez",
-  "bez-TZ",
-  "bg-BG",
-  "bg",
-  "bm-ML",
-  "bm",
-  "bn-BD",
-  "bn-IN",
-  "bn",
-  "bo-CN",
-  "bo-IN",
-  "bo",
-  "br-FR",
-  "br",
-  "brx-IN",
-  "brx",
-  "bs-BA",
-  "bs-Cyrl-BA",
-  "bs-Cyrl",
-  "bs-Latn-BA",
-  "bs-Latn",
-  "bs",
-  "ca-AD",
-  "ca-ES",
-  "ca-FR",
-  "ca-IT",
-  "ca",
-  "ccp-BD",
-  "ccp-IN",
-  "ccp",
-  "ce-RU",
-  "ce",
-  "cgg",
-  "cgg-UG",
-  "chr",
-  "chr-US",
-  "ckb-IQ",
-  "ckb-IR",
-  "ckb",
-  "cs-CZ",
-  "cs",
-  "cy-GB",
-  "cy",
-  "da-DK",
-  "da-GL",
-  "da",
-  "dav-KE",
-  "dav",
-  "de-AT",
-  "de-BE",
-  "de-CH",
-  "de-DE",
-  "de-IT",
-  "de-LI",
-  "de-LU",
-  "de",
-  "dje-NE",
-  "dje",
-  "dsb-DE",
-  "dsb",
-  "dua-CM",
-  "dua",
-  "dyo-SN",
-  "dyo",
-  "dz-BT",
-  "dz",
-  "ebu-KE",
-  "ebu",
-  "ee-GH",
-  "ee-TG",
-  "ee",
-  "el-CY",
-  "el-GR",
-  "el",
-  "en-001",
-  "en-150",
-  "en-AG",
-  "en-AI",
-  "en-AS",
-  "en-AT",
-  "en-AU",
-  "en-BB",
-  "en-BE",
-  "en-BI",
-  "en-BM",
-  "en-BS",
-  "en-BW",
-  "en-BZ",
-  "en-CA",
-  "en-CC",
-  "en-CH",
-  "en-CK",
-  "en-CM",
-  "en-CX",
-  "en-CY",
-  "en-DE",
-  "en-DG",
-  "en-DK",
-  "en-DM",
-  "en-ER",
-  "en-FI",
-  "en-FJ",
-  "en-FK",
-  "en-FM",
-  "en-GB",
-  "en-GD",
-  "en-GG",
-  "en-GH",
-  "en-GI",
-  "en-GM",
-  "en-GU",
-  "en-GY",
-  "en-HK",
-  "en-IE",
-  "en-IL",
-  "en-IM",
-  "en-IN",
-  "en-IO",
-  "en-JE",
-  "en-JM",
-  "en-KE",
-  "en-KI",
-  "en-KN",
-  "en-KY",
-  "en-LC",
-  "en-LR",
-  "en-LS",
-  "en-MG",
-  "en-MH",
-  "en-MO",
-  "en-MP",
-  "en-MS",
-  "en-MT",
-  "en-MU",
-  "en-MW",
-  "en-MY",
-  "en-NA",
-  "en-NF",
-  "en-NG",
-  "en-NH",
-  "en-NL",
-  "en-NR",
-  "en-NU",
-  "en-NZ",
-  "en-PG",
-  "en-PH",
-  "en-PK",
-  "en-PN",
-  "en-PR",
-  "en-PW",
-  "en-RH",
-  "en-RW",
-  "en-SB",
-  "en-SC",
-  "en-SD",
-  "en-SE",
-  "en-SG",
-  "en-SH",
-  "en-SI",
-  "en-SL",
-  "en-SS",
-  "en-SX",
-  "en-SZ",
-  "en-TC",
-  "en-TK",
-  "en-TO",
-  "en-TT",
-  "en-TV",
-  "en",
-  "en-TZ",
-  "en-UG",
-  "en-UM",
-  "en-US-POSIX",
-  "en-US",
-  "en-VC",
-  "en-VG",
-  "en-VI",
-  "en-VU",
-  "en-WS",
-  "en-ZA",
-  "en-ZM",
-  "en-ZW",
-  "eo",
-  "es-419",
-  "es-AR",
-  "es-BO",
-  "es-BR",
-  "es-BZ",
-  "es-CL",
-  "es-CO",
-  "es-CR",
-  "es-CU",
-  "es-DO",
-  "es-EA",
-  "es-EC",
-  "es-ES",
-  "es-GQ",
-  "es-GT",
-  "es-HN",
-  "es-IC",
-  "es-MX",
-  "es-NI",
-  "es-PA",
-  "es-PE",
-  "es-PH",
-  "es-PR",
-  "es-PY",
-  "es-SV",
-  "es",
-  "es-US",
-  "es-UY",
-  "es-VE",
-  "et-EE",
-  "et",
-  "eu-ES",
-  "eu",
-  "ewo-CM",
-  "ewo",
-  "fa-AF",
-  "fa-IR",
-  "fa",
-  "ff",
-  "fi-FI",
-  "fil-PH",
-  "fil",
-  "fi",
-  "fo-DK",
-  "fo-FO",
-  "fo",
-  "fr-BE",
-  "fr-BF",
-  "fr-BI",
-  "fr-BJ",
-  "fr-BL",
-  "fr-CA",
-  "fr-CD",
-  "fr-CF",
-  "fr-CG",
-  "fr-CH",
-  "fr-CI",
-  "fr-CM",
-  "fr-DJ",
-  "fr-DZ",
-  "fr-FR",
-  "fr-GA",
-  "fr-GF",
-  "fr-GN",
-  "fr-GP",
-  "fr-GQ",
-  "fr-HT",
-  "fr-KM",
-  "fr-LU",
-  "fr-MA",
-  "fr-MC",
-  "fr-MF",
-  "fr-MG",
-  "fr-ML",
-  "fr-MQ",
-  "fr-MR",
-  "fr-MU",
-  "fr-NC",
-  "fr-NE",
-  "fr-PF",
-  "fr-PM",
-  "fr-RE",
-  "fr-RW",
-  "fr-SC",
-  "fr-SN",
-  "fr-SY",
-  "fr-TD",
-  "fr-TG",
-  "fr-TN",
-  "fr",
-  "fr-VU",
-  "fr-WF",
-  "fr-YT",
-  "fur-IT",
-  "fur",
-  "fy-NL",
-  "fy",
-  "ga-IE",
-  "ga",
-  "gd-GB",
-  "gd",
-  "gl-ES",
-  "gl",
-  "gsw-CH",
-  "gsw-FR",
-  "gsw-LI",
-  "gsw",
-  "gu-IN",
-  "gu",
-  "guz-KE",
-  "guz",
-  "gv-IM",
-  "gv",
-  "ha-GH",
-  "ha-NE",
-  "ha-NG",
-  "ha",
-  "haw",
-  "haw-US",
-  "he-IL",
-  "he",
-  "hi-IN",
-  "hi",
-  "hr-BA",
-  "hr-HR",
-  "hr",
-  "hsb-DE",
-  "hsb",
-  "hu-HU",
-  "hu",
-  "hy-AM",
-  "hy",
-  "ia-001",
-  "ia",
-  "id-ID",
-  "id",
-  "ig-NG",
-  "ig",
-  "ii-CN",
-  "ii",
-  "in-ID",
-  "in",
-  "is-IS",
-  "is",
-  "it-CH",
-  "it-IT",
-  "it-SM",
-  "it",
-  "it-VA",
-  "iw-IL",
-  "iw",
-  "ja-JP",
-  "ja",
-  "jgo-CM",
-  "jgo",
-  "jmc",
-  "jmc-TZ",
-  "jv-ID",
-  "jv",
-  "kab-DZ",
-  "kab",
-  "ka-GE",
-  "kam-KE",
-  "kam",
-  "ka",
-  "kde",
-  "kde-TZ",
-  "kea-CV",
-  "kea",
-  "khq-ML",
-  "khq",
-  "ki-KE",
-  "ki",
-  "kkj-CM",
-  "kkj",
-  "kk-KZ",
-  "kk",
-  "kl-GL",
-  "kln-KE",
-  "kln",
-  "kl",
-  "km-KH",
-  "km",
-  "kn-IN",
-  "kn",
-  "kok-IN",
-  "ko-KP",
-  "ko-KR",
-  "kok",
-  "ko",
-  "ksb",
-  "ksb-TZ",
-  "ksf-CM",
-  "ksf",
-  "ksh-DE",
-  "ksh",
-  "ks-IN",
-  "ks",
-  "ku-TR",
-  "ku",
-  "kw-GB",
-  "kw",
-  "ky-KG",
-  "ky",
-  "lag",
-  "lag-TZ",
-  "lb-LU",
-  "lb",
-  "lg",
-  "lg-UG",
-  "lkt",
-  "lkt-US",
-  "ln-AO",
-  "ln-CD",
-  "ln-CF",
-  "ln-CG",
-  "ln",
-  "lo-LA",
-  "lo",
-  "lrc-IQ",
-  "lrc-IR",
-  "lrc",
-  "lt-LT",
-  "lt",
-  "lu-CD",
-  "luo-KE",
-  "luo",
-  "lu",
-  "luy-KE",
-  "luy",
-  "lv-LV",
-  "lv",
-  "mas-KE",
-  "mas",
-  "mas-TZ",
-  "mer-KE",
-  "mer",
-  "mfe-MU",
-  "mfe",
-  "mgh-MZ",
-  "mgh",
-  "mg-MG",
-  "mgo-CM",
-  "mgo",
-  "mg",
-  "mi-NZ",
-  "mi",
-  "mk-MK",
-  "mk",
-  "ml-IN",
-  "ml",
-  "mn-MN",
-  "mn",
-  "mo",
-  "mr-IN",
-  "mr",
-  "ms-BN",
-  "ms-MY",
-  "ms-SG",
-  "ms",
-  "mt-MT",
-  "mt",
-  "mua-CM",
-  "mua",
-  "my-MM",
-  "my",
-  "mzn-IR",
-  "mzn",
-  "naq-NA",
-  "naq",
-  "nb-NO",
-  "nb-SJ",
-  "nb",
-  "nds-DE",
-  "nds-NL",
-  "nds",
-  "nd",
-  "nd-ZW",
-  "ne-IN",
-  "ne-NP",
-  "ne",
-  "nl-AW",
-  "nl-BE",
-  "nl-BQ",
-  "nl-CW",
-  "nl-NL",
-  "nl-SR",
-  "nl-SX",
-  "nl",
-  "nmg-CM",
-  "nmg",
-  "nnh-CM",
-  "nnh",
-  "nn-NO",
-  "nn",
-  "no-NY",
-  "no-NO",
-  "no",
-  "nus-SS",
-  "nus",
-  "nyn",
-  "nyn-UG",
-  "om-ET",
-  "om-KE",
-  "om",
-  "or-IN",
-  "or",
-  "os-GE",
-  "os-RU",
-  "os",
-  "pa-Arab-PK",
-  "pa-Arab",
-  "pa-Guru-IN",
-  "pa-Guru",
-  "pa-IN",
-  "pa-PK",
-  "pa",
-  "pl-PL",
-  "pl",
-  "ps-AF",
-  "ps",
-  "pt-AO",
-  "pt-BR",
-  "pt-CH",
-  "pt-CV",
-  "pt-GQ",
-  "pt-GW",
-  "pt-LU",
-  "pt-MO",
-  "pt-MZ",
-  "pt-PT",
-  "pt-ST",
-  "pt-TL",
-  "pt",
-  "qu-BO",
-  "qu-EC",
-  "qu-PE",
-  "qu",
-  "rm-CH",
-  "rm",
-  "rn-BI",
-  "rn",
-  "rof",
-  "rof-TZ",
-  "ro-MD",
-  "root",
-  "ro-RO",
-  "ro",
-  "ru-BY",
-  "ru-KG",
-  "ru-KZ",
-  "ru-MD",
-  "ru-RU",
-  "ru",
-  "ru-UA",
-  "rwk",
-  "rwk-TZ",
-  "rw-RW",
-  "rw",
-  "sah-RU",
-  "sah",
-  "saq-KE",
-  "saq",
-  "sbp",
-  "sbp-TZ",
-  "sd-PK",
-  "sd",
-  "se-FI",
-  "seh-MZ",
-  "seh",
-  "se-NO",
-  "se-SE",
-  "ses-ML",
-  "ses",
-  "se",
-  "sg-CF",
-  "sg",
-  "sh-BA",
-  "sh-CS",
-  "shi-Latn-MA",
-  "shi-Latn",
-  "shi-MA",
-  "shi-Tfng-MA",
-  "shi-Tfng",
-  "shi",
-  "sh",
-  "sh-YU",
-  "si-LK",
-  "si",
-  "sk-SK",
-  "sk",
-  "sl-SI",
-  "sl",
-  "smn-FI",
-  "smn",
-  "sn",
-  "sn-ZW",
-  "so-DJ",
-  "so-ET",
-  "so-KE",
-  "so-SO",
-  "so",
-  "sq-AL",
-  "sq-MK",
-  "sq",
-  "sq-XK",
-  "sr-BA",
-  "sr-CS",
-  "sr-Cyrl-BA",
-  "sr-Cyrl-CS",
-  "sr-Cyrl-ME",
-  "sr-Cyrl-RS",
-  "sr-Cyrl",
-  "sr-Cyrl-XK",
-  "sr-Cyrl-YU",
-  "sr-Latn-BA",
-  "sr-Latn-CS",
-  "sr-Latn-ME",
-  "sr-Latn-RS",
-  "sr-Latn",
-  "sr-Latn-XK",
-  "sr-Latn-YU",
-  "sr-ME",
-  "sr-RS",
-  "sr",
-  "sr-XK",
-  "sr-YU",
-  "sv-AX",
-  "sv-FI",
-  "sv-SE",
-  "sv",
-  "sw-CD",
-  "sw-KE",
-  "sw",
-  "sw-TZ",
-  "sw-UG",
-  "ta-IN",
-  "ta-LK",
-  "ta-MY",
-  "ta-SG",
-  "ta",
-  "te-IN",
-  "teo-KE",
-  "teo",
-  "teo-UG",
-  "te",
-  "tg-TJ",
-  "tg",
-  "th-TH",
-  "th",
-  "ti-ER",
-  "ti-ET",
-  "ti",
-  "tk-TM",
-  "tk",
-  "tl-PH",
-  "tl",
-  "to-TO",
-  "to",
-  "tr-CY",
-  "tr-TR",
-  "tr",
-  "tt-RU",
-  "tt",
-  "twq-NE",
-  "twq",
-  "tzm-MA",
-  "tzm",
-  "ug-CN",
-  "ug",
-  "uk",
-  "uk-UA",
-  "ur-IN",
-  "ur-PK",
-  "ur",
-  "uz-AF",
-  "uz-Arab-AF",
-  "uz-Arab",
-  "uz-Cyrl",
-  "uz-Cyrl-UZ",
-  "uz-Latn",
-  "uz-Latn-UZ",
-  "uz",
-  "uz-UZ",
-  "vai-Latn-LR",
-  "vai-Latn",
-  "vai-LR",
-  "vai",
-  "vai-Vaii-LR",
-  "vai-Vaii",
-  "vi",
-  "vi-VN",
-  "vun",
-  "vun-TZ",
-  "wae-CH",
-  "wae",
-  "wa",
-  "wo-SN",
-  "wo",
-  "xh",
-  "xh-ZA",
-  "xog",
-  "xog-UG",
-  "yav-CM",
-  "yav",
-  "yi-001",
-  "yi",
-  "yo-BJ",
-  "yo-NG",
-  "yo",
-  "yue-CN",
-  "yue-Hans-CN",
-  "yue-Hans",
-  "yue-Hant-HK",
-  "yue-Hant",
-  "yue-HK",
-  "yue",
-  "zgh-MA",
-  "zgh",
-  "zh-CN",
-  "zh-Hans-CN",
-  "zh-Hans-HK",
-  "zh-Hans-MO",
-  "zh-Hans-SG",
-  "zh-Hans",
-  "zh-Hant-HK",
-  "zh-Hant-MO",
-  "zh-Hant-TW",
-  "zh-Hant",
-  "zh-HK",
-  "zh-MO",
-  "zh-SG",
-  "zh-TW",
-  "zh",
-  "zu",
-  "zu-ZA"
-];
-
-var intlObjectNames = [
-  "DateTimeFormat",
-  "NumberFormat",
-  "Collator",
-  "v8BreakIterator",
-  "PluralRules",
-  "Locale",
-  "ListFormat",
-  "Segmenter",
-  "RelativeTimeFormat"
-];
-
-for (let loc of locales) {
-  for (let constructor of intlObjectNames) {
-    let msg = `new Intl.${constructor}(${loc})`;
-    print(msg);
-    let obj = new Intl[constructor](loc);
-    assertNotNull(obj, msg + ' should not be null');
-  }
-}
diff --git a/implementation-contributed/v8/intl/regress-8469.js b/implementation-contributed/v8/intl/regress-8469.js
new file mode 100644
index 0000000000..7febb51cf9
--- /dev/null
+++ b/implementation-contributed/v8/intl/regress-8469.js
@@ -0,0 +1,87 @@
+// Copyright 2018 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.
+
+// The following tz are NOT impacted by v8:8469
+var some_tz_list = [
+  "ciabj",
+  "ghacc",
+];
+
+// The following tz ARE impacted by v8:8469
+var problem_tz_list = [
+  "etadd",
+  "tzdar",
+  "eheai",
+  "sttms",
+  "arirj",
+  "arrgl",
+  "aruaq",
+  "arluq",
+  "mxpvr",
+  "brbvb",
+  "arbue",
+  "caycb",
+  "brcgr",
+  "cayzs",
+  "crsjo",
+  "caydq",
+  "svsal",
+  "cafne",
+  "caglb",
+  "cagoo",
+  "tcgdt",
+  "ustel",
+  "bolpb",
+  "uslax",
+  "sxphi",
+  "mxmex",
+  "usnyc",
+  "usxul",
+  "usndcnt",
+  "usndnsl",
+  "ttpos",
+  "brpvh",
+  "prsju",
+  "clpuq",
+  "caffs",
+  "cayek",
+  "brrbr",
+  "mxstis",
+  "dosdq",
+  "brsao",
+  "gpsbh",
+  "casjf",
+  "knbas",
+  "lccas",
+  "vistt",
+  "vcsvd",
+  "cayyn",
+  "cathu",
+  "hkhkg",
+  "mykul",
+  "khpnh",
+  "cvrai",
+  "gsgrv",
+  "shshn",
+  "aubhq",
+  "auldh",
+  "imdgs",
+  "smsai",
+  "asppg",
+  "pgpom",
+];
+
+let expectedTimeZone = (new Intl.DateTimeFormat("en"))
+    .resolvedOptions().timeZone;
+
+function testTz(tz) {
+  print(tz);
+  let timeZone = (new Intl.DateTimeFormat("en-u-tz-" + tz))
+      .resolvedOptions().timeZone;
+  assertEquals(expectedTimeZone, timeZone);
+}
+
+// first test soem tz not impacted by v8:8469 to ensure testTz is correct.
+for (var tz of some_tz_list) testTz(tz);
+for (var tz of problem_tz_list) testTz(tz);
diff --git a/implementation-contributed/v8/intl/regress-8525.js b/implementation-contributed/v8/intl/regress-8525.js
new file mode 100644
index 0000000000..4d925d73c3
--- /dev/null
+++ b/implementation-contributed/v8/intl/regress-8525.js
@@ -0,0 +1,27 @@
+// Copyright 2018 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.
+
+// test the numberingSystem is set correctly via -u-nu-
+let dtf = new Intl.DateTimeFormat(["en-u-ba-rfoo-nu-arab-fo-obar"]);
+assertEquals("arab", dtf.resolvedOptions().numberingSystem);
+assertEquals("en-u-nu-arab", dtf.resolvedOptions().locale);
+
+let nf = new Intl.NumberFormat(["en-u-ba-rfoo-nu-arab-fo-obar"]);
+assertEquals("arab", nf.resolvedOptions().numberingSystem);
+assertEquals("١٢٣", nf.format(123));
+assertEquals("en-u-nu-arab", nf.resolvedOptions().locale);
+
+dtf = new Intl.DateTimeFormat(["en-u-ba-rfoo-nu-thai-fo-obar"]);
+assertEquals("thai", dtf.resolvedOptions().numberingSystem);
+assertEquals("en-u-nu-thai", dtf.resolvedOptions().locale);
+
+nf = new Intl.NumberFormat(["en-u-ba-rfoo-nu-thai-fo-obar"]);
+assertEquals("thai", nf.resolvedOptions().numberingSystem);
+assertEquals("๑๒๓", nf.format(123));
+assertEquals("en-u-nu-thai", nf.resolvedOptions().locale);
+
+nf = new Intl.NumberFormat(["ar-EG-u-nu-latn"]);
+assertEquals("latn", nf.resolvedOptions().numberingSystem);
+assertEquals("123", nf.format(123));
+assertEquals("ar-EG-u-nu-latn", nf.resolvedOptions().locale);
diff --git a/implementation-contributed/v8/mjsunit/code-coverage-block.js b/implementation-contributed/v8/mjsunit/code-coverage-block.js
index 8cbb2969f7..bdba90cd1e 100644
--- a/implementation-contributed/v8/mjsunit/code-coverage-block.js
+++ b/implementation-contributed/v8/mjsunit/code-coverage-block.js
@@ -213,7 +213,7 @@ TestCoverage(
     nop();                                // 0100
   }                                       // 0150
 }();                                      // 0200
-%RunMicrotasks();                         // 0250
+%PerformMicrotaskCheckpoint();            // 0250
 `,
 [{"start":0,"end":299,"count":1},
  {"start":1,"end":201,"count":6},  // TODO(jgruber): Invocation count is off.
@@ -662,7 +662,7 @@ async function f() {                      // 0000
   await 42;                               // 0100
 };                                        // 0150
 f();                                      // 0200
-%RunMicrotasks();                         // 0250
+%PerformMicrotaskCheckpoint();            // 0250
 `,
 [{"start":0,"end":299,"count":1},
  {"start":0,"end":151,"count":3},
diff --git a/implementation-contributed/v8/mjsunit/compiler/regress-910838.js b/implementation-contributed/v8/mjsunit/compiler/regress-910838.js
new file mode 100644
index 0000000000..6e62a453e0
--- /dev/null
+++ b/implementation-contributed/v8/mjsunit/compiler/regress-910838.js
@@ -0,0 +1,20 @@
+// Copyright 2018 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: --allow-natives-syntax
+
+function f(b, s, x) {
+  if (!b) {
+    return (x ? b : s * undefined) ? 1 : 42;
+  }
+}
+
+function g(b, x) {
+  return f(b, 'abc', x);
+}
+
+f(false, 0, 0);
+g(true, 0);
+%OptimizeFunctionOnNextCall(g);
+assertEquals(42, g(false, 0));
diff --git a/implementation-contributed/v8/mjsunit/es6/microtask-delivery.js b/implementation-contributed/v8/mjsunit/es6/microtask-delivery.js
index 6b239bea47..96035164f2 100644
--- a/implementation-contributed/v8/mjsunit/es6/microtask-delivery.js
+++ b/implementation-contributed/v8/mjsunit/es6/microtask-delivery.js
@@ -40,7 +40,7 @@ function assertArrayValues(expected, actual) {
 }
 
 function assertOrdering(expected) {
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertArrayValues(expected, ordering);
 }
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-arguments.js b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-arguments.js
index b29f17fce0..720770ef49 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-arguments.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-arguments.js
@@ -21,7 +21,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-new.target.js b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-new.target.js
index 943267e9d8..7d016281f8 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-new.target.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-new.target.js
@@ -21,7 +21,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-super.js b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-super.js
index b15a3834db..b175ac5ae1 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-super.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-super.js
@@ -21,7 +21,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-this.js b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-this.js
index 38bdddc2c7..a21978d1a0 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-this.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-arrow-lexical-this.js
@@ -21,7 +21,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-await-basic.js b/implementation-contributed/v8/mjsunit/es8/async-await-basic.js
index 6e9ee02ffe..1c7b2ac601 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-await-basic.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-await-basic.js
@@ -23,7 +23,7 @@ function assertThrowsAsync(run, errorType, message) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (!hadError) {
     throw new MjsUnitAssertionError(
@@ -57,7 +57,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
@@ -402,7 +402,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "a", "c"], log);
 }
 
@@ -416,7 +416,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "a", "c"], log);
 }
 
@@ -430,7 +430,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["a", "b", "c"], log);
 }
 
@@ -445,7 +445,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "c", "a"], log);
 }
 
@@ -459,7 +459,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "a", "c"], log);
 }
 
@@ -473,7 +473,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["a", "b", "c"], log);
 }
 
@@ -488,7 +488,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "a", "c"], log);
 }
 
@@ -502,7 +502,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "a", "c"], log);
 }
 
@@ -516,7 +516,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["a", "b", "c"], log);
 }
 
@@ -531,7 +531,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "c", "a"], log);
 }
 
@@ -545,7 +545,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["b", "c", "a"], log);
 }
 
@@ -559,7 +559,7 @@ assertDoesNotThrow(gaga);
     }
   }
   foo().then(() => log.push("c"));
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(["a", "b", "c"], log);
 }
 
@@ -585,7 +585,7 @@ assertDoesNotThrow(gaga);
 
   var ans;
   f2().then(x => ans = x).catch(e => ans = e);
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals([0], ans);
 }
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-await-no-constructor.js b/implementation-contributed/v8/mjsunit/es8/async-await-no-constructor.js
index e954e2ac57..5e4780a6ef 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-await-no-constructor.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-await-no-constructor.js
@@ -23,5 +23,5 @@ async function bar() {
 
 foo();
 bar();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(2, count);
diff --git a/implementation-contributed/v8/mjsunit/es8/async-await-species.js b/implementation-contributed/v8/mjsunit/es8/async-await-species.js
index b3e925433a..3fc46fd230 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-await-species.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-await-species.js
@@ -21,7 +21,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/es8/async-destructuring.js b/implementation-contributed/v8/mjsunit/es8/async-destructuring.js
index 1fbac5a072..d5e90eb057 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-destructuring.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-destructuring.js
@@ -21,7 +21,7 @@ function assertThrowsAsync(run, errorType, message) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (!hadError) {
     throw new MjsUnitAssertionError(
@@ -55,7 +55,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
@@ -77,7 +77,7 @@ function assertEqualsAsync(expected, run, msg) {
   assertEquals(1, y);
   assertEquals(1, z);
   assertEquals(0, w);
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
   assertEquals(1, y);
   assertEquals(1, z);
   assertEquals(1, w);
diff --git a/implementation-contributed/v8/mjsunit/es8/async-function-try-finally.js b/implementation-contributed/v8/mjsunit/es8/async-function-try-finally.js
index 9ba07eb427..43badc480a 100644
--- a/implementation-contributed/v8/mjsunit/es8/async-function-try-finally.js
+++ b/implementation-contributed/v8/mjsunit/es8/async-function-try-finally.js
@@ -21,7 +21,7 @@ function assertThrowsAsync(run, errorType, message) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (!hadError) {
     throw new MjsUnitAssertionError(
@@ -55,7 +55,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
diff --git a/implementation-contributed/v8/mjsunit/harmony/async-from-sync-iterator.js b/implementation-contributed/v8/mjsunit/harmony/async-from-sync-iterator.js
index 2d6be098a2..e9dfe5d322 100644
--- a/implementation-contributed/v8/mjsunit/harmony/async-from-sync-iterator.js
+++ b/implementation-contributed/v8/mjsunit/harmony/async-from-sync-iterator.js
@@ -24,7 +24,7 @@ function assertThrowsAsync(run, errorType, message) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (!hadError) {
     throw new MjsUnitAssertionError(
@@ -185,7 +185,7 @@ class MyError extends Error {};
   testFailure = error;
 });
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 if (testFailed) {
   throw testFailure;
 }
@@ -619,7 +619,7 @@ if (testFailed) {
   testFailure = error;
 });
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 if (testFailed) {
   throw testFailure;
 }
@@ -663,7 +663,7 @@ if (testFailed) {
 
   // Cycle through `f` to extract iterator methods
   f().catch(function() { %AbortJS("No error should have occurred"); });
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   assertEquals(typeof extractedNext, "function");
   assertThrowsAsync(() => extractedNext.call(undefined), TypeError);
diff --git a/implementation-contributed/v8/mjsunit/harmony/async-generators-basic.js b/implementation-contributed/v8/mjsunit/harmony/async-generators-basic.js
index cf21d9a8c8..5ff7d25eea 100644
--- a/implementation-contributed/v8/mjsunit/harmony/async-generators-basic.js
+++ b/implementation-contributed/v8/mjsunit/harmony/async-generators-basic.js
@@ -21,7 +21,7 @@ function assertThrowsAsync(run, errorType, message) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (!hadError) {
     throw new MjsUnitAssertionError(
@@ -55,7 +55,7 @@ function assertEqualsAsync(expected, run, msg) {
 
   assertFalse(hadValue || hadError);
 
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (hadError) throw actual;
 
@@ -448,7 +448,7 @@ async function* asyncGeneratorForNestedResumeNext() {
 }
 it = asyncGeneratorForNestedResumeNext();
 it.next().then(logIterResult, AbortUnreachable);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "rootbeer", done: false },
   { value: "float", done: false },
@@ -464,7 +464,7 @@ let asyncGeneratorExprForNestedResumeNext = async function*() {
 };
 it = asyncGeneratorExprForNestedResumeNext();
 it.next().then(logIterResult, AbortUnreachable);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "first", done: false },
   { value: "second", done: false },
@@ -482,7 +482,7 @@ let asyncGeneratorMethodForNestedResumeNext = ({
 }).method;
 it = asyncGeneratorMethodForNestedResumeNext();
 it.next().then(logIterResult, AbortUnreachable);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "remember", done: false },
   { value: "the cant!", done: false },
@@ -498,7 +498,7 @@ let asyncGeneratorCallEvalForNestedResumeNext =
       yield await Resolver("rainbow!");`);
 it = asyncGeneratorCallEvalForNestedResumeNext();
 it.next().then(logIterResult, AbortUnreachable);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "reading", done: false },
   { value: "rainbow!", done: false },
@@ -514,7 +514,7 @@ let asyncGeneratorNewEvalForNestedResumeNext =
       yield await Resolver("BB!");`);
 it = asyncGeneratorNewEvalForNestedResumeNext();
 it.next().then(logIterResult, AbortUnreachable);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: 731, done: false },
   { value: "BB!", done: false },
@@ -536,7 +536,7 @@ async function* asyncGeneratorForNestedResumeThrow() {
 }
 it = asyncGeneratorForNestedResumeThrow();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   "throw1",
   "throw2",
@@ -556,7 +556,7 @@ let asyncGeneratorExprForNestedResumeThrow = async function*() {
 };
 it = asyncGeneratorExprForNestedResumeThrow();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   "throw3",
   "throw4",
@@ -578,7 +578,7 @@ let asyncGeneratorMethodForNestedResumeThrow = ({
 }).method;
 it = asyncGeneratorMethodForNestedResumeThrow();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   "throw5",
   "throw6",
@@ -598,7 +598,7 @@ let asyncGeneratorCallEvalForNestedResumeThrow =
       AbortUnreachable();`);
 it = asyncGeneratorCallEvalForNestedResumeThrow();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   "throw7",
   "throw8",
@@ -618,7 +618,7 @@ let asyncGeneratorNewEvalForNestedResumeThrow =
       AbortUnreachable();`);
 it = asyncGeneratorNewEvalForNestedResumeThrow();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   "throw9",
   "throw10",
@@ -636,7 +636,7 @@ async function* asyncGeneratorForNestedResumeReturn() {
 }
 it = asyncGeneratorForNestedResumeReturn();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "step1", done: false },
   { value: "step2", done: true },
@@ -651,7 +651,7 @@ let asyncGeneratorExprForNestedResumeReturn = async function*() {
 };
 it = asyncGeneratorExprForNestedResumeReturn();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "step3", done: false },
   { value: "step4", done: true },
@@ -668,7 +668,7 @@ let asyncGeneratorMethodForNestedResumeReturn = ({
 }).method;
 it = asyncGeneratorMethodForNestedResumeReturn();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "step5", done: false },
   { value: "step6", done: true },
@@ -683,7 +683,7 @@ let asyncGeneratorCallEvalForNestedResumeReturn =
       yield "step7";`);
 it = asyncGeneratorCallEvalForNestedResumeReturn();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "step7", done: false },
   { value: "step8", done: true },
@@ -698,7 +698,7 @@ let asyncGeneratorNewEvalForNestedResumeReturn =
       yield "step9";`);
 it = asyncGeneratorNewEvalForNestedResumeReturn();
 it.next().then(logIterResult, logError);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals([
   { value: "step9", done: false },
   { value: "step10", done: true },
diff --git a/implementation-contributed/v8/mjsunit/harmony/for-await-of.js b/implementation-contributed/v8/mjsunit/harmony/for-await-of.js
index e23758a5e1..1b4fcd701a 100644
--- a/implementation-contributed/v8/mjsunit/harmony/for-await-of.js
+++ b/implementation-contributed/v8/mjsunit/harmony/for-await-of.js
@@ -1257,7 +1257,7 @@ let testFailure;
   testFailure = error;
 });
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 if (testFailed) {
   throw testFailure;
diff --git a/implementation-contributed/v8/mjsunit/harmony/import-from-compilation-errored.js b/implementation-contributed/v8/mjsunit/harmony/import-from-compilation-errored.js
index 3c99498d0e..49570b51de 100644
--- a/implementation-contributed/v8/mjsunit/harmony/import-from-compilation-errored.js
+++ b/implementation-contributed/v8/mjsunit/harmony/import-from-compilation-errored.js
@@ -7,7 +7,7 @@
 var error1, error2;
 import('modules-skip-12.js').catch(e => error1 = e);
 import('modules-skip-12.js').catch(e => error2 = e);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(error1, error2);
 assertInstanceof(error1, SyntaxError);
diff --git a/implementation-contributed/v8/mjsunit/harmony/import-from-evaluation-errored.js b/implementation-contributed/v8/mjsunit/harmony/import-from-evaluation-errored.js
index 3623091777..87dbc0a6aa 100644
--- a/implementation-contributed/v8/mjsunit/harmony/import-from-evaluation-errored.js
+++ b/implementation-contributed/v8/mjsunit/harmony/import-from-evaluation-errored.js
@@ -7,7 +7,7 @@
 var error1, error2;
 import('modules-skip-11.js').catch(e => error1 = e);
 import('modules-skip-11.js').catch(e => error2 = e);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(error1, error2);
 assertEquals(typeof error1, "symbol");
diff --git a/implementation-contributed/v8/mjsunit/harmony/import-from-fetch-errored.js b/implementation-contributed/v8/mjsunit/harmony/import-from-fetch-errored.js
index f3db881eb2..6d6510fcde 100644
--- a/implementation-contributed/v8/mjsunit/harmony/import-from-fetch-errored.js
+++ b/implementation-contributed/v8/mjsunit/harmony/import-from-fetch-errored.js
@@ -7,7 +7,7 @@
 var error1, error2;
 import('no-such-file').catch(e => error1 = e);
 import('no-such-file').catch(e => error2 = e);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(error1, error2);
 assertEquals(typeof error1, "string");
diff --git a/implementation-contributed/v8/mjsunit/harmony/import-from-instantiation-errored.js b/implementation-contributed/v8/mjsunit/harmony/import-from-instantiation-errored.js
index 2a481d5965..2cdbaaea32 100644
--- a/implementation-contributed/v8/mjsunit/harmony/import-from-instantiation-errored.js
+++ b/implementation-contributed/v8/mjsunit/harmony/import-from-instantiation-errored.js
@@ -7,7 +7,7 @@
 var error1, error2;
 import('modules-skip-10.js').catch(e => error1 = e);
 import('modules-skip-10.js').catch(e => error2 = e);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(error1, error2);
 assertInstanceof(error1, SyntaxError);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-1.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-1.js
index 7fd567f56f..f62d4d7b32 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-1.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-1.js
@@ -7,6 +7,6 @@
 var life;
 import('modules-skip-1.js').then(namespace => life = namespace.life());
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(42, life);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-10.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-10.js
index 68e000a131..eda4aaf7f9 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-10.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-10.js
@@ -9,7 +9,7 @@ import('modules-skip-6.js').then(namespace => life = namespace.life);
 
 assertEquals(undefined, Object.life);
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(42, Object.life);
 assertEquals("42", life);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-11.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-11.js
index a5afa10048..ffba6a0722 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-11.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-11.js
@@ -18,5 +18,5 @@ async function test() {
 }
 
 test();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-12.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-12.js
index bcb8569221..d898c984ad 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-12.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-12.js
@@ -15,5 +15,5 @@ async function test() {
 }
 
 test();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-13.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-13.js
index 1cec1cce61..52518350ba 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-13.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-13.js
@@ -19,7 +19,7 @@ async function test1() {
 }
 
 test1();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
 
 ran = false;
@@ -36,5 +36,5 @@ async function test2() {
 }
 
 test2();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-14.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-14.js
index 3849c54c59..32b307eb3b 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-14.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-14.js
@@ -22,5 +22,5 @@ async function test() {
 }
 
 test();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-15.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-15.js
index 32255ce980..d041add3db 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-15.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-15.js
@@ -17,7 +17,7 @@ async function test1() {
 }
 
 test1();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
 
 ran = false;
@@ -37,7 +37,7 @@ async function test2() {
 }
 
 test2();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
 
 ran = false;
@@ -53,5 +53,5 @@ async function test3() {
 }
 
 test3();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-16.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-16.js
index 94510d48fc..18ad445a84 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-16.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-16.js
@@ -12,7 +12,7 @@ var body = "import('modules-skip-1.js').then(ns => { x = ns.life();" +
 var func = new Function(body);
 func();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(42, x);
 assertTrue(ran);
 
@@ -21,7 +21,7 @@ var body = "import('modules-skip-1.js').then(ns => { x = ns.life();" +
     " ran = true;} ).catch(err => %AbortJS(err))"
 eval("var func = new Function(body); func();");
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(42, x);
 assertTrue(ran);
 
@@ -31,6 +31,6 @@ var body = "eval(import('modules-skip-1.js').then(ns => { x = ns.life();" +
 var func = new Function(body);
 func();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(42, x);
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-17.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-17.js
index f73aa68f3b..606ebcd385 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-17.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-17.js
@@ -6,6 +6,6 @@
 
 var ns;
 import('modules-skip-13.js').then(x => ns = x);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(42, ns.default);
 assertEquals(ns, ns.self);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-2.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-2.js
index f50a5c8c53..a3fe0bc601 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-2.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-2.js
@@ -12,7 +12,7 @@ import('modules-skip-2.js').catch(err => msg = err.message);
 assertEquals(undefined, life);
 assertEquals(undefined, msg);
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertEquals(42, life);
 assertEquals('42 is not the answer', msg);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-3.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-3.js
index 669f820fd7..d8cbe2a228 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-3.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-3.js
@@ -17,6 +17,6 @@ async function foo () {
 
 foo();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-5.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-5.js
index d9237828fe..c868a0c63f 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-5.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-5.js
@@ -9,5 +9,5 @@ let x = 'modules-skip-1.js';
 import(x).then(namespace => life = namespace.life());
 x = 'modules-skip-2.js';
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(42, life);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-6.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-6.js
index 6a5b7c8b5b..02fdf1b5fa 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-6.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-6.js
@@ -25,5 +25,5 @@ async function test() {
 
 test();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-7.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-7.js
index d0105112f4..8df8ddcdb2 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-7.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-7.js
@@ -19,6 +19,6 @@ async function test() {
 
 test();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-8.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-8.js
index 4417f0eb78..ac21a8c9e9 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-8.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-8.js
@@ -43,7 +43,7 @@ async function test1() {
 
 test1();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertTrue(ran);
 
@@ -66,7 +66,7 @@ async function test2() {
 
 test2();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertTrue(ran);
 
@@ -86,6 +86,6 @@ async function test3() {
 
 test3();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/modules-import-9.js b/implementation-contributed/v8/mjsunit/harmony/modules-import-9.js
index 6794311305..664416f0eb 100644
--- a/implementation-contributed/v8/mjsunit/harmony/modules-import-9.js
+++ b/implementation-contributed/v8/mjsunit/harmony/modules-import-9.js
@@ -18,5 +18,5 @@ async function test() {
 }
 
 test();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(ran);
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-and-cleared-weakref.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-and-cleared-weakref.js
index a7105771b3..66058e8bcd 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-and-cleared-weakref.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-and-cleared-weakref.js
@@ -25,7 +25,7 @@ let weak_ref;
 })();
 
 // Clear the KeepDuringJob set.
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 weak_ref.deref();
 o = null;
@@ -37,7 +37,7 @@ gc();
 wf.cleanupSome();
 assertEquals(0, cleanup_count);
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 // This GC detects the WeakRef as dirty.
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-weakref.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-weakref.js
index fb113bef0d..d6d9373094 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-weakref.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-dereffed-weakref.js
@@ -25,7 +25,7 @@ let weak_ref;
 })();
 
 // Clear the KeepDuringJob set.
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 weak_ref.deref();
 o = null;
@@ -37,7 +37,7 @@ gc();
 wf.cleanupSome();
 assertEquals(0, cleanup_count);
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 // Now the WeakRef can be cleared.
@@ -51,7 +51,7 @@ assertEquals(weak_ref, cleanup_cells[0]);
 // The cleanup task is not executed again since all WeakCells have been
 // processed.
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertEquals(1, cleanup_count);
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-weakref.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-weakref.js
index ab1e7ebe19..d478aaab8c 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-weakref.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/cleanupsome-weakref.js
@@ -31,7 +31,7 @@ gc();
 wf.cleanupSome();
 assertEquals(0, cleanup_count);
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 // Now the WeakRef can be cleared.
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/clear-after-deref.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/clear-after-deref.js
index e76ff0011f..9577f48b05 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/clear-after-deref.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/clear-after-deref.js
@@ -28,7 +28,7 @@ let wr;
 gc();
 assertNotEquals(undefined, wr.deref());
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // New turn.
 
 let o = wr.deref();
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/two-weakrefs.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/two-weakrefs.js
index 067578f29b..7109d51fde 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/two-weakrefs.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/two-weakrefs.js
@@ -38,7 +38,7 @@ gc();
   assertNotEquals(undefined, wr2.deref());
 })();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // New turn.
 
 assertEquals(0, cleanup_count);
@@ -47,7 +47,7 @@ wr1.deref();
 o1 = null;
 gc(); // deref makes sure we don't clean up wr1
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // New turn.
 
 assertEquals(0, cleanup_count);
@@ -56,7 +56,7 @@ wr2.deref();
 o2 = null;
 gc(); // deref makes sure we don't clean up wr2
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // New turn.
 
 assertEquals(1, cleanup_count);
@@ -64,7 +64,7 @@ assertEquals(wr1, cleared_cells1[0]);
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // New turn.
 
 assertEquals(2, cleanup_count);
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakcell-and-weakref.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakcell-and-weakref.js
index 4e5eec018b..fc400169d0 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakcell-and-weakref.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakcell-and-weakref.js
@@ -34,12 +34,12 @@ gc();
   assertNotEquals(undefined, weak_ref.deref());
 })();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertTrue(cleanup_called);
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-creation-keeps-alive.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-creation-keeps-alive.js
index fd22345104..02313fe761 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-creation-keeps-alive.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-creation-keeps-alive.js
@@ -33,14 +33,14 @@ gc();
   assertNotEquals(undefined, wr.deref());
 })();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertFalse(cleanup_called);
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertTrue(cleanup_called);
diff --git a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-deref-keeps-alive.js b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-deref-keeps-alive.js
index c67dc0a11b..05917c5261 100644
--- a/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-deref-keeps-alive.js
+++ b/implementation-contributed/v8/mjsunit/harmony/weakrefs/weakref-deref-keeps-alive.js
@@ -29,12 +29,12 @@ let strong = {a: wr.deref(), b: wr_control.deref()};
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 // We have a strong reference to the objects, so the WeakRefs are not cleared yet.
@@ -57,7 +57,7 @@ gc();
   assertEquals(undefined, wr_control.deref());
 })();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertEquals(1, cleanup_count);
@@ -66,7 +66,7 @@ assertEquals(wc, cleanup_cells[0]);
 
 gc();
 
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 // Next turn.
 
 assertEquals(2, cleanup_count);
diff --git a/implementation-contributed/v8/mjsunit/mjsunit.status b/implementation-contributed/v8/mjsunit/mjsunit.status
index 1901aded62..76b22d8467 100644
--- a/implementation-contributed/v8/mjsunit/mjsunit.status
+++ b/implementation-contributed/v8/mjsunit/mjsunit.status
@@ -32,6 +32,7 @@
   'modules-skip*': [SKIP],
   'harmony/modules-skip*': [SKIP],
   'regress/modules-skip*': [SKIP],
+  'wasm/exceptions-utils': [SKIP],
   'wasm/wasm-constants': [SKIP],
   'wasm/wasm-module-builder': [SKIP],
 
@@ -569,6 +570,10 @@
   'regress/regress-752764': [SKIP],
   'regress/regress-779407': [SKIP],
   'harmony/bigint/regressions': [SKIP],
+
+  # Pre-r6 MIPS32 doesn't have instructions needed to properly handle 64-bit
+  # atomic instructions.
+  'wasm/atomics64-stress': [PASS, ['mips_arch_variant != r6', SKIP]],
 }],  # 'arch == mipsel or arch == mips'
 
 ##############################################################################
@@ -623,6 +628,11 @@
   'regress/regress-779407': [SKIP],
 }],  # 'arch == mips64el or arch == mips64'
 
+['(arch == mips64el or arch == mips64) and simulator_run', {
+  # Slow tests which have flaky timeout on simulator.
+  'wasm/atomics64-stress': [SKIP],
+}],  # '(arch == mips64el or arch == mips64) and simulator_run'
+
 ##############################################################################
 ['system == windows', {
   # TODO(mstarzinger): Too slow with turbo fan.
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-5405.js b/implementation-contributed/v8/mjsunit/regress/regress-5405.js
index eeab479384..e21818c880 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-5405.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-5405.js
@@ -11,7 +11,7 @@ let log = [];
     return 10;
   }
 })();
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 
 (function() {
   with ({get ['.new.target']() { log.push('new.target') }}) {
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-5691.js b/implementation-contributed/v8/mjsunit/regress/regress-5691.js
index 6cda92ca79..b460ac4b99 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-5691.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-5691.js
@@ -18,6 +18,6 @@ Promise.resolve(Promise.resolve()).then(() => log += "|fast-resolve");
 (class extends Promise {}).resolve(Promise.resolve()).then(() => log += "|slow-resolve");
 
 log += "|start";
-  %RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals("|start|turn1|fast-resolve|turn2|turn3|slow-resolve|turn4\n\
 |start|turn1|fast-resolve|turn2|turn3|slow-resolve|turn4", result);
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-682349.js b/implementation-contributed/v8/mjsunit/regress/regress-682349.js
index d94e0691d6..f82f242f03 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-682349.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-682349.js
@@ -9,5 +9,5 @@ function f() {
   success = (f.caller === null);
 }
 Promise.resolve().then(f);
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(success);
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-740694.js b/implementation-contributed/v8/mjsunit/regress/regress-740694.js
index f07eb1b3a7..6f31fef0c7 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-740694.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-740694.js
@@ -17,6 +17,6 @@ var error;
 var promise = __f_0();
 promise.then(assertUnreachable,
              err => { done = true; error = err });
-%RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertTrue(error.startsWith('Error reading'));
 assertTrue(done);
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-797581.js b/implementation-contributed/v8/mjsunit/regress/regress-797581.js
index eb87e67128..3dfad4c463 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-797581.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-797581.js
@@ -17,7 +17,7 @@ function TryToLoadModule(filename, expect_error, token) {
   }
 
   import(filename).catch(SetError);
-  %RunMicrotasks();
+  %PerformMicrotaskCheckpoint();
 
   if (expect_error) {
     assertTrue(caught_error instanceof SyntaxError);
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-800651.js b/implementation-contributed/v8/mjsunit/regress/regress-800651.js
index c6410f702e..05e31fe4ca 100644
--- a/implementation-contributed/v8/mjsunit/regress/regress-800651.js
+++ b/implementation-contributed/v8/mjsunit/regress/regress-800651.js
@@ -27,5 +27,5 @@ function g() {
   let namespace = Promise.resolve().then(importUndefined);
 }
 g();
-  %RunMicrotasks();
+%PerformMicrotaskCheckpoint();
 assertEquals(list, [1,2]);
diff --git a/implementation-contributed/v8/mjsunit/regress/regress-crbug-911416.js b/implementation-contributed/v8/mjsunit/regress/regress-crbug-911416.js
new file mode 100644
index 0000000000..60d7ae892a
--- /dev/null
+++ b/implementation-contributed/v8/mjsunit/regress/regress-crbug-911416.js
@@ -0,0 +1,5 @@
+// Copyright 2018 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.
+
+assertEquals(7, ({[Symbol.hasInstance.description]:7})["Symbol.hasInstance"]);
diff --git a/implementation-contributed/v8/mjsunit/regress/wasm/regress-8533.js b/implementation-contributed/v8/mjsunit/regress/wasm/regress-8533.js
new file mode 100644
index 0000000000..5d782b747c
--- /dev/null
+++ b/implementation-contributed/v8/mjsunit/regress/wasm/regress-8533.js
@@ -0,0 +1,85 @@
+// Copyright 2018 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: --wasm-shared-engine --no-wasm-disable-structured-cloning --allow-natives-syntax --experimental-wasm-threads
+
+load('test/mjsunit/wasm/wasm-constants.js');
+load('test/mjsunit/wasm/wasm-module-builder.js');
+
+
+// In  this test we start a worker which enters wasm and stays there in a loop.
+// The main thread stays in JS and checks that its thread-in-wasm flag is not
+// set. The main thread calls setTimeout after every check to give the worker a
+// chance to be scheculed.
+const sync_address = 12;
+(function TestPostModule() {
+  let builder = new WasmModuleBuilder();
+  let sig_index = builder.addType(kSig_v_v);
+  let import_id = builder.addImport('m', 'func', sig_index);
+  builder.addFunction('wait', kSig_v_v)
+      .addBody([
+        // Calling the imported function sets the thread-in-wasm flag of the
+        // main thread.
+        kExprCallFunction, import_id,  // --
+        kExprLoop, kWasmStmt,          // --
+        kExprI32Const, sync_address,   // --
+        kExprI32LoadMem, 0, 0,         // --
+        kExprI32Eqz,
+        kExprBrIf, 0,                  // --
+        kExprEnd,
+      ])
+      .exportFunc();
+
+  builder.addFunction('signal', kSig_v_v)
+      .addBody([
+        kExprI32Const, sync_address,  // --
+        kExprI32Const, 1,             // --
+        kExprI32StoreMem, 0, 0,       // --
+        ])
+      .exportFunc();
+  builder.addImportedMemory("m", "imported_mem", 0, 1, "shared");
+
+  let module = builder.toModule();
+  let memory = new WebAssembly.Memory({initial: 1, maximum: 1, shared: true});
+
+  let workerScript = `
+    onmessage = function(msg) {
+      try {
+        let worker_instance = new WebAssembly.Instance(msg.module,
+            {m: {imported_mem: msg.memory,
+                 func: _ => 5}});
+        postMessage("start running");
+        worker_instance.exports.wait();
+        postMessage("finished");
+      } catch(e) {
+        postMessage('ERROR: ' + e);
+      }
+    }
+  `;
+
+  let worker = new Worker(workerScript, {type: 'string'});
+  worker.postMessage({module: module, memory: memory});
+
+  let main_instance = new WebAssembly.Instance(
+      module, {m: {imported_mem: memory, func: _ => 7}});
+
+  let counter = 0;
+  function CheckThreadNotInWasm() {
+    // We check the thread-in-wasm flag many times and reschedule ourselves in
+    // between to increase the chance that we read the flag set by the worker.
+    assertFalse(%IsThreadInWasm());
+    counter++;
+    if (counter < 100) {
+      setTimeout(CheckThreadNotInWasm, 0);
+    } else {
+      main_instance.exports.signal(sync_address);
+      assertEquals('finished', worker.getMessage());
+      worker.terminate();
+    }
+  }
+
+  assertFalse(%IsThreadInWasm());
+  assertEquals('start running', worker.getMessage());
+  CheckThreadNotInWasm();
+})();
diff --git a/implementation-contributed/v8/mjsunit/test-async.js b/implementation-contributed/v8/mjsunit/test-async.js
index d4fee9bfb9..8f7b553988 100644
--- a/implementation-contributed/v8/mjsunit/test-async.js
+++ b/implementation-contributed/v8/mjsunit/test-async.js
@@ -80,7 +80,7 @@ var testAsync;
     }
 
     drainMicrotasks() {
-      %RunMicrotasks();
+      %PerformMicrotaskCheckpoint();
     }
 
     done_() {
@@ -111,7 +111,7 @@ var testAsync;
   testAsync = function(test, name) {
     let assert = new AsyncAssertion(test, name);
     test(assert);
-    %RunMicrotasks();
+    %PerformMicrotaskCheckpoint();
     assert.done_();
   }
 })();
diff --git a/implementation-contributed/v8/test262/test262.status b/implementation-contributed/v8/test262/test262.status
index 26acc12570..ecab026c98 100644
--- a/implementation-contributed/v8/test262/test262.status
+++ b/implementation-contributed/v8/test262/test262.status
@@ -562,9 +562,6 @@
   'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-caller': [FAIL_SLOPPY],
   'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-arguments': [FAIL_SLOPPY],
 
-  # https://bugs.chromium.org/p/v8/issues/detail?id=7874
-  'built-ins/Reflect/ownKeys/return-on-corresponding-order-large-index': [FAIL],
-
   # https://bugs.chromium.org/p/v8/issues/detail?id=6776
   'built-ins/Proxy/ownKeys/return-duplicate-entries-throws': [FAIL],
   'built-ins/Proxy/ownKeys/return-duplicate-symbol-entries-throws': [FAIL],
@@ -666,6 +663,16 @@
   'language/expressions/await/for-await-of-interleaved': ['--harmony-await-optimization'],
   'language/expressions/await/async-await-interleaved': ['--harmony-await-optimization'],
 
+  # https://bugs.chromium.org/p/v8/issues/detail?id=6891
+  'intl402/Segmenter/iterator/following': [FAIL],
+  'intl402/Segmenter/iterator/granularity': [FAIL],
+  'intl402/Segmenter/iterator/preceding': [FAIL],
+  'intl402/Segmenter/prototype/segment/segment-line': [FAIL],
+  'intl402/Segmenter/prototype/segment/segment-sentence': [FAIL],
+  'intl402/Segmenter/prototype/segment/segment-word': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=8021
+  'built-ins/Object/fromEntries/requires-argument': [FAIL],
   ######################## NEEDS INVESTIGATION ###########################
 
   # These test failures are specific to the intl402 suite and need investigation
diff --git a/implementation-contributed/v8/test262/testcfg.py b/implementation-contributed/v8/test262/testcfg.py
index e62759885a..9052aab12f 100644
--- a/implementation-contributed/v8/test262/testcfg.py
+++ b/implementation-contributed/v8/test262/testcfg.py
@@ -63,7 +63,8 @@ FEATURE_FLAGS = {
 SKIPPED_FEATURES = set(['class-fields-private',
                         'class-static-fields-private',
                         'class-methods-private',
-                        'class-static-methods-private'])
+                        'class-static-methods-private',
+                        'Intl.NumberFormat-unified'])
 
 DATA = os.path.join(os.path.dirname(os.path.abspath(__file__)), "data")
 
diff --git a/implementation-contributed/v8/wasm-js/wasm-js.status b/implementation-contributed/v8/wasm-js/wasm-js.status
index 2f3111aa3a..fe74ca47f5 100644
--- a/implementation-contributed/v8/wasm-js/wasm-js.status
+++ b/implementation-contributed/v8/wasm-js/wasm-js.status
@@ -5,7 +5,6 @@
 [
 [ALWAYS, {
   # https://bugs.chromium.org/p/v8/issues/detail?id=8319
-  'interface': [FAIL],
   'memory/grow': [FAIL],
   'memory/constructor': [FAIL],
   'table/grow': [FAIL],
-- 
GitLab