Bug 164904 - We should support CreateThis in the FTL
Summary: We should support CreateThis in the FTL
Status: RESOLVED FIXED
Alias: None
Product: WebKit
Classification: Unclassified
Component: JavaScriptCore (show other bugs)
Version: WebKit Nightly Build
Hardware: Unspecified Unspecified
: P2 Normal
Assignee: Filip Pizlo
URL:
Keywords: InRadar
: 187908 (view as bug list)
Depends on: 165208 186237
Blocks: 187891
  Show dependency treegraph
 
Reported: 2016-11-17 19:37 PST by Saam Barati
Modified: 2018-07-23 09:15 PDT (History)
17 users (show)

See Also:


Attachments
patch (8.44 KB, patch)
2016-11-27 15:06 PST, Saam Barati
no flags Details | Formatted Diff | Diff
patch (11.37 KB, patch)
2016-11-28 12:53 PST, Saam Barati
no flags Details | Formatted Diff | Diff
Archive of layout-test-results from ews124 for ios-simulator-wk2 (deleted)
2016-11-28 22:01 PST, Build Bot
no flags Details
attempting a fix (28.89 KB, patch)
2018-05-27 22:15 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
more (39.77 KB, patch)
2018-05-28 18:02 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
more (80.95 KB, patch)
2018-05-29 17:18 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
CallLinkStatus is starting to look sensible (91.94 KB, patch)
2018-05-29 17:56 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
DFG/FTL filtering of statuses seems to be written (111.72 KB, patch)
2018-05-30 14:48 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
GetByIdStatus is starting to look good (117.05 KB, patch)
2018-05-30 15:39 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
maybe it's done (137.20 KB, patch)
2018-05-30 16:20 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
slowly getting it to compile (138.57 KB, patch)
2018-05-31 14:54 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
more (144.06 KB, patch)
2018-05-31 16:41 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
wow it compiles! (148.25 KB, patch)
2018-05-31 20:53 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
recursive polyvariant profiling appears to work (152.68 KB, patch)
2018-06-01 12:35 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
more (152.99 KB, patch)
2018-06-01 16:57 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
so close (153.62 KB, patch)
2018-06-01 17:53 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
it makes raytrace neutral! (154.67 KB, patch)
2018-06-01 19:34 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
passing so many tests (159.26 KB, patch)
2018-06-01 21:26 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
it works! (178.63 KB, patch)
2018-06-02 11:35 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
rebased patch (194.45 KB, patch)
2018-06-02 12:45 PDT, Filip Pizlo
ysuzuki: review+
Details | Formatted Diff | Diff
fix build (196.05 KB, patch)
2018-06-02 13:13 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
fix build (196.08 KB, patch)
2018-06-02 13:30 PDT, Filip Pizlo
ysuzuki: review+
ews-watchlist: commit-queue-
Details | Formatted Diff | Diff
Archive of layout-test-results from ews205 for win-future (12.74 MB, application/zip)
2018-06-02 20:04 PDT, EWS Watchlist
no flags Details
working to fix ARES-6 regression (224.79 KB, patch)
2018-06-04 15:36 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
fixed a bunch of perf bugs (237.26 KB, patch)
2018-06-06 21:37 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
neutral on JetStream, ARES-6, and Speedometer2 (239.86 KB, patch)
2018-06-07 10:05 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff
the patch (238.80 KB, patch)
2018-06-07 10:47 PDT, Filip Pizlo
ysuzuki: review+
ews-watchlist: commit-queue-
Details | Formatted Diff | Diff
Archive of layout-test-results from ews106 for mac-sierra-wk2 (3.55 MB, application/zip)
2018-06-07 12:30 PDT, EWS Watchlist
no flags Details
rebased patch (238.88 KB, patch)
2018-06-23 19:47 PDT, Filip Pizlo
no flags Details | Formatted Diff | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Saam Barati 2016-11-17 19:37:41 PST
...
Comment 1 Saam Barati 2016-11-27 15:06:57 PST
Created attachment 295471 [details]
patch
Comment 2 Filip Pizlo 2016-11-27 16:38:37 PST
Comment on attachment 295471 [details]
patch

View in context: https://bugs.webkit.org/attachment.cgi?id=295471&action=review

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9506
> +        LValue callee = lowCell(m_node->child1());

You should do LBasicBlock lastNext = m_out.insertNewBlocksBefore(isFunctionBlock) here.  That way, if lowCell produces blocks, they will be nicely ordered.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9507
> +        m_out.branch(isFunction(callee, provenType(m_node->child1())), unsure(isFunctionBlock), unsure(slowPath));

Could this be usually(isFunctionBlock), rarely(slowPath)?  Our register allocator will do a better job on the slow path call this way.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9508
> +        LBasicBlock lastNext = m_out.appendTo(isFunctionBlock, hasRareData);

Then you don't need to save lastNext here.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9511
> +        m_out.branch(m_out.isZero64(rareData), unsure(slowPath), unsure(hasRareData));

Ditto.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9528
> +    }

You need m_out.mutatorFence() here because you just allocated an object.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9961
> +        LValue id = m_out.load32(structure, m_heaps.Structure_structureID);
> +        LValue blob = m_out.load32(structure, m_heaps.Structure_initializationBlob);

You should have code to attempt to constant-fold these loads.  Maybe you can even add a helper in FTL::Output called m_out.constLoad32, which will check if its input LValue is a constant, and if so, it will just run the load and return the constant.  If you do this, you don't need to use templates and you don't need to duplicate the code for storeStructure.

> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9998
> +    template <typename StructureType>
>      LValue allocateObject(
> -        LValue allocator, Structure* structure, LValue butterfly, LBasicBlock slowPath)
> +        LValue allocator, StructureType structure, LValue butterfly, LBasicBlock slowPath)

This is strange: we're handling the possible constness of the allocator by using LValue and then querying if it's a constant, but instead of doing that for structure, you used templates.

I think that using LValue structure is better.  Places that want to do smart things in case it's a constant can extract that constant from the LValue.
Comment 3 Saam Barati 2016-11-28 12:22:06 PST
Comment on attachment 295471 [details]
patch

View in context: https://bugs.webkit.org/attachment.cgi?id=295471&action=review

>> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9506
>> +        LValue callee = lowCell(m_node->child1());
> 
> You should do LBasicBlock lastNext = m_out.insertNewBlocksBefore(isFunctionBlock) here.  That way, if lowCell produces blocks, they will be nicely ordered.

We don't really seem to do this elsewhere, do you think it's worth changing?

>> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9507
>> +        m_out.branch(isFunction(callee, provenType(m_node->child1())), unsure(isFunctionBlock), unsure(slowPath));
> 
> Could this be usually(isFunctionBlock), rarely(slowPath)?  Our register allocator will do a better job on the slow path call this way.

I'll do this.

>> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9511
>> +        m_out.branch(m_out.isZero64(rareData), unsure(slowPath), unsure(hasRareData));
> 
> Ditto.

I'll change this too.

>> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9528
>> +    }
> 
> You need m_out.mutatorFence() here because you just allocated an object.

Will add.

>> Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp:9998
>> +        LValue allocator, StructureType structure, LValue butterfly, LBasicBlock slowPath)
> 
> This is strange: we're handling the possible constness of the allocator by using LValue and then querying if it's a constant, but instead of doing that for structure, you used templates.
> 
> I think that using LValue structure is better.  Places that want to do smart things in case it's a constant can extract that constant from the LValue.

Ok I'll make it an LValue everwhere.
Comment 4 Saam Barati 2016-11-28 12:53:56 PST
Created attachment 295518 [details]
patch

Addressed Fil's feedback.
Comment 5 Build Bot 2016-11-28 22:01:23 PST
Comment on attachment 295518 [details]
patch

Attachment 295518 [details] did not pass ios-sim-ews (ios-simulator-wk2):
Output: http://webkit-queues.webkit.org/results/2586718

New failing tests:
intersection-observer/intersection-observer-entry-interface.html
Comment 6 Build Bot 2016-11-28 22:01:27 PST
Created attachment 295582 [details]
Archive of layout-test-results from ews124 for ios-simulator-wk2

The attached test failures were seen while running run-webkit-tests on the ios-sim-ews.
Bot: ews124  Port: ios-simulator-wk2  Platform: Mac OS X 10.11.6
Comment 7 Saam Barati 2016-11-29 11:50:09 PST
(In reply to comment #5)
> Comment on attachment 295518 [details]
> patch
> 
> Attachment 295518 [details] did not pass ios-sim-ews (ios-simulator-wk2):
> Output: http://webkit-queues.webkit.org/results/2586718
> 
> New failing tests:
> intersection-observer/intersection-observer-entry-interface.html

I seriously doubt this is actually from this patch.
Comment 8 Geoffrey Garen 2016-11-29 15:11:36 PST
Comment on attachment 295518 [details]
patch

r=me
Comment 9 WebKit Commit Bot 2016-11-29 19:09:30 PST
Comment on attachment 295518 [details]
patch

Clearing flags on attachment: 295518

Committed r209112: <http://trac.webkit.org/changeset/209112>
Comment 10 WebKit Commit Bot 2016-11-29 19:09:34 PST
All reviewed patches have been landed.  Closing bug.
Comment 11 Yusuke Suzuki 2016-11-29 22:29:09 PST
Hm, it seems that this patch causes regression in Octane/Raytrace.
Comment 12 Saam Barati 2016-11-30 00:30:48 PST
(In reply to comment #11)
> Hm, it seems that this patch causes regression in Octane/Raytrace.

This is weird. I'm investigating now.
Comment 13 Saam Barati 2016-11-30 02:57:06 PST
(In reply to comment #12)
> (In reply to comment #11)
> > Hm, it seems that this patch causes regression in Octane/Raytrace.
> 
> This is weird. I'm investigating now.

I'm still not sure why it's slower. It's not because we're hitting the slow path more. So it must be because something else.

My current hypothesis is that it might be related to emitting a MultiGetByOffset instead of a GetById somewhere, which causes us to recompile. The reason I think this is that if I disable access inlining, the patch with FTL CreateThis runs faster. But if accessInlining is enabled, it's slower.
Comment 14 Chris Dumez 2016-11-30 09:11:47 PST
(In reply to comment #13)
> (In reply to comment #12)
> > (In reply to comment #11)
> > > Hm, it seems that this patch causes regression in Octane/Raytrace.
> > 
> > This is weird. I'm investigating now.
> 
> I'm still not sure why it's slower. It's not because we're hitting the slow
> path more. So it must be because something else.
> 
> My current hypothesis is that it might be related to emitting a
> MultiGetByOffset instead of a GetById somewhere, which causes us to
> recompile. The reason I think this is that if I disable access inlining, the
> patch with FTL CreateThis runs faster. But if accessInlining is enabled,
> it's slower.

JetStream also regressed.
Comment 15 Filip Pizlo 2016-11-30 09:24:31 PST
(In reply to comment #13)
> (In reply to comment #12)
> > (In reply to comment #11)
> > > Hm, it seems that this patch causes regression in Octane/Raytrace.
> > 
> > This is weird. I'm investigating now.
> 
> I'm still not sure why it's slower. It's not because we're hitting the slow
> path more. So it must be because something else.
> 
> My current hypothesis is that it might be related to emitting a
> MultiGetByOffset instead of a GetById somewhere, which causes us to
> recompile. The reason I think this is that if I disable access inlining, the
> patch with FTL CreateThis runs faster. But if accessInlining is enabled,
> it's slower.

You probably broke object allocation sinking.

That's only effective in Raytrace if all arguments forwarding is consistently blown away.

It would be good to get this fixed rapidly so we don't lose test coverage on object allocation sinking.
Comment 16 WebKit Commit Bot 2016-11-30 11:50:56 PST
Re-opened since this is blocked by bug 165208
Comment 17 Saam Barati 2016-11-30 15:17:56 PST
(In reply to comment #15)
> (In reply to comment #13)
> > (In reply to comment #12)
> > > (In reply to comment #11)
> > > > Hm, it seems that this patch causes regression in Octane/Raytrace.
> > > 
> > > This is weird. I'm investigating now.
> > 
> > I'm still not sure why it's slower. It's not because we're hitting the slow
> > path more. So it must be because something else.
> > 
> > My current hypothesis is that it might be related to emitting a
> > MultiGetByOffset instead of a GetById somewhere, which causes us to
> > recompile. The reason I think this is that if I disable access inlining, the
> > patch with FTL CreateThis runs faster. But if accessInlining is enabled,
> > it's slower.
> 
> You probably broke object allocation sinking.
> 
> That's only effective in Raytrace if all arguments forwarding is
> consistently blown away.
> 
> It would be good to get this fixed rapidly so we don't lose test coverage on
> object allocation sinking.
Yeah it appears to be because of this. But interestingly, it appears to be because we end up not inlining the constructor function as much. If I explicitly prevent the constructor from being FTL compiled, the regression is gone. This is extremely weird. I'm still trying to figure out why the FTL compilation is preventing inlining.
Comment 18 Saam Barati 2016-11-30 19:35:49 PST
I'm still quite confused as to why this is happening. One symptom (or maybe the cause) I've noticed is happening is that we're not constant folding some GetByIds that we were constant folding before. This obviously prevents allocation sinking. But it also prevents inlining of a particular function call. So I think my next step is to figure out why we're not constant folding this anymore.

Also another interesting tidbit:
If I prevent the compilation of a particular constructor in the FTL (i.e, the top-level compilation), the perf regression goes away. So it's somewhat confusing that compiling the top-level function is somehow preventing optimizations when it gets inlined later on.
Comment 19 Geoffrey Garen 2016-12-01 10:21:47 PST
> Also another interesting tidbit:
> If I prevent the compilation of a particular constructor in the FTL (i.e,
> the top-level compilation), the perf regression goes away. So it's somewhat
> confusing that compiling the top-level function is somehow preventing
> optimizations when it gets inlined later on.

Maybe the non-inlined version of the function produces a value profile that enables constant folding, whereas, for some reason, the inlined version does not propagate type information that's as precise.
Comment 20 Filip Pizlo 2016-12-01 11:16:33 PST
(In reply to comment #19)
> > Also another interesting tidbit:
> > If I prevent the compilation of a particular constructor in the FTL (i.e,
> > the top-level compilation), the perf regression goes away. So it's somewhat
> > confusing that compiling the top-level function is somehow preventing
> > optimizations when it gets inlined later on.
> 
> Maybe the non-inlined version of the function produces a value profile that
> enables constant folding, whereas, for some reason, the inlined version does
> not propagate type information that's as precise.

Right!

This could be one of those bugs caused by someone having things return Top in the prediction propagation phase.
Comment 21 Saam Barati 2016-12-04 13:38:32 PST
Ok, so I'm pretty sure that the bug is timing related. It's definitely timing related when running without the concurrent JIT, but it's probably timing related when running with the concurrent JIT, too, but that's hard to verify 100%.

Without the concurrent JIT, this is what happens:

In the benchmark, there is a function defined as:
```
var Class = {
  create: function(s) {
    function r() {
      this.initialize.apply(this, arguments);
    };
    return r;
  }
};
```

and then this is used like this:

```
var c1 = Class.create();
c1.prototype = {
  ... some properties
  initialize: function(...) { ... }
  ... more properties
}

var c2 = Class.create();
c2.prototype = {
  ... some properties
  initialize: function(...) { ... }
  ... more properties
}

... a few more Class.create() 

```

The issue is occurring with the "initialize" GetById inside the function "r". What happens is this:

We tier up that function to the FTL before all the various Class.create() prototypes are seen by the inline cache. This isn't problematic if the get_by_id is compiled as GetById by the DFG, which it is. But it becomes a problem in the FTL, because we compile the get_by_id as MultiGetByOffset. Because the inline caching hasn't yet seen all the various prototype structures, the MultiGetByOffset will eventually exit when it starts to see new incoming structures. This exit then pollutes the GetByIdStatus when the function "r" gets inlined later on, causing us to not constant fold it because GetByIdStatus claims to take the slow path any time it sees an exit site with BadCache. Therefore, when "r" gets inlined, we end up with a GetById, instead of a constant value. This is one part of the slow down. The GetById prevents many occurrences of allocation sinking and inlining. Secondly, the DFG compile also slows us down because it continually exits after it gets compiled because it sees structures it hadn't anticipated. These together cause the total slow down.

I'm trying to figure out the best way to prevent this behavior when we try to inline "r" because when we inline "r" we know exactly which structure will be produced by the incoming value to the get_by_id because the base always is a NewObject node. Because of this, I think it's safe to ignore the BadCache exit site because we've proven what the incoming Structure is. That said, I'm not sure if this will entirely eliminate the slow down, because the FTL compilation of the standalone "r" is slower than the DFG version because of the exits from MultiGetByOffset. Note that if I manually force this one MultiGetByOffset to become a GetById, the entire perf regression goes away and things might even be a little faster.
Comment 22 Filip Pizlo 2016-12-04 15:30:57 PST
Is this the 'this.initialize' GetById?

If so, I think there are two bugs here.

1) We should constant fold this no matter what.

This one could be constant folded by AI if we taught AI how to constant-fold prototype loads.  This wouldn't be terribly hard:

- Structure needs to be able to tell you if there is a chance of any additional properties on top of the ones that the PropertyTable reports.
- If the base object has a known structure that excludes the property in question and the structure indicates that the property table exhaustively lists all properties, then we can proceed through the prototype chain.

See the code in GetByIdStatus that gets called from AI and ConstantFoldingPhase; it should have a FIXME to implement this.

2) The polyvariant GetById profiler should have chosen to trust the DFG's context-sensitive profile over the FTL's context-insensitive exit site.

The FTL was previously using the DFG's context-sensitive profiling of the GetById to observe that the GetById only ever needs one case.

This breaks if the FTL exits.

I think we just need to ensure that a context-insensitive exit site from the FTL does not affect decisions we make based on context-sensitive profiling.
Comment 23 Saam Barati 2016-12-05 11:51:27 PST
(In reply to comment #22)
> Is this the 'this.initialize' GetById?
> 
> If so, I think there are two bugs here.
> 
> 1) We should constant fold this no matter what.
> 
> This one could be constant folded by AI if we taught AI how to constant-fold
> prototype loads.  This wouldn't be terribly hard:
> 
> - Structure needs to be able to tell you if there is a chance of any
> additional properties on top of the ones that the PropertyTable reports.
> - If the base object has a known structure that excludes the property in
> question and the structure indicates that the property table exhaustively
> lists all properties, then we can proceed through the prototype chain.
> 
> See the code in GetByIdStatus that gets called from AI and
> ConstantFoldingPhase; it should have a FIXME to implement this.
> 
> 2) The polyvariant GetById profiler should have chosen to trust the DFG's
> context-sensitive profile over the FTL's context-insensitive exit site.
> 
> The FTL was previously using the DFG's context-sensitive profiling of the
> GetById to observe that the GetById only ever needs one case.
> 
> This breaks if the FTL exits.
> 
> I think we just need to ensure that a context-insensitive exit site from the
> FTL does not affect decisions we make based on context-sensitive profiling.

I've filed bugs for these:

(1): https://bugs.webkit.org/show_bug.cgi?id=164904
(2): https://bugs.webkit.org/show_bug.cgi?id=165396
Comment 24 Saam Barati 2016-12-05 11:52:57 PST
(In reply to comment #23)
> (In reply to comment #22)
> > Is this the 'this.initialize' GetById?
> > 
> > If so, I think there are two bugs here.
> > 
> > 1) We should constant fold this no matter what.
> > 
> > This one could be constant folded by AI if we taught AI how to constant-fold
> > prototype loads.  This wouldn't be terribly hard:
> > 
> > - Structure needs to be able to tell you if there is a chance of any
> > additional properties on top of the ones that the PropertyTable reports.
> > - If the base object has a known structure that excludes the property in
> > question and the structure indicates that the property table exhaustively
> > lists all properties, then we can proceed through the prototype chain.
> > 
> > See the code in GetByIdStatus that gets called from AI and
> > ConstantFoldingPhase; it should have a FIXME to implement this.
> > 
> > 2) The polyvariant GetById profiler should have chosen to trust the DFG's
> > context-sensitive profile over the FTL's context-insensitive exit site.
> > 
> > The FTL was previously using the DFG's context-sensitive profiling of the
> > GetById to observe that the GetById only ever needs one case.
> > 
> > This breaks if the FTL exits.
> > 
> > I think we just need to ensure that a context-insensitive exit site from the
> > FTL does not affect decisions we make based on context-sensitive profiling.
> 
> I've filed bugs for these:
> 
> (1): https://bugs.webkit.org/show_bug.cgi?id=164904
> (2): https://bugs.webkit.org/show_bug.cgi?id=165396
Oops, (1) should be: https://bugs.webkit.org/show_bug.cgi?id=165395
Comment 25 Yusuke Suzuki 2018-02-28 10:01:37 PST
I've a bit investigated it.
I crafted GetById AI rule to load value from prototype or upper, introduced CreateThis -> NewObject conversion rule in AI, and updated this patch.
Yeah, now, GetById is gone. But I still saw performance regression.
I think that early MultiGetByOffset causes FTL OSR exit, and it involves materializations, and running this FTL code with OSR exit causes severe performance regression.
Comment 26 Filip Pizlo 2018-05-18 12:36:00 PDT
We should fix this.
Comment 27 Filip Pizlo 2018-05-18 12:54:29 PDT
Thinking about this more, I think we need this approach:

1) Implement the GetById proto folding.  We should do that anyway, independent of this patch.

2) Figure out if we can make the exit profiling smarter.  The way that the GetById gets turned into a monomorphic access is via the polyvariant profiler, if I remember right.  That profiler is apparently getting overridden by the MultiGetByOffset's exit site. But, if we're in polyvariant mode then we're asking about the previous outcomes of that DFG or FTL code block being inlined at our inline stack. Maybe all we need to do is modify FrequentExitSite's ExitingJITType to differentiate between uninlined contexts and inlined contexts when using exit sites as an override for the outcome of a polyvariant profiling decision.

3) Figure out how to not use MultiGetByOffset here.  It seems that the IC probably grows between when we tier up from baseline to DFG and when we tier up from DFG to FTL.  Maybe we can use that as a hint that MultiGetByOffset is now a good idea: if more crap was added to it in the time between finishing the DFG compile and when started the FTL compile then we probably don't want to inline it.  Note that the DFG's version of the IC might have fewer cases than the baseline version.  So the heuristic shouldn't be number of cases, it should be: if the DFG's IC for this get_by_id saw any case that can't be handled by the cases of the baseline's IC, then don't do MultiGetByOffset.  If that doesn't work at preventing emission of the MultiGetByOffset, then we can explore trying to understand the timing of repatchings of the MultiGetByOffset - it sorta knows whether it saw all of the structures it would see in a short period of time or if it saw them in a slow trickle.  Or maybe we can figure out how to make the IC track this.  With that information, we could probably pick with high confidence if MultiGetByOffset would be profitable.

4) We have an awesome optimization for richards that tries to prevent tiny functions from being FTL compiled because we are going to inline them anyway.  I wonder why that doesn't work here!
Comment 28 Filip Pizlo 2018-05-27 22:15:36 PDT
Created attachment 341446 [details]
attempting a fix

I found out what's going on and it's more subtle than I expected.

First of all, there's no easy way of getting the FTL to emit anything other than a MultiGetByOffset inside initialize without also breaking MultiGetByOffset for other benchmarks in JetStream.  There's a MultiGetByOffset in richards that looks indistinguishable in all ways, and that one wants to be a MultiGetByOffset.

The reason why OSR exiting from FTL creates a bad situation is disturbing.  A DFG or FTL compile with a GetById means that the baseline get_by_id stops seeing new structures.  Baseline ICs are the ones used for GetByIdStatus etc, so this means that optimized compiles hide future polymorphism from the ICs used as profiling input to other compilations of that same code block, for example in case of inlining.  If the FTL emits a GetById or if the FTL compile doesn't happen, raytrace runs quickly because the IC for this GetById never gets crazy in baseline.  But if FTL emits a MultiGetByOffset and then exits, then baseline sees the full polymorphism and ends up claiming that it takes slow path.

The biggest bug here is that DFG and FTL ICs hide information from profiling in this way. The polyvariant profiler does save us sometimes, but not when the code block gets inlined in a place where it's never been inlined before.

This may be fixable with improved polyvariant profiling. The biggest hole in the polyvariant profile is that if the DFG ends up inlining the access then we don't get a polyvariant profile at all. This patch tries to fix that issue, but I'm not sure if it's the right approach.  It has the benefit that FTL compiles of DFG compiles that got good profiling will also get the same good profiling.

One observation that I made is that this problem mostly goes away if we allow PolymorphicAccess to cache up to 13 variants.  If we do this, then the DFG bytecode parser's filtering of GetByIdVariants filters this down to one case.  It's importnat that this filtering happens in the bytecode parser since that's what unlocks the subsequent inlining.

I think that means that the right approach not only adds GetByIdStatus prototype folding but invokes it in the DFG bytecode parser.

In a weird way, getting the FTL to emit a MultiGetByOffset is what fixes the baseline profile.  But we do need to fix that problem as well.  If we're sucking profiling data from a baseline code block then we should also look at whether it has a replacement, and if that replacement has an IC as well.
Comment 29 Filip Pizlo 2018-05-27 22:17:25 PDT
(In reply to Filip Pizlo from comment #27)
> Thinking about this more, I think we need this approach:
> 
> 1) Implement the GetById proto folding.  We should do that anyway,
> independent of this patch.

The key here is to implement proto folding that also runs in the bytecode parser!

raytrace depends on us chain-folding a bunch of things to fold this GetById down to a constant so that the call instruction that uses it can get inlined.  So, whatever folding we do to benefit this GetById needs to run both in the AI and at bytecode parse time.

> 
> 2) Figure out if we can make the exit profiling smarter.  The way that the
> GetById gets turned into a monomorphic access is via the polyvariant
> profiler, if I remember right.  That profiler is apparently getting
> overridden by the MultiGetByOffset's exit site. But, if we're in polyvariant
> mode then we're asking about the previous outcomes of that DFG or FTL code
> block being inlined at our inline stack. Maybe all we need to do is modify
> FrequentExitSite's ExitingJITType to differentiate between uninlined
> contexts and inlined contexts when using exit sites as an override for the
> outcome of a polyvariant profiling decision.
> 
> 3) Figure out how to not use MultiGetByOffset here.  It seems that the IC
> probably grows between when we tier up from baseline to DFG and when we tier
> up from DFG to FTL.  Maybe we can use that as a hint that MultiGetByOffset
> is now a good idea: if more crap was added to it in the time between
> finishing the DFG compile and when started the FTL compile then we probably
> don't want to inline it.  Note that the DFG's version of the IC might have
> fewer cases than the baseline version.  So the heuristic shouldn't be number
> of cases, it should be: if the DFG's IC for this get_by_id saw any case that
> can't be handled by the cases of the baseline's IC, then don't do
> MultiGetByOffset.  If that doesn't work at preventing emission of the
> MultiGetByOffset, then we can explore trying to understand the timing of
> repatchings of the MultiGetByOffset - it sorta knows whether it saw all of
> the structures it would see in a short period of time or if it saw them in a
> slow trickle.  Or maybe we can figure out how to make the IC track this. 
> With that information, we could probably pick with high confidence if
> MultiGetByOffset would be profitable.

This doesn't work here.  At the time the FTL runs, the baseline and DFG IC both report four cases.

> 
> 4) We have an awesome optimization for richards that tries to prevent tiny
> functions from being FTL compiled because we are going to inline them
> anyway.  I wonder why that doesn't work here!
Comment 30 Filip Pizlo 2018-05-28 18:02:48 PDT
Created attachment 341462 [details]
more

I've confirmed that if the DFG never figures out how to inline that dreaded IC, but the FTL always figures it out, then we will be within 4% of trunk perf.  This means that all I need to do is figure out how to make this work using polyvariant profiling.

This means strengthening polyvariant profiling as follows:

- Need to record the GetByIdStatus that bytecode parser or constant folder used to fold a GetById.  This allows us to see polyvariant profiles of things that got folded.  This recored GetByIdStatus needs to be filtered by the backend, in case we proved some of the cases away.  This lets future compiles start out with the proof in hand.

- Polyvariant profiling needs to search all available stacks, not just the ones attached to the machine code block.

- Need to ignore uninlined FTL OSR exits when making decisions using polyvariant profiles.

I think that the way that I'm improving the polyvariant profiler will implicitly fix the problem where DFG or FTL code blocks' ICs can hide future polymorphism from the IC profiling.  Now, if we are compiling foo and we have are looking at something in bar with the inline stack foo->bar, then we will look for profiling associated with optimized foo->bar, optimized bar, and baseline bar.
Comment 31 Filip Pizlo 2018-05-29 17:18:17 PDT
Created attachment 341542 [details]
more

Still more work to do
Comment 32 Filip Pizlo 2018-05-29 17:56:57 PDT
Created attachment 341545 [details]
CallLinkStatus is starting to look sensible
Comment 33 Filip Pizlo 2018-05-30 14:48:49 PDT
Created attachment 341604 [details]
DFG/FTL filtering of statuses seems to be written
Comment 34 Filip Pizlo 2018-05-30 15:39:42 PDT
Created attachment 341611 [details]
GetByIdStatus is starting to look good
Comment 35 Filip Pizlo 2018-05-30 16:20:13 PDT
Created attachment 341614 [details]
maybe it's done
Comment 36 EWS Watchlist 2018-05-31 02:28:14 PDT
Attachment 341614 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:49:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:479:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
Total errors found: 5 in 59 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 37 Filip Pizlo 2018-05-31 14:54:31 PDT
Created attachment 341693 [details]
slowly getting it to compile
Comment 38 Filip Pizlo 2018-05-31 16:41:06 PDT
Created attachment 341703 [details]
more

Still not compiling :-)
Comment 39 Filip Pizlo 2018-05-31 20:53:05 PDT
Created attachment 341728 [details]
wow it compiles!
Comment 40 Filip Pizlo 2018-06-01 12:35:53 PDT
Created attachment 341779 [details]
recursive polyvariant profiling appears to work
Comment 41 Filip Pizlo 2018-06-01 16:57:41 PDT
Created attachment 341807 [details]
more

It fails a lot of tests and still cannot run raytrace, but it does polyvariant type inference better than what we had before.
Comment 42 Filip Pizlo 2018-06-01 17:53:06 PDT
Created attachment 341811 [details]
so close

Raytrace appears to benefit nicely from this polyvariant profiler.  It seems to infer all of the calls.  To make raytrace neutral, I just need to make object allocation sinking ignore the new Filter nodes.  I'll do that later.
Comment 43 Filip Pizlo 2018-06-01 19:34:26 PDT
Created attachment 341817 [details]
it makes raytrace neutral!
Comment 44 Filip Pizlo 2018-06-01 21:26:35 PDT
Created attachment 341825 [details]
passing so many tests
Comment 45 Filip Pizlo 2018-06-02 11:35:22 PDT
Created attachment 341848 [details]
it works!
Comment 46 Filip Pizlo 2018-06-02 12:45:13 PDT
Created attachment 341849 [details]
rebased patch

It turns out that I had to implement all of the same things for InById.
Comment 47 EWS Watchlist 2018-06-02 12:47:08 PDT
Attachment 341849 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/PutByIdStatus.h:77:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:479:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:51:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/InByIdStatus.h:64:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 7 in 80 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 48 Filip Pizlo 2018-06-02 13:13:14 PDT
Created attachment 341850 [details]
fix build
Comment 49 EWS Watchlist 2018-06-02 13:16:32 PDT
Attachment 341850 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/PutByIdStatus.h:77:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:479:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:51:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/InByIdStatus.h:64:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 7 in 80 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 50 Filip Pizlo 2018-06-02 13:30:27 PDT
Created attachment 341851 [details]
fix build
Comment 51 EWS Watchlist 2018-06-02 13:32:57 PDT
Attachment 341851 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/PutByIdStatus.h:77:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:479:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:51:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/InByIdStatus.h:64:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 7 in 80 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 52 Yusuke Suzuki 2018-06-02 13:54:45 PDT
Comment on attachment 341849 [details]
rebased patch

View in context: https://bugs.webkit.org/attachment.cgi?id=341849&action=review

r=me

> Source/JavaScriptCore/ChangeLog:21
> +          that the helper was compiled by the DFG, the baseline get_by_id would not see those cases.

Yeah, this should be fixed!!!

> Source/JavaScriptCore/bytecode/CodeBlock.cpp:1446
> +        if (JITCode::isOptimizingJIT(jitType())) {
> +            DFG::CommonData* dfgCommon = m_jitCode->dfgCommon();
> +            for (auto& pair : dfgCommon->recordedStatuses.calls)
> +                result.add(pair.first, ICStatus()).iterator->value.callStatus = pair.second.get();
> +            for (auto& pair : dfgCommon->recordedStatuses.gets)
> +                result.add(pair.first, ICStatus()).iterator->value.getStatus = pair.second.get();
> +            for (auto& pair : dfgCommon->recordedStatuses.puts)
> +                result.add(pair.first, ICStatus()).iterator->value.putStatus = pair.second.get();
> +            for (auto& pair : dfgCommon->recordedStatuses.ins)
> +                result.add(pair.first, ICStatus()).iterator->value.inStatus = pair.second.get();
> +        }

Yay

> Source/JavaScriptCore/dfg/DFGByteCodeParser.cpp:6678
> +    if (Options::usePolyvariantDevirtualization()) {
> +        CodeBlock* optimizedBlock = m_profiledBlock->replacement();
> +        m_optimizedContext.optimizedCodeBlock = optimizedBlock;
> +        if (optimizedBlock) {
> +            ConcurrentJSLocker locker(optimizedBlock->m_lock);
> +            optimizedBlock->getICStatusMap(locker, m_optimizedContext.map);
>          }
>      }
> +    byteCodeParser->m_icContextStack.append(&m_optimizedContext);

Nice.
Comment 53 EWS Watchlist 2018-06-02 20:04:32 PDT
Comment on attachment 341851 [details]
fix build

Attachment 341851 [details] did not pass win-ews (win):
Output: http://webkit-queues.webkit.org/results/7952595

New failing tests:
http/tests/security/canvas-remote-read-remote-video-blocked-no-crossorigin.html
Comment 54 EWS Watchlist 2018-06-02 20:04:43 PDT
Created attachment 341861 [details]
Archive of layout-test-results from ews205 for win-future

The attached test failures were seen while running run-webkit-tests on the win-ews.
Bot: ews205  Port: win-future  Platform: CYGWIN_NT-6.1-2.9.0-0.318-5-3-x86_64-64bit
Comment 55 Filip Pizlo 2018-06-04 15:36:05 PDT
Created attachment 341924 [details]
working to fix ARES-6 regression
Comment 56 Filip Pizlo 2018-06-06 21:37:01 PDT
Created attachment 342117 [details]
fixed a bunch of perf bugs

- CallLinkInfo forgets to record when it goes virtual.  It's crazy that this ever worked.

- PutByIdVariant in Transition mode doesn't know how to merge with itself.  This creates weird pathologies now that we rely on variant merging more.
Comment 57 Filip Pizlo 2018-06-07 10:05:39 PDT
Created attachment 342182 [details]
neutral on JetStream, ARES-6, and Speedometer2

Still gotta test Speedometer2.  The last version was a definitely Speedometer2 regression in the neighborhood of 1.5%, but that was before I fixed issues in PutByIdVariant and CallLinkInfo.
Comment 58 Filip Pizlo 2018-06-07 10:42:44 PDT
Comment on attachment 342182 [details]
neutral on JetStream, ARES-6, and Speedometer2

It's neutral on Speedometer2 now!
Comment 59 Filip Pizlo 2018-06-07 10:47:59 PDT
Created attachment 342188 [details]
the patch
Comment 60 EWS Watchlist 2018-06-07 10:51:07 PDT
Attachment 342188 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/PutByIdStatus.h:98:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:481:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:51:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/InByIdStatus.h:84:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 7 in 91 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 61 EWS Watchlist 2018-06-07 12:30:34 PDT
Comment on attachment 342188 [details]
the patch

Attachment 342188 [details] did not pass mac-wk2-ews (mac-wk2):
Output: http://webkit-queues.webkit.org/results/8061581

New failing tests:
accessibility/smart-invert-reference.html
Comment 62 EWS Watchlist 2018-06-07 12:30:36 PDT
Created attachment 342200 [details]
Archive of layout-test-results from ews106 for mac-sierra-wk2

The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews.
Bot: ews106  Port: mac-sierra-wk2  Platform: Mac OS X 10.12.6
Comment 63 Filip Pizlo 2018-06-07 12:41:52 PDT
(In reply to Build Bot from comment #61)
> Comment on attachment 342188 [details]
> the patch
> 
> Attachment 342188 [details] did not pass mac-wk2-ews (mac-wk2):
> Output: http://webkit-queues.webkit.org/results/8061581
> 
> New failing tests:
> accessibility/smart-invert-reference.html

Seems super unlikely that this is my patch.
Comment 64 Yusuke Suzuki 2018-06-07 20:16:40 PDT
Comment on attachment 342188 [details]
the patch

r=me with windows fix.
Comment 65 Filip Pizlo 2018-06-23 19:47:40 PDT
Created attachment 343463 [details]
rebased patch
Comment 66 EWS Watchlist 2018-06-23 19:50:11 PDT
Attachment 343463 [details] did not pass style-queue:


ERROR: Source/JavaScriptCore/bytecode/ExitFlag.h:54:  Missing spaces around |  [whitespace/operators] [3]
ERROR: Source/JavaScriptCore/bytecode/PutByIdStatus.h:98:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/dfg/DFGNodeType.h:481:  Weird number of spaces at line-start.  Are you using a 4-space indent?  [whitespace/indent] [3]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:42:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/BytecodeDumper.h:43:  The parameter name "statusMap" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/RecordedStatuses.h:51:  The parameter name "slotVisitor" adds no information, so it should be removed.  [readability/parameter_name] [5]
ERROR: Source/JavaScriptCore/bytecode/InByIdStatus.h:84:  The parameter name "contextStack" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 7 in 90 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 67 Filip Pizlo 2018-07-21 19:48:42 PDT
Landed in https://trac.webkit.org/changeset/234086/webkit
Comment 68 Radar WebKit Bug Importer 2018-07-21 19:50:16 PDT
<rdar://problem/42472172>
Comment 69 Yusuke Suzuki 2018-07-22 09:26:29 PDT
It seems that https://arewefastyet.com/#machine=29&view=single&suite=six-speed&subtest=destructuring-es6 is regressed. Due to breaking object allocation sinking? (for iterator object)?
Comment 70 Filip Pizlo 2018-07-22 09:30:26 PDT
(In reply to Yusuke Suzuki from comment #69)
> It seems that
> https://arewefastyet.com/#machine=29&view=single&suite=six-
> speed&subtest=destructuring-es6 is regressed. Due to breaking object
> allocation sinking? (for iterator object)?

It's possible!  Ideally, adding coverage to the FTL should be neutral, but it usually isn't since it knocks us off our local maximum of tuning.  This patch is 20x larger than just the patch adding CreateThis to FTL to make it neutral on our own tuning benchmarks.  It achieved neutrality by essentially retuning the whole engine.

One option is to roll out the patch and have the patch grow some more to add more retuning.

But I think that it's better if we do more tuning in follow-on patches.
Comment 71 Yusuke Suzuki 2018-07-22 09:35:35 PDT
(In reply to Filip Pizlo from comment #70)
> (In reply to Yusuke Suzuki from comment #69)
> > It seems that
> > https://arewefastyet.com/#machine=29&view=single&suite=six-
> > speed&subtest=destructuring-es6 is regressed. Due to breaking object
> > allocation sinking? (for iterator object)?
> 
> It's possible!  Ideally, adding coverage to the FTL should be neutral, but
> it usually isn't since it knocks us off our local maximum of tuning.  This
> patch is 20x larger than just the patch adding CreateThis to FTL to make it
> neutral on our own tuning benchmarks.  It achieved neutrality by essentially
> retuning the whole engine.
> 
> One option is to roll out the patch and have the patch grow some more to add
> more retuning.
> 
> But I think that it's better if we do more tuning in follow-on patches.

I've a bit investigated. And I've found that in DFGByteCodeParser, looking up "return" property at bc#212 is changed from,

CheckStructure() + JSConstant(undefined) => GetById(id{return}).

I think this causes materialization in FTL. Not sure why this happens yet.
Comment 72 Yusuke Suzuki 2018-07-22 10:55:32 PDT
(In reply to Yusuke Suzuki from comment #71)
> (In reply to Filip Pizlo from comment #70)
> > (In reply to Yusuke Suzuki from comment #69)
> > > It seems that
> > > https://arewefastyet.com/#machine=29&view=single&suite=six-
> > > speed&subtest=destructuring-es6 is regressed. Due to breaking object
> > > allocation sinking? (for iterator object)?
> > 
> > It's possible!  Ideally, adding coverage to the FTL should be neutral, but
> > it usually isn't since it knocks us off our local maximum of tuning.  This
> > patch is 20x larger than just the patch adding CreateThis to FTL to make it
> > neutral on our own tuning benchmarks.  It achieved neutrality by essentially
> > retuning the whole engine.
> > 
> > One option is to roll out the patch and have the patch grow some more to add
> > more retuning.
> > 
> > But I think that it's better if we do more tuning in follow-on patches.
> 
> I've a bit investigated. And I've found that in DFGByteCodeParser, looking
> up "return" property at bc#212 is changed from,
> 
> CheckStructure() + JSConstant(undefined) => GetById(id{return}).
> 
> I think this causes materialization in FTL. Not sure why this happens yet.

I think it reveals a bit interesting existing bug.
When we have Absent state OPC, and multiple Absent state OPCs are merged in GetByVariant merging phase, it seems that it becomes invalid since `!mergedConditionSet.hasOneSlotBaseCondition()` becomes true.
I think this condition seems incorrect... I'll upload a patch in a separate bug.
Comment 73 Yusuke Suzuki 2018-07-22 11:13:17 PDT
(In reply to Yusuke Suzuki from comment #72)
> (In reply to Yusuke Suzuki from comment #71)
> > (In reply to Filip Pizlo from comment #70)
> > > (In reply to Yusuke Suzuki from comment #69)
> > > > It seems that
> > > > https://arewefastyet.com/#machine=29&view=single&suite=six-
> > > > speed&subtest=destructuring-es6 is regressed. Due to breaking object
> > > > allocation sinking? (for iterator object)?
> > > 
> > > It's possible!  Ideally, adding coverage to the FTL should be neutral, but
> > > it usually isn't since it knocks us off our local maximum of tuning.  This
> > > patch is 20x larger than just the patch adding CreateThis to FTL to make it
> > > neutral on our own tuning benchmarks.  It achieved neutrality by essentially
> > > retuning the whole engine.
> > > 
> > > One option is to roll out the patch and have the patch grow some more to add
> > > more retuning.
> > > 
> > > But I think that it's better if we do more tuning in follow-on patches.
> > 
> > I've a bit investigated. And I've found that in DFGByteCodeParser, looking
> > up "return" property at bc#212 is changed from,
> > 
> > CheckStructure() + JSConstant(undefined) => GetById(id{return}).
> > 
> > I think this causes materialization in FTL. Not sure why this happens yet.
> 
> I think it reveals a bit interesting existing bug.
> When we have Absent state OPC, and multiple Absent state OPCs are merged in
> GetByVariant merging phase, it seems that it becomes invalid since
> `!mergedConditionSet.hasOneSlotBaseCondition()` becomes true.
> I think this condition seems incorrect... I'll upload a patch in a separate
> bug.

https://bugs.webkit.org/show_bug.cgi?id=187891 WIP, but the pre-reviews are welcome!
Comment 74 Dawei Fenton (:realdawei) 2018-07-23 08:50:48 PDT
(In reply to Filip Pizlo from comment #67)
> Landed in https://trac.webkit.org/changeset/234086/webkit

Windows is failing to build after this revision

Sample Log:
https://build.webkit.org/builders/Apple%20Win%20Debug%20%28Build%29/builds/10497/steps/compile-webkit/logs/stdio

C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/GetByIdStatus.cpp(323): error C3861: 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource29.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  UnifiedSource33.cpp
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CallLinkStatus.cpp(344): error C2027: use of undefined type 'JSC::CallLinkInfo' (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource26.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  c:\cygwin\home\buildbot\slave\win-debug\build\source\javascriptcore\bytecode\CallLinkStatus.h(42): note: see declaration of 'JSC::CallLinkInfo' (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource26.cpp)
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CallLinkStatus.cpp(344): error C2227: left of '->codeOrigin' must point to class/struct/union/generic type (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource26.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CallLinkStatus.cpp(350): error C2661: 'JSC::CallLinkStatus::computeFor': no overloaded function takes 5 arguments (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource26.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  UnifiedSource34.cpp
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/InByIdStatus.cpp(95): error C3861: 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource30.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  UnifiedSource35.cpp
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CodeBlock.cpp(1420): error C2027: use of undefined type 'JSC::DFG::CommonData' (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource27.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\jit\JITCode.h(39): note: see declaration of 'JSC::DFG::CommonData' (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource27.cpp)
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CodeBlock.cpp(1420): error C2227: left of '->recordedStatuses' must point to class/struct/union/generic type (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource27.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/CodeBlock.cpp(1420): error C2228: left of '.finalize' must have class/struct/union (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource27.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  UnifiedSource36.cpp
  UnifiedSource37.cpp
  UnifiedSource38.cpp
  UnifiedSource39.cpp
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/PutByIdStatus.cpp(250): error C3861: 'hasExitSite': identifier not found (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource33.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/PutByIdStatus.cpp(272): error C3861: 'computeForStubInfo': identifier not found (compiling source file C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-sources\UnifiedSource33.cpp) [C:\cygwin\home\buildbot\slave\win-debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
  UnifiedSource40.cpp
Comment 75 Filip Pizlo 2018-07-23 08:51:35 PDT
(In reply to David Fenton (:realdawei) from comment #74)
> (In reply to Filip Pizlo from comment #67)
> > Landed in https://trac.webkit.org/changeset/234086/webkit
> 
> Windows is failing to build after this revision
> 
> Sample Log:
> https://build.webkit.org/builders/Apple%20Win%20Debug%20%28Build%29/builds/
> 10497/steps/compile-webkit/logs/stdio
> 
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> GetByIdStatus.cpp(323): error C3861:
> 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource29.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>   UnifiedSource33.cpp
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CallLinkStatus.cpp(344): error C2027: use of undefined type
> 'JSC::CallLinkInfo' (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource26.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>  
> c:\cygwin\home\buildbot\slave\win-
> debug\build\source\javascriptcore\bytecode\CallLinkStatus.h(42): note: see
> declaration of 'JSC::CallLinkInfo' (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource26.cpp)
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CallLinkStatus.cpp(344): error C2227: left of '->codeOrigin' must point to
> class/struct/union/generic type (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource26.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CallLinkStatus.cpp(350): error C2661: 'JSC::CallLinkStatus::computeFor': no
> overloaded function takes 5 arguments (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource26.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>   UnifiedSource34.cpp
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> InByIdStatus.cpp(95): error C3861:
> 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource30.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>   UnifiedSource35.cpp
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CodeBlock.cpp(1420): error C2027: use of undefined type
> 'JSC::DFG::CommonData' (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource27.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>  
> C:\cygwin\home\buildbot\slave\win-
> debug\build\Source\JavaScriptCore\jit\JITCode.h(39): note: see declaration
> of 'JSC::DFG::CommonData' (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource27.cpp)
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CodeBlock.cpp(1420): error C2227: left of '->recordedStatuses' must point to
> class/struct/union/generic type (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource27.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> CodeBlock.cpp(1420): error C2228: left of '.finalize' must have
> class/struct/union (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource27.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>   UnifiedSource36.cpp
>   UnifiedSource37.cpp
>   UnifiedSource38.cpp
>   UnifiedSource39.cpp
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> PutByIdStatus.cpp(250): error C3861: 'hasExitSite': identifier not found
> (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource33.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> PutByIdStatus.cpp(272): error C3861: 'computeForStubInfo': identifier not
> found (compiling source file
> C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> sources\UnifiedSource33.cpp)
> [C:\cygwin\home\buildbot\slave\win-
> debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
>   UnifiedSource40.cpp

Looking.
Comment 76 Dawei Fenton (:realdawei) 2018-07-23 09:05:35 PDT
(In reply to Filip Pizlo from comment #75)
> (In reply to David Fenton (:realdawei) from comment #74)
> > (In reply to Filip Pizlo from comment #67)
> > > Landed in https://trac.webkit.org/changeset/234086/webkit
> > 
> > Windows is failing to build after this revision
> > 
> > Sample Log:
> > https://build.webkit.org/builders/Apple%20Win%20Debug%20%28Build%29/builds/
> > 10497/steps/compile-webkit/logs/stdio
> > 
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > GetByIdStatus.cpp(323): error C3861:
> > 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> > source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource29.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >   UnifiedSource33.cpp
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CallLinkStatus.cpp(344): error C2027: use of undefined type
> > 'JSC::CallLinkInfo' (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource26.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >  
> > c:\cygwin\home\buildbot\slave\win-
> > debug\build\source\javascriptcore\bytecode\CallLinkStatus.h(42): note: see
> > declaration of 'JSC::CallLinkInfo' (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource26.cpp)
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CallLinkStatus.cpp(344): error C2227: left of '->codeOrigin' must point to
> > class/struct/union/generic type (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource26.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CallLinkStatus.cpp(350): error C2661: 'JSC::CallLinkStatus::computeFor': no
> > overloaded function takes 5 arguments (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource26.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >   UnifiedSource34.cpp
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > InByIdStatus.cpp(95): error C3861:
> > 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> > source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource30.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >   UnifiedSource35.cpp
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CodeBlock.cpp(1420): error C2027: use of undefined type
> > 'JSC::DFG::CommonData' (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource27.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >  
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\Source\JavaScriptCore\jit\JITCode.h(39): note: see declaration
> > of 'JSC::DFG::CommonData' (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource27.cpp)
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CodeBlock.cpp(1420): error C2227: left of '->recordedStatuses' must point to
> > class/struct/union/generic type (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource27.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > CodeBlock.cpp(1420): error C2228: left of '.finalize' must have
> > class/struct/union (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource27.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >   UnifiedSource36.cpp
> >   UnifiedSource37.cpp
> >   UnifiedSource38.cpp
> >   UnifiedSource39.cpp
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > PutByIdStatus.cpp(250): error C3861: 'hasExitSite': identifier not found
> > (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource33.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > PutByIdStatus.cpp(272): error C3861: 'computeForStubInfo': identifier not
> > found (compiling source file
> > C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > sources\UnifiedSource33.cpp)
> > [C:\cygwin\home\buildbot\slave\win-
> > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> >   UnifiedSource40.cpp
> 
> Looking.

thanks, it also broke LLINT CLoop
https://build.webkit.org/builders/Apple%20High%20Sierra%20LLINT%20CLoop%20%28BuildAndTest%29/builds/7507/steps/compile-webkit/logs/stdio

./bytecode/CallLinkStatus.cpp:81:18: error: unused parameter 'exitSiteData' [-Werror,-Wunused-parameter]
./bytecode/CallLinkStatus.cpp:344:84: error: member access into incomplete type 'JSC::CallLinkInfo'
./bytecode/CallLinkStatus.cpp:348:26: error: no matching function for call to 'computeFor'
Comment 77 Filip Pizlo 2018-07-23 09:13:59 PDT
(In reply to David Fenton (:realdawei) from comment #76)
> (In reply to Filip Pizlo from comment #75)
> > (In reply to David Fenton (:realdawei) from comment #74)
> > > (In reply to Filip Pizlo from comment #67)
> > > > Landed in https://trac.webkit.org/changeset/234086/webkit
> > > 
> > > Windows is failing to build after this revision
> > > 
> > > Sample Log:
> > > https://build.webkit.org/builders/Apple%20Win%20Debug%20%28Build%29/builds/
> > > 10497/steps/compile-webkit/logs/stdio
> > > 
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > GetByIdStatus.cpp(323): error C3861:
> > > 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> > > source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource29.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >   UnifiedSource33.cpp
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CallLinkStatus.cpp(344): error C2027: use of undefined type
> > > 'JSC::CallLinkInfo' (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource26.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >  
> > > c:\cygwin\home\buildbot\slave\win-
> > > debug\build\source\javascriptcore\bytecode\CallLinkStatus.h(42): note: see
> > > declaration of 'JSC::CallLinkInfo' (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource26.cpp)
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CallLinkStatus.cpp(344): error C2227: left of '->codeOrigin' must point to
> > > class/struct/union/generic type (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource26.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CallLinkStatus.cpp(350): error C2661: 'JSC::CallLinkStatus::computeFor': no
> > > overloaded function takes 5 arguments (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource26.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >   UnifiedSource34.cpp
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > InByIdStatus.cpp(95): error C3861:
> > > 'computeForStubInfoWithoutExitSiteFeedback': identifier not found (compiling
> > > source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource30.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >   UnifiedSource35.cpp
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CodeBlock.cpp(1420): error C2027: use of undefined type
> > > 'JSC::DFG::CommonData' (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource27.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >  
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\Source\JavaScriptCore\jit\JITCode.h(39): note: see declaration
> > > of 'JSC::DFG::CommonData' (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource27.cpp)
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CodeBlock.cpp(1420): error C2227: left of '->recordedStatuses' must point to
> > > class/struct/union/generic type (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource27.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > CodeBlock.cpp(1420): error C2228: left of '.finalize' must have
> > > class/struct/union (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource27.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >   UnifiedSource36.cpp
> > >   UnifiedSource37.cpp
> > >   UnifiedSource38.cpp
> > >   UnifiedSource39.cpp
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > PutByIdStatus.cpp(250): error C3861: 'hasExitSite': identifier not found
> > > (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource33.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > > C:\cygwin\home\buildbot\slave\win-debug\build\Source\JavaScriptCore\bytecode/
> > > PutByIdStatus.cpp(272): error C3861: 'computeForStubInfo': identifier not
> > > found (compiling source file
> > > C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\DerivedSources\JavaScriptCore\unified-
> > > sources\UnifiedSource33.cpp)
> > > [C:\cygwin\home\buildbot\slave\win-
> > > debug\build\WebKitBuild\Debug\Source\JavaScriptCore\JavaScriptCore.vcxproj]
> > >   UnifiedSource40.cpp
> > 
> > Looking.
> 
> thanks, it also broke LLINT CLoop
> https://build.webkit.org/builders/
> Apple%20High%20Sierra%20LLINT%20CLoop%20%28BuildAndTest%29/builds/7507/steps/
> compile-webkit/logs/stdio
> 
> ./bytecode/CallLinkStatus.cpp:81:18: error: unused parameter 'exitSiteData'
> [-Werror,-Wunused-parameter]
> ./bytecode/CallLinkStatus.cpp:344:84: error: member access into incomplete
> type 'JSC::CallLinkInfo'
> ./bytecode/CallLinkStatus.cpp:348:26: error: no matching function for call
> to 'computeFor'

No-JIT build fix landed in r234097.
Comment 78 Dawei Fenton (:realdawei) 2018-07-23 09:15:38 PDT
*** Bug 187908 has been marked as a duplicate of this bug. ***