<?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>184718</bug_id>
          
          <creation_ts>2018-04-17 17:02:39 -0700</creation_ts>
          <short_desc>WebKit::DisplayLink maintains a strong reference to WebPageProxy, creating a reference cycle</short_desc>
          <delta_ts>2018-04-17 20:07:17 -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>WebKit API</component>
          <version>WebKit Nightly Build</version>
          <rep_platform>Unspecified</rep_platform>
          <op_sys>Unspecified</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords>InRadar</keywords>
          <priority>P1</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Conrad Shultz">conrad_shultz</reporter>
          <assigned_to name="Conrad Shultz">conrad_shultz</assigned_to>
          <cc>commit-queue</cc>
    
    <cc>conrad_shultz</cc>
    
    <cc>pvollan</cc>
    
    <cc>thorton</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1415353</commentid>
    <comment_count>0</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:02:39 -0700</bug_when>
    <thetext>WebKit::DisplayLink maintains a strong reference to WebPageProxy, creating a reference cycle.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415355</commentid>
    <comment_count>1</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:03:31 -0700</bug_when>
    <thetext>&lt;rdar://problem/39468022&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415356</commentid>
    <comment_count>2</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:03:46 -0700</bug_when>
    <thetext>rdar://problem/39468022</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415357</commentid>
    <comment_count>3</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:04:11 -0700</bug_when>
    <thetext>&lt;rdar://problem/39468022&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415362</commentid>
    <comment_count>4</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:06:32 -0700</bug_when>
    <thetext>rdar://problem/39468022</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415364</commentid>
    <comment_count>5</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:07:45 -0700</bug_when>
    <thetext>rdar://problem/39468022</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415368</commentid>
    <comment_count>6</comment_count>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:08:55 -0700</bug_when>
    <thetext>Oops...</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415382</commentid>
    <comment_count>7</comment_count>
      <attachid>338167</attachid>
    <who name="Conrad Shultz">conrad_shultz</who>
    <bug_when>2018-04-17 17:25:23 -0700</bug_when>
    <thetext>Created attachment 338167
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415392</commentid>
    <comment_count>8</comment_count>
      <attachid>338167</attachid>
    <who name="Per Arne Vollan">pvollan</who>
    <bug_when>2018-04-17 17:41:18 -0700</bug_when>
    <thetext>Comment on attachment 338167
Patch

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

Thanks for finding and fixing this!

&gt; Source/WebKit/UIProcess/mac/DisplayLink.cpp:-39
&gt; -    : m_webPageProxy(webPageProxy)

The address of the WebPageProxy object is passed as a parameter to the function CVDisplayLinkSetOutputCallback below. This pointer is then passed as a void* parameter in the DisplayLink::displayLinkCallback method where it is casted to a WebPageProxy object. If it is guaranteed that we will not receive any callbacks after CVDisplayLinkStop is called in the destructor, then this patch is correct. Otherwise I think we have to use a weak pointer instead.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415396</commentid>
    <comment_count>9</comment_count>
      <attachid>338167</attachid>
    <who name="Tim Horton">thorton</who>
    <bug_when>2018-04-17 17:44:05 -0700</bug_when>
    <thetext>Comment on attachment 338167
Patch

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

&gt;&gt; Source/WebKit/UIProcess/mac/DisplayLink.cpp:-39
&gt;&gt; -    : m_webPageProxy(webPageProxy)
&gt; 
&gt; The address of the WebPageProxy object is passed as a parameter to the function CVDisplayLinkSetOutputCallback below. This pointer is then passed as a void* parameter in the DisplayLink::displayLinkCallback method where it is casted to a WebPageProxy object. If it is guaranteed that we will not receive any callbacks after CVDisplayLinkStop is called in the destructor, then this patch is correct. Otherwise I think we have to use a weak pointer instead.

Good point</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415449</commentid>
    <comment_count>10</comment_count>
      <attachid>338167</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2018-04-17 20:07:16 -0700</bug_when>
    <thetext>Comment on attachment 338167
Patch

Clearing flags on attachment: 338167

Committed r230747: &lt;https://trac.webkit.org/changeset/230747&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1415450</commentid>
    <comment_count>11</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2018-04-17 20:07:17 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>338167</attachid>
            <date>2018-04-17 17:25:23 -0700</date>
            <delta_ts>2018-04-17 20:07:16 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-184718-20180417172523.patch</filename>
            <type>text/plain</type>
            <size>2202</size>
            <attacher name="Conrad Shultz">conrad_shultz</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMjMwNzQwCmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViS2l0L0No
YW5nZUxvZyBiL1NvdXJjZS9XZWJLaXQvQ2hhbmdlTG9nCmluZGV4IDYyOTc4MWM2NWZhMDVhYmQy
N2RjZDdlYWEyOTViZjBhMjBmMDE4MjMuLjNjYjMwNjQ5MzRjNGRiMTJhZmZhYzNhYzc1NmQxMjA1
ZDRmZWNhNDggMTAwNjQ0Ci0tLSBhL1NvdXJjZS9XZWJLaXQvQ2hhbmdlTG9nCisrKyBiL1NvdXJj
ZS9XZWJLaXQvQ2hhbmdlTG9nCkBAIC0xLDMgKzEsMTcgQEAKKzIwMTgtMDQtMTcgIENvbnJhZCBT
aHVsdHogIDxjb25yYWRfc2h1bHR6QGFwcGxlLmNvbT4KKworICAgICAgICBXZWJLaXQ6OkRpc3Bs
YXlMaW5rIG1haW50YWlucyBhIHN0cm9uZyByZWZlcmVuY2UgdG8gV2ViUGFnZVByb3h5LCBjcmVh
dGluZyBhIHJlZmVyZW5jZSBjeWNsZQorICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9z
aG93X2J1Zy5jZ2k/aWQ9MTg0NzE4CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BT
ISkuCisKKyAgICAgICAgSXQgdHVybnMgb3V0IHRoYXQgdGhlIG1fd2ViUGFnZVByb3h5IGJhY2st
cmVmZXJlbmNlIGluIERpc3BsYXlMaW5rLCB3aGljaCB3YXMgY3JlYXRpbmcgYQorICAgICAgICBy
ZWZlcmVuY2UgY3ljbGUsIHdhc24ndCBldmVyIHJlYWQsIHNvIHdlIGNhbiBqdXN0IHJlbW92ZSBp
dC4KKworICAgICAgICAqIFVJUHJvY2Vzcy9tYWMvRGlzcGxheUxpbmsuY3BwOgorICAgICAgICAo
V2ViS2l0OjpEaXNwbGF5TGluazo6RGlzcGxheUxpbmspOgorICAgICAgICAqIFVJUHJvY2Vzcy9t
YWMvRGlzcGxheUxpbmsuaDoKKwogMjAxOC0wNC0xNyAgQWRyaWFuIFBlcmV6IGRlIENhc3RybyAg
PGFwZXJlekBpZ2FsaWEuY29tPgogCiAgICAgICAgIFtHVEtdW1dQRV0gQnVpbGQgZmFpbHVyZSBk
dWUgdG8gcHJlc2VuY2Ugb2YgQXZhaGkncyA8ZG5zX3NkLmg+IGhlYWRlcgpkaWZmIC0tZ2l0IGEv
U291cmNlL1dlYktpdC9VSVByb2Nlc3MvbWFjL0Rpc3BsYXlMaW5rLmNwcCBiL1NvdXJjZS9XZWJL
aXQvVUlQcm9jZXNzL21hYy9EaXNwbGF5TGluay5jcHAKaW5kZXggOWU2MWRkYjQwMWM4MTFiYzE3
ODQwMGEwOTA5MzdhOTAyMzNhYzFkOS4uYjRmYTZkZTI1Zjc2ZTg0Nzc4MTg1NzZjNzAzZGZhODg2
NDI4OGZkYiAxMDA2NDQKLS0tIGEvU291cmNlL1dlYktpdC9VSVByb2Nlc3MvbWFjL0Rpc3BsYXlM
aW5rLmNwcAorKysgYi9Tb3VyY2UvV2ViS2l0L1VJUHJvY2Vzcy9tYWMvRGlzcGxheUxpbmsuY3Bw
CkBAIC0zNiw3ICszNiw2IEBACiBuYW1lc3BhY2UgV2ViS2l0IHsKICAgICAKIERpc3BsYXlMaW5r
OjpEaXNwbGF5TGluayhXZWJDb3JlOjpQbGF0Zm9ybURpc3BsYXlJRCBkaXNwbGF5SUQsIFdlYlBh
Z2VQcm94eSYgd2ViUGFnZVByb3h5KQotICAgIDogbV93ZWJQYWdlUHJveHkod2ViUGFnZVByb3h5
KQogewogICAgIFJFTEVBU0VfQVNTRVJUKGhhc1Byb2Nlc3NQcml2aWxlZ2UoUHJvY2Vzc1ByaXZp
bGVnZTo6Q2FuQ29tbXVuaWNhdGVXaXRoV2luZG93U2VydmVyKSk7CiAgICAgQ1ZSZXR1cm4gZXJy
b3IgPSBDVkRpc3BsYXlMaW5rQ3JlYXRlV2l0aENHRGlzcGxheShkaXNwbGF5SUQsICZtX2Rpc3Bs
YXlMaW5rKTsKZGlmZiAtLWdpdCBhL1NvdXJjZS9XZWJLaXQvVUlQcm9jZXNzL21hYy9EaXNwbGF5
TGluay5oIGIvU291cmNlL1dlYktpdC9VSVByb2Nlc3MvbWFjL0Rpc3BsYXlMaW5rLmgKaW5kZXgg
MTBhMTdiN2VjNTQzMGZkOGQ0N2I2MTFhZjUxYzdiOWI5MjMxMzkyMi4uOGZlOWFkZDkwNDRkNjkz
NTRmYjg0NWIxMmUzYmZkZDJjMDUzMWFiZSAxMDA2NDQKLS0tIGEvU291cmNlL1dlYktpdC9VSVBy
b2Nlc3MvbWFjL0Rpc3BsYXlMaW5rLmgKKysrIGIvU291cmNlL1dlYktpdC9VSVByb2Nlc3MvbWFj
L0Rpc3BsYXlMaW5rLmgKQEAgLTQ5LDcgKzQ5LDYgQEAgcHJpdmF0ZToKICAgICBzdGF0aWMgQ1ZS
ZXR1cm4gZGlzcGxheUxpbmtDYWxsYmFjayhDVkRpc3BsYXlMaW5rUmVmLCBjb25zdCBDVlRpbWVT
dGFtcCosIGNvbnN0IENWVGltZVN0YW1wKiwgQ1ZPcHRpb25GbGFncywgQ1ZPcHRpb25GbGFncyos
IHZvaWQqIGRhdGEpOwogICAgIAogICAgIENWRGlzcGxheUxpbmtSZWYgbV9kaXNwbGF5TGluayB7
IG51bGxwdHIgfTsKLSAgICBSZWY8V2ViUGFnZVByb3h5PiBtX3dlYlBhZ2VQcm94eTsKICAgICBI
YXNoU2V0PHVuc2lnbmVkPiBtX29ic2VydmVyczsKIH07CiAK
</data>

          </attachment>
      

    </bug>

</bugzilla>