RESOLVED FIXED 136258
[Win] WebKit IDL incorrectly passes HWND values as OLE_HANDLE
https://bugs.webkit.org/show_bug.cgi?id=136258
Summary [Win] WebKit IDL incorrectly passes HWND values as OLE_HANDLE
Brent Fulgham
Reported 2014-08-26 10:31:10 PDT
We have a 64-bit porting problem with HWND's through the WebKit IDL layer. For some reason, these handles were declared as OLE_HANDLE values, which map to 32-bits on both 32- and 64-bit platforms. Internally, these are converted to HWND, which are 64-bit values on 64-bit builds. This causes problems when WebCore attempts to locate and use the windows associated with these incorrect HWND values. This problem can be difficult to reproduce as we only experience a problem when the original HWND included active bits in the unique 64-bit portion of the HWND value.
Attachments
Patch (87.58 KB, patch)
2014-08-26 14:13 PDT, Brent Fulgham
no flags
Patch (87.31 KB, patch)
2014-08-26 14:21 PDT, Brent Fulgham
thorton: review+
Brent Fulgham
Comment 1 2014-08-26 11:06:43 PDT
Brent Fulgham
Comment 2 2014-08-26 12:59:42 PDT
HWND, HBITMAP, HDC, HICON, HCURSOR, and HMENU are now passed as these types, since they have proper 32-bit and 64-bit behavior depending on compile platform. OLE_HANDLE for certificates and other "void*" types are now ULONG_PTR.
Brent Fulgham
Comment 3 2014-08-26 14:13:28 PDT
Brent Fulgham
Comment 4 2014-08-26 14:21:55 PDT
Brent Fulgham
Comment 5 2014-08-26 14:40:07 PDT
Brent Fulgham
Comment 6 2014-08-26 14:57:07 PDT
Brent Fulgham
Comment 7 2014-08-26 14:57:27 PDT
(In reply to comment #1) > <rdar://problem/18134138> Whoops! I meant <rdar://problem/18134163>.
Note You need to log in before you can comment on or make changes to this bug.