u/pacing: Add vblank timing function for display control

This commit is contained in:
Jakob Bornecrantz 2022-04-23 17:29:47 +01:00
parent 57070ad620
commit e140cfad5c
3 changed files with 46 additions and 0 deletions

View file

@ -134,6 +134,19 @@ struct u_pacing_compositor
uint64_t present_margin_ns, uint64_t present_margin_ns,
uint64_t when_ns); uint64_t when_ns);
/*!
* Provide a vblank timing information, derived from the
* VK_EXT_display_control extension. Since the extension only says when
* a vblank happened (somewhat inaccurate as well) but not if a specific
* present happened at that time no frame_id is given.
*
* @param[in] upc The compositor pacing helper.
* @param[in] last_vblank_ns The last time that the GPU started scanning out.
*
* @see @ref frame-pacing.
*/
void (*update_vblank_from_display_control)(struct u_pacing_compositor *upc, uint64_t last_vblank_ns);
/*! /*!
* Provide an updated estimate of the present offset. * Provide an updated estimate of the present offset.
* *
@ -220,6 +233,20 @@ u_pc_info(struct u_pacing_compositor *upc,
present_margin_ns, when_ns); present_margin_ns, when_ns);
} }
/*!
* @copydoc u_pacing_compositor::info_display_control
*
* Helper for calling through the function pointer.
*
* @public @memberof u_pacing_compositor
* @ingroup aux_pacing
*/
static inline void
u_pc_update_vblank_from_display_control(struct u_pacing_compositor *upc, uint64_t last_vblank_ns)
{
upc->update_vblank_from_display_control(upc, last_vblank_ns);
}
/*! /*!
* @copydoc u_pacing_compositor::update_present_offset * @copydoc u_pacing_compositor::update_present_offset
* *

View file

@ -641,6 +641,14 @@ pc_info(struct u_pacing_compositor *upc,
#undef TE_END #undef TE_END
} }
static void
pc_update_vblank_from_display_control(struct u_pacing_compositor *upc, uint64_t last_vblank_ns)
{
/*
* This is a no-op, here just in case display control is used at the
* same time as the google extension. We ignore this call.
*/
}
static void static void
pc_update_present_offset(struct u_pacing_compositor *upc, int64_t frame_id, uint64_t present_to_display_offset_ns) pc_update_present_offset(struct u_pacing_compositor *upc, int64_t frame_id, uint64_t present_to_display_offset_ns)
@ -682,6 +690,7 @@ u_pc_display_timing_create(uint64_t estimated_frame_period_ns,
pc->base.predict = pc_predict; pc->base.predict = pc_predict;
pc->base.mark_point = pc_mark_point; pc->base.mark_point = pc_mark_point;
pc->base.info = pc_info; pc->base.info = pc_info;
pc->base.update_vblank_from_display_control = pc_update_vblank_from_display_control;
pc->base.update_present_offset = pc_update_present_offset; pc->base.update_present_offset = pc_update_present_offset;
pc->base.destroy = pc_destroy; pc->base.destroy = pc_destroy;
pc->frame_period_ns = estimated_frame_period_ns; pc->frame_period_ns = estimated_frame_period_ns;

View file

@ -152,6 +152,15 @@ pc_info(struct u_pacing_compositor *upc,
*/ */
} }
static void
pc_update_vblank_from_display_control(struct u_pacing_compositor *upc, uint64_t last_vblank_ns)
{
struct fake_timing *ft = fake_timing(upc);
// Use the last vblank time to sync to the output.
ft->last_present_time_ns = last_vblank_ns;
}
static void static void
pc_update_present_offset(struct u_pacing_compositor *upc, int64_t frame_id, uint64_t present_to_display_offset_ns) pc_update_present_offset(struct u_pacing_compositor *upc, int64_t frame_id, uint64_t present_to_display_offset_ns)
{ {
@ -184,6 +193,7 @@ u_pc_fake_create(uint64_t estimated_frame_period_ns, uint64_t now_ns, struct u_p
ft->base.predict = pc_predict; ft->base.predict = pc_predict;
ft->base.mark_point = pc_mark_point; ft->base.mark_point = pc_mark_point;
ft->base.info = pc_info; ft->base.info = pc_info;
ft->base.update_vblank_from_display_control = pc_update_vblank_from_display_control;
ft->base.update_present_offset = pc_update_present_offset; ft->base.update_present_offset = pc_update_present_offset;
ft->base.destroy = pc_destroy; ft->base.destroy = pc_destroy;
ft->frame_period_ns = estimated_frame_period_ns; ft->frame_period_ns = estimated_frame_period_ns;