| Age | Commit message (Collapse) | Author | 
|---|
|  | Not needs set GL_DEPTH_TEST, Because when rendering to a framebuffer
that has no depth buffer, depth testing always behaves as though
the test is disabled, The initial value for each capability with
the exception of GL_DITHER is GL_FALSE. | 
|  | References: #3386 | 
|  |  | 
|  |  | 
|  | sRGB encoding/decoding needs to happen with straight alpha, not
pre-multiplied alpha. | 
|  | When the backend and renderer would need GBM but it's disabled at
compile-time, log a message to make this situation easier to debug. | 
|  | It can be a bit confusing to debug when the user requests an
explicit renderer but it's disabled at build-time. Log an error
when that happens. | 
|  | This commit only applies to the render pass API. | 
|  | Pixman won't be chosen by default if the system has a valid render node
but gles2 and vulkan creation failed. | 
|  |  | 
|  |  | 
|  |  | 
|  | Fixes: #3697 | 
|  |  | 
|  | Specfically, VUID-vkCmdBlitImage-srcImage-00247. | 
|  | The flags passed to vkCreateImage() must match the flags used when
querying formats. Make this clearer by using the same variable. | 
|  | Ported from wlr_render_rect(). | 
|  | This optimization also fixes an validation error with the Vulkan
renderer by ensuring vkCmdClearAttachments does not receive empty
regions. | 
|  | Only open a render node if we actually need one (ie, if we're about
to attempt GLES2 or Vulkan). | 
|  | We could potentially leak a display here, but not really because the
display acts as a singleton that will be returned next time a renderer
of the same device is created. | 
|  | Display is always NULL here since egl_init is always last to be called. | 
|  | If the compositor were to try to handle a GPU reset within the lost
signal (by recreating the renderer) we should avoid referencing renderer
resources after the lost signal. This prevents use after free for such
compositors. | 
|  |  | 
|  | We can just use a regular assignment instead. This is more
type-safe since there is no need to provide the struct size.
The remaining memcpy() calls perform array copies or copies from
void pointers (which may be unaligned). | 
|  | glslang 12.3.0 renamed glslangValidator to glslang,
use that by default and use the old name as a fallback.
References: https://github.com/KhronosGroup/glslang/blob/main/CHANGES.md?plain=1#L14 | 
|  | With this, errors should be properly wrapped in the debug scope. | 
|  | Let's not allow renderer implementations to mutate the passed in
options. | 
|  | This slightly improves type safety.
The culprits were found with:
    git grep -E '\([a-z0-9_ ]+ \*\)\W?[a-z]' | 
|  | We can just refer to the struct field here. | 
|  | This is a bit more type-safe. | 
|  | ...texture view is dynamically created | 
|  |  | 
|  | Legacy DRM auth will only work if we are DRM master. Keep using an
unauthenticated DRM FD if we are not DRM master. This should be
enough for GBM.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3674 | 
|  |  | 
|  |  | 
|  |  | 
|  | Now that we are dynamically creating pipeline layouts, we need separate
texture views for each pipeline layout we choose to use with a texture. | 
|  |  | 
|  | These will happen lazily when pipelines get created. | 
|  | This will become necessary when we switch away from scissoring. For the
time being, this cleans things up a bit and allows for a trivial
blending implementation for textures when that comes. | 
|  |  | 
|  | If we ever wanted to handle dynamic state that requires new pipelines
such as using different texture filters those can be added here with more
ease. | 
|  | Same motivation as fdb199a43c44 ("render/vulkan: rename
tex_features to shm_tex_features"). | 
|  | Otherwise only the last command's area will be copied over. | 
|  | renderer->render_{width,height} are unused with the render pass
API. | 
|  | renderer->bound_pipe is legacy, pass->bound_pipeline is used for
the render pass API code-path.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3657 | 
|  | We use the format info to check the stride and need it to perform
the texture upload. | 
|  | The logic is the same for both shm and DMA-BUF. | 
|  | Avoids repeating the common bits between dma_tex_features and
dma_tex_ycbcr_features, and we will need just the YCbCr-related
flags for shm YCbCr support soon. | 
|  | These features are required for shm only: the TRANSFER stuff is
for texture upload. We don't need these for DMA-BUFs. Make this
clearer by changing the name.
Also re-order the definitions to group all texture-related features
together. |