WebKit Bugzilla
New
Browse
Search+
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
272486
REGRESSION (
276827@main
): BitmapImageSource may outlive its creator BitmapImage
https://bugs.webkit.org/show_bug.cgi?id=272486
Summary
REGRESSION (276827@main): BitmapImageSource may outlive its creator BitmapImage
Said Abou-Hallawa
Reported
2024-04-10 15:03:02 PDT
If the image is decoded asynchronously the BitmapImageSource will be protected by the ImageDecoder thread in ImageFrameWorkQueue::start(). But this does not protect the creator of the BitmapImageSource which is BitmapImage. This means the BitmapImage might be freed on the main thread while the ImageFrameWorkQueue is still decoding an image frame and holding a valid BitmapImageSource. When an image frame finishes decoding, the decoding thread calls BitmapImageSource::imageFrameDecodeAtIndexHasFinished(). In this function the BitmapImage is used to notify the ImageObserver about the decoded frame. The problem is BitmapImageSource holds a raw reference to the BitmapImage which may have been freed before it is used. Currently there is no way for BitmapImageSource to know that. Before
276827@main
, ImageSource used to hold a raw pointer BitmapImage and it had function to clear this pointer which is called from the destructor of BitmapImage. Moreover ImageSource methods used to check the nullability of this pointer before it is used.
Attachments
Add attachment
proposed patch, testcase, etc.
Said Abou-Hallawa
Comment 1
2024-04-10 15:03:33 PDT
rdar://126113651
Said Abou-Hallawa
Comment 2
2024-04-10 15:54:47 PDT
Pull request:
https://github.com/apple/WebKit/pull/1193
Said Abou-Hallawa
Comment 3
2024-04-10 17:57:22 PDT
Pull request:
https://github.com/WebKit/WebKit/pull/27121
EWS
Comment 4
2024-04-11 03:51:48 PDT
Committed
277375@main
(4a9fc932842d): <
https://commits.webkit.org/277375@main
> Reviewed commits have been landed. Closing PR #27121 and removing active labels.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug