mirror of
https://github.com/brl/mutter.git
synced 2024-11-22 08:00:42 -05:00
clutter/frame-info: Add HW_CLOCK flag
A flag indicating whether the presentation timestamp was provided by the display hardware (rather than sampled in user space). It will be used for the presentation-time Wayland protocol. Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1484>
This commit is contained in:
parent
9d54ef3994
commit
9f53b691c4
@ -114,6 +114,13 @@ struct _ClutterPerspective
|
|||||||
gfloat z_far;
|
gfloat z_far;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CLUTTER_FRAME_INFO_FLAG_NONE = 0,
|
||||||
|
/* presentation_time timestamp was provided by the hardware */
|
||||||
|
CLUTTER_FRAME_INFO_FLAG_HW_CLOCK = 1 << 0,
|
||||||
|
} ClutterFrameInfoFlag;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ClutterFrameInfo: (skip)
|
* ClutterFrameInfo: (skip)
|
||||||
*/
|
*/
|
||||||
@ -122,6 +129,8 @@ struct _ClutterFrameInfo
|
|||||||
int64_t frame_counter;
|
int64_t frame_counter;
|
||||||
int64_t presentation_time;
|
int64_t presentation_time;
|
||||||
float refresh_rate;
|
float refresh_rate;
|
||||||
|
|
||||||
|
ClutterFrameInfoFlag flags;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _ClutterCapture
|
typedef struct _ClutterCapture
|
||||||
|
@ -318,6 +318,7 @@ swap_framebuffer (ClutterStageWindow *stage_window,
|
|||||||
.frame_counter = priv->global_frame_counter,
|
.frame_counter = priv->global_frame_counter,
|
||||||
.refresh_rate = clutter_stage_view_get_refresh_rate (view),
|
.refresh_rate = clutter_stage_view_get_refresh_rate (view),
|
||||||
.presentation_time = g_get_monotonic_time (),
|
.presentation_time = g_get_monotonic_time (),
|
||||||
|
.flags = CLUTTER_FRAME_INFO_FLAG_NONE,
|
||||||
};
|
};
|
||||||
priv->global_frame_counter++;
|
priv->global_frame_counter++;
|
||||||
|
|
||||||
@ -825,12 +826,17 @@ frame_cb (CoglOnscreen *onscreen,
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
ClutterFrameInfo clutter_frame_info;
|
ClutterFrameInfo clutter_frame_info;
|
||||||
|
ClutterFrameInfoFlag flags = CLUTTER_FRAME_INFO_FLAG_NONE;
|
||||||
|
|
||||||
|
if (cogl_frame_info_is_hw_clock (frame_info))
|
||||||
|
flags |= CLUTTER_FRAME_INFO_FLAG_HW_CLOCK;
|
||||||
|
|
||||||
clutter_frame_info = (ClutterFrameInfo) {
|
clutter_frame_info = (ClutterFrameInfo) {
|
||||||
.frame_counter = cogl_frame_info_get_global_frame_counter (frame_info),
|
.frame_counter = cogl_frame_info_get_global_frame_counter (frame_info),
|
||||||
.refresh_rate = cogl_frame_info_get_refresh_rate (frame_info),
|
.refresh_rate = cogl_frame_info_get_refresh_rate (frame_info),
|
||||||
.presentation_time =
|
.presentation_time =
|
||||||
ns2us (cogl_frame_info_get_presentation_time (frame_info)),
|
ns2us (cogl_frame_info_get_presentation_time (frame_info)),
|
||||||
|
.flags = flags,
|
||||||
};
|
};
|
||||||
clutter_stage_view_notify_presented (view, &clutter_frame_info);
|
clutter_stage_view_notify_presented (view, &clutter_frame_info);
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ timeline_frame_clock_frame (ClutterFrameClock *frame_clock,
|
|||||||
frame_info = (ClutterFrameInfo) {
|
frame_info = (ClutterFrameInfo) {
|
||||||
.presentation_time = g_get_monotonic_time (),
|
.presentation_time = g_get_monotonic_time (),
|
||||||
.refresh_rate = refresh_rate,
|
.refresh_rate = refresh_rate,
|
||||||
|
.flags = CLUTTER_FRAME_INFO_FLAG_NONE,
|
||||||
};
|
};
|
||||||
clutter_frame_clock_notify_presented (frame_clock, &frame_info);
|
clutter_frame_clock_notify_presented (frame_clock, &frame_info);
|
||||||
clutter_frame_clock_schedule_update (frame_clock);
|
clutter_frame_clock_schedule_update (frame_clock);
|
||||||
|
@ -32,6 +32,7 @@ init_frame_info (ClutterFrameInfo *frame_info,
|
|||||||
*frame_info = (ClutterFrameInfo) {
|
*frame_info = (ClutterFrameInfo) {
|
||||||
.presentation_time = presentation_time_us,
|
.presentation_time = presentation_time_us,
|
||||||
.refresh_rate = refresh_rate,
|
.refresh_rate = refresh_rate,
|
||||||
|
.flags = CLUTTER_FRAME_INFO_FLAG_NONE,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user