<table><tr><td style="">fvogt added a comment.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D28535">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
          color: #6B748C;
          font-style: italic;
          margin: 4px 0 12px 0;
          padding: 8px 12px;
          background-color: #F8F9FC;">
<div style="font-style: normal;
          padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D28535#640656" style="background-color: #e7e7e7;
          border-color: #e7e7e7;
          border-radius: 3px;
          padding: 0 4px;
          font-weight: bold;
          color: black;text-decoration: none;">D28535#640656</a>, <a href="https://phabricator.kde.org/p/anthonyfieroni/" style="
              border-color: #f1f7ff;
              color: #19558d;
              background-color: #f1f7ff;
                border: 1px solid transparent;
                border-radius: 3px;
                font-weight: bold;
                padding: 0 4px;">@anthonyfieroni</a> wrote:</div>
<div style="margin: 0;
          padding: 0;
          border: 0;
          color: rgb(107, 116, 140);"><p>You're right about bug report, but it can fail in any other place, just in particular version it happen in  <tt style="background: #ebebeb; font-size: 13px;">updateStorageInfo</tt> Can we cache <tt style="background: #ebebeb; font-size: 13px;">getDevice</tt> in m_device (in constructor) then use it everywhere. I think libmtp has guard against disconnected device and will not crash.</p></div>
</blockquote>

<p><tt style="background: #ebebeb; font-size: 13px;">MTPDevice</tt> already does that.</p>

<p>If <tt style="background: #ebebeb; font-size: 13px;">getDevice()</tt> returns nullptr, this means that <tt style="background: #ebebeb; font-size: 13px;">MTPDevice::getDevice()</tt> returns nullptr. This can only happen if <tt style="background: #ebebeb; font-size: 13px;">m_mtpdevice</tt> is nullptr, which will crash in <tt style="background: #ebebeb; font-size: 13px;">MTPDevice::~MTPDevice</tt> sooner or later anyway.</p>

<p>So this patch will at most just delay the crash.</p>

<p>AFAICT <tt style="background: #ebebeb; font-size: 13px;">MTPDevice</tt> is supposed to be destroyed in <tt style="background: #ebebeb; font-size: 13px;">KMTPd::deviceRemoved</tt> on disconnection, but this is obviously racy.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R320 KIO Extras</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D28535">https://phabricator.kde.org/D28535</a></div></div><br /><div><strong>To: </strong>feverfew, akrutzler, dfaure, elvisangelaccio<br /><strong>Cc: </strong>anthonyfieroni, kde-frameworks-devel, fvogt, kfm-devel, ngraham, nikolaik, pberestov, iasensio, fprice, LeGast00n, cblack, fbampaloukas, alexde, GB_2, Codezela, feverfew, meven, michaelh, spoorun, navarromorales, firef, andrebarros, bruns, emmanuelp, mikesomov<br /></div>