Skip to content

Commit 8ce6d5e

Browse files
committed
tools headers uapi: Synchronize drm/drm.h
To pick up the new ioctls added in these csets: 3064abf ("drm: Add CRTC_GET_SEQUENCE and CRTC_QUEUE_SEQUENCE ioctls [v3]") 62884cd ("drm: Add four ioctls for managing drm mode object leases [v7]") That will be automatically decoded (the ioctl cmd parameter, the structs will be supported when we start using eBPF for that, which is in the works). This silences this warning when building tools/perf: Warning: Kernel ABI header at 'tools/include/uapi/drm/drm.h' differs from latest version at 'include/uapi/drm/drm.h' Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Dave Airlie <airlied@redhat.com> Cc: David Ahern <dsahern@gmail.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Keith Packard <keithp@keithp.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Wang Nan <wangnan0@huawei.com> Link: https://lkml.kernel.org/n/tip-bivwf1pkfmi1ugpswbsxd9e9@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
1 parent 0f1aabe commit 8ce6d5e

File tree

1 file changed

+41
-0
lines changed
  • tools/include/uapi/drm

1 file changed

+41
-0
lines changed

tools/include/uapi/drm/drm.h

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -737,6 +737,28 @@ struct drm_syncobj_array {
737737
__u32 pad;
738738
};
739739

740+
/* Query current scanout sequence number */
741+
struct drm_crtc_get_sequence {
742+
__u32 crtc_id; /* requested crtc_id */
743+
__u32 active; /* return: crtc output is active */
744+
__u64 sequence; /* return: most recent vblank sequence */
745+
__s64 sequence_ns; /* return: most recent time of first pixel out */
746+
};
747+
748+
/* Queue event to be delivered at specified sequence. Time stamp marks
749+
* when the first pixel of the refresh cycle leaves the display engine
750+
* for the display
751+
*/
752+
#define DRM_CRTC_SEQUENCE_RELATIVE 0x00000001 /* sequence is relative to current */
753+
#define DRM_CRTC_SEQUENCE_NEXT_ON_MISS 0x00000002 /* Use next sequence if we've missed */
754+
755+
struct drm_crtc_queue_sequence {
756+
__u32 crtc_id;
757+
__u32 flags;
758+
__u64 sequence; /* on input, target sequence. on output, actual sequence */
759+
__u64 user_data; /* user data passed to event */
760+
};
761+
740762
#if defined(__cplusplus)
741763
}
742764
#endif
@@ -819,6 +841,9 @@ extern "C" {
819841

820842
#define DRM_IOCTL_WAIT_VBLANK DRM_IOWR(0x3a, union drm_wait_vblank)
821843

844+
#define DRM_IOCTL_CRTC_GET_SEQUENCE DRM_IOWR(0x3b, struct drm_crtc_get_sequence)
845+
#define DRM_IOCTL_CRTC_QUEUE_SEQUENCE DRM_IOWR(0x3c, struct drm_crtc_queue_sequence)
846+
822847
#define DRM_IOCTL_UPDATE_DRAW DRM_IOW(0x3f, struct drm_update_draw)
823848

824849
#define DRM_IOCTL_MODE_GETRESOURCES DRM_IOWR(0xA0, struct drm_mode_card_res)
@@ -863,6 +888,11 @@ extern "C" {
863888
#define DRM_IOCTL_SYNCOBJ_RESET DRM_IOWR(0xC4, struct drm_syncobj_array)
864889
#define DRM_IOCTL_SYNCOBJ_SIGNAL DRM_IOWR(0xC5, struct drm_syncobj_array)
865890

891+
#define DRM_IOCTL_MODE_CREATE_LEASE DRM_IOWR(0xC6, struct drm_mode_create_lease)
892+
#define DRM_IOCTL_MODE_LIST_LESSEES DRM_IOWR(0xC7, struct drm_mode_list_lessees)
893+
#define DRM_IOCTL_MODE_GET_LEASE DRM_IOWR(0xC8, struct drm_mode_get_lease)
894+
#define DRM_IOCTL_MODE_REVOKE_LEASE DRM_IOWR(0xC9, struct drm_mode_revoke_lease)
895+
866896
/**
867897
* Device specific ioctls should only be in their respective headers
868898
* The device specific ioctl range is from 0x40 to 0x9f.
@@ -893,6 +923,7 @@ struct drm_event {
893923

894924
#define DRM_EVENT_VBLANK 0x01
895925
#define DRM_EVENT_FLIP_COMPLETE 0x02
926+
#define DRM_EVENT_CRTC_SEQUENCE 0x03
896927

897928
struct drm_event_vblank {
898929
struct drm_event base;
@@ -903,6 +934,16 @@ struct drm_event_vblank {
903934
__u32 crtc_id; /* 0 on older kernels that do not support this */
904935
};
905936

937+
/* Event delivered at sequence. Time stamp marks when the first pixel
938+
* of the refresh cycle leaves the display engine for the display
939+
*/
940+
struct drm_event_crtc_sequence {
941+
struct drm_event base;
942+
__u64 user_data;
943+
__s64 time_ns;
944+
__u64 sequence;
945+
};
946+
906947
/* typedef area */
907948
#ifndef __KERNEL__
908949
typedef struct drm_clip_rect drm_clip_rect_t;

0 commit comments

Comments
 (0)