<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - [SKL/KBL] Init time is high"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=94722#c19">Comment # 19</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - [SKL/KBL] Init time is high"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=94722">bug 94722</a>
              from <span class="vcard"><a class="email" href="mailto:david.weinehall@intel.com" title="David Weinehall <david.weinehall@intel.com>"> <span class="fn">David Weinehall</span></a>
</span></b>
        <pre>Measurements using SuspendResume on a KBL-Y yields roughly these numbers:

suspend: 320ms -- out of this 300ms is spent turning off panel + backlight; the
delays here cannot be optimised away, so at most we can shave off a few
milliseconds. This values will vary greatly depending on the panel used.

resume: 470ms -- out of this 30ms is spent in restore_gtt, 230ms is spent
turning on panel + backlight, 170ms on probing for new displays, and 30ms in
one of the opregion-related calls.

The probing for new displays can be parallelised once the atomic modeset code
is finalised. There are various other things that can be optimised here too, as
the numbers probably show, but -- and here's the important part, for resume we
are not blocking the critical path. There are several components that take
longer to resume, and they are resuming in parallel to our driver.

Finally, for init, after consultation with Daniel Vetter it seems unlikely that
the init-time target is realistic. According to him none of our earlier
platforms have been able to meet this target, and the basis for the requirement
isn't fully understood. It should, however, be noted that on startup all
modules load in parallel, so we're not actually blocking anything.

Conclusion -- the situation is much better than the initial bug report
indicates.
A lot of the time spent during init/suspend/resume is spent in delays that are
specified by hardware (enabling/disabling/probing) and thus not amenable to
optimisation. The main remaining area is likely to see improvements once the
atomic modeset is finalised.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the QA Contact for the bug.</li>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>