<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<!DOCTYPE bugzilla SYSTEM "https://bugs.webkit.org/page.cgi?id=bugzilla.dtd">

<bugzilla version="5.0.4.1"
          urlbase="https://bugs.webkit.org/"
          
          maintainer="admin@webkit.org"
>

    <bug>
          <bug_id>156409</bug_id>
          
          <creation_ts>2016-04-08 11:17:03 -0700</creation_ts>
          <short_desc>[WK1] Wheel event callback removing the window causes crash in WebCore</short_desc>
          <delta_ts>2016-04-08 17:21:48 -0700</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>UI Events</component>
          <version>WebKit Nightly Build</version>
          <rep_platform>All</rep_platform>
          <op_sys>All</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords>InRadar</keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          <dependson>150871</dependson>
          <blocked>156420</blocked>
          <everconfirmed>1</everconfirmed>
          <reporter name="Brent Fulgham">bfulgham</reporter>
          <assigned_to name="Brent Fulgham">bfulgham</assigned_to>
          <cc>bfulgham</cc>
    
    <cc>simon.fraser</cc>
    
    <cc>webkit-bug-importer</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1182218</commentid>
    <comment_count>0</comment_count>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 11:17:03 -0700</bug_when>
    <thetext>This is a follow-up to Bug 150871, which dealt with this problem in a WK2 context.

If a window is removed while it is triggering a wheel event, it will crash with a bad memory access, because WebKit will attempt to use the destroyed view. While we corrected the WK2 version of this problem, WK1 takes a slightly different code path that needs to be fixed.

The crash is shown by fast/events/wheel-event-destroys-frame.html.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182263</commentid>
    <comment_count>1</comment_count>
    <who name="Radar WebKit Bug Importer">webkit-bug-importer</who>
    <bug_when>2016-04-08 12:47:55 -0700</bug_when>
    <thetext>&lt;rdar://problem/25631267&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182264</commentid>
    <comment_count>2</comment_count>
      <attachid>276027</attachid>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 12:51:22 -0700</bug_when>
    <thetext>Created attachment 276027
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182265</commentid>
    <comment_count>3</comment_count>
      <attachid>276027</attachid>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 12:53:50 -0700</bug_when>
    <thetext>Comment on attachment 276027
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=276027&amp;action=review

&gt; Source/WebCore/page/EventHandler.cpp:2679
&gt; +                return platformCompletePlatformWidgetWheelEvent(event, *widget, scrollableContainer.get());

Most of this is whitespace change due to removing a level of indent.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182282</commentid>
    <comment_count>4</comment_count>
      <attachid>276027</attachid>
    <who name="Simon Fraser (smfr)">simon.fraser</who>
    <bug_when>2016-04-08 13:17:36 -0700</bug_when>
    <thetext>Comment on attachment 276027
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=276027&amp;action=review

&gt; Source/WebCore/page/EventHandler.cpp:-2654
&gt; -            if (is&lt;RenderWidget&gt;(target)) {

I don&apos;t get the change because is&lt;RenderWidget&gt;(target) already null-checks.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182286</commentid>
    <comment_count>5</comment_count>
      <attachid>276027</attachid>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 13:27:16 -0700</bug_when>
    <thetext>Comment on attachment 276027
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=276027&amp;action=review

&gt;&gt; Source/WebCore/page/EventHandler.cpp:-2654
&gt;&gt; -            if (is&lt;RenderWidget&gt;(target)) {
&gt; 
&gt; I don&apos;t get the change because is&lt;RenderWidget&gt;(target) already null-checks.

This isn&apos;t the relevant part of the change. This stuff only changed because I moved it into a helper function so I could call it twice.

&gt; Source/WebCore/page/EventHandler.cpp:2670
&gt; +                Widget* widget = widgetForElement(*element);

THIS is the change. I found that in WK1 the underlying RenderWidget gets destroyed when the iFrame is destroyed, so the &quot;widget&quot; pointer pointed to deallocated memory. This &quot;widgetForElement&quot; call re-gets it, and will return nullptr in the case of a destroyed iFrame.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182287</commentid>
    <comment_count>6</comment_count>
      <attachid>276027</attachid>
    <who name="Simon Fraser (smfr)">simon.fraser</who>
    <bug_when>2016-04-08 13:29:50 -0700</bug_when>
    <thetext>Comment on attachment 276027
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=276027&amp;action=review

&gt;&gt; Source/WebCore/page/EventHandler.cpp:2670
&gt;&gt; +                Widget* widget = widgetForElement(*element);
&gt; 
&gt; THIS is the change. I found that in WK1 the underlying RenderWidget gets destroyed when the iFrame is destroyed, so the &quot;widget&quot; pointer pointed to deallocated memory. This &quot;widgetForElement&quot; call re-gets it, and will return nullptr in the case of a destroyed iFrame.

I see. I think the fact that passWheelEventToWidget() is in the condition makes it a little harder to see that it could make the widget invalid.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182295</commentid>
    <comment_count>7</comment_count>
      <attachid>276027</attachid>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 13:43:27 -0700</bug_when>
    <thetext>Comment on attachment 276027
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=276027&amp;action=review

&gt;&gt;&gt; Source/WebCore/page/EventHandler.cpp:2670
&gt;&gt;&gt; +                Widget* widget = widgetForElement(*element);
&gt;&gt; 
&gt;&gt; THIS is the change. I found that in WK1 the underlying RenderWidget gets destroyed when the iFrame is destroyed, so the &quot;widget&quot; pointer pointed to deallocated memory. This &quot;widgetForElement&quot; call re-gets it, and will return nullptr in the case of a destroyed iFrame.
&gt; 
&gt; I see. I think the fact that passWheelEventToWidget() is in the condition makes it a little harder to see that it could make the widget invalid.

That is a little confusing. That&apos;s actually not new to this patch, but I agree it would be easier to understand without doing both tests on the same line. I think it was done that way originally to avoid using two levels of indent. Of course, I probably did the original code, too :-\</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1182296</commentid>
    <comment_count>8</comment_count>
    <who name="Brent Fulgham">bfulgham</who>
    <bug_when>2016-04-08 13:46:22 -0700</bug_when>
    <thetext>Committed r199245: &lt;http://trac.webkit.org/changeset/199245&gt;</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>276027</attachid>
            <date>2016-04-08 12:51:22 -0700</date>
            <delta_ts>2016-04-08 13:29:50 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-156409-20160408125127.patch</filename>
            <type>text/plain</type>
            <size>3580</size>
            <attacher name="Brent Fulgham">bfulgham</attacher>
            
              <data encoding="base64">SW5kZXg6IFNvdXJjZS9XZWJDb3JlL0NoYW5nZUxvZwo9PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBTb3VyY2UvV2Vi
Q29yZS9DaGFuZ2VMb2cJKHJldmlzaW9uIDE5OTI0MSkKKysrIFNvdXJjZS9XZWJDb3JlL0NoYW5n
ZUxvZwkod29ya2luZyBjb3B5KQpAQCAtMSwzICsxLDI0IEBACisyMDE2LTA0LTA4ICBCcmVudCBG
dWxnaGFtICA8YmZ1bGdoYW1AYXBwbGUuY29tPgorCisgICAgICAgIFtXSzFdIFdoZWVsIGV2ZW50
IGNhbGxiYWNrIHJlbW92aW5nIHRoZSB3aW5kb3cgY2F1c2VzIGNyYXNoIGluIFdlYkNvcmUKKyAg
ICAgICAgaHR0cHM6Ly9idWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTE1NjQwOQorICAg
ICAgICA8cmRhcjovL3Byb2JsZW0vMjU2MzEyNjc+CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9C
T0RZIChPT1BTISkuCisKKyAgICAgICAgTnVsbCBjaGVjayB0aGUgV2lkZ2V0IGJlZm9yZSB1c2lu
ZyBpdCwgc2luY2UgdGhlIGlmcmFtZSBtYXkgaGF2ZSBiZWVuIHJlbW92ZWQKKyAgICAgICAgZnJv
bSBpdHMgcGFyZW50IGRvY3VtZW50IGluc2lkZSB0aGUgZXZlbnQgaGFuZGxlci4KKworICAgICAg
ICBUaGlzIGlzIHRoZSBXSzEgZml4IGZvciBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1
Zy5jZ2k/aWQ9MTUwODcxLgorCisgICAgICAgIFRlc3RlZCBieSBmYXN0L2V2ZW50cy93aGVlbC1l
dmVudC1kZXN0cm95cy1mcmFtZS5odG1sCisKKyAgICAgICAgKiBwYWdlL0V2ZW50SGFuZGxlci5j
cHA6CisgICAgICAgIChXZWJDb3JlOjp3aWRnZXRGb3JFbGVtZW50KTogQWRkZWQuCisgICAgICAg
IChXZWJDb3JlOjpFdmVudEhhbmRsZXI6OmhhbmRsZVdoZWVsRXZlbnQpOiBVc2UgbmV3IGhlbHBl
ciBmdW5jdGlvbiB0bworICAgICAgICBjbGVhbiB1cCB0aGUgY29kZSwgYW5kIGFsbG93IHVzIHRv
IGNoZWNrIHRoYXQgdGhlIFdpZGdldCBoYXMgbm90IGJlZW4KKyAgICAgICAgZGVzdHJveWVkIGR1
cmluZyB0aGUgZXZlbnQgaGFuZGxlci4KKwogMjAxNi0wNC0wOCAgQmV0aCBEYWtpbiAgPGJkYWtp
bkBhcHBsZS5jb20+CiAKICAgICAgICAgRml4IGxlYWtzIGluIFdlYkFWTWVkaWFTZWxlY3Rpb25P
cHRpb25NYWMgYW5kIFdlYlBsYXliYWNrQ29udHJvbHNNYW5hZ2VyCkluZGV4OiBTb3VyY2UvV2Vi
Q29yZS9wYWdlL0V2ZW50SGFuZGxlci5jcHAKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gU291cmNlL1dlYkNvcmUv
cGFnZS9FdmVudEhhbmRsZXIuY3BwCShyZXZpc2lvbiAxOTkyMzEpCisrKyBTb3VyY2UvV2ViQ29y
ZS9wYWdlL0V2ZW50SGFuZGxlci5jcHAJKHdvcmtpbmcgY29weSkKQEAgLTI2MTAsNiArMjYxMCwx
OCBAQCB2b2lkIEV2ZW50SGFuZGxlcjo6Y2xlYXJPclNjaGVkdWxlQ2xlYXJpCiB9CiAjZW5kaWYK
IAorc3RhdGljIFdpZGdldCogd2lkZ2V0Rm9yRWxlbWVudChjb25zdCBFbGVtZW50JiBlbGVtZW50
KQoreworICAgIFJlbmRlckVsZW1lbnQqIHRhcmdldCA9IGVsZW1lbnQucmVuZGVyZXIoKTsKKyAg
ICBpZiAoIXRhcmdldCkKKyAgICAgICAgcmV0dXJuIG51bGxwdHI7CisKKyAgICBpZiAoIWlzPFJl
bmRlcldpZGdldD4odGFyZ2V0KSkKKyAgICAgICAgcmV0dXJuIG51bGxwdHI7CisKKyAgICByZXR1
cm4gZG93bmNhc3Q8UmVuZGVyV2lkZ2V0PigqdGFyZ2V0KS53aWRnZXQoKTsKK30KKwogYm9vbCBF
dmVudEhhbmRsZXI6OmhhbmRsZVdoZWVsRXZlbnQoY29uc3QgUGxhdGZvcm1XaGVlbEV2ZW50JiBl
dmVudCkKIHsKICAgICBSZW5kZXJWaWV3KiByZW5kZXJWaWV3ID0gbV9mcmFtZS5jb250ZW50UmVu
ZGVyZXIoKTsKQEAgLTI2NTAsMTggKzI2NjIsMjEgQEAgYm9vbCBFdmVudEhhbmRsZXI6OmhhbmRs
ZVdoZWVsRXZlbnQoY29ucwogCiAgICAgaWYgKGVsZW1lbnQpIHsKICAgICAgICAgaWYgKGlzT3Zl
cldpZGdldCkgewotICAgICAgICAgICAgUmVuZGVyRWxlbWVudCogdGFyZ2V0ID0gZWxlbWVudC0+
cmVuZGVyZXIoKTsKLSAgICAgICAgICAgIGlmIChpczxSZW5kZXJXaWRnZXQ+KHRhcmdldCkpIHsK
LSAgICAgICAgICAgICAgICBXaWRnZXQqIHdpZGdldCA9IGRvd25jYXN0PFJlbmRlcldpZGdldD4o
KnRhcmdldCkud2lkZ2V0KCk7Ci0gICAgICAgICAgICAgICAgaWYgKHdpZGdldCAmJiBwYXNzV2hl
ZWxFdmVudFRvV2lkZ2V0KGV2ZW50LCAqd2lkZ2V0KSkgewotICAgICAgICAgICAgICAgICAgICBt
X2lzSGFuZGxpbmdXaGVlbEV2ZW50ID0gZmFsc2U7Ci0gICAgICAgICAgICAgICAgICAgIGlmIChz
Y3JvbGxhYmxlQXJlYSkKLSAgICAgICAgICAgICAgICAgICAgICAgIHNjcm9sbGFibGVBcmVhLT5z
ZXRTY3JvbGxlZFByb2dyYW1tYXRpY2FsbHkoZmFsc2UpOwotICAgICAgICAgICAgICAgICAgICBw
bGF0Zm9ybU5vdGlmeUlmRW5kR2VzdHVyZShhZGp1c3RlZEV2ZW50LCBzY3JvbGxhYmxlQXJlYSk7
Ci0gICAgICAgICAgICAgICAgICAgIGlmICghd2lkZ2V0LT5wbGF0Zm9ybVdpZGdldCgpKQotICAg
ICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7Ci0gICAgICAgICAgICAgICAgICAgIHJl
dHVybiBwbGF0Zm9ybUNvbXBsZXRlUGxhdGZvcm1XaWRnZXRXaGVlbEV2ZW50KGV2ZW50LCAqd2lk
Z2V0LCBzY3JvbGxhYmxlQ29udGFpbmVyLmdldCgpKTsKLSAgICAgICAgICAgICAgICB9CisgICAg
ICAgICAgICBXaWRnZXQqIHdpZGdldCA9IHdpZGdldEZvckVsZW1lbnQoKmVsZW1lbnQpOworICAg
ICAgICAgICAgaWYgKHdpZGdldCAmJiBwYXNzV2hlZWxFdmVudFRvV2lkZ2V0KGV2ZW50LCAqd2lk
Z2V0KSkgeworICAgICAgICAgICAgICAgIG1faXNIYW5kbGluZ1doZWVsRXZlbnQgPSBmYWxzZTsK
KworICAgICAgICAgICAgICAgIC8vIFdlIGRvIGFub3RoZXIgY2hlY2sgb24gdGhlIHdpZGdldCBi
ZWNhdXNlIHRoZSBldmVudCBoYW5kbGVyIGNhbiBydW4gSlMgd2hpY2ggcmVzdWx0cyBpbiB0aGUg
ZnJhbWUgZ2V0dGluZyBkZXN0cm95ZWQuCisgICAgICAgICAgICAgICAgV2lkZ2V0KiB3aWRnZXQg
PSB3aWRnZXRGb3JFbGVtZW50KCplbGVtZW50KTsKKyAgICAgICAgICAgICAgICBpZiAoIXdpZGdl
dCkKKyAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlOworCisgICAgICAgICAgICAgICAg
aWYgKHNjcm9sbGFibGVBcmVhKQorICAgICAgICAgICAgICAgICAgICBzY3JvbGxhYmxlQXJlYS0+
c2V0U2Nyb2xsZWRQcm9ncmFtbWF0aWNhbGx5KGZhbHNlKTsKKyAgICAgICAgICAgICAgICBwbGF0
Zm9ybU5vdGlmeUlmRW5kR2VzdHVyZShhZGp1c3RlZEV2ZW50LCBzY3JvbGxhYmxlQXJlYSk7Cisg
ICAgICAgICAgICAgICAgaWYgKCF3aWRnZXQtPnBsYXRmb3JtV2lkZ2V0KCkpCisgICAgICAgICAg
ICAgICAgICAgIHJldHVybiB0cnVlOworICAgICAgICAgICAgICAgIHJldHVybiBwbGF0Zm9ybUNv
bXBsZXRlUGxhdGZvcm1XaWRnZXRXaGVlbEV2ZW50KGV2ZW50LCAqd2lkZ2V0LCBzY3JvbGxhYmxl
Q29udGFpbmVyLmdldCgpKTsKICAgICAgICAgICAgIH0KICAgICAgICAgfQogCg==
</data>
<flag name="review"
          id="300340"
          type_id="1"
          status="+"
          setter="simon.fraser"
    />
          </attachment>
      

    </bug>

</bugzilla>