<?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>147849</bug_id>
          
          <creation_ts>2015-08-10 15:45:53 -0700</creation_ts>
          <short_desc>jsc-tailcall: REGRESSION: DFGByteCodeParser fails when a tail call is inside a ternary</short_desc>
          <delta_ts>2015-09-14 10:59:11 -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>JavaScriptCore</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="Basile Clement">basile_clement</reporter>
          <assigned_to name="Basile Clement">basile_clement</assigned_to>
          <cc>msaboff</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1116365</commentid>
    <comment_count>0</comment_count>
    <who name="Basile Clement">basile_clement</who>
    <bug_when>2015-08-10 15:45:53 -0700</bug_when>
    <thetext>DFGByteCodeParser erroneously assumes that a tail call is always followed by a return. But it can also be followed by a jump to a return in return c ? f() : 0;.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1116647</commentid>
    <comment_count>1</comment_count>
      <attachid>258736</attachid>
    <who name="Basile Clement">basile_clement</who>
    <bug_when>2015-08-11 12:37:09 -0700</bug_when>
    <thetext>Created attachment 258736
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1116652</commentid>
    <comment_count>2</comment_count>
    <who name="Basile Clement">basile_clement</who>
    <bug_when>2015-08-11 12:44:11 -0700</bug_when>
    <thetext>I guess we should make the tests in tail-call-recognize.js run enough to be compiled in all tiers.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1116661</commentid>
    <comment_count>3</comment_count>
      <attachid>258736</attachid>
    <who name="Michael Saboff">msaboff</who>
    <bug_when>2015-08-11 13:02:41 -0700</bug_when>
    <thetext>Comment on attachment 258736
Patch

r=me</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1116665</commentid>
    <comment_count>4</comment_count>
    <who name="Basile Clement">basile_clement</who>
    <bug_when>2015-08-11 13:09:32 -0700</bug_when>
    <thetext>Committed r188282 &lt;http://trac.webkit.org/changeset/188282&gt;.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1125645</commentid>
    <comment_count>5</comment_count>
      <attachid>258736</attachid>
    <who name="Csaba Osztrogonác">ossy</who>
    <bug_when>2015-09-14 10:59:11 -0700</bug_when>
    <thetext>Comment on attachment 258736
Patch

Cleared review? from attachment 258736 so that this bug does not appear in http://webkit.org/pending-review.  If you would like this patch reviewed, please attach it to a new bug (or re-open this bug before marking it for review again).</thetext>
  </long_desc>
      
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>258736</attachid>
            <date>2015-08-11 12:37:09 -0700</date>
            <delta_ts>2015-09-14 10:59:11 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-147849-20150811123654.patch</filename>
            <type>text/plain</type>
            <size>3445</size>
            <attacher name="Basile Clement">basile_clement</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMTg4MTQ5CmRpZmYgLS1naXQgYS9Tb3VyY2UvSmF2YVNjcmlw
dENvcmUvQ2hhbmdlTG9nIGIvU291cmNlL0phdmFTY3JpcHRDb3JlL0NoYW5nZUxvZwppbmRleCBh
YjdiZGQ5ODBiZmFkYWFmNzUwNDRjZWZhYzdmN2JiNzE0OTVmZWJkLi5iN2Y2YTczY2VkZWRlODIw
NzZhNzVmYTljZWJhMjg5NWY2MDkyMWFjIDEwMDY0NAotLS0gYS9Tb3VyY2UvSmF2YVNjcmlwdENv
cmUvQ2hhbmdlTG9nCisrKyBiL1NvdXJjZS9KYXZhU2NyaXB0Q29yZS9DaGFuZ2VMb2cKQEAgLTEs
MyArMSwxNyBAQAorMjAxNS0wOC0xMSAgQmFzaWxlIENsZW1lbnQgIDxiYXNpbGVfY2xlbWVudEBh
cHBsZS5jb20+CisKKyAgICAgICAganNjLXRhaWxjYWxsOiBSRUdSRVNTSU9OOiBERkdCeXRlQ29k
ZVBhcnNlciBmYWlscyB3aGVuIGEgdGFpbCBjYWxsIGlzIGluc2lkZSBhIHRlcm5hcnkKKyAgICAg
ICAgaHR0cHM6Ly9idWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTE0Nzg0OQorCisgICAg
ICAgIFJldmlld2VkIGJ5IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgIFdlIHdlcmUgYXNzdW1p
bmcgdGhhdCBhIHRhaWwgY2FsbCBjb3VsZCBvbmx5IGJlIGZvbGxvd2VkIGJ5IGEgcmV0dXJuLgor
ICAgICAgICBCdXQgaXQgY291bGQgYWxzbyBiZSBmb2xsb3dlZCBieSBhIGp1bXAgdG8gYSByZXR1
cm4gd2hlbiB0aGUgdGFpbCBjYWxsCisgICAgICAgIGlzIGluc2lkZSBhIHRlcm5hcnkgZXhwcmVz
c2lvbi4KKworICAgICAgICAqIGRmZy9ERkdCeXRlQ29kZVBhcnNlci5jcHA6CisgICAgICAgIChK
U0M6OkRGRzo6Qnl0ZUNvZGVQYXJzZXI6OnBhcnNlQmxvY2spOgorCiAyMDE1LTA4LTA3ICBNaWNo
YWVsIFNhYm9mZiAgPG1zYWJvZmZAYXBwbGUuY29tPgogCiAgICAgICAgIFVucmV2aWV3ZWQuIFJv
bGxvdXQgcjE4ODA3MiBhcyB0aGVyZSBhcmUgY3Jhc2hlcyB3aXRoIHJlbGVhc2UgYnVpbGRzLgpk
aWZmIC0tZ2l0IGEvU291cmNlL0phdmFTY3JpcHRDb3JlL2RmZy9ERkdCeXRlQ29kZVBhcnNlci5j
cHAgYi9Tb3VyY2UvSmF2YVNjcmlwdENvcmUvZGZnL0RGR0J5dGVDb2RlUGFyc2VyLmNwcAppbmRl
eCA2ZGEzNDFlMmU1NmY0OGVmM2VhNDBmY2ZmN2NjMDNjNGQyN2RkNTEzLi4xYWQ4MTgyNzExNDM4
NzA5Zjc0NmVlNmY0MmUyNTMzOTZhNDRlMjU0IDEwMDY0NAotLS0gYS9Tb3VyY2UvSmF2YVNjcmlw
dENvcmUvZGZnL0RGR0J5dGVDb2RlUGFyc2VyLmNwcAorKysgYi9Tb3VyY2UvSmF2YVNjcmlwdENv
cmUvZGZnL0RGR0J5dGVDb2RlUGFyc2VyLmNwcApAQCAtMjY5NCw3ICsyNjk0LDExIEBAIGJvb2wg
Qnl0ZUNvZGVQYXJzZXI6OnBhcnNlQmxvY2sodW5zaWduZWQgbGltaXQpCiAgICAgICAgICAgICAv
LyBsb2dpYyByZWxpZXMgb24gZXZlcnkgYnl0ZWNvZGUgcmVzdWx0aW5nIGluIG9uZSBvciBtb3Jl
IG5vZGVzLCB3aGljaCB3b3VsZAogICAgICAgICAgICAgLy8gYmUgdHJ1ZSBhbnl3YXkgZXhjZXB0
IGZvciBvcF9sb29wX2hpbnQsIHdoaWNoIGVtaXRzIGEgUGhhbnRvbSB0byBmb3JjZSB0aGlzCiAg
ICAgICAgICAgICAvLyB0byBiZSB0cnVlLgotICAgICAgICAgICAgaWYgKCFtX2N1cnJlbnRCbG9j
ay0+aXNFbXB0eSgpKQorICAgICAgICAgICAgLy8gV2UgYWxzbyBkb24ndCBpbnNlcnQgYSBqdW1w
IGlmIHRoZSBibG9jayBhbHJlYWR5IGhhcyBhIHRlcm1pbmFsLAorICAgICAgICAgICAgLy8gd2hp
Y2ggY291bGQgaGFwcGVuIGFmdGVyIGEgdGFpbCBjYWxsLgorICAgICAgICAgICAgQVNTRVJUKG1f
Y3VycmVudEJsb2NrLT5pc0VtcHR5KCkgfHwgIW1fY3VycmVudEJsb2NrLT50ZXJtaW5hbCgpCisg
ICAgICAgICAgICAgICAgfHwgbV9jdXJyZW50QmxvY2stPnRlcm1pbmFsKCktPm9wKCkgPT0gVGFp
bENhbGwgfHwgbV9jdXJyZW50QmxvY2stPnRlcm1pbmFsKCktPm9wKCkgPT0gVGFpbENhbGxWYXJh
cmdzKTsKKyAgICAgICAgICAgIGlmICghbV9jdXJyZW50QmxvY2stPmlzRW1wdHkoKSAmJiAhbV9j
dXJyZW50QmxvY2stPnRlcm1pbmFsKCkpCiAgICAgICAgICAgICAgICAgYWRkVG9HcmFwaChKdW1w
LCBPcEluZm8obV9jdXJyZW50SW5kZXgpKTsKICAgICAgICAgICAgIHJldHVybiBzaG91bGRDb250
aW51ZVBhcnNpbmc7CiAgICAgICAgIH0KQEAgLTMyNTYsNiArMzI2MCwxMiBAQCBib29sIEJ5dGVD
b2RlUGFyc2VyOjpwYXJzZUJsb2NrKHVuc2lnbmVkIGxpbWl0KQogICAgICAgICAvLyA9PT0gQmxv
Y2sgdGVybWluYXRvcnMuID09PQogCiAgICAgICAgIGNhc2Ugb3Bfam1wOiB7CisgICAgICAgICAg
ICBpZiAobV9jdXJyZW50QmxvY2stPnRlcm1pbmFsKCkpIHsKKyAgICAgICAgICAgICAgICAvLyBX
ZSBjb3VsZCBiZSB0aGUgZHVtbXkganVtcCB0byBhIHJldHVybiBhZnRlciBhIG5vbi1pbmxpbmVk
LCBub24tZW11bGF0ZWQgdGFpbCBjYWxsIGluIGEgdGVybmFyeSBvcGVyYXRvcgorICAgICAgICAg
ICAgICAgIE5vZGUqIHRlcm1pbmFsID0gbV9jdXJyZW50QmxvY2stPnRlcm1pbmFsKCk7CisgICAg
ICAgICAgICAgICAgQVNTRVJUX1VOVVNFRCh0ZXJtaW5hbCwgdGVybWluYWwtPm9wKCkgPT0gVGFp
bENhbGwgfHwgdGVybWluYWwtPm9wKCkgPT0gVGFpbENhbGxWYXJhcmdzKTsKKyAgICAgICAgICAg
ICAgICBMQVNUX09QQ09ERShvcF9yZXQpOworICAgICAgICAgICAgfQogICAgICAgICAgICAgaW50
IHJlbGF0aXZlT2Zmc2V0ID0gY3VycmVudEluc3RydWN0aW9uWzFdLnUub3BlcmFuZDsKICAgICAg
ICAgICAgIGFkZFRvR3JhcGgoSnVtcCwgT3BJbmZvKG1fY3VycmVudEluZGV4ICsgcmVsYXRpdmVP
ZmZzZXQpKTsKICAgICAgICAgICAgIGlmIChyZWxhdGl2ZU9mZnNldCA8PSAwKQpAQCAtMzQyOCw3
ICszNDM4LDcgQEAgYm9vbCBCeXRlQ29kZVBhcnNlcjo6cGFyc2VCbG9jayh1bnNpZ25lZCBsaW1p
dCkKICAgICAgICAgICAgIGlmIChtX2N1cnJlbnRCbG9jay0+dGVybWluYWwoKSkgewogICAgICAg
ICAgICAgICAgIC8vIFdlIGNvdWxkIGJlIHRoZSBkdW1teSByZXR1cm4gYWZ0ZXIgYSBub24taW5s
aW5lZCwgbm9uLWVtdWxhdGVkIHRhaWwgY2FsbAogICAgICAgICAgICAgICAgIE5vZGUqIHRlcm1p
bmFsID0gbV9jdXJyZW50QmxvY2stPnRlcm1pbmFsKCk7Ci0gICAgICAgICAgICAgICAgQVNTRVJU
X1VOVVNFRCh0ZXJtaW5hbCwgdGVybWluYWwtPm9wKCkgPT0gUmV0dXJuIHx8IHRlcm1pbmFsLT5v
cCgpID09IFRhaWxDYWxsIHx8IHRlcm1pbmFsLT5vcCgpID09IFRhaWxDYWxsVmFyYXJncyk7Cisg
ICAgICAgICAgICAgICAgQVNTRVJUX1VOVVNFRCh0ZXJtaW5hbCwgdGVybWluYWwtPm9wKCkgPT0g
VGFpbENhbGwgfHwgdGVybWluYWwtPm9wKCkgPT0gVGFpbENhbGxWYXJhcmdzKTsKICAgICAgICAg
ICAgICAgICBMQVNUX09QQ09ERShvcF9yZXQpOwogICAgICAgICAgICAgfQogICAgICAgICAgICAg
aWYgKGlubGluZUNhbGxGcmFtZSgpKSB7Cg==
</data>

          </attachment>
      

    </bug>

</bugzilla>