[PATCH v9 0/4] drm: Add support for atomic async page-flip
Hamza Mahfooz
hamza.mahfooz at amd.com
Wed Nov 22 20:23:46 UTC 2023
Hi André,
On 11/22/23 11:19, André Almeida wrote:
> Hi,
>
> This work from me and Simon adds support for DRM_MODE_PAGE_FLIP_ASYNC through
> the atomic API. This feature is already available via the legacy API. The use
> case is to be able to present a new frame immediately (or as soon as
> possible), even if after missing a vblank. This might result in tearing, but
> it's useful when a high framerate is desired, such as for gaming.
>
> Differently from earlier versions, this one refuses to flip if any prop changes
> for async flips. The idea is that the fast path of immediate page flips doesn't
> play well with modeset changes, so only the fb_id can be changed.
>
> Tested with:
> - Intel TigerLake-LP GT2
> - AMD VanGogh
Have you had a chance to test this with VRR enabled? Since, I suspect
this series might break that feature.
>
> Thanks,
> André
>
> - User-space patch: https://github.com/Plagman/gamescope/pull/595
> - IGT tests: https://lore.kernel.org/all/20231110163811.24158-1-andrealmeid@igalia.com/
>
> Changes from v8:
> - Dropped atomic_async_page_flip_not_supported, giving that current design works
> with any driver that support atomic and async at the same time.
> - Dropped the patch that disabled atomic_async_page_flip_not_supported for AMD.
> - Reordered commits
> v8: https://lore.kernel.org/all/20231025005318.293690-1-andrealmeid@igalia.com/
>
> Changes from v7:
> - Only accept flips to primary planes. If a driver support flips in different
> planes, support will be added later.
> v7: https://lore.kernel.org/dri-devel/20231017092837.32428-1-andrealmeid@igalia.com/
>
> Changes from v6:
> - Dropped the exception to allow MODE_ID changes (Simon)
> - Clarify what happens when flipping with the same FB_ID (Pekka)
>
> v6: https://lore.kernel.org/dri-devel/20230815185710.159779-1-andrealmeid@igalia.com/
>
> Changes from v5:
> - Add note in the docs that not every redundant attribute will result in no-op,
> some might cause oversynchronization issues.
>
> v5: https://lore.kernel.org/dri-devel/20230707224059.305474-1-andrealmeid@igalia.com/
>
> Changes from v4:
> - Documentation rewrote by Pekka Paalanen
>
> v4: https://lore.kernel.org/dri-devel/20230701020917.143394-1-andrealmeid@igalia.com/
>
> Changes from v3:
> - Add new patch to reject prop changes
> - Add a documentation clarifying the KMS atomic state set
>
> v3: https://lore.kernel.org/dri-devel/20220929184307.258331-1-contact@emersion.fr/
>
> André Almeida (1):
> drm: Refuse to async flip with atomic prop changes
>
> Pekka Paalanen (1):
> drm/doc: Define KMS atomic state set
>
> Simon Ser (2):
> drm: allow DRM_MODE_PAGE_FLIP_ASYNC for atomic commits
> drm: introduce DRM_CAP_ATOMIC_ASYNC_PAGE_FLIP
>
> Documentation/gpu/drm-uapi.rst | 47 ++++++++++++++++++
> drivers/gpu/drm/drm_atomic_uapi.c | 77 ++++++++++++++++++++++++++---
> drivers/gpu/drm/drm_crtc_internal.h | 2 +-
> drivers/gpu/drm/drm_ioctl.c | 4 ++
> drivers/gpu/drm/drm_mode_object.c | 2 +-
> include/uapi/drm/drm.h | 10 +++-
> include/uapi/drm/drm_mode.h | 9 ++++
> 7 files changed, 142 insertions(+), 9 deletions(-)
>
--
Hamza
More information about the dri-devel
mailing list