Populate host latency for kms/x11 grab (#2273)
This commit is contained in:
parent
e5ef0375f3
commit
526121d81d
2 changed files with 8 additions and 3 deletions
|
|
@ -1069,7 +1069,7 @@ namespace platf {
|
|||
}
|
||||
|
||||
inline capture_e
|
||||
refresh(file_t *file, egl::surface_descriptor_t *sd) {
|
||||
refresh(file_t *file, egl::surface_descriptor_t *sd, std::optional<std::chrono::steady_clock::time_point> &frame_timestamp) {
|
||||
// Check for a change in HDR metadata
|
||||
if (connector_id) {
|
||||
auto connector_props = card.connector_props(*connector_id);
|
||||
|
|
@ -1080,6 +1080,7 @@ namespace platf {
|
|||
}
|
||||
|
||||
plane_t plane = drmModeGetPlane(card.fd.el, plane_id);
|
||||
frame_timestamp = std::chrono::steady_clock::now();
|
||||
|
||||
auto fb = card.fb(plane.get());
|
||||
if (!fb) {
|
||||
|
|
@ -1303,7 +1304,8 @@ namespace platf {
|
|||
|
||||
egl::surface_descriptor_t sd;
|
||||
|
||||
auto status = refresh(fb_fd, &sd);
|
||||
std::optional<std::chrono::steady_clock::time_point> frame_timestamp;
|
||||
auto status = refresh(fb_fd, &sd, frame_timestamp);
|
||||
if (status != capture_e::ok) {
|
||||
return status;
|
||||
}
|
||||
|
|
@ -1330,6 +1332,8 @@ namespace platf {
|
|||
|
||||
gl::ctx.GetTextureSubImage(rgb->tex[0], 0, img_offset_x, img_offset_y, 0, width, height, 1, GL_BGRA, GL_UNSIGNED_BYTE, img_out->height * img_out->row_pitch, img_out->data);
|
||||
|
||||
img_out->frame_timestamp = frame_timestamp;
|
||||
|
||||
if (cursor && captured_cursor.visible) {
|
||||
blend_cursor(*img_out);
|
||||
}
|
||||
|
|
@ -1456,7 +1460,7 @@ namespace platf {
|
|||
auto img = (egl::img_descriptor_t *) img_out.get();
|
||||
img->reset();
|
||||
|
||||
auto status = refresh(fb_fd, &img->sd);
|
||||
auto status = refresh(fb_fd, &img->sd, img->frame_timestamp);
|
||||
if (status != capture_e::ok) {
|
||||
return status;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue