kms/update: Make explicit page flip just listeners
Page flipping shouldn't necessarily be an actively requested action, but happen implicitly depending on the given state. Thus, change the "page flip" update into adding listeners for page flip feedback instead. Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1488>
This commit is contained in:
parent
0acae7f3c1
commit
5c7e2bfe22
8 changed files with 195 additions and 70 deletions
|
@ -633,7 +633,6 @@ mode_set_fallback_feedback_idle (gpointer user_data)
|
||||||
static gboolean
|
static gboolean
|
||||||
mode_set_fallback (MetaKmsImplDeviceSimple *impl_device_simple,
|
mode_set_fallback (MetaKmsImplDeviceSimple *impl_device_simple,
|
||||||
MetaKmsUpdate *update,
|
MetaKmsUpdate *update,
|
||||||
MetaKmsPageFlip *page_flip,
|
|
||||||
MetaKmsPlaneAssignment *plane_assignment,
|
MetaKmsPlaneAssignment *plane_assignment,
|
||||||
MetaKmsPageFlipData *page_flip_data,
|
MetaKmsPageFlipData *page_flip_data,
|
||||||
GError **error)
|
GError **error)
|
||||||
|
@ -641,7 +640,7 @@ mode_set_fallback (MetaKmsImplDeviceSimple *impl_device_simple,
|
||||||
MetaKmsImplDevice *impl_device = META_KMS_IMPL_DEVICE (impl_device_simple);
|
MetaKmsImplDevice *impl_device = META_KMS_IMPL_DEVICE (impl_device_simple);
|
||||||
MetaKmsDevice *device = meta_kms_impl_device_get_device (impl_device);
|
MetaKmsDevice *device = meta_kms_impl_device_get_device (impl_device);
|
||||||
MetaKms *kms = meta_kms_device_get_kms (device);
|
MetaKms *kms = meta_kms_device_get_kms (device);
|
||||||
MetaKmsCrtc *crtc = page_flip->crtc;
|
MetaKmsCrtc *crtc = meta_kms_page_flip_data_get_crtc (page_flip_data);
|
||||||
CachedModeSet *cached_mode_set;
|
CachedModeSet *cached_mode_set;
|
||||||
g_autofree uint32_t *connectors = NULL;
|
g_autofree uint32_t *connectors = NULL;
|
||||||
int n_connectors;
|
int n_connectors;
|
||||||
|
@ -704,31 +703,24 @@ mode_set_fallback (MetaKmsImplDeviceSimple *impl_device_simple,
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
process_page_flip (MetaKmsImplDevice *impl_device,
|
dispatch_page_flip (MetaKmsImplDevice *impl_device,
|
||||||
MetaKmsUpdate *update,
|
MetaKmsUpdate *update,
|
||||||
gpointer update_entry,
|
MetaKmsPageFlipData *page_flip_data,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
MetaKmsImplDeviceSimple *impl_device_simple =
|
MetaKmsImplDeviceSimple *impl_device_simple =
|
||||||
META_KMS_IMPL_DEVICE_SIMPLE (impl_device);
|
META_KMS_IMPL_DEVICE_SIMPLE (impl_device);
|
||||||
MetaKmsPageFlip *page_flip = update_entry;
|
|
||||||
MetaKmsCrtc *crtc;
|
MetaKmsCrtc *crtc;
|
||||||
MetaKmsPlaneAssignment *plane_assignment;
|
MetaKmsPlaneAssignment *plane_assignment;
|
||||||
MetaKmsPageFlipData *page_flip_data;
|
|
||||||
MetaKmsCustomPageFlipFunc custom_page_flip_func;
|
MetaKmsCustomPageFlipFunc custom_page_flip_func;
|
||||||
gpointer custom_page_flip_user_data;
|
gpointer custom_page_flip_user_data;
|
||||||
int fd;
|
int fd;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
crtc = page_flip->crtc;
|
crtc = meta_kms_page_flip_data_get_crtc (page_flip_data);
|
||||||
plane_assignment = meta_kms_update_get_primary_plane_assignment (update,
|
plane_assignment = meta_kms_update_get_primary_plane_assignment (update,
|
||||||
crtc);
|
crtc);
|
||||||
|
|
||||||
page_flip_data = meta_kms_page_flip_data_new (impl_device,
|
|
||||||
crtc,
|
|
||||||
page_flip->feedback,
|
|
||||||
page_flip->user_data);
|
|
||||||
|
|
||||||
fd = meta_kms_impl_device_get_fd (impl_device);
|
fd = meta_kms_impl_device_get_fd (impl_device);
|
||||||
meta_kms_update_get_custom_page_flip_func (update,
|
meta_kms_update_get_custom_page_flip_func (update,
|
||||||
&custom_page_flip_func,
|
&custom_page_flip_func,
|
||||||
|
@ -791,7 +783,6 @@ process_page_flip (MetaKmsImplDevice *impl_device,
|
||||||
{
|
{
|
||||||
if (!mode_set_fallback (impl_device_simple,
|
if (!mode_set_fallback (impl_device_simple,
|
||||||
update,
|
update,
|
||||||
page_flip,
|
|
||||||
plane_assignment,
|
plane_assignment,
|
||||||
page_flip_data,
|
page_flip_data,
|
||||||
error))
|
error))
|
||||||
|
@ -814,6 +805,95 @@ process_page_flip (MetaKmsImplDevice *impl_device,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GList *
|
||||||
|
generate_page_flip_datas (MetaKmsImplDevice *impl_device,
|
||||||
|
MetaKmsUpdate *update)
|
||||||
|
{
|
||||||
|
GList *listeners;
|
||||||
|
GList *page_flip_datas = NULL;
|
||||||
|
|
||||||
|
listeners = g_list_copy (meta_kms_update_get_page_flip_listeners (update));
|
||||||
|
|
||||||
|
while (listeners)
|
||||||
|
{
|
||||||
|
MetaKmsPageFlipListener *listener = listeners->data;
|
||||||
|
MetaKmsCrtc *crtc = listener->crtc;
|
||||||
|
MetaKmsPageFlipData *page_flip_data;
|
||||||
|
GList *l;
|
||||||
|
|
||||||
|
page_flip_data = meta_kms_page_flip_data_new (impl_device, crtc);
|
||||||
|
page_flip_datas = g_list_append (page_flip_datas, page_flip_data);
|
||||||
|
|
||||||
|
meta_kms_page_flip_data_add_listener (page_flip_data,
|
||||||
|
listener->vtable,
|
||||||
|
listener->user_data);
|
||||||
|
|
||||||
|
listeners = g_list_delete_link (listeners, listeners);
|
||||||
|
|
||||||
|
l = listeners;
|
||||||
|
while (l)
|
||||||
|
{
|
||||||
|
MetaKmsPageFlipListener *other_listener = l->data;
|
||||||
|
GList *l_next = l->next;
|
||||||
|
|
||||||
|
if (other_listener->crtc == crtc)
|
||||||
|
{
|
||||||
|
meta_kms_page_flip_data_add_listener (page_flip_data,
|
||||||
|
other_listener->vtable,
|
||||||
|
other_listener->user_data);
|
||||||
|
listeners = g_list_delete_link (listeners, l);
|
||||||
|
}
|
||||||
|
|
||||||
|
l = l_next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return page_flip_datas;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
maybe_dispatch_page_flips (MetaKmsImplDevice *impl_device,
|
||||||
|
MetaKmsUpdate *update,
|
||||||
|
GList **failed_planes,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
g_autoptr (GList) page_flip_datas = NULL;
|
||||||
|
GList *l;
|
||||||
|
|
||||||
|
page_flip_datas = generate_page_flip_datas (impl_device, update);
|
||||||
|
|
||||||
|
for (l = page_flip_datas; l; l = l->next)
|
||||||
|
{
|
||||||
|
MetaKmsPageFlipData *page_flip_data = l->data;
|
||||||
|
|
||||||
|
if (!dispatch_page_flip (impl_device, update, page_flip_data, error))
|
||||||
|
{
|
||||||
|
if (!g_error_matches (*error,
|
||||||
|
G_IO_ERROR,
|
||||||
|
G_IO_ERROR_PERMISSION_DENIED))
|
||||||
|
{
|
||||||
|
MetaKmsCrtc *crtc =
|
||||||
|
meta_kms_page_flip_data_get_crtc (page_flip_data);
|
||||||
|
MetaKmsPlaneAssignment *plane_assignment;
|
||||||
|
MetaKmsPlaneFeedback *plane_feedback;
|
||||||
|
|
||||||
|
plane_assignment =
|
||||||
|
meta_kms_update_get_primary_plane_assignment (update, crtc);
|
||||||
|
|
||||||
|
plane_feedback =
|
||||||
|
meta_kms_plane_feedback_new_take_error (plane_assignment->plane,
|
||||||
|
plane_assignment->crtc,
|
||||||
|
g_error_copy (*error));
|
||||||
|
*failed_planes = g_list_prepend (*failed_planes, plane_feedback);
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
process_entries (MetaKmsImplDevice *impl_device,
|
process_entries (MetaKmsImplDevice *impl_device,
|
||||||
MetaKmsUpdate *update,
|
MetaKmsUpdate *update,
|
||||||
|
@ -1023,11 +1103,7 @@ meta_kms_impl_device_simple_process_update (MetaKmsImplDevice *impl_device,
|
||||||
if (!process_plane_assignments (impl_device, update, &failed_planes, &error))
|
if (!process_plane_assignments (impl_device, update, &failed_planes, &error))
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if (!process_entries (impl_device,
|
if (!maybe_dispatch_page_flips (impl_device, update, &failed_planes, &error))
|
||||||
update,
|
|
||||||
meta_kms_update_get_page_flips (update),
|
|
||||||
process_page_flip,
|
|
||||||
&error))
|
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
return meta_kms_feedback_new_passed (failed_planes);
|
return meta_kms_feedback_new_passed (failed_planes);
|
||||||
|
|
|
@ -29,16 +29,20 @@ typedef struct _MetaKmsPageFlipData MetaKmsPageFlipData;
|
||||||
typedef void (* MetaPageFlipDataFeedbackFunc) (MetaKmsPageFlipData *page_flip_data);
|
typedef void (* MetaPageFlipDataFeedbackFunc) (MetaKmsPageFlipData *page_flip_data);
|
||||||
|
|
||||||
MetaKmsPageFlipData * meta_kms_page_flip_data_new (MetaKmsImplDevice *impl_device,
|
MetaKmsPageFlipData * meta_kms_page_flip_data_new (MetaKmsImplDevice *impl_device,
|
||||||
MetaKmsCrtc *crtc,
|
MetaKmsCrtc *crtc);
|
||||||
const MetaKmsPageFlipFeedback *feedback,
|
|
||||||
gpointer user_data);
|
|
||||||
|
|
||||||
MetaKmsPageFlipData * meta_kms_page_flip_data_ref (MetaKmsPageFlipData *page_flip_data);
|
MetaKmsPageFlipData * meta_kms_page_flip_data_ref (MetaKmsPageFlipData *page_flip_data);
|
||||||
|
|
||||||
void meta_kms_page_flip_data_unref (MetaKmsPageFlipData *page_flip_data);
|
void meta_kms_page_flip_data_unref (MetaKmsPageFlipData *page_flip_data);
|
||||||
|
|
||||||
|
void meta_kms_page_flip_data_add_listener (MetaKmsPageFlipData *page_flip_data,
|
||||||
|
const MetaKmsPageFlipListenerVtable *vtable,
|
||||||
|
gpointer user_data);
|
||||||
|
|
||||||
MetaKmsImplDevice * meta_kms_page_flip_data_get_impl_device (MetaKmsPageFlipData *page_flip_data);
|
MetaKmsImplDevice * meta_kms_page_flip_data_get_impl_device (MetaKmsPageFlipData *page_flip_data);
|
||||||
|
|
||||||
|
MetaKmsCrtc * meta_kms_page_flip_data_get_crtc (MetaKmsPageFlipData *page_flip_data);
|
||||||
|
|
||||||
void meta_kms_page_flip_data_set_timings_in_impl (MetaKmsPageFlipData *page_flip_data,
|
void meta_kms_page_flip_data_set_timings_in_impl (MetaKmsPageFlipData *page_flip_data,
|
||||||
unsigned int sequence,
|
unsigned int sequence,
|
||||||
unsigned int sec,
|
unsigned int sec,
|
||||||
|
|
|
@ -25,6 +25,12 @@
|
||||||
#include "backends/native/meta-kms-private.h"
|
#include "backends/native/meta-kms-private.h"
|
||||||
#include "backends/native/meta-kms-update.h"
|
#include "backends/native/meta-kms-update.h"
|
||||||
|
|
||||||
|
typedef struct _MetaKmsPageFlipClosure
|
||||||
|
{
|
||||||
|
const MetaKmsPageFlipListenerVtable *vtable;
|
||||||
|
gpointer user_data;
|
||||||
|
} MetaKmsPageFlipClosure;
|
||||||
|
|
||||||
struct _MetaKmsPageFlipData
|
struct _MetaKmsPageFlipData
|
||||||
{
|
{
|
||||||
int ref_count;
|
int ref_count;
|
||||||
|
@ -32,8 +38,7 @@ struct _MetaKmsPageFlipData
|
||||||
MetaKmsImplDevice *impl_device;
|
MetaKmsImplDevice *impl_device;
|
||||||
MetaKmsCrtc *crtc;
|
MetaKmsCrtc *crtc;
|
||||||
|
|
||||||
const MetaKmsPageFlipFeedback *feedback;
|
GList *closures;
|
||||||
gpointer user_data;
|
|
||||||
|
|
||||||
unsigned int sequence;
|
unsigned int sequence;
|
||||||
unsigned int sec;
|
unsigned int sec;
|
||||||
|
@ -44,9 +49,7 @@ struct _MetaKmsPageFlipData
|
||||||
|
|
||||||
MetaKmsPageFlipData *
|
MetaKmsPageFlipData *
|
||||||
meta_kms_page_flip_data_new (MetaKmsImplDevice *impl_device,
|
meta_kms_page_flip_data_new (MetaKmsImplDevice *impl_device,
|
||||||
MetaKmsCrtc *crtc,
|
MetaKmsCrtc *crtc)
|
||||||
const MetaKmsPageFlipFeedback *feedback,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
{
|
||||||
MetaKmsPageFlipData *page_flip_data;
|
MetaKmsPageFlipData *page_flip_data;
|
||||||
|
|
||||||
|
@ -55,8 +58,6 @@ meta_kms_page_flip_data_new (MetaKmsImplDevice *impl_device,
|
||||||
.ref_count = 1,
|
.ref_count = 1,
|
||||||
.impl_device = impl_device,
|
.impl_device = impl_device,
|
||||||
.crtc = crtc,
|
.crtc = crtc,
|
||||||
.feedback = feedback,
|
|
||||||
.user_data = user_data,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return page_flip_data;
|
return page_flip_data;
|
||||||
|
@ -77,30 +78,59 @@ meta_kms_page_flip_data_unref (MetaKmsPageFlipData *page_flip_data)
|
||||||
|
|
||||||
if (page_flip_data->ref_count == 0)
|
if (page_flip_data->ref_count == 0)
|
||||||
{
|
{
|
||||||
|
g_list_free_full (page_flip_data->closures, g_free);
|
||||||
g_clear_error (&page_flip_data->error);
|
g_clear_error (&page_flip_data->error);
|
||||||
g_free (page_flip_data);
|
g_free (page_flip_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_kms_page_flip_data_add_listener (MetaKmsPageFlipData *page_flip_data,
|
||||||
|
const MetaKmsPageFlipListenerVtable *vtable,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
MetaKmsPageFlipClosure *closure;
|
||||||
|
|
||||||
|
closure = g_new0 (MetaKmsPageFlipClosure, 1);
|
||||||
|
*closure = (MetaKmsPageFlipClosure) {
|
||||||
|
.vtable = vtable,
|
||||||
|
.user_data = user_data,
|
||||||
|
};
|
||||||
|
|
||||||
|
page_flip_data->closures = g_list_append (page_flip_data->closures, closure);
|
||||||
|
}
|
||||||
|
|
||||||
MetaKmsImplDevice *
|
MetaKmsImplDevice *
|
||||||
meta_kms_page_flip_data_get_impl_device (MetaKmsPageFlipData *page_flip_data)
|
meta_kms_page_flip_data_get_impl_device (MetaKmsPageFlipData *page_flip_data)
|
||||||
{
|
{
|
||||||
return page_flip_data->impl_device;
|
return page_flip_data->impl_device;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MetaKmsCrtc *
|
||||||
|
meta_kms_page_flip_data_get_crtc (MetaKmsPageFlipData *page_flip_data)
|
||||||
|
{
|
||||||
|
return page_flip_data->crtc;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_kms_page_flip_data_flipped (MetaKms *kms,
|
meta_kms_page_flip_data_flipped (MetaKms *kms,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
MetaKmsPageFlipData *page_flip_data = user_data;
|
MetaKmsPageFlipData *page_flip_data = user_data;
|
||||||
|
GList *l;
|
||||||
|
|
||||||
meta_assert_not_in_kms_impl (kms);
|
meta_assert_not_in_kms_impl (kms);
|
||||||
|
|
||||||
page_flip_data->feedback->flipped (page_flip_data->crtc,
|
for (l = page_flip_data->closures; l; l = l->next)
|
||||||
|
{
|
||||||
|
MetaKmsPageFlipClosure *closure = l->data;
|
||||||
|
|
||||||
|
closure->vtable->flipped (page_flip_data->crtc,
|
||||||
page_flip_data->sequence,
|
page_flip_data->sequence,
|
||||||
page_flip_data->sec,
|
page_flip_data->sec,
|
||||||
page_flip_data->usec,
|
page_flip_data->usec,
|
||||||
page_flip_data->user_data);
|
closure->user_data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static MetaKms *
|
static MetaKms *
|
||||||
|
@ -144,11 +174,17 @@ meta_kms_page_flip_data_mode_set_fallback (MetaKms *kms,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
MetaKmsPageFlipData *page_flip_data = user_data;
|
MetaKmsPageFlipData *page_flip_data = user_data;
|
||||||
|
GList *l;
|
||||||
|
|
||||||
meta_assert_not_in_kms_impl (kms);
|
meta_assert_not_in_kms_impl (kms);
|
||||||
|
|
||||||
page_flip_data->feedback->mode_set_fallback (page_flip_data->crtc,
|
for (l = page_flip_data->closures; l; l = l->next)
|
||||||
page_flip_data->user_data);
|
{
|
||||||
|
MetaKmsPageFlipClosure *closure = l->data;
|
||||||
|
|
||||||
|
closure->vtable->mode_set_fallback (page_flip_data->crtc,
|
||||||
|
closure->user_data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -169,12 +205,18 @@ meta_kms_page_flip_data_discard (MetaKms *kms,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
MetaKmsPageFlipData *page_flip_data = user_data;
|
MetaKmsPageFlipData *page_flip_data = user_data;
|
||||||
|
GList *l;
|
||||||
|
|
||||||
meta_assert_not_in_kms_impl (kms);
|
meta_assert_not_in_kms_impl (kms);
|
||||||
|
|
||||||
page_flip_data->feedback->discarded (page_flip_data->crtc,
|
for (l = page_flip_data->closures; l; l = l->next)
|
||||||
page_flip_data->user_data,
|
{
|
||||||
|
MetaKmsPageFlipClosure *closure = l->data;
|
||||||
|
|
||||||
|
closure->vtable->discarded (page_flip_data->crtc,
|
||||||
|
closure->user_data,
|
||||||
page_flip_data->error);
|
page_flip_data->error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -37,7 +37,7 @@ typedef struct _MetaKmsMode MetaKmsMode;
|
||||||
|
|
||||||
typedef struct _MetaKmsFeedback MetaKmsFeedback;
|
typedef struct _MetaKmsFeedback MetaKmsFeedback;
|
||||||
|
|
||||||
typedef struct _MetaKmsPageFlipFeedback MetaKmsPageFlipFeedback;
|
typedef struct _MetaKmsPageFlipListenerVtable MetaKmsPageFlipListenerVtable;
|
||||||
|
|
||||||
typedef struct _MetaKmsImpl MetaKmsImpl;
|
typedef struct _MetaKmsImpl MetaKmsImpl;
|
||||||
typedef struct _MetaKmsImplDevice MetaKmsImplDevice;
|
typedef struct _MetaKmsImplDevice MetaKmsImplDevice;
|
||||||
|
|
|
@ -86,12 +86,12 @@ typedef struct _MetaKmsCrtcGamma
|
||||||
uint16_t *blue;
|
uint16_t *blue;
|
||||||
} MetaKmsCrtcGamma;
|
} MetaKmsCrtcGamma;
|
||||||
|
|
||||||
typedef struct _MetaKmsPageFlip
|
typedef struct _MetaKmsPageFlipListener
|
||||||
{
|
{
|
||||||
MetaKmsCrtc *crtc;
|
MetaKmsCrtc *crtc;
|
||||||
const MetaKmsPageFlipFeedback *feedback;
|
const MetaKmsPageFlipListenerVtable *vtable;
|
||||||
gpointer user_data;
|
gpointer user_data;
|
||||||
} MetaKmsPageFlip;
|
} MetaKmsPageFlipListener;
|
||||||
|
|
||||||
void meta_kms_plane_feedback_free (MetaKmsPlaneFeedback *plane_feedback);
|
void meta_kms_plane_feedback_free (MetaKmsPlaneFeedback *plane_feedback);
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ GList * meta_kms_update_get_plane_assignments (MetaKmsUpdate *update);
|
||||||
|
|
||||||
GList * meta_kms_update_get_mode_sets (MetaKmsUpdate *update);
|
GList * meta_kms_update_get_mode_sets (MetaKmsUpdate *update);
|
||||||
|
|
||||||
GList * meta_kms_update_get_page_flips (MetaKmsUpdate *update);
|
GList * meta_kms_update_get_page_flip_listeners (MetaKmsUpdate *update);
|
||||||
|
|
||||||
GList * meta_kms_update_get_connector_updates (MetaKmsUpdate *update);
|
GList * meta_kms_update_get_connector_updates (MetaKmsUpdate *update);
|
||||||
|
|
||||||
|
|
|
@ -37,12 +37,13 @@ struct _MetaKmsUpdate
|
||||||
MetaPowerSave power_save;
|
MetaPowerSave power_save;
|
||||||
GList *mode_sets;
|
GList *mode_sets;
|
||||||
GList *plane_assignments;
|
GList *plane_assignments;
|
||||||
GList *page_flips;
|
|
||||||
GList *connector_updates;
|
GList *connector_updates;
|
||||||
GList *crtc_gammas;
|
GList *crtc_gammas;
|
||||||
|
|
||||||
MetaKmsCustomPageFlipFunc custom_page_flip_func;
|
MetaKmsCustomPageFlipFunc custom_page_flip_func;
|
||||||
gpointer custom_page_flip_user_data;
|
gpointer custom_page_flip_user_data;
|
||||||
|
|
||||||
|
GList *page_flip_listeners;
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -326,24 +327,25 @@ meta_kms_update_set_crtc_gamma (MetaKmsUpdate *update,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
meta_kms_update_page_flip (MetaKmsUpdate *update,
|
meta_kms_update_add_page_flip_listener (MetaKmsUpdate *update,
|
||||||
MetaKmsCrtc *crtc,
|
MetaKmsCrtc *crtc,
|
||||||
const MetaKmsPageFlipFeedback *feedback,
|
const MetaKmsPageFlipListenerVtable *vtable,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
MetaKmsPageFlip *page_flip;
|
MetaKmsPageFlipListener *listener;
|
||||||
|
|
||||||
g_assert (!meta_kms_update_is_sealed (update));
|
g_assert (!meta_kms_update_is_sealed (update));
|
||||||
g_assert (meta_kms_crtc_get_device (crtc) == update->device);
|
g_assert (meta_kms_crtc_get_device (crtc) == update->device);
|
||||||
|
|
||||||
page_flip = g_new0 (MetaKmsPageFlip, 1);
|
listener = g_new0 (MetaKmsPageFlipListener, 1);
|
||||||
*page_flip = (MetaKmsPageFlip) {
|
*listener = (MetaKmsPageFlipListener) {
|
||||||
.crtc = crtc,
|
.crtc = crtc,
|
||||||
.feedback = feedback,
|
.vtable = vtable,
|
||||||
.user_data = user_data,
|
.user_data = user_data,
|
||||||
};
|
};
|
||||||
|
|
||||||
update->page_flips = g_list_prepend (update->page_flips, page_flip);
|
update->page_flip_listeners = g_list_prepend (update->page_flip_listeners,
|
||||||
|
listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -407,9 +409,9 @@ meta_kms_update_get_mode_sets (MetaKmsUpdate *update)
|
||||||
}
|
}
|
||||||
|
|
||||||
GList *
|
GList *
|
||||||
meta_kms_update_get_page_flips (MetaKmsUpdate *update)
|
meta_kms_update_get_page_flip_listeners (MetaKmsUpdate *update)
|
||||||
{
|
{
|
||||||
return update->page_flips;
|
return update->page_flip_listeners;
|
||||||
}
|
}
|
||||||
|
|
||||||
GList *
|
GList *
|
||||||
|
@ -469,7 +471,7 @@ meta_kms_update_free (MetaKmsUpdate *update)
|
||||||
(GDestroyNotify) meta_kms_plane_assignment_free);
|
(GDestroyNotify) meta_kms_plane_assignment_free);
|
||||||
g_list_free_full (update->mode_sets,
|
g_list_free_full (update->mode_sets,
|
||||||
(GDestroyNotify) meta_kms_mode_set_free);
|
(GDestroyNotify) meta_kms_mode_set_free);
|
||||||
g_list_free_full (update->page_flips, g_free);
|
g_list_free_full (update->page_flip_listeners, g_free);
|
||||||
g_list_free_full (update->connector_updates, g_free);
|
g_list_free_full (update->connector_updates, g_free);
|
||||||
g_list_free_full (update->crtc_gammas, (GDestroyNotify) meta_kms_crtc_gamma_free);
|
g_list_free_full (update->crtc_gammas, (GDestroyNotify) meta_kms_crtc_gamma_free);
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,7 @@ typedef enum _MetaKmsAssignPlaneFlag
|
||||||
META_KMS_ASSIGN_PLANE_FLAG_ALLOW_FAIL = 1 << 1,
|
META_KMS_ASSIGN_PLANE_FLAG_ALLOW_FAIL = 1 << 1,
|
||||||
} MetaKmsAssignPlaneFlag;
|
} MetaKmsAssignPlaneFlag;
|
||||||
|
|
||||||
struct _MetaKmsPageFlipFeedback
|
struct _MetaKmsPageFlipListenerVtable
|
||||||
{
|
{
|
||||||
void (* flipped) (MetaKmsCrtc *crtc,
|
void (* flipped) (MetaKmsCrtc *crtc,
|
||||||
unsigned int sequence,
|
unsigned int sequence,
|
||||||
|
@ -117,9 +117,9 @@ MetaKmsPlaneAssignment * meta_kms_update_unassign_plane (MetaKmsUpdate *update,
|
||||||
MetaKmsCrtc *crtc,
|
MetaKmsCrtc *crtc,
|
||||||
MetaKmsPlane *plane);
|
MetaKmsPlane *plane);
|
||||||
|
|
||||||
void meta_kms_update_page_flip (MetaKmsUpdate *update,
|
void meta_kms_update_add_page_flip_listener (MetaKmsUpdate *update,
|
||||||
MetaKmsCrtc *crtc,
|
MetaKmsCrtc *crtc,
|
||||||
const MetaKmsPageFlipFeedback *feedback,
|
const MetaKmsPageFlipListenerVtable *vtable,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
void meta_kms_update_set_custom_page_flip (MetaKmsUpdate *update,
|
void meta_kms_update_set_custom_page_flip (MetaKmsUpdate *update,
|
||||||
|
|
|
@ -1160,7 +1160,7 @@ page_flip_feedback_discarded (MetaKmsCrtc *kms_crtc,
|
||||||
g_object_unref (view);
|
g_object_unref (view);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const MetaKmsPageFlipFeedback page_flip_feedback = {
|
static const MetaKmsPageFlipListenerVtable page_flip_listener_vtable = {
|
||||||
.flipped = page_flip_feedback_flipped,
|
.flipped = page_flip_feedback_flipped,
|
||||||
.mode_set_fallback = page_flip_feedback_mode_set_fallback,
|
.mode_set_fallback = page_flip_feedback_mode_set_fallback,
|
||||||
.discarded = page_flip_feedback_discarded,
|
.discarded = page_flip_feedback_discarded,
|
||||||
|
@ -1259,6 +1259,7 @@ meta_onscreen_native_flip_crtc (CoglOnscreen *onscreen,
|
||||||
MetaRendererNative *renderer_native = onscreen_native->renderer_native;
|
MetaRendererNative *renderer_native = onscreen_native->renderer_native;
|
||||||
MetaGpuKms *render_gpu = onscreen_native->render_gpu;
|
MetaGpuKms *render_gpu = onscreen_native->render_gpu;
|
||||||
MetaCrtcKms *crtc_kms = META_CRTC_KMS (crtc);
|
MetaCrtcKms *crtc_kms = META_CRTC_KMS (crtc);
|
||||||
|
MetaKmsCrtc *kms_crtc = meta_crtc_kms_get_kms_crtc (crtc_kms);
|
||||||
MetaRendererNativeGpuData *renderer_gpu_data;
|
MetaRendererNativeGpuData *renderer_gpu_data;
|
||||||
MetaGpuKms *gpu_kms;
|
MetaGpuKms *gpu_kms;
|
||||||
MetaKmsDevice *kms_device;
|
MetaKmsDevice *kms_device;
|
||||||
|
@ -1301,9 +1302,9 @@ meta_onscreen_native_flip_crtc (CoglOnscreen *onscreen,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
meta_kms_update_page_flip (kms_update,
|
meta_kms_update_add_page_flip_listener (kms_update,
|
||||||
meta_crtc_kms_get_kms_crtc (crtc_kms),
|
kms_crtc,
|
||||||
&page_flip_feedback,
|
&page_flip_listener_vtable,
|
||||||
g_object_ref (view));
|
g_object_ref (view));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue