Bug 183285 - [GTK] Switch to use always complex text code path
Summary: [GTK] Switch to use always complex text code path
Status: RESOLVED FIXED
Alias: None
Product: WebKit
Classification: Unclassified
Component: WebKitGTK (show other bugs)
Version: WebKit Nightly Build
Hardware: Unspecified Unspecified
: P2 Normal
Assignee: Nobody
URL:
Keywords: Gtk
Depends on:
Blocks:
 
Reported: 2018-03-02 04:55 PST by Carlos Garcia Campos
Modified: 2019-10-28 21:15 PDT (History)
2 users (show)

See Also:


Attachments
Patch (3.25 KB, patch)
2018-03-02 05:00 PST, Carlos Garcia Campos
mcatanzaro: review+
Details | Formatted Diff | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Carlos Garcia Campos 2018-03-02 04:55:32 PST
Now that we have branched for 2.20, it's a good time to try using complex text path always. We can simply force it for GTK+ port and see how it works for the whole release cycle and if we don't notice any issues or performance regressions we release 2.22 with complex text path forced. We can add a debug env variable to switch back to auto without having to recompile. We should also keep the auto mode for the layout tests to avoid having to rebaseline a lot of tests. After 2.22 is released we can make a final decision and remove the env variable.
Comment 1 Carlos Garcia Campos 2018-03-02 05:00:11 PST
Created attachment 334892 [details]
Patch
Comment 2 Michael Catanzaro 2018-03-02 08:30:26 PST
Comment on attachment 334892 [details]
Patch

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

> Source/WebKit/UIProcess/gtk/WebProcessPoolGtk.cpp:96
> +    const char* forceComplexText = getenv("WEBKIT_FORCE_COMPLEX_TEXT");

The semantics of this are backwards.

Should be either WEBKIT_FORCE_SIMPLE_TEXT=1 or WEBKIT_DISABLE_COMPLEX_TEXT=1.

Let's not check for 0.

> Tools/ChangeLog:8
> +        Keep the auto mode for the layout tests to avoid having to rebaseline a lot of tests.

I don't think this is a great idea... now we are not testing the code that users are actually running anymore. I would do a rebaseline at the same time.
Comment 3 Carlos Garcia Campos 2018-03-02 08:37:16 PST
(In reply to Michael Catanzaro from comment #2)
> Comment on attachment 334892 [details]
> Patch
> 
> View in context:
> https://bugs.webkit.org/attachment.cgi?id=334892&action=review
> 
> > Source/WebKit/UIProcess/gtk/WebProcessPoolGtk.cpp:96
> > +    const char* forceComplexText = getenv("WEBKIT_FORCE_COMPLEX_TEXT");
> 
> The semantics of this are backwards.
> 
> Should be either WEBKIT_FORCE_SIMPLE_TEXT=1 or WEBKIT_DISABLE_COMPLEX_TEXT=1.

This doesn't force simple text and it doesn't disable complex text either. It either forces complex text or leaves the current auto where complex or simple is used depending on the context.

> Let's not check for 0.

I don't see why.

> > Tools/ChangeLog:8
> > +        Keep the auto mode for the layout tests to avoid having to rebaseline a lot of tests.
> 
> I don't think this is a great idea... now we are not testing the code that
> users are actually running anymore. I would do a rebaseline at the same time.

The default is auto, so complex test is still tested when required. Most of the changes that we will have to rebaseline are in text that doesn't affect the test at all, like text explaining what the test does, for example. The idea is to try it our during the next release cycle in the unstable releases, and once we make a decision we do the rebaseline. I don't want to waste the time doing a huge rebaseline to roll out the patch tomorrow.
Comment 4 Carlos Garcia Campos 2018-03-02 08:38:01 PST
Note that my main concern is performance, and our layout tests don't help with that, but real usage does.
Comment 5 Carlos Garcia Campos 2018-03-02 08:59:35 PST
This is not different than GTK_OVERLAY_SCROLLING, for example, that defaults to enabled when not present or != "0" is used. You need to export GTK_OVERLAY_SCROLLING=0 to disable it.
Comment 6 Michael Catanzaro 2018-03-02 09:06:05 PST
(In reply to Carlos Garcia Campos from comment #3)
> This doesn't force simple text and it doesn't disable complex text either.
> It either forces complex text or leaves the current auto where complex or
> simple is used depending on the context.

Good point.

Other options:

WEBKIT_DO_NOT_FORCE_COMPLEX_TEXT=1
WEBKIT_ALLOW_SIMPLE_TEXT=1

> > Let's not check for 0.
> 
> I don't see why.

It's very confusing to have an environment variable that only works when set to 0.

> Most of
> the changes that we will have to rebaseline are in text that doesn't affect
> the test at all, like text explaining what the test does, for example. The
> idea is to try it our during the next release cycle in the unstable
> releases, and once we make a decision we do the rebaseline. I don't want to
> waste the time doing a huge rebaseline to roll out the patch tomorrow.

Fair enough, as long as you're confident you won't forget to complete this before 2.22.

One more thing. The most likely reason to revert this change would be if we notice performance problems. But we are not actually going to notice performance problems, not without real perf testing. We do have a perf bot that I never look at, but it won't be able to test this change because the environment variable will be set in the test runner. How do you plan to evaluate the performance impact?
Comment 7 Michael Catanzaro 2018-03-02 09:07:43 PST
(In reply to Carlos Garcia Campos from comment #5)
> This is not different than GTK_OVERLAY_SCROLLING, for example, that defaults
> to enabled when not present or != "0" is used. You need to export
> GTK_OVERLAY_SCROLLING=0 to disable it.

True, but that seems bad to me. Let's not copy that example, when it is *simple* to avoid. ;) WEBKIT_ALLOW_SIMPLE_TEXT=1 is fine, right?

It's not a big deal, since we don't plan to keep this environment variable all the way until 2.22, but it would be nicer IMO.
Comment 8 Michael Catanzaro 2018-03-02 09:09:03 PST
(In reply to Michael Catanzaro from comment #6)
> How do you plan to evaluate the performance impact?

Myles needs to do similar testing in https://bugs.webkit.org/show_bug.cgi?id=178960#c11, so we could ask him for advice.
Comment 9 Carlos Garcia Campos 2018-03-04 02:18:24 PST
(In reply to Michael Catanzaro from comment #6)
> (In reply to Carlos Garcia Campos from comment #3)
> > This doesn't force simple text and it doesn't disable complex text either.
> > It either forces complex text or leaves the current auto where complex or
> > simple is used depending on the context.
> 
> Good point.
> 
> Other options:
> 
> WEBKIT_DO_NOT_FORCE_COMPLEX_TEXT=1
> WEBKIT_ALLOW_SIMPLE_TEXT=1
> 
> > > Let's not check for 0.
> > 
> > I don't see why.
> 
> It's very confusing to have an environment variable that only works when set
> to 0.

I don't thin it's confusing and it's consistent with other env vars like force AC where we also check for 0, the only difference is that in this case the default is disabled instead of enabled.
 
> > Most of
> > the changes that we will have to rebaseline are in text that doesn't affect
> > the test at all, like text explaining what the test does, for example. The
> > idea is to try it our during the next release cycle in the unstable
> > releases, and once we make a decision we do the rebaseline. I don't want to
> > waste the time doing a huge rebaseline to roll out the patch tomorrow.
> 
> Fair enough, as long as you're confident you won't forget to complete this
> before 2.22.

Sure.

> One more thing. The most likely reason to revert this change would be if we
> notice performance problems. But we are not actually going to notice
> performance problems, not without real perf testing. We do have a perf bot
> that I never look at, but it won't be able to test this change because the
> environment variable will be set in the test runner. How do you plan to
> evaluate the performance impact?

I'm not worried about a performance regression, it's not a problem if complex text is a bit slower. My concern is only if performance i really noticeable and affects real usage. If we think a particular website is too slow, we can try disabling the complex text force and see if there's any significant difference.
Comment 10 Carlos Garcia Campos 2018-03-04 02:19:37 PST
We can run the perf tests with complex text forced, note that WTR doesn't override the variable if present.
Comment 11 Carlos Garcia Campos 2018-04-12 00:02:06 PDT
Committed r230559: <https://trac.webkit.org/changeset/230559>