Bug 252876
Summary: | Slow performance of GPUP WebGL for rendering-heavy applications (like machine learning inference) | ||
---|---|---|---|
Product: | WebKit | Reporter: | tmullen.webkit |
Component: | WebGL | Assignee: | Kimmo Kinnunen <kkinnunen> |
Status: | RESOLVED FIXED | ||
Severity: | Normal | CC: | dino, kbr, kkinnunen, webkit-bug-importer |
Priority: | P2 | Keywords: | InRadar |
Version: | Safari 16 | ||
Hardware: | iPhone / iPad | ||
OS: | iOS 16 | ||
See Also: |
https://bugs.webkit.org/show_bug.cgi?id=250899 https://bugs.webkit.org/show_bug.cgi?id=257644 https://bugs.webkit.org/show_bug.cgi?id=235002 https://bugs.webkit.org/show_bug.cgi?id=257958 |
||
Bug Depends on: | 257259, 257314, 257319, 257452, 257595, 257602 | ||
Bug Blocks: |
tmullen.webkit
Observed so far on iPhone 12, 13 and 14, with iOS 16.2 and iOS 16.3.
Repro steps:
- Go to https://codepen.io/catchinglight/pen/JjaKvNQ
- Acknowledge warning and allow access to camera
- Point phone camera so as to keep exactly one hand visible in the selfie camera's field of view
- Observe FPS number
- Close this Safari tab
- Disable Settings app --> Safari --> Advanced --> Experimental Features --> Gpu Process: WebGL
- Open a new Safari tab
- Go back to https://codepen.io/catchinglight/pen/JjaKvNQ and observe much higher FPS number when repeating the same steps as before
The problem is not unique to the above CodePen, but the heavy use of WebGL there (for machine learning inference) coupled with an FPS display, makes it a nicer repro case than many other sites.
This bug seems possibly related: https://bugs.webkit.org/show_bug.cgi?id=250899, since the ML applications where this has been observed do use a readPixels call to grab GPU data back to CPU every frame for post-processing. However, I'm not sure how to verify definitively one way or the other.
Attachments | ||
---|---|---|
Add attachment proposed patch, testcase, etc. |
Radar WebKit Bug Importer
<rdar://problem/106173126>
tmullen.webkit
Tested on the public iOS Beta 16.4, and the issue does not appear to be fixed there.
Furthermore, it seems that the experimental toggle to disable the WebGL GPUP feature may be no longer available as well, which would prevent even user action from working around the problem.
Kimmo Kinnunen
Thank you for the report.
Yes, readPixels is slower on GPU process.
I'll see about some approaches improve it.
Kimmo Kinnunen
The read pixels performance is improved in the depending bugs.
These should be available in iOS 17 betas, macOS 14 betas.
Based on quick testing, the test case FPS number seem to improve ~50%, IIRC.
Bug 235002 tracks the slowness of the read pixels of the ANGLE/Metal backend. This is directly related to this task, but likely not addressed in near future.
Bug 257958 tracks the slowness of texture uploads, which might be relevant for some apps that touch the rendering with CPU. However, this is not directly relevant to this task.
Closing this bug to make progress. Please re-open or open new bug report if there's new observations on the lack of performance.