<html>
<head>
<base href="https://bugs.freedesktop.org/">
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW - [CI][DRMTIP] igt@kms_ccs@pipe-b-crc-primary-basic - fail - Failed assertion: __gem_create(fd, size, &handle) == 0, error: -22 != 0"
href="https://bugs.freedesktop.org/show_bug.cgi?id=111603#c2">Comment # 2</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW - [CI][DRMTIP] igt@kms_ccs@pipe-b-crc-primary-basic - fail - Failed assertion: __gem_create(fd, size, &handle) == 0, error: -22 != 0"
href="https://bugs.freedesktop.org/show_bug.cgi?id=111603">bug 111603</a>
from <span class="vcard"><a class="email" href="mailto:matthew.d.roper@intel.com" title="Matt Roper <matthew.d.roper@intel.com>"> <span class="fn">Matt Roper</span></a>
</span></b>
<pre>There aren't enough debugging messages in the gem_create path to know with 100%
certainty, but based on the clues here it appears this is quite likely another
case of a display link going down mid-test:
<7>[ 30.093477] [drm:drm_helper_probe_single_connector_modes]
[CONNECTOR:95:DP-2] status updated from connected to disconnected
which results in the mode obtained by the test being 0x0. The test fails to
notice and attempts to allocate a 0-sized framebuffer, which will be rejected
with -EINVAL (-22) in i915_gem_create().
End-user impact of this should be nil (if a monitor is unplugged then a hotplug
event is sent to userspace and handled appropriately by whatever graphical
environment is running). But the impact of this sequence of events on general
CI stability is a bit higher. I know we've got other fdo bugs that are all
triggered by the same general sequence of events where a display connection
goes down mid-test (maybe due to flaky cables, dying boards, or just plain
loose cables) and IGT doesn't notice so it tries to allocate 0-sized
framebuffers for this inactive mode; when the kernel (correctly) rejects the
buffer creation ioctl, IGT registers that as a test failure, even though the
behavior doesn't have anything to do with what the test app was attempting to
exercise.
We probably need a strategy for IGT tests (all IGT tests, not just this one) to
react to unexpected mid-test hot(un)plugs that occur due to flaky
hardware/dongles/cables/etc. Or at the very least, force all of these
occurrences across all IGT tests to fail with one easily-recognizable signature
so that we can capture them all in a single bug.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
<li>You are on the CC list for the bug.</li>
<li>You are the QA Contact for the bug.</li>
</ul>
</body>
</html>