mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-07 15:46:12 +00:00
u/pacing: Predict present time and then calculate display time in fake pacer
This commit is contained in:
parent
6c9c1e9249
commit
b9b9ced43d
|
@ -38,9 +38,9 @@ struct fake_timing
|
||||||
uint64_t frame_period_ns;
|
uint64_t frame_period_ns;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* When the last frame was made.
|
* When the last frame was presented, not displayed.
|
||||||
*/
|
*/
|
||||||
uint64_t last_display_time_ns;
|
uint64_t last_present_time_ns;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Very often the present time that we get from the system is only when
|
* Very often the present time that we get from the system is only when
|
||||||
|
@ -69,16 +69,16 @@ fake_timing(struct u_pacing_compositor *upc)
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t
|
static uint64_t
|
||||||
predict_next_frame(struct fake_timing *ft, uint64_t now_ns)
|
predict_next_frame_present_time(struct fake_timing *ft, uint64_t now_ns)
|
||||||
{
|
{
|
||||||
uint64_t time_needed_ns = ft->present_to_display_offset_ns + ft->comp_time_ns;
|
uint64_t time_needed_ns = ft->comp_time_ns;
|
||||||
uint64_t predicted_display_time_ns = ft->last_display_time_ns + ft->frame_period_ns;
|
uint64_t predicted_present_time_ns = ft->last_present_time_ns + ft->frame_period_ns;
|
||||||
|
|
||||||
while (now_ns + time_needed_ns > predicted_display_time_ns) {
|
while (now_ns + time_needed_ns > predicted_present_time_ns) {
|
||||||
predicted_display_time_ns += ft->frame_period_ns;
|
predicted_present_time_ns += ft->frame_period_ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
return predicted_display_time_ns;
|
return predicted_present_time_ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t
|
static uint64_t
|
||||||
|
@ -109,8 +109,8 @@ pc_predict(struct u_pacing_compositor *upc,
|
||||||
struct fake_timing *ft = fake_timing(upc);
|
struct fake_timing *ft = fake_timing(upc);
|
||||||
|
|
||||||
int64_t frame_id = ft->frame_id_generator++;
|
int64_t frame_id = ft->frame_id_generator++;
|
||||||
uint64_t predicted_display_time_ns = predict_next_frame(ft, now_ns);
|
uint64_t desired_present_time_ns = predict_next_frame_present_time(ft, now_ns);
|
||||||
uint64_t desired_present_time_ns = predicted_display_time_ns - ft->present_to_display_offset_ns;
|
uint64_t predicted_display_time_ns = desired_present_time_ns + ft->present_to_display_offset_ns;
|
||||||
uint64_t wake_up_time_ns = desired_present_time_ns - ft->comp_time_ns;
|
uint64_t wake_up_time_ns = desired_present_time_ns - ft->comp_time_ns;
|
||||||
uint64_t present_slop_ns = U_TIME_HALF_MS_IN_NS;
|
uint64_t present_slop_ns = U_TIME_HALF_MS_IN_NS;
|
||||||
uint64_t predicted_display_period_ns = ft->frame_period_ns;
|
uint64_t predicted_display_period_ns = ft->frame_period_ns;
|
||||||
|
@ -198,8 +198,8 @@ u_pc_fake_create(uint64_t estimated_frame_period_ns, uint64_t now_ns, struct u_p
|
||||||
// 20% of the frame time.
|
// 20% of the frame time.
|
||||||
ft->comp_time_ns = get_percent_of_time(estimated_frame_period_ns, 20);
|
ft->comp_time_ns = get_percent_of_time(estimated_frame_period_ns, 20);
|
||||||
|
|
||||||
// Make the next display time be in the future.
|
// Make the next present time be in the future.
|
||||||
ft->last_display_time_ns = now_ns + U_TIME_1MS_IN_NS * 50;
|
ft->last_present_time_ns = now_ns + U_TIME_1MS_IN_NS * 50;
|
||||||
|
|
||||||
// Return value.
|
// Return value.
|
||||||
*out_upc = &ft->base;
|
*out_upc = &ft->base;
|
||||||
|
|
Loading…
Reference in a new issue