<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW --- - [i965 Bisected]Piglit/glx_glx-make-glxdrawable-current fails"
href="https://bugs.freedesktop.org/show_bug.cgi?id=74005#c8">Comment # 8</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW --- - [i965 Bisected]Piglit/glx_glx-make-glxdrawable-current fails"
href="https://bugs.freedesktop.org/show_bug.cgi?id=74005">bug 74005</a>
from <span class="vcard"><a class="email" href="mailto:krh@bitplanet.net" title="Kristian Høgsberg <krh@bitplanet.net>"> <span class="fn">Kristian Høgsberg</span></a>
</span></b>
<pre>(In reply to <a href="show_bug.cgi?id=74005#c6">comment #6</a>)
<span class="quote">> Created <span class=""><a href="attachment.cgi?id=95650" name="attach_95650" title="Patch">attachment 95650</a> <a href="attachment.cgi?id=95650&action=edit" title="Patch">[details]</a></span> <a href='page.cgi?id=splinter.html&bug=74005&attachment=95650'>[review]</a> [review]
> Patch
>
> The problem seems to live in the fact that we check whether we have a
> viewport set to decide if we need to generate buffers for the drawable. This
> is not a valid solution for the scenario in which we switch drawables for
> the same context, since the viewport will be initialized the first time that
> we call MakeCurrent with one of the drawables. Thus, switching to a
> different drawable after the first MakeCurrent will not produce buffers for
> the new drawable, leading to the problem.
>
> The patch reverts the behavior to the original solution with a small change
> to support single buffer drawables (which was the reason the bad commit was
> introduced). Basically, it checks if we have a render buffer for the
> drawable, but instead of checking the BACK_LEFT buffer which only works for
> double buffer drawables we check the FRONT_LEFT buffer, which should work
> for both single buffer and double buffer drawables.</span >
We don't want to revert the behaviour. The initial patch removed a call to
intel_prepare_render() in intelMakeCurrent(). We're supposed to call
intel_prepare_render() any time we're about to touch the buffers, but the
up-front call to intel_prepare_render() in intelMakeCurrent covered up a few
places where we forgot. The fix now isn't to put back the up-front
intel_prepare_render() call but to add it in the rendering paths that are
missing it.
Also, for reference, we need the buffer size for the initial value of the
context viewport. So the first time a context is made current, we call
intel_prepare_render() to get the buffers so we can see what size they are.
When the same context is later made current with a different drawable, we have
a value for the viewport and we're not supposed to change it, so there's no
point in getting buffers.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the QA Contact for the bug.</li>
</ul>
</body>
</html>