<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Priority</th>
<td>medium
</td>
</tr>
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Difference with software render and without (clipping vertex?)"
href="https://bugs.freedesktop.org/show_bug.cgi?id=81649">81649</a>
</td>
</tr>
<tr>
<th>Assignee</th>
<td>idr@freedesktop.org
</td>
</tr>
<tr>
<th>Summary</th>
<td>Difference with software render and without (clipping vertex?)
</td>
</tr>
<tr>
<th>QA Contact</th>
<td>intel-3d-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>Severity</th>
<td>normal
</td>
</tr>
<tr>
<th>Classification</th>
<td>Unclassified
</td>
</tr>
<tr>
<th>OS</th>
<td>Linux (All)
</td>
</tr>
<tr>
<th>Reporter</th>
<td>fevrier.dorian@yahoo.fr
</td>
</tr>
<tr>
<th>Hardware</th>
<td>x86 (IA32)
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Version</th>
<td>8.0
</td>
</tr>
<tr>
<th>Component</th>
<td>Drivers/DRI/i965
</td>
</tr>
<tr>
<th>Product</th>
<td>Mesa
</td>
</tr></table>
<p>
<div>
<pre>Created <span class=""><a href="attachment.cgi?id=103299" name="attach_103299" title="Without LIBGL_ALWAYS_SOFTWARE">attachment 103299</a> <a href="attachment.cgi?id=103299&action=edit" title="Without LIBGL_ALWAYS_SOFTWARE">[details]</a></span>
Without LIBGL_ALWAYS_SOFTWARE
Hi, I'm currently working on mupen64plus rice video plugin.
I have an intel chipset:
Tungsten Graphics, Inc - Mesa DRI Intel(R) 965GM x86/MMX/SSE2 : 2.1 Mesa 8.0.4
After moving the plugin from a fixed OpenGL pipeline to a GLSL one, I have some
vertex clipping problems:
<a href="http://i.imgur.com/ltMZSpG.png">http://i.imgur.com/ltMZSpG.png</a>
After some investigation, I realize I shoud try using this to help me to know
if it's a programming problem or a driver problem:
export LIBGL_ALWAYS_SOFTWARE=1
And there is no more face clipped and everything work as except.
I've found this bug: <a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Clipping is performed incorrectly when using shaders with intel/nouveau/radeon drivers."
href="show_bug.cgi?id=64668">https://bugs.freedesktop.org/show_bug.cgi?id=64668</a>
Paul suggest to add this to the shader:
gl_ClipVertex = gl_ModelViewMatrix * gl_Vertex;
And I guess there is an important point: The vertex projection transform is
done on the CPU side. The reason is that N64 apply "current matrix" (where
"current" is a model matrix stack * projection matrix stack) at the moment
where the vertex is provided. So you really have this "gl_ModelViewMatrix".
Anyway, adding this to the vertex shader doesn't solve the problem so maybe
this is not related at all. Same for the example code provided in the linked
bug (64668) it clip what ever LIBGL_ALWAYS_SOFTWARE is set or not. So once
again, it's maybe not related.
Anyway, the fact it works in software (LIBGL_ALWAYS_SOFTWARE) make me realize
the current code is supposed to work but maybe just fail on the 965GM chipset.
FYI, whe I define LIBGL_ALWAYS_SOFTWARE I guet this OpenGL string:
VMware, Inc. - Gallium 0.4 on llvmpipe (LLVM 0x300) : 2.1 Mesa 8.0.4
It's hard to reproduce the bug but I probide the ".trace" for qapitrace:
<a href="https://github.com/apitrace/apitrace">https://github.com/apitrace/apitrace</a>. If you open it on 965GM without
LIBGL_ALWAYS_SOFTWARE and trace the frame 4 you will see the bug (image 001).
If you define LIBGL_ALWAYS_SOFTWARE, run qaptitrace and trace the frame 4 you
will see what is expected (image 002).
If you have any workaround to share I would really love that. :)
Best,
Dorian</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>