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

Issue 2090983002: Revert of Reland [heap] Avoid the use of cells to point from code to new-space objects. (Closed)

Created:
4 years, 6 months ago by vogelheim
Modified:
4 years, 6 months ago
Reviewers:
Michael Lippautz, ahaas
CC:
Hannes Payer (out of office), ulan, v8-mips-ports_googlegroups.com, v8-ppc-ports_googlegroups.com, v8-reviews_googlegroups.com, v8-x87-ports_googlegroups.com
Base URL:
https://chromium.googlesource.com/v8/v8.git@master
Target Ref:
refs/pending/heads/master
Project:
v8
Visibility:
Public.

Description

Revert of Reland [heap] Avoid the use of cells to point from code to new-space objects. (patchset #3 id:40001 of https://codereview.chromium.org/2091733002/ ) Reason for revert: This breaks gc-stress bot: https://chromegw.corp.google.com/i/client.v8/builders/V8%20Linux64%20GC%20Stress%20-%20custom%20snapshot # # Fatal error in ../../src/heap/mark-compact.cc, line 3715 # Check failed: Page::FromAddress(reinterpret_cast<HeapObject*>(*slot)->address()) ->IsFlagSet(Page::PAGE_NEW_NEW_PROMOTION). # I can reproduce locally, and local revert also fixes it -> revert. Reproduce with: out/Debug/d8 --test --random-seed=2140216864 --nohard-abort --nodead-code-elimination --nofold-constants --enable-slow-asserts --debug-code --verify-heap --allow-natives-syntax --harmony-tailcalls test/mjsunit/mjsunit.js test/mjsunit/es6/tail-call-megatest-shard2.js --gc-interval=500 --stress-compaction --concurrent-recompilation-queue-length=64 --concurrent-recompilation-delay=500 --concurrent-recompilation (Maybe run in loop; it's flaky when broken; but passes reliably w/ revert.) Original issue's description: > Reland [heap] Avoid the use of cells to point from code to new-space objects. > > The reason for reverting was: [Sheriff] Breaks arm debug: > https://build.chromium.org/p/client.v8.ports/builders/V8%20Linux%20-%20arm%20-%20sim%20-%20debug/builds/1038. > > The problem was the dereferencing of handles for smi checks. It turned out > that these smi checks can be removed anyways, both on arm and on mips. > > Additionally some rebasing was necessary. > > Original issue's description: > > Cells were needed originally because there was no typed remembered set to > record direct pointers from code space to new space. A previous > CL (https://codereview.chromium.org/2003553002/) already introduced > the remembered set, this CL uses it. > > This CL > * stores direct pointers in code objects, even if the target is in new space, > * records the slot of the pointer in typed-old-to-new remembered set, > * adds a list which stores weak code-to-new-space references, > * adds a test to test-heap.cc for weak code-to-new-space references, > * removes prints in tail-call-megatest.js > > R=mlippautz@chromium.org > > Committed: https://crrev.com/5508e16592522658587da71ba6743c8e832fe4d1 > Cr-Commit-Position: refs/heads/master@{#37217} TBR=mlippautz@chromium.org,ahaas@chromium.org # Skipping CQ checks because original CL landed less than 1 days ago. NOPRESUBMIT=true NOTREECHECKS=true NOTRY=true Committed: https://crrev.com/25d59e9d48b83202962cd1932606ede39b782ce8 Cr-Commit-Position: refs/heads/master@{#37221}

Patch Set 1 #

Unified diffs Side-by-side diffs Delta from patch set Stats (+169 lines, -253 lines) Patch
M src/arm/assembler-arm.cc View 1 chunk +1 line, -0 lines 0 comments Download
M src/arm/assembler-arm-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M src/arm/macro-assembler-arm.cc View 1 chunk +13 lines, -1 line 0 comments Download
M src/arm64/assembler-arm64.cc View 1 chunk +1 line, -0 lines 0 comments Download
M src/arm64/assembler-arm64-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M src/arm64/macro-assembler-arm64.cc View 1 chunk +8 lines, -1 line 0 comments Download
M src/compiler.cc View 1 chunk +3 lines, -8 lines 0 comments Download
M src/heap/heap.h View 3 chunks +0 lines, -10 lines 0 comments Download
M src/heap/heap.cc View 7 chunks +37 lines, -37 lines 0 comments Download
M src/heap/heap-inl.h View 1 chunk +0 lines, -6 lines 0 comments Download
M src/heap/mark-compact.cc View 9 chunks +20 lines, -50 lines 0 comments Download
M src/heap/remembered-set.h View 1 chunk +0 lines, -14 lines 0 comments Download
M src/heap/remembered-set.cc View 2 chunks +0 lines, -14 lines 0 comments Download
M src/ia32/assembler-ia32-inl.h View 3 chunks +4 lines, -1 line 0 comments Download
M src/ia32/macro-assembler-ia32.cc View 1 chunk +27 lines, -5 lines 0 comments Download
M src/mips/assembler-mips.cc View 1 chunk +1 line, -0 lines 0 comments Download
M src/mips/assembler-mips-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M src/mips/macro-assembler-mips.cc View 1 chunk +13 lines, -1 line 0 comments Download
M src/mips64/assembler-mips64.cc View 1 chunk +1 line, -0 lines 0 comments Download
M src/mips64/assembler-mips64-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M src/mips64/macro-assembler-mips64.cc View 1 chunk +13 lines, -1 line 0 comments Download
M src/objects.h View 1 chunk +1 line, -2 lines 0 comments Download
M src/objects-debug.cc View 1 chunk +5 lines, -19 lines 0 comments Download
M src/objects-inl.h View 1 chunk +3 lines, -2 lines 0 comments Download
M src/x64/assembler-x64-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M src/x64/macro-assembler-x64.h View 1 chunk +1 line, -0 lines 0 comments Download
M src/x64/macro-assembler-x64.cc View 1 chunk +8 lines, -1 line 0 comments Download
M src/x87/assembler-x87-inl.h View 1 chunk +0 lines, -1 line 0 comments Download
M test/cctest/heap/test-heap.cc View 1 chunk +0 lines, -61 lines 0 comments Download
M test/cctest/test-serialize.cc View 1 chunk +9 lines, -13 lines 0 comments Download

Messages

Total messages: 7 (3 generated)
vogelheim
Created Revert of Reland [heap] Avoid the use of cells to point from code to ...
4 years, 6 months ago (2016-06-23 16:02:10 UTC) #2
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/2090983002/1
4 years, 6 months ago (2016-06-23 16:02:17 UTC) #3
commit-bot: I haz the power
Committed patchset #1 (id:1)
4 years, 6 months ago (2016-06-23 16:02:44 UTC) #5
commit-bot: I haz the power
4 years, 6 months ago (2016-06-23 16:07:18 UTC) #7
Message was sent while issue was closed.
Patchset 1 (id:??) landed as
https://crrev.com/25d59e9d48b83202962cd1932606ede39b782ce8
Cr-Commit-Position: refs/heads/master@{#37221}

Powered by Google App Engine
This is Rietveld 408576698