Bug 199626

Summary: Fix non thread-safe use of WeakPtr in DisplayRefreshMonitorMac::displayLinkFired()
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: WebCore Misc.Assignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: achristensen, beidson, commit-queue, ews-watchlist, ggaren, rniwa, webkit-bug-importer, youennf
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 199517    
Attachments:
Description Flags
Patch
none
Patch
none
Archive of layout-test-results from ews117 for mac-highsierra
none
Patch none

Chris Dumez
Reported 2019-07-09 10:49:21 PDT
Fix non thread-safe use of WeakPtr in DisplayRefreshMonitorMac::displayLinkFired(): Thread 11 Crashed:: CVDisplayLink 0 com.apple.JavaScriptCore 0x000000010e6a837e WTFCrash + 14 (Assertions.cpp:305) 1 com.apple.WebCore 0x0000000123e867eb WTFCrashWithInfo(int, char const*, char const*, int) + 27 2 com.apple.WebCore 0x000000012734032c WebCore::DisplayRefreshMonitorMac::WeakValueType* WTF::WeakPtrImpl::get<WebCore::DisplayRefreshMonitorMac>() + 140 (WeakPtr.h:65) 3 com.apple.WebCore 0x00000001273401aa WTF::WeakPtrFactory<WebCore::DisplayRefreshMonitorMac>::createWeakPtr(WebCore::DisplayRefreshMonitorMac&) const + 138 (WeakPtr.h:142) 4 com.apple.WebCore 0x000000012733dab7 WTF::WeakPtr<WebCore::DisplayRefreshMonitorMac> WTF::makeWeakPtr<WebCore::DisplayRefreshMonitorMac>(WebCore::DisplayRefreshMonitorMac&) + 55 (WeakPtr.h:212) 5 com.apple.WebCore 0x000000012733d9ef WebCore::DisplayRefreshMonitorMac::displayLinkFired() + 111 (DisplayRefreshMonitorMac.cpp:92) 6 com.apple.WebCore 0x000000012733d935 WebCore::displayLinkCallback(__CVDisplayLink*, CVTimeStamp const*, CVTimeStamp const*, unsigned long long, unsigned long long*, void*) + 53 (DisplayRefreshMonitorMac.cpp:53) 7 com.apple.CoreVideo 0x00007fff3833fe16 CVDisplayLink::performIO(CVTimeStamp*) + 230 8 com.apple.CoreVideo 0x00007fff3833f2ee CVDisplayLink::runIOThread() + 626 9 libsystem_pthread.dylib 0x00007fff6dd36daa _pthread_start + 125 10 libsystem_pthread.dylib 0x00007fff6dd336af thread_start + 15
Attachments
Patch (5.73 KB, patch)
2019-07-09 10:52 PDT, Chris Dumez
no flags
Patch (6.08 KB, patch)
2019-07-09 11:00 PDT, Chris Dumez
no flags
Archive of layout-test-results from ews117 for mac-highsierra (2.33 MB, application/zip)
2019-07-09 11:44 PDT, EWS Watchlist
no flags
Patch (8.93 KB, patch)
2019-07-09 11:53 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2019-07-09 10:52:33 PDT
EWS Watchlist
Comment 2 2019-07-09 10:53:48 PDT
Attachment 373731 [details] did not pass style-queue: ERROR: Source/WebCore/platform/graphics/DisplayRefreshMonitor.h:33: Alphabetical sorting problem. [build/include_order] [4] Total errors found: 1 in 5 files If any of these errors are false positives, please file a bug against check-webkit-style.
Ryosuke Niwa
Comment 3 2019-07-09 10:56:46 PDT
Comment on attachment 373731 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=373731&action=review Maybe we need ThreadSafeWeakPtr... > Source/WebCore/platform/graphics/mac/DisplayRefreshMonitorMac.h:46 > void displayLinkFired() override; This does class need to inherit from CanMakeWeakPtr now?
Chris Dumez
Comment 4 2019-07-09 10:57:29 PDT
(In reply to Ryosuke Niwa from comment #3) > Comment on attachment 373731 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=373731&action=review > > Maybe we need ThreadSafeWeakPtr... > > > Source/WebCore/platform/graphics/mac/DisplayRefreshMonitorMac.h:46 > > void displayLinkFired() override; > > This does class need to inherit from CanMakeWeakPtr now? Oh, it likely doesn't. Good catch.
Chris Dumez
Comment 5 2019-07-09 11:00:17 PDT
EWS Watchlist
Comment 6 2019-07-09 11:02:47 PDT
Attachment 373733 [details] did not pass style-queue: ERROR: Source/WebCore/platform/graphics/DisplayRefreshMonitor.h:33: Alphabetical sorting problem. [build/include_order] [4] Total errors found: 1 in 5 files If any of these errors are false positives, please file a bug against check-webkit-style.
EWS Watchlist
Comment 7 2019-07-09 11:44:39 PDT
Comment on attachment 373733 [details] Patch Attachment 373733 [details] did not pass mac-debug-ews (mac): Output: https://webkit-queues.webkit.org/results/12699554 Number of test failures exceeded the failure limit.
EWS Watchlist
Comment 8 2019-07-09 11:44:41 PDT
Created attachment 373736 [details] Archive of layout-test-results from ews117 for mac-highsierra The attached test failures were seen while running run-webkit-tests on the mac-debug-ews. Bot: ews117 Port: mac-highsierra Platform: Mac OS X 10.13.6
Chris Dumez
Comment 9 2019-07-09 11:53:12 PDT
EWS Watchlist
Comment 10 2019-07-09 11:55:14 PDT
Attachment 373737 [details] did not pass style-queue: ERROR: Source/WebCore/platform/graphics/DisplayRefreshMonitor.h:33: Alphabetical sorting problem. [build/include_order] [4] ERROR: Source/WebCore/platform/graphics/DisplayRefreshMonitorManager.cpp:112: More than one command on the same line [whitespace/newline] [4] Total errors found: 2 in 6 files If any of these errors are false positives, please file a bug against check-webkit-style.
Chris Dumez
Comment 11 2019-07-09 13:03:12 PDT
Comment on attachment 373737 [details] Patch Clearing flags on attachment: 373737 Committed r247273: <https://trac.webkit.org/changeset/247273>
Chris Dumez
Comment 12 2019-07-09 13:03:15 PDT
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 13 2019-07-09 13:04:21 PDT
Note You need to log in before you can comment on or make changes to this bug.