Bug 210888

Summary: [Cocoa] REGRESSION (r260485): Crash in Legacy WebKit createMenu item function (reproducible under Asan)
Product: WebKit Reporter: Darin Adler <darin>
Component: WebKit Misc.Assignee: Darin Adler <darin>
Status: RESOLVED FIXED    
Severity: Critical CC: achristensen, ap, Lawrence.j, ryanhaddad
Priority: P1 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Mac   
OS: All   
Attachments:
Description Flags
Patch none

Darin Adler
Reported 2020-04-22 16:38:08 PDT
[Cocoa] REGRESSION (r260485): Crash in Legacy WebKit createMenu item function (reproducible under Asan)
Attachments
Patch (1.87 KB, patch)
2020-04-22 16:39 PDT, Darin Adler
no flags
Darin Adler
Comment 1 2020-04-22 16:39:07 PDT
Darin Adler
Comment 2 2020-04-22 16:39:37 PDT
Alex Christensen
Comment 3 2020-04-22 17:25:53 PDT
Comment on attachment 397287 [details] Patch I verified this fixes the issue.
EWS
Comment 4 2020-04-22 17:28:02 PDT
Committed r260545: <https://trac.webkit.org/changeset/260545> All reviewed patches have been landed. Closing bug and clearing flags on attachment 397287 [details].
Alex Christensen
Comment 5 2020-04-22 17:31:41 PDT
View in context: https://bugs.webkit.org/attachment.cgi?id=397287&action=review > Source/WebKitLegacy/mac/ChangeLog:11 > + (createMenuItem): Speculative fix: Go back to using a local variable. Apparently > + the Objective-C for loop doesn't extend the lifetime of its argument the way the > + C++ range-based for loop does, so the local variable is needed. You can actually replace this ObjC for-in loop with a C++ range-based for loop and that doesn't fix the bug. The bug is that the RetainPtr is a temporary that goes out of scope immediately. The for loop (C++ or ObjC) iterates over the result of .get() so it keeps a raw NSMutableArray * in scope for the entirety of the iteration, but it's pointing to an array that has been freed. Just another bug that ARC would fix.
Darin Adler
Comment 6 2020-04-22 17:51:49 PDT
(In reply to Alex Christensen from comment #5) > You can actually replace this ObjC for-in loop with a C++ range-based for > loop and that doesn't fix the bug. Oh, right, because of the ".get()" because C++ extends the life of the expression, but not the subexpression before ".get()". Darn, frustrated I got that wrong!
Note You need to log in before you can comment on or make changes to this bug.