Bug 200018

Summary: Sometimes we miss removable CheckInBounds
Product: WebKit Reporter: Justin Michaud <justin_michaud>
Component: JavaScriptCoreAssignee: Justin Michaud <justin_michaud>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, ews-watchlist, keith_miller, mark.lam, msaboff, saam, tzagallo, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch none

Justin Michaud
Reported 2019-07-22 15:54:51 PDT
In the following loop: +function doTest(arr1) { + let sum = 0 + for (let i=0; i<arr1.length; ++i) { + sum += arr1[i] + } + return sum +} +noInline(doTest); + +let arr1 = new Int32Array(1000) +//let arr1 = new Array(1000) + +for (let i=0; i<1000; ++i) doTest(arr1) we should not need to emit a checkInBounds, but we do.
Attachments
Patch (2.24 KB, patch)
2019-07-22 16:00 PDT, Justin Michaud
no flags
Patch (2.71 KB, patch)
2019-07-22 16:40 PDT, Justin Michaud
no flags
Patch (3.84 KB, patch)
2019-07-22 16:56 PDT, Justin Michaud
no flags
Justin Michaud
Comment 1 2019-07-22 16:00:23 PDT
Justin Michaud
Comment 2 2019-07-22 16:40:07 PDT
Saam Barati
Comment 3 2019-07-22 16:47:51 PDT
Comment on attachment 374652 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=374652&action=review r=me > Source/JavaScriptCore/ChangeLog:8 > + We failed to remove the CheckInBounds bounds because we did not see that the index was nonnegative. This is because we do not see the relationship between the two > + separate zero constants that appear in the IR for the given test case. This patch re-adds the hack to de-duplicate m_zero that was removed in > + <https://trac.webkit.org/changeset/241228/webkit>. nit: should go below "Reviewed by ..." Might be worth also opening a bug on not being reliant on the exact node pointer. Or at least understanding why it's ok to rely on the actual node pointer value.
Saam Barati
Comment 4 2019-07-22 16:48:24 PDT
Comment on attachment 374652 [details] Patch Can you also add a microbenchmark if one doesn't already exist
Justin Michaud
Comment 5 2019-07-22 16:56:51 PDT
WebKit Commit Bot
Comment 6 2019-07-23 10:24:20 PDT
Comment on attachment 374654 [details] Patch Clearing flags on attachment: 374654 Committed r247724: <https://trac.webkit.org/changeset/247724>
WebKit Commit Bot
Comment 7 2019-07-23 10:24:21 PDT
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 8 2019-07-23 10:25:18 PDT
Note You need to log in before you can comment on or make changes to this bug.