mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-07 15:46:12 +00:00
st/oxr: Add OXR_FRAME_TIMING_SPEW var to print basic frame timing information
This commit is contained in:
parent
2a00c9f09e
commit
5478bad3d0
|
@ -1330,6 +1330,11 @@ struct oxr_session
|
||||||
*/
|
*/
|
||||||
float ipd_meters;
|
float ipd_meters;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Frame timing debug output.
|
||||||
|
*/
|
||||||
|
bool frame_timing_spew;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* To pipe swapchain creation to right code.
|
* To pipe swapchain creation to right code.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
|
|
||||||
|
|
||||||
DEBUG_GET_ONCE_NUM_OPTION(ipd, "OXR_DEBUG_IPD_MM", 63)
|
DEBUG_GET_ONCE_NUM_OPTION(ipd, "OXR_DEBUG_IPD_MM", 63)
|
||||||
|
DEBUG_GET_ONCE_BOOL_OPTION(frame_timing_spew, "OXR_FRAME_TIMING_SPEW", false)
|
||||||
|
|
||||||
#define CALL_CHK(call) \
|
#define CALL_CHK(call) \
|
||||||
if ((call) == XRT_ERROR_IPC_FAILURE) { \
|
if ((call) == XRT_ERROR_IPC_FAILURE) { \
|
||||||
|
@ -499,6 +500,22 @@ oxr_session_views(struct oxr_logger *log,
|
||||||
return oxr_session_success_result(sess);
|
return oxr_session_success_result(sess);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static double
|
||||||
|
ns_to_ms(int64_t ns)
|
||||||
|
{
|
||||||
|
double ms = ((double)ns) * 1. / 1000. * 1. / 1000.;
|
||||||
|
return ms;
|
||||||
|
}
|
||||||
|
|
||||||
|
static double
|
||||||
|
ts_ms(struct oxr_session *sess)
|
||||||
|
{
|
||||||
|
timepoint_ns now = time_state_get_now(sess->sys->inst->timekeeping);
|
||||||
|
int64_t monotonic =
|
||||||
|
time_state_ts_to_monotonic_ns(sess->sys->inst->timekeeping, now);
|
||||||
|
return ns_to_ms(monotonic);
|
||||||
|
}
|
||||||
|
|
||||||
XrResult
|
XrResult
|
||||||
oxr_session_frame_wait(struct oxr_logger *log,
|
oxr_session_frame_wait(struct oxr_logger *log,
|
||||||
struct oxr_session *sess,
|
struct oxr_session *sess,
|
||||||
|
@ -525,10 +542,20 @@ oxr_session_frame_wait(struct oxr_logger *log,
|
||||||
sess->active_wait_frames++;
|
sess->active_wait_frames++;
|
||||||
os_mutex_unlock(&sess->active_wait_frames_lock);
|
os_mutex_unlock(&sess->active_wait_frames_lock);
|
||||||
|
|
||||||
|
if (sess->frame_timing_spew) {
|
||||||
|
oxr_log(log, "Called at %8.3fms", ts_ms(sess));
|
||||||
|
}
|
||||||
|
|
||||||
// A subsequent xrWaitFrame call must: block until the previous frame
|
// A subsequent xrWaitFrame call must: block until the previous frame
|
||||||
// has been begun
|
// has been begun
|
||||||
os_semaphore_wait(&sess->sem, 0);
|
os_semaphore_wait(&sess->sem, 0);
|
||||||
|
|
||||||
|
if (sess->frame_timing_spew) {
|
||||||
|
oxr_log(log,
|
||||||
|
"Finished waiting for previous frame begin at %8.3fms",
|
||||||
|
ts_ms(sess));
|
||||||
|
}
|
||||||
|
|
||||||
uint64_t predicted_display_time;
|
uint64_t predicted_display_time;
|
||||||
uint64_t predicted_display_period;
|
uint64_t predicted_display_period;
|
||||||
CALL_CHK(xrt_comp_wait_frame(xc, &sess->frame_id.waited,
|
CALL_CHK(xrt_comp_wait_frame(xc, &sess->frame_id.waited,
|
||||||
|
@ -553,6 +580,15 @@ oxr_session_frame_wait(struct oxr_logger *log,
|
||||||
frameState->predictedDisplayTime);
|
frameState->predictedDisplayTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (sess->frame_timing_spew) {
|
||||||
|
oxr_log(log,
|
||||||
|
"Waiting finished at %8.3fms. Predicted display time "
|
||||||
|
"%8.3fms, "
|
||||||
|
"period %8.3fms",
|
||||||
|
ts_ms(sess), ns_to_ms(predicted_display_time),
|
||||||
|
ns_to_ms(predicted_display_period));
|
||||||
|
}
|
||||||
|
|
||||||
return oxr_session_success_result(sess);
|
return oxr_session_success_result(sess);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1867,6 +1903,13 @@ oxr_session_frame_end(struct oxr_logger *log,
|
||||||
frameEndInfo->displayTime);
|
frameEndInfo->displayTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int64_t timestamp = time_state_ts_to_monotonic_ns(
|
||||||
|
sess->sys->inst->timekeeping, frameEndInfo->displayTime);
|
||||||
|
if (sess->frame_timing_spew) {
|
||||||
|
oxr_log(log, "End frame at %8.3fms with display time %8.3fms",
|
||||||
|
ts_ms(sess), ns_to_ms(timestamp));
|
||||||
|
}
|
||||||
|
|
||||||
struct xrt_compositor *xc = sess->compositor;
|
struct xrt_compositor *xc = sess->compositor;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2250,6 +2293,7 @@ oxr_session_create(struct oxr_logger *log,
|
||||||
}
|
}
|
||||||
|
|
||||||
sess->ipd_meters = debug_get_num_option_ipd() / 1000.0f;
|
sess->ipd_meters = debug_get_num_option_ipd() / 1000.0f;
|
||||||
|
sess->frame_timing_spew = debug_get_bool_option_frame_timing_spew();
|
||||||
|
|
||||||
oxr_session_change_state(log, sess, XR_SESSION_STATE_IDLE);
|
oxr_session_change_state(log, sess, XR_SESSION_STATE_IDLE);
|
||||||
oxr_session_change_state(log, sess, XR_SESSION_STATE_READY);
|
oxr_session_change_state(log, sess, XR_SESSION_STATE_READY);
|
||||||
|
|
Loading…
Reference in a new issue