Closed Bug 1677224 Opened 4 years ago Closed 4 years ago

Use tagged index in ParserScopeData

Categories

(Core :: JavaScript Engine, task, P1)

task

Tracking

()

RESOLVED FIXED
86 Branch
Tracking Status
firefox86 --- fixed

People

(Reporter: arai, Assigned: arai)

References

Details

Attachments

(4 files)

Just like bug 1675804, we can use tagged index in scope data.
we have topmost 2-bit available in TaggedParserAtomIndex, and we can use them for ClosedOverFlag and TopLevelFunctionFlag

  • Replace ParserAtom pointer with TaggedParserAtomIndex in ParserScopeData
    • Add TaggedParserAtomIndex specialization for AbstractBindingName,
      in order to store closed-over and top-level-function flag in
      highest bits of TaggedParserAtomIndex
    • Moved existing implementation of AbstractBindingName to
      JSAtom specialization

Now trailing names is an array of TaggedParserAtomIndex, and can be
encoded/decoded by codeBytes.

Depends on D99299

Depends on D99300

Depends on D99301

Pushed by arai_a@mac.com: https://hg.mozilla.org/integration/autoland/rev/2d9a14218c49 Part 1: Use TaggedParserAtomIndex in ParserScopeData. r=nbp https://hg.mozilla.org/integration/autoland/rev/b46b9e2360f6 Part 2: Encode/decode trailing names at once. r=nbp https://hg.mozilla.org/integration/autoland/rev/9f10e3fb773b Part 3: Remove XDRParserAtomOrNull. r=nbp https://hg.mozilla.org/integration/autoland/rev/0ff8fe67a6ae Part 4: Remove XDRParserAtom. r=nbp

there seems to be some heap corruption or something in BumpChunk.

it crashes while poisoning trailing array here
https://searchfox.org/mozilla-central/rev/8883276967d39918e2ce64e873afdd432fb406ca/js/src/vm/Scope.h#265-267

the memory block is inside the chunk allocated by the following, and so far I don't see the block gets freed.
https://searchfox.org/mozilla-central/rev/8883276967d39918e2ce64e873afdd432fb406ca/js/src/ds/LifoAlloc.cpp#31

no, it's not memory corruption.
it's just that we shouldn't use poison for non-pointer-size-aligned memory block.

Attachment #9192315 - Attachment description: Bug 1677224 - Part 1: Use TaggedParserAtomIndex in ParserScopeData. r?nbp! → Bug 1677224 - Part 1: Use TaggedParserAtomIndex in ParserScopeData. r=nbp
Flags: needinfo?(arai.unmht)
Pushed by arai_a@mac.com: https://hg.mozilla.org/integration/autoland/rev/1cdeca7d522e Part 1: Use TaggedParserAtomIndex in ParserScopeData. r=nbp https://hg.mozilla.org/integration/autoland/rev/6cf94ea511b2 Part 2: Encode/decode trailing names at once. r=nbp https://hg.mozilla.org/integration/autoland/rev/98c42effee5c Part 3: Remove XDRParserAtomOrNull. r=nbp https://hg.mozilla.org/integration/autoland/rev/b2d6946fb3a2 Part 4: Remove XDRParserAtom. r=nbp
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: