Bug 253275

Summary: REGRESSION(260512@main): HDR images should be drawn directly if the destination context has HDR color space
Product: WebKit Reporter: Said Abou-Hallawa <sabouhallawa>
Component: ImagesAssignee: Said Abou-Hallawa <sabouhallawa>
Status: RESOLVED FIXED    
Severity: Normal CC: sabouhallawa, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=245858
https://bugs.webkit.org/show_bug.cgi?id=253365

Said Abou-Hallawa
Reported 2023-03-02 15:36:15 PST
When playing some HDR videos, RemoteMediaPlayerManagerProxy::bitmapImageForCurrentTime() may create a ShareableBitmap with HDR colorSpace which it gets it from MediaPlayer. In this case, the workaround in NativeImage::draw() will cause recursion. The workaround draws the HDR NativeImage to a temporary ImageBuffer. This temporary ImageBuffer will have HDR colorSpace also because it will match the colorSpace of destinationContext which is the colorSpace of MediaPlayer. When we call ImageBuffer::draw(), a temporary NativeImage will be created from this ImageBuffer. This NativeImage will have HDR colorSpace also. So when NativeImage::draw() is called from ImageBuffer::draw(), it will go through the workaround code path again. This will cause an infinite recursion.
Attachments
Said Abou-Hallawa
Comment 1 2023-03-02 15:37:34 PST
Said Abou-Hallawa
Comment 2 2023-03-02 15:50:49 PST
Said Abou-Hallawa
Comment 3 2023-03-02 18:02:15 PST
EWS
Comment 4 2023-03-03 09:13:23 PST
Committed 261149@main (9180e60fc30a): <https://commits.webkit.org/261149@main> Reviewed commits have been landed. Closing PR #10970 and removing active labels.
Note You need to log in before you can comment on or make changes to this bug.