<?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>209398</bug_id>
          
          <creation_ts>2020-03-22 04:39:34 -0700</creation_ts>
          <short_desc>[JSC] Add JSC::keepAlive(JSValue)</short_desc>
          <delta_ts>2020-03-23 10:17:21 -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>New Bugs</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>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Yusuke Suzuki">ysuzuki</reporter>
          <assigned_to name="Yusuke Suzuki">ysuzuki</assigned_to>
          <cc>darin</cc>
    
    <cc>ews-watchlist</cc>
    
    <cc>ggaren</cc>
    
    <cc>keith_miller</cc>
    
    <cc>mark.lam</cc>
    
    <cc>msaboff</cc>
    
    <cc>saam</cc>
    
    <cc>tzagallo</cc>
    
    <cc>webkit-bug-importer</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1632623</commentid>
    <comment_count>0</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 04:39:34 -0700</bug_when>
    <thetext>[JSC] Add JSC::keepAlive(JSValue)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632624</commentid>
    <comment_count>1</comment_count>
      <attachid>394212</attachid>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 04:40:31 -0700</bug_when>
    <thetext>Created attachment 394212
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632625</commentid>
    <comment_count>2</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 04:40:46 -0700</bug_when>
    <thetext>Will be used in &lt;rdar://problem/60541567&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632633</commentid>
    <comment_count>3</comment_count>
      <attachid>394212</attachid>
    <who name="Mark Lam">mark.lam</who>
    <bug_when>2020-03-22 08:05:30 -0700</bug_when>
    <thetext>Comment on attachment 394212
Patch

r=me.  It would have been nice if there‘s some way to share the implementation instead of having 2 copies, but I couldn’t think of a clean way to express that: probably more hassle than it’s worth.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632711</commentid>
    <comment_count>4</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 17:39:10 -0700</bug_when>
    <thetext>(In reply to Mark Lam from comment #3)
&gt; Comment on attachment 394212 [details]
&gt; Patch
&gt; 
&gt; r=me.  It would have been nice if there‘s some way to share the
&gt; implementation instead of having 2 copies, but I couldn’t think of a clean
&gt; way to express that: probably more hassle than it’s worth.

Yeah, I was thinking about sharing implementation, but there is many conditions like CPU(ADDRESS64), USE(JSVALUE64) etc. And I think just writing this simple function here would be clear than sharing the implementation by putting a lot of ifdefs.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632712</commentid>
    <comment_count>5</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 17:40:59 -0700</bug_when>
    <thetext>Committed r258824: &lt;https://trac.webkit.org/changeset/258824&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632713</commentid>
    <comment_count>6</comment_count>
    <who name="Radar WebKit Bug Importer">webkit-bug-importer</who>
    <bug_when>2020-03-22 17:41:15 -0700</bug_when>
    <thetext>&lt;rdar://problem/60752174&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632727</commentid>
    <comment_count>7</comment_count>
      <attachid>394212</attachid>
    <who name="Geoffrey Garen">ggaren</who>
    <bug_when>2020-03-22 20:20:59 -0700</bug_when>
    <thetext>Comment on attachment 394212
Patch

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

&gt; Source/JavaScriptCore/runtime/JSCJSValue.h:641
&gt; +ALWAYS_INLINE void keepAlive(JSValue value)

This function does not seem to keep &apos;value&apos; alive, so &quot;keep alive&quot; is not a great name for it.

It appears that you&apos;re trying to show the compiler that a given value is used at the point of the call. A better name for that might simply be &quot;use&quot; or &quot;compilerUse&quot;.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632728</commentid>
    <comment_count>8</comment_count>
      <attachid>394212</attachid>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 20:31:55 -0700</bug_when>
    <thetext>Comment on attachment 394212
Patch

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

&gt;&gt; Source/JavaScriptCore/runtime/JSCJSValue.h:641
&gt;&gt; +ALWAYS_INLINE void keepAlive(JSValue value)
&gt; 
&gt; This function does not seem to keep &apos;value&apos; alive, so &quot;keep alive&quot; is not a great name for it.
&gt; 
&gt; It appears that you&apos;re trying to show the compiler that a given value is used at the point of the call. A better name for that might simply be &quot;use&quot; or &quot;compilerUse&quot;.

I think this &quot;keepAlive&quot; is keeping &apos;value&apos; alive.
While the implementation of this is `compilerUse` or `use`, the effect and goal of this function is keeping &apos;value&apos; alive by keeping it in conservative roots at the calling point.
So, this &quot;keepAlive&quot; name is describing the purpose and effect of this function, no?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632729</commentid>
    <comment_count>9</comment_count>
      <attachid>394212</attachid>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 20:36:32 -0700</bug_when>
    <thetext>Comment on attachment 394212
Patch

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

&gt;&gt;&gt; Source/JavaScriptCore/runtime/JSCJSValue.h:641
&gt;&gt;&gt; +ALWAYS_INLINE void keepAlive(JSValue value)
&gt;&gt; 
&gt;&gt; This function does not seem to keep &apos;value&apos; alive, so &quot;keep alive&quot; is not a great name for it.
&gt;&gt; 
&gt;&gt; It appears that you&apos;re trying to show the compiler that a given value is used at the point of the call. A better name for that might simply be &quot;use&quot; or &quot;compilerUse&quot;.
&gt; 
&gt; I think this &quot;keepAlive&quot; is keeping &apos;value&apos; alive.
&gt; While the implementation of this is `compilerUse` or `use`, the effect and goal of this function is keeping &apos;value&apos; alive by keeping it in conservative roots at the calling point.
&gt; So, this &quot;keepAlive&quot; name is describing the purpose and effect of this function, no?

Note that FTL has the same feature. https://github.com/WebKit/webkit/blob/master/Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp#L18347-L18355</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632731</commentid>
    <comment_count>10</comment_count>
    <who name="Geoffrey Garen">ggaren</who>
    <bug_when>2020-03-22 20:52:02 -0700</bug_when>
    <thetext>Most confusing to me about the phrase &quot;keepAlive&quot; is when the function will stop keeping the value alive. 

If the goal is to create a root for conservative GC, maybe a better name is &quot;gcRoot&quot; or &quot;conservativeRoot&quot;.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632733</commentid>
    <comment_count>11</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 20:58:54 -0700</bug_when>
    <thetext>(In reply to Geoffrey Garen from comment #10)
&gt; Most confusing to me about the phrase &quot;keepAlive&quot; is when the function will
&gt; stop keeping the value alive. 
&gt; 
&gt; If the goal is to create a root for conservative GC, maybe a better name is
&gt; &quot;gcRoot&quot; or &quot;conservativeRoot&quot;.

I think `gcRoot` and `conservativeRoot` look ambiguous given that we already have `root` function in WebCore, and it is used for completely different purpose: returning opaque-root for the given pointer. Since &quot;root&quot; function is also used in GC&apos;s context, I think `gcRoot` / `conservativeRoot` look like the similar / same to `root` function in WebCore. But they are different.

How about using `keepAliveAtThisPoint` `ensureReachableFromGCRootAtThisPoint` instead? They clarify that this keep-alive continue until this point.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632734</commentid>
    <comment_count>12</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 21:01:16 -0700</bug_when>
    <thetext>(In reply to Yusuke Suzuki from comment #11)
&gt; (In reply to Geoffrey Garen from comment #10)
&gt; &gt; Most confusing to me about the phrase &quot;keepAlive&quot; is when the function will
&gt; &gt; stop keeping the value alive. 
&gt; &gt; 
&gt; &gt; If the goal is to create a root for conservative GC, maybe a better name is
&gt; &gt; &quot;gcRoot&quot; or &quot;conservativeRoot&quot;.
&gt; 
&gt; I think `gcRoot` and `conservativeRoot` look ambiguous given that we already
&gt; have `root` function in WebCore, and it is used for completely different
&gt; purpose: returning opaque-root for the given pointer. Since &quot;root&quot; function
&gt; is also used in GC&apos;s context, I think `gcRoot` / `conservativeRoot` look
&gt; like the similar / same to `root` function in WebCore. But they are
&gt; different.
&gt; 
&gt; How about using `keepAliveAtThisPoint`
&gt; `ensureReachableFromGCRootAtThisPoint` instead? They clarify that this
&gt; keep-alive continue until this point.

Example of root function in WebCore. https://github.com/WebKit/webkit/blob/master/Source/WebCore/bindings/js/JSCSSRuleCustom.h#L33-L42 This is not used for keeping value alive in conservative root. It is a function returning opaque-root for the given pointer.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632736</commentid>
    <comment_count>13</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 21:06:46 -0700</bug_when>
    <thetext>(In reply to Yusuke Suzuki from comment #12)
&gt; (In reply to Yusuke Suzuki from comment #11)
&gt; &gt; (In reply to Geoffrey Garen from comment #10)
&gt; &gt; &gt; Most confusing to me about the phrase &quot;keepAlive&quot; is when the function will
&gt; &gt; &gt; stop keeping the value alive. 
&gt; &gt; &gt; 
&gt; &gt; &gt; If the goal is to create a root for conservative GC, maybe a better name is
&gt; &gt; &gt; &quot;gcRoot&quot; or &quot;conservativeRoot&quot;.
&gt; &gt; 
&gt; &gt; I think `gcRoot` and `conservativeRoot` look ambiguous given that we already
&gt; &gt; have `root` function in WebCore, and it is used for completely different
&gt; &gt; purpose: returning opaque-root for the given pointer. Since &quot;root&quot; function
&gt; &gt; is also used in GC&apos;s context, I think `gcRoot` / `conservativeRoot` look
&gt; &gt; like the similar / same to `root` function in WebCore. But they are
&gt; &gt; different.
&gt; &gt; 
&gt; &gt; How about using `keepAliveAtThisPoint`
&gt; &gt; `ensureReachableFromGCRootAtThisPoint` instead? They clarify that this
&gt; &gt; keep-alive continue until this point.
&gt; 
&gt; Example of root function in WebCore.
&gt; https://github.com/WebKit/webkit/blob/master/Source/WebCore/bindings/js/
&gt; JSCSSRuleCustom.h#L33-L42 This is not used for keeping value alive in
&gt; conservative root. It is a function returning opaque-root for the given
&gt; pointer.

If user uses `root` function instead of `gcRoot` / `conservativeRoot` functions to keep value alive, this is wrong. And since both `root` and `gcRoot` will accept void*, it would be difficult to notice. So I think we should pick clear name here. Maybe, &quot;ensureReachableFromGCRootAtThisPoint&quot; would be the best.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632737</commentid>
    <comment_count>14</comment_count>
    <who name="Mark Lam">mark.lam</who>
    <bug_when>2020-03-22 21:42:30 -0700</bug_when>
    <thetext>(In reply to Yusuke Suzuki from comment #13)
&gt; If user uses `root` function instead of `gcRoot` / `conservativeRoot`
&gt; functions to keep value alive, this is wrong. And since both `root` and
&gt; `gcRoot` will accept void*, it would be difficult to notice. So I think we
&gt; should pick clear name here. Maybe, &quot;ensureReachableFromGCRootAtThisPoint&quot;
&gt; would be the best.

How about something shorter like &quot;ensureStillAliveHere&quot;?  I like &quot;ensure&quot; better than &quot;keep&quot;, and I think it is a better description of what this function is trying to do.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632739</commentid>
    <comment_count>15</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 21:52:51 -0700</bug_when>
    <thetext>(In reply to Mark Lam from comment #14)
&gt; (In reply to Yusuke Suzuki from comment #13)
&gt; &gt; If user uses `root` function instead of `gcRoot` / `conservativeRoot`
&gt; &gt; functions to keep value alive, this is wrong. And since both `root` and
&gt; &gt; `gcRoot` will accept void*, it would be difficult to notice. So I think we
&gt; &gt; should pick clear name here. Maybe, &quot;ensureReachableFromGCRootAtThisPoint&quot;
&gt; &gt; would be the best.
&gt; 
&gt; How about something shorter like &quot;ensureStillAliveHere&quot;?  I like &quot;ensure&quot;
&gt; better than &quot;keep&quot;, and I think it is a better description of what this
&gt; function is trying to do.

Sounds fine! I&apos;ll rename it to ensureStillAliveHere.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632740</commentid>
    <comment_count>16</comment_count>
    <who name="Yusuke Suzuki">ysuzuki</who>
    <bug_when>2020-03-22 21:57:12 -0700</bug_when>
    <thetext>Committed r258825: &lt;https://trac.webkit.org/changeset/258825&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632905</commentid>
    <comment_count>17</comment_count>
    <who name="Darin Adler">darin</who>
    <bug_when>2020-03-23 10:13:58 -0700</bug_when>
    <thetext>Nice! Way better name!</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1632908</commentid>
    <comment_count>18</comment_count>
      <attachid>394212</attachid>
    <who name="Keith Miller">keith_miller</who>
    <bug_when>2020-03-23 10:17:21 -0700</bug_when>
    <thetext>Comment on attachment 394212
Patch

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

&gt;&gt;&gt;&gt; Source/JavaScriptCore/runtime/JSCJSValue.h:641
&gt;&gt;&gt;&gt; +ALWAYS_INLINE void keepAlive(JSValue value)
&gt;&gt;&gt; 
&gt;&gt;&gt; This function does not seem to keep &apos;value&apos; alive, so &quot;keep alive&quot; is not a great name for it.
&gt;&gt;&gt; 
&gt;&gt;&gt; It appears that you&apos;re trying to show the compiler that a given value is used at the point of the call. A better name for that might simply be &quot;use&quot; or &quot;compilerUse&quot;.
&gt;&gt; 
&gt;&gt; I think this &quot;keepAlive&quot; is keeping &apos;value&apos; alive.
&gt;&gt; While the implementation of this is `compilerUse` or `use`, the effect and goal of this function is keeping &apos;value&apos; alive by keeping it in conservative roots at the calling point.
&gt;&gt; So, this &quot;keepAlive&quot; name is describing the purpose and effect of this function, no?
&gt; 
&gt; Note that FTL has the same feature. https://github.com/WebKit/webkit/blob/master/Source/JavaScriptCore/ftl/FTLLowerDFGToB3.cpp#L18347-L18355

I think it might have been clearer if this was a C++ class that does this when being destructed.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>394212</attachid>
            <date>2020-03-22 04:40:31 -0700</date>
            <delta_ts>2020-03-22 08:05:30 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-209398-20200322044031.patch</filename>
            <type>text/plain</type>
            <size>2807</size>
            <attacher name="Yusuke Suzuki">ysuzuki</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMjU4ODE4CmRpZmYgLS1naXQgYS9Tb3VyY2UvSmF2YVNjcmlw
dENvcmUvQ2hhbmdlTG9nIGIvU291cmNlL0phdmFTY3JpcHRDb3JlL0NoYW5nZUxvZwppbmRleCA2
YmFiM2JmZmM0NjY2ODk5MWJhOTk2NWYzZmZjMWFiNmU4ZjQ2NGRlLi4xODViNDY0YmUxYTA3OTBj
MTUzYmFhZDgxOGE0YTc5MDg5ZjJlMWU0IDEwMDY0NAotLS0gYS9Tb3VyY2UvSmF2YVNjcmlwdENv
cmUvQ2hhbmdlTG9nCisrKyBiL1NvdXJjZS9KYXZhU2NyaXB0Q29yZS9DaGFuZ2VMb2cKQEAgLTEs
MyArMSwxOCBAQAorMjAyMC0wMy0yMiAgWXVzdWtlIFN1enVraSAgPHlzdXp1a2lAYXBwbGUuY29t
PgorCisgICAgICAgIFtKU0NdIEFkZCBKU0M6OmtlZXBBbGl2ZShKU1ZhbHVlKQorICAgICAgICBo
dHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MjA5Mzk4CisKKyAgICAgICAg
UmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisKKyAgICAgICAgQWRkIEpTQzo6a2VlcEFsaXZl
KEpTVmFsdWUpLiBUaGlzIGlzIHVzZWZ1bCB0byBtYWtlIHNvbWUgSlNWYWx1ZSB2YXJpYWJsZSBh
bGl2ZSBmcm9tIEdDLgorCisgICAgICAgICogaGVhcC9IZWFwQ2VsbC5jcHA6CisgICAgICAgICog
cnVudGltZS9KU0NKU1ZhbHVlLmNwcDoKKyAgICAgICAgKEpTQzo6a2VlcEFsaXZlKToKKyAgICAg
ICAgKiBydW50aW1lL0pTQ0pTVmFsdWUuaDoKKyAgICAgICAgKEpTQzo6a2VlcEFsaXZlKToKKwog
MjAyMC0wMy0yMCAgUm9zcyBLaXJzbGluZyAgPHJvc3Mua2lyc2xpbmdAc29ueS5jb20+CiAKICAg
ICAgICAgaGFzT2JzZXJ2YWJsZVNpZGVFZmZlY3RzRm9yUmVnRXhwU3BsaXQgZG9lc24ndCBjaGVj
ayBmb3IgQEBtYXRjaCBvdmVycmlkZQpkaWZmIC0tZ2l0IGEvU291cmNlL0phdmFTY3JpcHRDb3Jl
L2hlYXAvSGVhcENlbGwuY3BwIGIvU291cmNlL0phdmFTY3JpcHRDb3JlL2hlYXAvSGVhcENlbGwu
Y3BwCmluZGV4IDhkNzE0NjUwMDNjNTBiOWI3OGYxYWZjMjRhNzNjM2Q2NTE2OTU3OTIuLmI4MDZj
OGU3NTVjNDlkMTM1YWUwZWUxYWYyNzIxODI3YjAwZWEyNmYgMTAwNjQ0Ci0tLSBhL1NvdXJjZS9K
YXZhU2NyaXB0Q29yZS9oZWFwL0hlYXBDZWxsLmNwcAorKysgYi9Tb3VyY2UvSmF2YVNjcmlwdENv
cmUvaGVhcC9IZWFwQ2VsbC5jcHAKQEAgLTQzLDYgKzQzLDcgQEAgYm9vbCBIZWFwQ2VsbDo6aXNM
aXZlKCkKIH0KIAogI2lmICFDT01QSUxFUihHQ0NfQ09NUEFUSUJMRSkKKy8vIFRoaXMgbWFrZXMg
dGhlIGFyZ3VtZW50IG9wYXF1ZSBmcm9tIHRoZSBjb21waWxlci4KIE5FVkVSX0lOTElORSB2b2lk
IGtlZXBBbGl2ZShjb25zdCB2b2lkKikKIHsKIH0KZGlmZiAtLWdpdCBhL1NvdXJjZS9KYXZhU2Ny
aXB0Q29yZS9ydW50aW1lL0pTQ0pTVmFsdWUuY3BwIGIvU291cmNlL0phdmFTY3JpcHRDb3JlL3J1
bnRpbWUvSlNDSlNWYWx1ZS5jcHAKaW5kZXggNTQ4MDEwZWIxYzA3MDE2MmZkMGM5NjIzMjZmZWUy
OWIxMTAzZDMzZi4uZTU5MGMxYTI5MGMwZmE4YjVjZDBkNWRjN2Y4MWI4YmQ0N2NmYzA2MSAxMDA2
NDQKLS0tIGEvU291cmNlL0phdmFTY3JpcHRDb3JlL3J1bnRpbWUvSlNDSlNWYWx1ZS5jcHAKKysr
IGIvU291cmNlL0phdmFTY3JpcHRDb3JlL3J1bnRpbWUvSlNDSlNWYWx1ZS5jcHAKQEAgLTQyNyw0
ICs0MjcsMTEgQEAgU3RyaW5nIEpTVmFsdWU6OnRvV1RGU3RyaW5nU2xvd0Nhc2UoSlNHbG9iYWxP
YmplY3QqIGdsb2JhbE9iamVjdCkgY29uc3QKICAgICBSRUxFQVNFX0FORF9SRVRVUk4oc2NvcGUs
IHN0cmluZy0+dmFsdWUoZ2xvYmFsT2JqZWN0KSk7CiB9CiAKKyNpZiAhQ09NUElMRVIoR0NDX0NP
TVBBVElCTEUpCisvLyBUaGlzIG1ha2VzIHRoZSBhcmd1bWVudCBvcGFxdWUgZnJvbSB0aGUgY29t
cGlsZXIuCitORVZFUl9JTkxJTkUgdm9pZCBrZWVwQWxpdmUoSlNWYWx1ZSkKK3sKK30KKyNlbmRp
ZgorCiB9IC8vIG5hbWVzcGFjZSBKU0MKZGlmZiAtLWdpdCBhL1NvdXJjZS9KYXZhU2NyaXB0Q29y
ZS9ydW50aW1lL0pTQ0pTVmFsdWUuaCBiL1NvdXJjZS9KYXZhU2NyaXB0Q29yZS9ydW50aW1lL0pT
Q0pTVmFsdWUuaAppbmRleCA1ODZhZjNmYWIzNzk1MmUzZmRlMWNlNDcwYzk5YWIxZWRjNGE3NDFl
Li5mYjA2ZjFmMmIwNjkwMmE2NmE2YThjZjRjZjI0YjIxNTE2MmU0NTI4IDEwMDY0NAotLS0gYS9T
b3VyY2UvSmF2YVNjcmlwdENvcmUvcnVudGltZS9KU0NKU1ZhbHVlLmgKKysrIGIvU291cmNlL0ph
dmFTY3JpcHRDb3JlL3J1bnRpbWUvSlNDSlNWYWx1ZS5oCkBAIC02MzcsNCArNjM3LDE3IEBAIGJv
b2wgaXNUaGlzVmFsdWVBbHRlcmVkKGNvbnN0IFB1dFByb3BlcnR5U2xvdCYsIEpTT2JqZWN0KiBi
YXNlT2JqZWN0KTsKIC8vIFNlZSBzZWN0aW9uIDcuMi45OiBodHRwczovL3RjMzkuZ2l0aHViLmlv
L2VjbWEyNjIvI3NlYy1zYW1ldmFsdWUKIGJvb2wgc2FtZVZhbHVlKEpTR2xvYmFsT2JqZWN0Kiwg
SlNWYWx1ZSBhLCBKU1ZhbHVlIGIpOwogCisjaWYgQ09NUElMRVIoR0NDX0NPTVBBVElCTEUpCitB
TFdBWVNfSU5MSU5FIHZvaWQga2VlcEFsaXZlKEpTVmFsdWUgdmFsdWUpCit7CisjaWYgVVNFKEpT
VkFMVUU2NCkKKyAgICBhc20gdm9sYXRpbGUgKCIiIDogOiAiciIoYml0d2lzZV9jYXN0PHVpbnQ2
NF90Pih2YWx1ZSkpIDogIm1lbW9yeSIpOworI2Vsc2UKKyAgICBhc20gdm9sYXRpbGUgKCIiIDog
OiAiciIodmFsdWUucGF5bG9hZCgpKSA6ICJtZW1vcnkiKTsKKyNlbmRpZgorfQorI2Vsc2UKK0pT
X0VYUE9SVF9QUklWQVRFIHZvaWQga2VlcEFsaXZlKEpTVmFsdWUpOworI2VuZGlmCisKIH0gLy8g
bmFtZXNwYWNlIEpTQwo=
</data>
<flag name="review"
          id="409642"
          type_id="1"
          status="+"
          setter="mark.lam"
    />
          </attachment>
      

    </bug>

</bugzilla>