<?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>126805</bug_id>
          
          <creation_ts>2014-01-10 21:07:16 -0800</creation_ts>
          <short_desc>[iOS] Fix GCController::releaseExecutableMemory</short_desc>
          <delta_ts>2014-01-10 22:53:47 -0800</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 Misc.</component>
          <version>528+ (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></keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Joseph Pecoraro">joepeck</reporter>
          <assigned_to name="Nobody">webkit-unassigned</assigned_to>
          <cc>joepeck</cc>
    
    <cc>mark.lam</cc>
    
    <cc>oliver</cc>
    
    <cc>psolanki</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>966746</commentid>
    <comment_count>0</comment_count>
    <who name="Joseph Pecoraro">joepeck</who>
    <bug_when>2014-01-10 21:07:16 -0800</bug_when>
    <thetext>GCController::releaseExecutableMemory uses JSDOMWindow::commonVM()-&gt;dynamicGlobalObject which no longer exists. It moved to VMEntryScope-&gt;globalObject. Can the same trick still be applied?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>966747</commentid>
    <comment_count>1</comment_count>
      <attachid>220919</attachid>
    <who name="Joseph Pecoraro">joepeck</who>
    <bug_when>2014-01-10 21:10:01 -0800</bug_when>
    <thetext>Created attachment 220919
[PATCH] Proposed Fix

JSC folks, does this look correct? Should I be null checking JSDOMWindow::commonVM()-&gt;entryScope now instead of JSDOMWindow::commonVM()-&gt;entryScope-&gt;globalObject()?

This is one of the iOS in OpenSource build errors.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>966751</commentid>
    <comment_count>2</comment_count>
      <attachid>220919</attachid>
    <who name="Sam Weinig">sam</who>
    <bug_when>2014-01-10 21:43:55 -0800</bug_when>
    <thetext>Comment on attachment 220919
[PATCH] Proposed Fix

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

&gt; Source/WebCore/bindings/js/GCController.cpp:37
&gt;  
&gt; +#if PLATFORM(IOS)
&gt; +#include &lt;runtime/VMEntryScope.h&gt;
&gt; +#endif

Seems like while you are here, you might as well make this function not iOS specific as it seems generally useful (and you can remove the #ifdefs)!</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>966753</commentid>
    <comment_count>3</comment_count>
      <attachid>220919</attachid>
    <who name="Mark Lam">mark.lam</who>
    <bug_when>2014-01-10 21:56:39 -0800</bug_when>
    <thetext>Comment on attachment 220919
[PATCH] Proposed Fix

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

r=me with the needed fixes.

&gt; Source/WebCore/bindings/js/GCController.cpp:120
&gt; +    ASSERT(!JSDOMWindow::commonVM()-&gt;entryScope-&gt;globalObject());

This is not right.  The entryScope will be NULL if we haven’t entered the VM to run any JS code.  Hence, the assertion you want is:
    ASSERT(!JSDOMWindow::commonVM()-&gt;entryScope);

&gt; Source/WebCore/bindings/js/GCController.cpp:123
&gt; +    if (JSDOMWindow::commonVM()-&gt;entryScope-&gt;globalObject())

Similarly here, what you want is:
    if (JSDOMDOMWindow::commonVM()-&gt;entryScope)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>966758</commentid>
    <comment_count>4</comment_count>
    <who name="Joseph Pecoraro">joepeck</who>
    <bug_when>2014-01-10 22:53:47 -0800</bug_when>
    <thetext>Landed in &lt;http://trac.webkit.org/changeset/161747&gt;.
And follow fix to in &lt;http://trac.webkit.org/changeset/161748&gt; cause even though I thought I tested building Mac, my terminal tricked me into thinking it compiled!</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>220919</attachid>
            <date>2014-01-10 21:10:01 -0800</date>
            <delta_ts>2014-01-10 21:56:39 -0800</delta_ts>
            <desc>[PATCH] Proposed Fix</desc>
            <filename>fix.patch</filename>
            <type>text/plain</type>
            <size>2073</size>
            <attacher name="Joseph Pecoraro">joepeck</attacher>
            
              <data encoding="base64">ZGlmZiAtLWdpdCBhL1NvdXJjZS9XZWJDb3JlL0NoYW5nZUxvZyBiL1NvdXJjZS9XZWJDb3JlL0No
YW5nZUxvZwppbmRleCBlMGE5NmUxLi40ZTI4ODFiIDEwMDY0NAotLS0gYS9Tb3VyY2UvV2ViQ29y
ZS9DaGFuZ2VMb2cKKysrIGIvU291cmNlL1dlYkNvcmUvQ2hhbmdlTG9nCkBAIC0xLDUgKzEsMTUg
QEAKIDIwMTQtMDEtMTAgIEpvc2VwaCBQZWNvcmFybyAgPHBlY29yYXJvQGFwcGxlLmNvbT4KIAor
ICAgICAgICBbaU9TXSBGaXggR0NDb250cm9sbGVyOjpyZWxlYXNlRXhlY3V0YWJsZU1lbW9yeQor
ICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MTI2ODA1CisK
KyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisKKyAgICAgICAgKiBiaW5kaW5n
cy9qcy9HQ0NvbnRyb2xsZXIuY3BwOgorICAgICAgICAoV2ViQ29yZTo6R0NDb250cm9sbGVyOjpy
ZWxlYXNlRXhlY3V0YWJsZU1lbW9yeSk6CisKKzIwMTQtMDEtMTAgIEpvc2VwaCBQZWNvcmFybyAg
PHBlY29yYXJvQGFwcGxlLmNvbT4KKwogICAgICAgICBGaXggR3JhcGhpY3NMYXllckNBLm8gZm9y
IGlPUy4gVW5yZXZpZXdlZCBidWlsZCBmaXguCiAKICAgICAgICAgVXNlIG9mIHN5c3RlbU1lbW9y
eUxldmVsIHdhcyBtaXNzaW5nIGluY2x1ZGUgb2YgU3lzdGVtTWVtb3J5LmguCmRpZmYgLS1naXQg
YS9Tb3VyY2UvV2ViQ29yZS9iaW5kaW5ncy9qcy9HQ0NvbnRyb2xsZXIuY3BwIGIvU291cmNlL1dl
YkNvcmUvYmluZGluZ3MvanMvR0NDb250cm9sbGVyLmNwcAppbmRleCBkYjY5MDFlLi45NGU2Mzdk
IDEwMDY0NAotLS0gYS9Tb3VyY2UvV2ViQ29yZS9iaW5kaW5ncy9qcy9HQ0NvbnRyb2xsZXIuY3Bw
CisrKyBiL1NvdXJjZS9XZWJDb3JlL2JpbmRpbmdzL2pzL0dDQ29udHJvbGxlci5jcHAKQEAgLTIw
LDcgKzIwLDcgQEAKICAqIFBST0ZJVFM7IE9SIEJVU0lORVNTIElOVEVSUlVQVElPTikgSE9XRVZF
UiBDQVVTRUQgQU5EIE9OIEFOWSBUSEVPUlkKICAqIE9GIExJQUJJTElUWSwgV0hFVEhFUiBJTiBD
T05UUkFDVCwgU1RSSUNUIExJQUJJTElUWSwgT1IgVE9SVAogICogKElOQ0xVRElORyBORUdMSUdF
TkNFIE9SIE9USEVSV0lTRSkgQVJJU0lORyBJTiBBTlkgV0FZIE9VVCBPRiBUSEUgVVNFCi0gKiBP
RiBUSElTIFNPRlRXQVJFLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIE9GIFNV
Q0ggREFNQUdFLiAKKyAqIE9GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRiBUSEUg
UE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0UuCiAgKi8KIAogI2luY2x1ZGUgImNvbmZpZy5oIgpA
QCAtMzIsNiArMzIsMTAgQEAKICNpbmNsdWRlIDxoZWFwL0hlYXAuaD4KICNpbmNsdWRlIDx3dGYv
U3RkTGliRXh0cmFzLmg+CiAKKyNpZiBQTEFURk9STShJT1MpCisjaW5jbHVkZSA8cnVudGltZS9W
TUVudHJ5U2NvcGUuaD4KKyNlbmRpZgorCiB1c2luZyBuYW1lc3BhY2UgSlNDOwogCiBuYW1lc3Bh
Y2UgV2ViQ29yZSB7CkBAIC0xMTMsMTAgKzExNywxMCBAQCB2b2lkIEdDQ29udHJvbGxlcjo6cmVs
ZWFzZUV4ZWN1dGFibGVNZW1vcnkoKQogCiAgICAgLy8gV2Ugc2hvdWxkbid0IGhhdmUgYW55IGph
dmFzY3JpcHQgcnVubmluZyBvbiBvdXIgc3RhY2sgd2hlbiB0aGlzIGZ1bmN0aW9uIGlzIGNhbGxl
ZC4gVGhlCiAgICAgLy8gZm9sbG93aW5nIGxpbmUgYXNzZXJ0cyB0aGF0LgotICAgIEFTU0VSVCgh
SlNET01XaW5kb3c6OmNvbW1vblZNKCktPmR5bmFtaWNHbG9iYWxPYmplY3QpOworICAgIEFTU0VS
VCghSlNET01XaW5kb3c6OmNvbW1vblZNKCktPmVudHJ5U2NvcGUtPmdsb2JhbE9iamVjdCgpKTsK
IAogICAgIC8vIEJ1dCBiZSBzYWZlIGluIHJlbGVhc2UgYnVpbGRzIGp1c3QgaW4gY2FzZS4uLgot
ICAgIGlmIChKU0RPTVdpbmRvdzo6Y29tbW9uVk0oKS0+ZHluYW1pY0dsb2JhbE9iamVjdCkKKyAg
ICBpZiAoSlNET01XaW5kb3c6OmNvbW1vblZNKCktPmVudHJ5U2NvcGUtPmdsb2JhbE9iamVjdCgp
KQogICAgICAgICByZXR1cm47CiAKICAgICBKU0RPTVdpbmRvdzo6Y29tbW9uVk0oKS0+cmVsZWFz
ZUV4ZWN1dGFibGVNZW1vcnkoKTsK
</data>
<flag name="review"
          id="244726"
          type_id="1"
          status="+"
          setter="sam"
    />
          </attachment>
      

    </bug>

</bugzilla>