| Age | Commit message (Collapse) | Author | 
|---|
|  | Atomic doesn't support such flags yet. | 
|  |  | 
|  | Since e5fc8cd4c734 ("output: trigger frame/present events on all
commits on enabled output"), any commit on an enabled output is
supposed to trigger frame/present events.
The DRM backend was skipping the commit completely for no-op
commits. Stop doing so.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3719 | 
|  | Up until now, frame/present events were only triggered when the
user submitted a buffer. Change the wlr_output API so that these
events are triggered when any commit is applied on an enabled
output.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3708 | 
|  |  | 
|  | https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3664#note_2020392
we're gonna have to trust Simon on this one 🤞 | 
|  | frame_delay was set to 0.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3712 | 
|  | We were assuming a roundtrip was enough to get an
xdg_surface.configure event. That's not the case, the protocol
spec doesn't make such a guarantee. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | By using this function, a compositor can display a wlroots
compositor in a sub-surface, for instance. | 
|  | When integrating wlroots with another toolkit, wlroots may receive
wl_pointer.enter events for surfaces not backed by a wlr_output.
Ignore such surfaces by tagging the ones we're aware of with
wl_proxy_set_tag(). | 
|  | This allows compositors to use an existing wl_display, to integrate
wlroots with an existing toolkit. | 
|  | We were only restoring fixed modes here. The DRM backend no longer
creates fixed modes when the compositor sets a custom mode, so we
need to handle this situation when restoring.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3698 | 
|  |  | 
|  |  | 
|  | wlr_client_buffer is a bad indicator for direct scan-out.
Compositors might use the underlying wlr_buffer instead. | 
|  | This slightly improves type safety.
The culprits were found with:
    git grep -E '\([a-z0-9_ ]+ \*\)\W?[a-z]' | 
|  | This is a bit more type-safe. | 
|  | This fixes an issue where the panel_orientation parameter was set but wlroots was ignoring it and
returning OUTPUT_TRANSFORM_NORMAL.
Fixes 2e12de96 | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Leave it up to the compositor to enable new outputs (just like the
DRM backend does). | 
|  | We have nothing to do when a headless output is enabled/disabled. | 
|  | A no-op commit should not schedule a new frame. This aligns the
headless backend with the rest of the backends.
This will be important to handle the enabled → disabled transition. | 
|  |  | 
|  |  | 
|  | Removes duplication across all the backends to finally apply the mode
to the output. | 
|  |  | 
|  |  | 
|  | Nobody remembers why this is done and it isn't that great if people
use a lot of custom modes. | 
|  | wlr_output_update_needs_frame() is called unconditionally at the
end of the function already. | 
|  | This changes the semantics of wlr_output_state. Instead of having
fields with uninitialized memory when missing from the committed
bitflag, all fields are always initialized (and maybe NULL/empty),
just like we do in wlr_surface_state. This reduces the chances of
footguns when reading a field, and removes the need to check for
the committed bitfield everywhere.
A new wlr_output_state_init() function takes care of initializing
the Pixman region. | 
|  | Destroying the liftoff_device invalidates all of the liftoff_planes.
Destroy the liftoff_planes before the liftoff_device to fix this. | 
|  |  | 
|  |  | 
|  | This is more readable and consistent with the rest of wlroots. | 
|  | If the same button is pressed on two devices on the same seat,
ignore the second event.
This is also what Mutter does.
Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3665 | 
|  | The kernel complains when the damage exceeds the FB bounds:
    [73850.448326] i915 0000:00:02.0: [drm:drm_atomic_check_only] [PLANE:31:plane 1A] invalid damage clip 0 0 2147483647 2147483647
Make the DRM backend behave like the Wayland one and allow compositors
to damage (0, 0, INT32_MAX, INT32_MAX) to repaint everything without
needing to know the exact buffer size.
Closes: https://github.com/swaywm/sway/issues/7632 | 
|  | Based on five calls:
wlr_render_timer_create - creates a timer which can be reused across
  frames on the same renderer
wlr_renderer_begin_buffer_pass - now takes a timer so that backends can
  record when the rendering starts and finishes
wlr_render_timer_get_time - should be called as late as possible so that
  queries can make their way back from the GPU
wlr_render_timer_destroy - self-explanatory
The timer is exposed as an opaque `struct wlr_render_timer` so that
backends can store whatever they want in there. | 
|  |  | 
|  | Use the viewporter protocol to scale output layers. | 
|  | This allows compositors to get back the raw drmModeModeInfo and
look at DRM-specific fields and flags. | 
|  |  |