Closed Bug 1647153 Opened 5 years ago Closed 2 years ago

Slow reloading of Pocket Explore on Moto G (XT1031)

Categories

(Core :: JavaScript Engine, defect, P3)

Unspecified
Android
defect

Tracking

()

RESOLVED DUPLICATE of bug 1707066
Performance Impact high
Tracking Status
firefox79 --- affected

People

(Reporter: yoasif, Unassigned)

References

(Blocks 1 open bug)

Details

(Keywords: perf:pageload, reproducible, top50)

Attachments

(2 files)

Basic information

Playing with a family member's old Moto G (XT1031) to get a better idea of how Fenix performs on the device and ran into some slowness while browsing the Pocket Explore page.

This page is significant because it is included as a top site on Fenix.

Steps to Reproduce:

  1. Load https://getpocket.com/explore?src=ff_android&cdn=0
  2. Refresh page.

Expected Results:

Page reloads quickly (within 2 seconds like Chrome on this device).

Actual Results:

Page loads in 5 seconds or so.

More information

Profile URL: https://share.firefox.dev/3enJy7A

Basic systems configuration:

OS version: Android 5.1

GPU model: Adreno 305

Number of cores: Quad-core 1.2 GHz Cortex-A7

Amount of memory (RAM): 1GB

Thanks so much for your help.

Summary: Slow loading of Pocket Explore on Moto G (XT1031) → Slow reloading of Pocket Explore on Moto G (XT1031)

Unfortunately I cannot reproduce this on my Moto G5, however my device is on Android 8.1. The article loads fairly quickly for me. From the profile, it seems we spend most of the time waiting for network requests to come in so it seems odd that Chrome would be much faster here. Asif, I'm wondering if it was just a bad network day and do you still see the same behavior 5 days later? Thanks.

Flags: needinfo?(yoasif)

Denis, I continue to see the issue. FWIW, I ran a speed test using speedtest.net and got 30 Mbps on Fenix, 40 Mbps in Chrome. My network is fast as well (symmetrical gigabit), although I recognize that the Wifi chipset inside this device is quite slow. Would you like another profile or network log?

Flags: needinfo?(yoasif) → needinfo?(dpalmeiro)

A HAR file from chrome compared to a firefox profile at a similar time could be very useful. Thanks!

Flags: needinfo?(dpalmeiro)

In fact, har files from both would be useful to directly compare as well.

Attached file chrome-pocket.com.har
Attached file firefox-pocket.har

I attached two har files of reloading the page in both Chrome and Fenix Nightly.

I then took another profile of Fenix of the same reload steps: https://share.firefox.dev/2ZcZJi0 (the har is not of the profiled run).

Flags: needinfo?(dpalmeiro)

There are some really long network requests going on here - although it looks like majority of the network requests seem to take most of their time waiting for the HTTP response, and then the vast majority is spent dispatching that response back to the main thread, I think.

Hey snorp, do you know who the right person is to talk to about Android networking?

Flags: needinfo?(snorp)
Whiteboard: [qf:p1:pageload]
OS: Unspecified → Android

Android networking is just Gecko networking, so I suspect Dragana will be able to route this to someone :)

Flags: needinfo?(snorp) → needinfo?(dd.mozilla)

Hmm, as Mike says in comment #8, most of the time in the network requests is spent waiting to deliver the response to the main thread. The main thread seems to be busy doing scripts, layout, and painting. I'm not sure there is really anything actionable for the neetworking folks.

Hm, you're right - the web content thread seems to be pretty busy both painting and running JS. There's a big block of obfuscated JS that runs as a result of a Promise resolving here too: https://share.firefox.dev/2ZJqcUE

From comment #8 the problem seems to be that the main thread is busy. We cannot do anything about that. If you are sure the that is a problem there is nothing for networking to fix here. If you are not sure, I can take a look (info: to debug networking problems we will nee http logs)

Flags: needinfo?(dd.mozilla)

Nazim and I looked at the following fenix nightly profile on a pixel 3xl, a bit more powerful phone

https://share.firefox.dev/3dZG9yj

First jank (115ms) looks loading of all the JS modules
Second jank (around 5.1 - 7 sec) is a bit more. We looked at the reflow, and that's concerning but we don't know how actionable. However, of more interest is the read immediately after and font loading, which seems significant. Is there a font load as part of the reflow going on here? Can the font load be separated out or only loaded once on startup? More questions...

Focusing in on the cookie related bits:
https://cdn.cookielaw.org/scripttemplates/6.14.0/otBannerSdk.js

From:
https://share.firefox.dev/32T7fki

get Element.clientHeight on the pocket side is causing a reflow. May be related cookie popup is trying to figure out the size of the window so it can be adjusted on the frame? Either this call should be avoided or made more performant.

Iain, we have collected some more profiles. An interesting finding is that the u function took about 300ms in Chrome, but about 1 full second in Firefox.

Chrome profile: https://share.firefox.dev/3gO7rtl
Firefox: https://share.firefox.dev/331xoNY

What do you think?

Flags: needinfo?(dpalmeiro) → needinfo?(iireland)

The hottest leaf functions in the Firefox profile are (in what should not be a surprise at this point) in what looks like minified React code.

This function is 5.7% of samples in Firefox, but is only sampled once in Chrome:

function Si(e, t, n) {
    if (null !== (e = n.ref) && "function" !== typeof e && "object" !== typeof e) {
        if (n._owner) {
            if (n = n._owner) {
                if (1 !== n.tag) throw Error(a(309));
                var r = n.stateNode
            }
            if (!r) throw Error(a(147, e));
            var l = "" + e;
            return null !== t && null !== t.ref && "function" === typeof t.ref && t.ref._stringRef === l ? t.ref : ((t = function(e) {
                var t = r.refs;
                t === gi && (t = r.refs = {}), null === e ? delete t[l] : t[l] = e
            })._stringRef = l, t)
        }
        if ("string" !== typeof e) throw Error(a(284));
        if (!n._owner) throw Error(a(290, e))
    }
    return e
}

I believe it is coerceRef here. This code is doing some sort of weird caching using delete to clear things from the cache. It's possible that we are worse than Chrome here.

Blocks: ReactDOMPerf
Flags: needinfo?(iireland)

The function above is Si in the profile. The function that we label _i< and Chrome labels (anonymous) is also hotter in Firefox (2.3% of samples) than in Chrome (1.2% of samples). It corresponds to reconcileChildFibers here.

According to comment 16 and comment 17 this sounds like a JS Engine issue. Moving the bug.

Component: Performance → JavaScript Engine

Changing severity to S3 as we suspect it's part of a larger React issue.

Severity: -- → S3
Priority: -- → P3
Performance Impact: --- → P1
Keywords: perf:pageload
Whiteboard: [qf:p1:pageload]

The Performance Priority Calculator has determined this bug's performance priority to be P1.

Platforms: Android
Page load impact: Some
[x] Affects major website
[x] Able to reproduce locally

Keywords: reproducible, top50

The severity field for this bug is set to S3. However, the Performance Impact field flags this bug as having a high impact on the performance.
:sdetar, could you consider increasing the severity of this performance-impacting bug? Alternatively, if you think the performance impact is lower than previously assessed, could you request a re-triage from the performance team by setting the Performance Impact flag to ??

For more information, please visit auto_nag documentation.

Flags: needinfo?(sdetar)
Flags: needinfo?(sdetar)
Whiteboard: [sp3]

On the JS side, it doesn't look like there's anything actionable here beyond general React performance, which is being addressed by our sp3 work and elsewhere. We've had a bunch of people from different teams take a look at this, and nobody spotted any obvious opportunities. Talking to Denis at the performance team work week, he didn't think it was valuable to keep this bug around.

I'm going to dupe this to the react perf metabug.

Status: NEW → RESOLVED
Closed: 2 years ago
Duplicate of bug: ReactDOMPerf
Resolution: --- → DUPLICATE
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Creator:
Created:
Updated:
Size: