<html>
    <head>
      <base href="https://bugs.freedesktop.org/">
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Buffer corruption with Chromium on gnome-shell (wayland) after taking a screenshot"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=111140#c14">Comment # 14</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Buffer corruption with Chromium on gnome-shell (wayland) after taking a screenshot"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=111140">bug 111140</a>
              from <span class="vcard"><a class="email" href="mailto:lionel.g.landwerlin@linux.intel.com" title="Lionel Landwerlin <lionel.g.landwerlin@linux.intel.com>"> <span class="fn">Lionel Landwerlin</span></a>
</span></b>
        <pre>(In reply to Jonas Ã…dahl from <a href="show_bug.cgi?id=111140#c9">comment #9</a>)
<span class="quote">> (In reply to Lionel Landwerlin from <a href="show_bug.cgi?id=111140#c8">comment #8</a>)
> > So looking at the way mutter bind the dmabuf shared with chromium to a 2D
> > texture, it does so through cogl_egl_texture_2d_new_from_image().
> > That function seems to rely on GL_OES_EGL_image_external extension :
> > <a href="https://www.khronos.org/registry/EGL/extensions/EXT/">https://www.khronos.org/registry/EGL/extensions/EXT/</a>
> > EGL_EXT_image_dma_buf_import.txt
> > 
> > The extension has this bit in the spec :
> > 
> > 
> >     There is no support for most of the functions that manipulate
> >     other texture targets (e.g. you cannot use gl*Tex*Image*() functions with
> >     TEXTURE_EXTERNAL_OES).</span >

Duh! I pointed to the wrong spec...
Here is the good one :
<a href="https://www.khronos.org/registry/OpenGL/extensions/OES/OES_EGL_image_external.txt">https://www.khronos.org/registry/OpenGL/extensions/OES/OES_EGL_image_external.txt</a>

<span class="quote">> > 
> > That makes me think what mutter is doing is illegal.

> Does gl*Tex*Image() here imply glGetTexImage() too then you mean? Does
> reading from it mean "manipulate"?</span >

My reading of manipulate goes for both read/write operations.
Essentially anything that could alter the metadata associated with the texture
(size, format and those hidden compression settings).

I agree that the spec is a bit vague on this point and I'm not 100% sure what
was the intent.
I could image we could allow glGet*Image* in the driver but that would
essentially be replicating what you would otherwise do in the application (e.g.
blit to an offscreen buffer and read that one back).

The problem is that the driver does a bunch of tracking on what you do with the
texture and puts it in the most sensible disposition for what it's used.
Once that goes out of sync with what the other processes have, we're in
trouble.

<span class="quote">> 
> Either way, I created
> <a href="https://gitlab.gnome.org/GNOME/mutter/merge_requests/687">https://gitlab.gnome.org/GNOME/mutter/merge_requests/687</a> that should avoid
> reading directly from it. It didn't reproduce with or without it, so if
> anyone that can reproduce it can give it a test I'd appreciate it.</span >

That fixes the problem on my side too. Thanks!</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 the assignee for the bug.</li>
      </ul>
    </body>
</html>