<?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>182409</bug_id>
          
          <creation_ts>2018-02-01 15:50:26 -0800</creation_ts>
          <short_desc>REGRESSION (r222824): UI process crashes in WebKit::WebBackForwardList::backItem const</short_desc>
          <delta_ts>2018-02-01 16:40:38 -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>WebKit2</component>
          <version>Other</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>
          <dependson>177843</dependson>
          
          <everconfirmed>1</everconfirmed>
          <reporter name="David Kilzer (:ddkilzer)">ddkilzer</reporter>
          <assigned_to name="David Kilzer (:ddkilzer)">ddkilzer</assigned_to>
          <cc>achristensen</cc>
    
    <cc>bfulgham</cc>
    
    <cc>commit-queue</cc>
    
    <cc>webkit-bug-importer</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1395674</commentid>
    <comment_count>0</comment_count>
    <who name="David Kilzer (:ddkilzer)">ddkilzer</who>
    <bug_when>2018-02-01 15:50:26 -0800</bug_when>
    <thetext>The UI process crashes in WebKit::WebBackForwardList::backItem const during a programmatic back navigation.

In a Debug build, this assertion in WebKit::WebBackForwardList::goToItem fires instead:

        ASSERT(targetIndex != notFound);

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   com.apple.JavaScriptCore      	0x0000000116506834 WTFCrash + 36 (Assertions.cpp:272)
1   com.apple.WebKit              	0x000000011137d13c WebKit::WebBackForwardList::goToItem(WebKit::WebBackForwardListItem&amp;) + 892 (WebBackForwardList.cpp:207)
2   com.apple.WebKit              	0x000000011168788e WebKit::WebPageProxy::backForwardGoToItem(unsigned long long, WebKit::SandboxExtension::Handle&amp;) + 254 (WebPageProxy.cpp:4547)
3   com.apple.WebKit              	0x000000011174efe1 void IPC::callMemberFunctionImpl&lt;WebKit::WebPageProxy, void (WebKit::WebPageProxy::*)(unsigned long long, WebKit::SandboxExtension::Handle&amp;), std::__1::tuple&lt;unsigned long long&gt;, 0ul, std::__1::tuple&lt;WebKit::SandboxExtension::Handle&gt;, 0ul&gt;(WebKit::WebPageProxy*, void (WebKit::WebPageProxy::*)(unsigned long long, WebKit::SandboxExtension::Handle&amp;), std::__1::tuple&lt;unsigned long long&gt;&amp;&amp;, std::__1::tuple&lt;WebKit::SandboxExtension::Handle&gt;&amp;, std::__1::integer_sequence&lt;unsigned long, 0ul&gt;, std::__1::integer_sequence&lt;unsigned long, 0ul&gt;) + 193 (HandleMessage.h:55)
[...]

The debug assertion crash is due to a typo in a for loop that causes `targetIndex` to be left at the value -1, which then causes unsigned integer overflow using checked arithmetic (resulting in the release crash):

Thread 0 Crashed ↩:: Dispatch queue: com.apple.main-thread
0   com.apple.WebKit              	0x00007fff372572cd WTF::CrashOnOverflow::crash() + 5
1   com.apple.WebKit              	0x00007fff3724ea81 WTF::CrashOnOverflow::overflowed() + 9
2   com.apple.WebKit              	0x00007fff373ed706 WebKit::WebBackForwardList::backItem() const + 60
3   com.apple.WebKit              	0x00007fff3747f3fd WebKit::WebPageProxy::didChangeBackForwardList(WebKit::WebBackForwardListItem*, WTF::Vector&lt;WTF::Ref&lt;WebKit::WebBackForwardListItem, WTF::DumbPtrTraits&lt;WebKit::WebBackForwardListItem&gt; &gt;, 0ul, WTF::CrashOnOverflow, 16ul, WTF::FastMalloc&gt;&amp;&amp;) + 143
4   com.apple.WebKit              	0x00007fff373ed67a WebKit::WebBackForwardList::goToItem(WebKit::WebBackForwardListItem&amp;) + 496
5   com.apple.WebKit              	0x00007fff372239b3 WebKit::WebPageProxy::backForwardGoToItem(unsigned long long, WebKit::SandboxExtension::Handle&amp;) + 201
6   com.apple.WebKit              	0x00007fff374a713f void IPC::handleMessage&lt;Messages::WebPageProxy::BackForwardGoToItem, WebKit::WebPageProxy, void (WebKit::WebPageProxy::*)(unsigned long long, WebKit::SandboxExtension::Handle&amp;)&gt;(IPC::Decoder&amp;, IPC::Encoder&amp;, WebKit::WebPageProxy*, void (WebKit::WebPageProxy::*)(unsigned long long, WebKit::SandboxExtension::Handle&amp;)) + 90
[...]</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1395675</commentid>
    <comment_count>1</comment_count>
    <who name="David Kilzer (:ddkilzer)">ddkilzer</who>
    <bug_when>2018-02-01 15:50:35 -0800</bug_when>
    <thetext>&lt;rdar://problem/35495094&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1395678</commentid>
    <comment_count>2</comment_count>
      <attachid>332920</attachid>
    <who name="David Kilzer (:ddkilzer)">ddkilzer</who>
    <bug_when>2018-02-01 15:58:29 -0800</bug_when>
    <thetext>Created attachment 332920
Patch v1</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1395693</commentid>
    <comment_count>3</comment_count>
      <attachid>332920</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2018-02-01 16:40:36 -0800</bug_when>
    <thetext>Comment on attachment 332920
Patch v1

Clearing flags on attachment: 332920

Committed r227990: &lt;https://trac.webkit.org/changeset/227990&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1395695</commentid>
    <comment_count>4</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2018-02-01 16:40:38 -0800</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>332920</attachid>
            <date>2018-02-01 15:58:29 -0800</date>
            <delta_ts>2018-02-01 16:40:36 -0800</delta_ts>
            <desc>Patch v1</desc>
            <filename>bug-182409-20180201155828.patch</filename>
            <type>text/plain</type>
            <size>1514</size>
            <attacher name="David Kilzer (:ddkilzer)">ddkilzer</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMjI3OTczCmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViS2l0L0No
YW5nZUxvZyBiL1NvdXJjZS9XZWJLaXQvQ2hhbmdlTG9nCmluZGV4IGYzMWQ3YjRjODk3MDA2MDFm
NjRlNDM2YjhiZWY5MGZjODIzODFlMjkuLjJhMWI4YTJkZDcyZjQ1YjU1N2IwZGJjODQyZDkyNjUy
YWM2NThlZTYgMTAwNjQ0Ci0tLSBhL1NvdXJjZS9XZWJLaXQvQ2hhbmdlTG9nCisrKyBiL1NvdXJj
ZS9XZWJLaXQvQ2hhbmdlTG9nCkBAIC0xLDMgKzEsMTUgQEAKKzIwMTgtMDItMDEgIERhdmlkIEtp
bHplciAgPGRka2lsemVyQGFwcGxlLmNvbT4KKworICAgICAgICBSRUdSRVNTSU9OIChyMjIyODI0
KTogVUkgcHJvY2VzcyBjcmFzaGVzIGluIFdlYktpdDo6V2ViQmFja0ZvcndhcmRMaXN0OjpiYWNr
SXRlbSBjb25zdAorICAgICAgICA8aHR0cHM6Ly93ZWJraXQub3JnL2IvMTgyNDA5PgorICAgICAg
ICA8cmRhcjovL3Byb2JsZW0vMzU0OTUwOTQ+CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZ
IChPT1BTISkuCisKKyAgICAgICAgKiBVSVByb2Nlc3MvV2ViQmFja0ZvcndhcmRMaXN0LmNwcDoK
KyAgICAgICAgKFdlYktpdDo6V2ViQmFja0ZvcndhcmRMaXN0Ojpnb1RvSXRlbSk6IEZpeCB0eXBv
IHNvIHRoZSBmb3IgbG9vcAorICAgICAgICBhY3R1YWxseSBjaGVja3MgZWFjaCB2YWx1ZSBpbiBt
X2VudHJpZXMuCisKIDIwMTgtMDItMDEgIENhcmxvcyBHYXJjaWEgQ2FtcG9zICA8Y2dhcmNpYUBp
Z2FsaWEuY29tPgogCiAgICAgICAgIFtHVEtdIFNoaWZ0ICsgbW91c2Ugc2Nyb2xsIHNob3VsZCBz
Y3JvbGwgaG9yaXpvbnRhbGx5CmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViS2l0L1VJUHJvY2Vzcy9X
ZWJCYWNrRm9yd2FyZExpc3QuY3BwIGIvU291cmNlL1dlYktpdC9VSVByb2Nlc3MvV2ViQmFja0Zv
cndhcmRMaXN0LmNwcAppbmRleCAxZDFiODNlNTFmNjUxOGZmZGMyMDRiYzA1YjUyMGEzZjEyNmMw
Y2M4Li45OTgyZDgxNjM3MGJmYmFlYjEwMWE4N2I5ZTRhOTk4MGRiNmY3NjY1IDEwMDY0NAotLS0g
YS9Tb3VyY2UvV2ViS2l0L1VJUHJvY2Vzcy9XZWJCYWNrRm9yd2FyZExpc3QuY3BwCisrKyBiL1Nv
dXJjZS9XZWJLaXQvVUlQcm9jZXNzL1dlYkJhY2tGb3J3YXJkTGlzdC5jcHAKQEAgLTE5OSw3ICsx
OTksNyBAQCB2b2lkIFdlYkJhY2tGb3J3YXJkTGlzdDo6Z29Ub0l0ZW0oV2ViQmFja0ZvcndhcmRM
aXN0SXRlbSYgaXRlbSkKICAgICAgICAgbV9lbnRyaWVzLnJlbW92ZShtX2N1cnJlbnRJbmRleCk7
CiAgICAgICAgIHRhcmdldEluZGV4ID0gbm90Rm91bmQ7CiAgICAgICAgIGZvciAoc2l6ZV90IGkg
PSAwOyBpIDwgbV9lbnRyaWVzLnNpemUoKTsgKytpKSB7Ci0gICAgICAgICAgICBpZiAobV9lbnRy
aWVzWzBdLnB0cigpID09ICZpdGVtKSB7CisgICAgICAgICAgICBpZiAobV9lbnRyaWVzW2ldLnB0
cigpID09ICZpdGVtKSB7CiAgICAgICAgICAgICAgICAgdGFyZ2V0SW5kZXggPSBpOwogICAgICAg
ICAgICAgICAgIGJyZWFrOwogICAgICAgICAgICAgfQo=
</data>

          </attachment>
      

    </bug>

</bugzilla>