mirror of
https://github.com/brl/mutter.git
synced 2025-01-09 19:22:22 +00:00
3e4a330ae7
Calculate the frame deadline in ClutterFrameClock's calculate_next_update_time_us() rather than in MetaWaylandCompositor's on_after_update(). The specifics of the deadline calculation for a given frame should be implementation detail of the frame clock and and remain internal to allow extensibility. This extensibility is specifically useful for scenarios where a different deadline calculation is needed due to alternative frame scheduling logic, such as for VRR. No change in behavior. Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3521>
116 lines
2.6 KiB
C
116 lines
2.6 KiB
C
/*
|
|
* Copyright (C) 2020 Red Hat Inc.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "clutter/clutter-frame-private.h"
|
|
|
|
G_DEFINE_BOXED_TYPE (ClutterFrame, clutter_frame,
|
|
clutter_frame_ref,
|
|
clutter_frame_unref)
|
|
|
|
ClutterFrame *
|
|
clutter_frame_ref (ClutterFrame *frame)
|
|
{
|
|
g_ref_count_inc (&frame->ref_count);
|
|
return frame;
|
|
}
|
|
|
|
void
|
|
clutter_frame_unref (ClutterFrame *frame)
|
|
{
|
|
if (g_ref_count_dec (&frame->ref_count))
|
|
{
|
|
if (frame->release)
|
|
frame->release (frame);
|
|
g_free (frame);
|
|
}
|
|
}
|
|
|
|
gpointer
|
|
(clutter_frame_new) (size_t size,
|
|
ClutterFrameRelease release)
|
|
{
|
|
ClutterFrame *frame;
|
|
|
|
g_assert (size >= sizeof (ClutterFrame));
|
|
|
|
frame = g_malloc0 (size);
|
|
g_ref_count_init (&frame->ref_count);
|
|
frame->release = release;
|
|
|
|
return frame;
|
|
}
|
|
|
|
int64_t
|
|
clutter_frame_get_count (ClutterFrame *frame)
|
|
{
|
|
return frame->frame_count;
|
|
}
|
|
|
|
gboolean
|
|
clutter_frame_get_target_presentation_time (ClutterFrame *frame,
|
|
int64_t *target_presentation_time_us)
|
|
{
|
|
if (frame->has_target_presentation_time)
|
|
{
|
|
*target_presentation_time_us = frame->target_presentation_time_us;
|
|
return TRUE;
|
|
}
|
|
else
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
gboolean
|
|
clutter_frame_get_frame_deadline (ClutterFrame *frame,
|
|
int64_t *frame_deadline_us)
|
|
{
|
|
if (frame->has_frame_deadline)
|
|
{
|
|
*frame_deadline_us = frame->frame_deadline_us;
|
|
return TRUE;
|
|
}
|
|
else
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
ClutterFrameResult
|
|
clutter_frame_get_result (ClutterFrame *frame)
|
|
{
|
|
g_return_val_if_fail (frame->has_result, CLUTTER_FRAME_RESULT_IDLE);
|
|
|
|
return frame->result;
|
|
}
|
|
|
|
gboolean
|
|
clutter_frame_has_result (ClutterFrame *frame)
|
|
{
|
|
return frame->has_result;
|
|
}
|
|
|
|
void
|
|
clutter_frame_set_result (ClutterFrame *frame,
|
|
ClutterFrameResult result)
|
|
{
|
|
g_warn_if_fail (!frame->has_result);
|
|
|
|
frame->result = result;
|
|
frame->has_result = TRUE;
|
|
}
|