Closed Bug 1790791 Opened 2 years ago Closed 2 years ago

Optimize megamorphic SetProp/SetElem for PlainObject

Categories

(Core :: JavaScript Engine: JIT, task, P3)

task

Tracking

()

RESOLVED FIXED
106 Branch
Tracking Status
firefox106 --- fixed

People

(Reporter: jandem, Assigned: jandem)

References

(Blocks 3 open bugs)

Details

(Whiteboard: [sp3])

Attachments

(3 files)

We've optimized megamorphic GetProp and HasProp pretty well, but SetProp/SetElem often shows up in profiles because we go through SetObjectElementWithReceiver => NativeSetProperty. This is the generic set-property code and it's relatively slow.

In practice, almost all of these megamorphic sets are setting/adding a string property on a PlainObject and we can carve out a fast path for just this case. I wrote a patch for this and collected some data:

matrix-react benchmark:

Optimized (PlainObject):    94.2%
Not optimized (other):       3.3%
Not optimized (PlainObject): 2.5%

Speedometer 2:

Optimized (PlainObject):    98.0%
Not optimized (other):       2.0%
Not optimized (PlainObject): 0.0% (actually 0.027%)

The JS shell micro-benchmark below improves from ~364 ms to ~211 ms.

function f() {
    var t = new Date;
    var props = ["x1", "x2", "x3", "x4", "x5", "x6", "x7",
                 "x3", "x5", "x8", "x1"];
    var o;
    for (var i = 0; i < 1_000_000; i++) {
        o = {};
        for (var j = 0; j < props.length; j++) {
            o[props[j]] = j;
        }
    }
    print(new Date - t);
    return o;
}
f();

This matches the name of the corresponding CacheIR instruction.

More than 94% of calls to SetElementMegamorphic on matrix-react-bench, Speedometer 2,
and a number of popular websites can be optimized with this fast path.

This makes a micro-benchmark 1.72x faster and should eliminate most of the overhead,
but we could potentially optimize this more in the future with the megamorphic
cache.

Depends on D157331

Pushed by jdemooij@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/548e62dfe628
part 1 - Rename MCallSetElement to MMegamorphicSetElement. r=iain
https://hg.mozilla.org/integration/autoland/rev/a9c7e9eba6b8
part 2 - Add js::jit::SetElementMegamorphic. r=iain
https://hg.mozilla.org/integration/autoland/rev/900845a8e813
part 3 - Add a fast path for megamorphic set/add on plain objects. r=iain
Status: ASSIGNED → RESOLVED
Closed: 2 years ago
Resolution: --- → FIXED
Target Milestone: --- → 106 Branch

Some nice improvements on AWFY Speedometer:
Elm-TodoMVC/*
React-Redux-TodoMVC*

Whiteboard: [sp3]
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: