<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - i915 is leaking frame buffers"
href="https://bugs.freedesktop.org/show_bug.cgi?id=93251">93251</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>i915 is leaking frame buffers
</td>
</tr>
<tr>
<th>Product</th>
<td>DRI
</td>
</tr>
<tr>
<th>Version</th>
<td>unspecified
</td>
</tr>
<tr>
<th>Hardware</th>
<td>Other
</td>
</tr>
<tr>
<th>OS</th>
<td>All
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>major
</td>
</tr>
<tr>
<th>Priority</th>
<td>medium
</td>
</tr>
<tr>
<th>Component</th>
<td>DRM/Intel
</td>
</tr>
<tr>
<th>Assignee</th>
<td>intel-gfx-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>tvrtko.ursulin@linux.intel.com
</td>
</tr>
<tr>
<th>QA Contact</th>
<td>intel-gfx-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>CC</th>
<td>intel-gfx-bugs@lists.freedesktop.org
</td>
</tr></table>
<p>
<div>
<pre>(Since appealing to people directly does not seem to work, here is an Bugzilla
entry so I've done my bit.)
Definitely when legacy fbcon is not enabled, maybe even leaks extra
(non-primary) planes with it.
I ran igt/kms_rotation_crc on a system without legacy fbcon and it crashed.
This left any planes it happened to be displaying stuck on screen.
For example kms_rotation_crc has crashed, and kernel still hangs onto the frame
buffers:
# cat /sys/kernel/debug/dri/0/i915_gem_framebuffer
user size: 128 x 128, depth 32, 32 bpp, modifier 0x0, refcount 2, obj
ffff8800aa0486c0: p g 64KiB 40 00 [ 0 0 0 0 ] 0 0 uncached dirty (pinned
x 1) (display) (ggtt offset: 0281b000, size: 00010000, type: 0) (pf mappable)
(frontbuffer: 0x002)
user size: 1920 x 1080, depth 24, 32 bpp, modifier 0x0, refcount 2, obj
ffff8800aa049d40: p g 8100KiB 41 00 [ 0 0 0 0 ] 0 0 uncached (pinned x 1)
(display) (ggtt offset: 0282b000, size: 007e9000, type: 0) (p mappable)
(frontbuffer: 0x001)
user size: 1920 x 1080, depth 24, 32 bpp, modifier 0x0, refcount 2, obj
ffff8800aa048fc0: p g 8100KiB 40 00 [ 0 0 0 0 ] 0 0 uncached dirty (pinned
x 1) (display) (ggtt offset: 00819000, size: 007e9000, type: 0) (pf mappable)
(frontbuffer: 0x004)
One consequence is that should the user start something which puts stuff on the
primary plane, say igt/testdisplay, the sprite and cursor belonging to gone
kms_rotation_crc will still be on screen. Even hiding the testdisplay output.
And it also makes subsequent CRC tests fail.
When I now start Xorg the desktop is hidden by the left over sprite plane.
Imagine a scenario with multiple displays and multiple planes and Xorg
segfaults. Kernel will keep, number of displays times number of planes frame
buffers around, pinned in memory, wasting resources.
Not to mention it keeps displaying potentially sensitive data on screen.
Someone will say it is an userspace problem, that something should enumerate
all displays and all planes and clear them should a display server crash. I
disagree because that would mean changing all existing userspace programs which
currently assume that when they start up nothing is on screen or on the extra
planes.</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>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>