Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(376)

Issue 1425743002: Modify %AddElement to accept large indices out of array bounds (Closed)

Created:
5 years, 1 month ago by Dan Ehrenberg
Modified:
5 years, 1 month ago
Reviewers:
adamk, Toon Verwaest
CC:
v8-reviews_googlegroups.com
Base URL:
https://chromium.googlesource.com/v8/v8.git@master
Target Ref:
refs/pending/heads/master
Project:
v8
Visibility:
Public.

Description

Modify %AddElement to accept large indices out of array bounds This patch changes %AddElement to fall back to adding a named property in case it is given an argument of 2**32 or greater. The change is needed because %AddElement is called by Array functions in various places, and ES2015 changes these Array functions to use ToLength rather than ToUint32, so several callsites of %AddElement which used to be reliable array indices may be larger numbers. While the proper long-term solution may be to call out to Object.defineProperty, this fix should allow the ToLength semantics to be shipped while preserving correctness and not requiring a rewrite. BUG=v8:4516 LOG=Y R=adamk TEST=Interactively ran Array.prototype.slice on an Array-like which exceeded array bounds, and found that this did not check-fail at runtime as it did before. Interactively used %AddElements with larger number inputs and observed it to correctly manipulate objects.

Patch Set 1 #

Patch Set 2 : Fix debug assertions #

Unified diffs Side-by-side diffs Delta from patch set Stats (+30 lines, -14 lines) Patch
M src/runtime/runtime-object.cc View 1 2 chunks +30 lines, -14 lines 0 comments Download

Messages

Total messages: 14 (5 generated)
Dan Ehrenberg
5 years, 1 month ago (2015-10-27 00:44:50 UTC) #2
commit-bot: I haz the power
Dry run: CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/1425743002/1 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/1425743002/1
5 years, 1 month ago (2015-10-27 00:44:54 UTC) #3
commit-bot: I haz the power
Dry run: Try jobs failed on following builders: v8_linux64_avx2_rel on tryserver.v8 (JOB_FAILED, http://build.chromium.org/p/tryserver.v8/builders/v8_linux64_avx2_rel/builds/5787)
5 years, 1 month ago (2015-10-27 00:54:46 UTC) #5
commit-bot: I haz the power
Dry run: CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/1425743002/20001 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/1425743002/20001
5 years, 1 month ago (2015-10-27 03:55:31 UTC) #7
commit-bot: I haz the power
Dry run: This issue passed the CQ dry run.
5 years, 1 month ago (2015-10-27 04:38:53 UTC) #9
Dan Ehrenberg
5 years, 1 month ago (2015-10-27 05:14:27 UTC) #10
Toon Verwaest
The idea of these specific runtime functions is that they do exactly what they claim, ...
5 years, 1 month ago (2015-10-27 08:26:45 UTC) #12
Dan Ehrenberg
On 2015/10/27 at 08:26:45, verwaest wrote: > The idea of these specific runtime functions is ...
5 years, 1 month ago (2015-10-27 13:42:37 UTC) #13
Dan Ehrenberg
5 years, 1 month ago (2015-10-27 21:38:52 UTC) #14
Message was sent while issue was closed.
Closing this in favor of https://codereview.chromium.org/1420663003/

Powered by Google App Engine
This is Rietveld 408576698