On 15 June 2012 14:44, Chad Versace <span dir="ltr">&lt;<a href="mailto:chad.versace@linux.intel.com" target="_blank">chad.versace@linux.intel.com</a>&gt;</span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
-----BEGIN PGP SIGNED MESSAGE-----<br>
Hash: SHA1<br>
<div><div class="h5"><br>
On 06/15/2012 11:12 AM, Paul Berry wrote:<br>
&gt; Due to hardware limitations, MSAA is unsupported on Gen6 for formats<br>
&gt; containing &gt;64 bits of data per pixel.  From the Sandy Bridge PRM,<br>
&gt; vol4 part1, p72 (&quot;Surface Format&quot;):<br>
&gt;<br>
&gt;     If Number of Multisamples is set to a value other than<br>
&gt;     MULTISAMPLECOUNT_1, this field cannot be set to the following<br>
&gt;     formats:<br>
&gt;     - any format with greater than 64 bits per element<br>
&gt;     - any compressed texture format (BC*)<br>
&gt;     - any YCRCB* format<br>
&gt;<br>
&gt; Gen7 has a similar, but less stringent limitation: formats with &gt;64<br>
&gt; bits of data per pixel only support 4x MSAA.<br>
&gt;<br>
&gt; This patch causes the unsupported formats to report<br>
&gt; GL_FRAMEBUFFER_UNSUPPORTED.<br>
&gt;<br>
&gt; Fixes piglit &quot;multisample-formats&quot; tests on Gen6.<br>
&gt; ---<br>
&gt;<br>
&gt; It is not 100% clear to me whether this approach is compliant with the<br>
&gt; spec.  On the one hand, the spec requires formats RGBA32F, RGBA32I,<br>
&gt; and RGBA32UI to be color-renderable.  On the other hand, the spec<br>
&gt; allows for the implementation to report GL_FRAMEBUFFER_UNSUPPORTED if<br>
&gt; the set of attached images violates &quot;an implementation-dependent set<br>
&gt; of restrictions&quot;, which seems to leave a lot of leeway.<br>
&gt;<br>
&gt; If we decide that it&#39;s not ok to report GL_FRAMEBUFFER_UNSUPPORTED for<br>
&gt; MSAA buffers using these formats, then we&#39;ll have to figure out some<br>
&gt; other way to work around the hardware&#39;s lack of support for MSAA on<br>
&gt; these formats, and I haven&#39;t thought of a good way to do that.  The<br>
&gt; alternatives I&#39;ve considered (substitute another buffer format, or<br>
&gt; substitute a non-multisampled renderbuffer) are definitely<br>
&gt; non-spec-compliant, and also fraught with implementation difficulties.<br>
&gt;<br>
&gt; So for the moment my inclination is to go through with this patch as<br>
&gt; is, and if we later discover that it causes trouble for a client<br>
&gt; application, we can consider other options.  I&#39;m curious to hear what<br>
&gt; others think.<br>
<br>
</div></div>After releasing GL3.0, but before implementing real MSAA, we lied to the app.<br>
If the app requested an MSAA buffer, we said &quot;ok&quot; and just created a single-sample<br>
buffer.<br>
<br>
Can we do that for these formats? It may be better to do that than report<br>
GL_FRAMEBUFFER_UNSUPPORTED. I&#39;m unsure what&#39;s best, though.<br></blockquote><div><br></div><div>Thanks for the suggestion.  At the risk of giving off the impression that I already have my mind made up, I *did* consider this approach, and here&#39;s why I rejected it: all attachments to a framebuffer need to have the same sample count.  So if we secretly substitute a single-sampled RGBA32F buffer in place of the 4x RGBA32F buffer the client program requests, we&#39;ll also have to secretly substitute single-sampled depth and stencil buffers, as well as single-sampled versions of all the other color buffers the client program might have attached to the same framebuffer (because a framebuffer can have multiple color attachments).  We can&#39;t do this substitution until drawing is done (or the client program calls glCheckFramebufferStatus()), because between draws, the client program might have incompatible renderbuffers attached to the same framebuffer as a transitory condition.  Getting the logic right for secretly swapping in single-sampled framebuffers, at the time of the draw call, is going to be tricky.</div>
<div><br></div><div>More difficulties arise if the client program tries to re-use some, but not all, of the renderbuffers in the same framebuffer.  Let&#39;s say that after doing some rendering using an RGBA32F/DEPTH24_STENCIL8 combination, the user detaches the RGBA32F renderbuffer and attaches a 4x RGBA8 renderbuffer in its place.  Do we now magically transform the single-sampled DEPTH24_STENCIL8 buffer (which the client thinks is multisampled) into a truly multisampled DEPTH24_STENCIL8 buffer?  When do we do the switch?  Do we try to preserve the contents of the depth/stencil buffer when we do the switch?</div>
<div><br></div><div>Things get worse for Gen7, which supports these formats for 4x MSAA but not for 8x MSAA?  Do we substitute in 4x MSAA in the place of 8x MSAA?  If so, then what happens if the client program tries to blit from a 4x depth buffer (which they think is 8x) to a depth buffer that truly is 8x?  The client program would expect that to work, but we can&#39;t do it, because the true sample counts don&#39;t match.</div>
<div><br></div><div>These kinds of questions make me really scared of this alternative.  None of these kinds of questions arose during the period after releasing GL 3.0 when we were deliberately lying to the app, because we were lying uniformly for all renderbuffers.  Also we were deliberately lying as a stopgap solution, so that apps that required GL 3.0 but didn&#39;t require MSAA would be able to run while we were finishing the MSAA implementation.  Deliberately lying as a permanent solution to a hardware limitation seems harder to justify.</div>
<div><br></div><div>Finally, I&#39;m not entirely convinced that my proposed solution goes against the spec.  The part of the spec that lists RGBA32F as a &quot;required&quot; color buffer format is very far away from the part of the spec that specifies how GL_FRAMEBUFFER_UNSUPPORTED is supposed to behave, and you have to follow a lot of cross-references and make some assumptions in order to connect them.  Also, the spec lists RGBA32I and RGBA32UI in the same place as it lists RGBA32F as &quot;required&quot; color buffer formats, but my nVidia system reports GL_FRAMEBUFFER_UNSUPPORTED for those (regardless of whether MSAA is in use), so there is some precedent for reporting GL_FRAMEBUFFER_UNSUPPORTED even on supposedly &quot;required&quot; formats.</div>
<div><br></div><div>Having said all that (and I said a lot more than I expected to), I&#39;m still trying to keep an open mind.  One thing that would change my mind pretty quick, for example, would be if we knew about a popular OpenGL app that assumed it could do MSAA rendering using an RGBA32F buffer, and didn&#39;t have a fallback available in case the framebuffer was incomplete :)</div>
<div><br></div><div>Paul</div></div>