From 16d65009236226ed9ae351dccadc2824aa73c531 Mon Sep 17 00:00:00 2001 From: Lubosz Sarnecki Date: Wed, 1 Apr 2020 17:51:20 +0200 Subject: [PATCH] c/direct_mode: Don't cache enumerated modes in a std:map. --- .../main/comp_window_direct_mode.cpp | 43 +++++++------------ 1 file changed, 15 insertions(+), 28 deletions(-) diff --git a/src/xrt/compositor/main/comp_window_direct_mode.cpp b/src/xrt/compositor/main/comp_window_direct_mode.cpp index 903fceee2..e0c312b26 100644 --- a/src/xrt/compositor/main/comp_window_direct_mode.cpp +++ b/src/xrt/compositor/main/comp_window_direct_mode.cpp @@ -61,7 +61,6 @@ struct comp_window_direct Display *dpy = nullptr; xcb_screen_t *screen = nullptr; - std::map randr_modes = {}; std::vector randr_displays = {}; std::vector nv_displays = {}; @@ -126,11 +125,6 @@ static VkDisplayKHR comp_window_direct_get_xlib_randr_output(struct comp_window_direct *w, RROutput output); -static void -comp_window_direct_enumerate_randr_modes( - struct comp_window_direct *w, - xcb_randr_get_screen_resources_reply_t *resources_reply); - static void comp_window_direct_get_randr_outputs(struct comp_window_direct *w); @@ -161,7 +155,6 @@ comp_window_direct_create(struct comp_compositor *c) w->base.init_swapchain = comp_window_direct_init_swapchain; w->base.update_window_title = comp_window_direct_update_window_title; w->base.c = c; - w->randr_modes.clear(); return &w->base; } @@ -719,24 +712,10 @@ comp_window_direct_get_xlib_randr_output(struct comp_window_direct *w, return display; } -static void -comp_window_direct_enumerate_randr_modes( - struct comp_window_direct *w, - xcb_randr_get_screen_resources_reply_t *resources_reply) -{ - xcb_randr_mode_info_t *mode_infos = - xcb_randr_get_screen_resources_modes(resources_reply); - - int n = xcb_randr_get_screen_resources_modes_length(resources_reply); - for (int i = 0; i < n; i++) - w->randr_modes.insert( - std::pair(mode_infos[i].id, - mode_infos[i])); -} - static void append_randr_display(struct comp_window_direct *w, xcb_randr_get_output_info_reply_t *output_reply, + xcb_randr_get_screen_resources_reply_t *resources_reply, xcb_randr_output_t xcb_output) { xcb_randr_mode_t *output_modes = @@ -754,10 +733,19 @@ append_randr_display(struct comp_window_direct *w, name); } - if (w->randr_modes.count(output_modes[0]) == 0) { + xcb_randr_mode_info_t *mode_infos = + xcb_randr_get_screen_resources_modes(resources_reply); + + int n = xcb_randr_get_screen_resources_modes_length(resources_reply); + + xcb_randr_mode_info_t *mode_info = NULL; + for (int i = 0; i < n; i++) + if (mode_infos[i].id == output_modes[0]) + mode_info = &mode_infos[i]; + + if (mode_info == NULL) COMP_ERROR(w->base.c, "No mode with id %d found??", output_modes[0]); - } char *name_str = U_TYPED_ARRAY_CALLOC(char, name_len + 1); memcpy(name_str, name, name_len); @@ -766,7 +754,7 @@ append_randr_display(struct comp_window_direct *w, comp_window_direct_randr_display d = { .name = std::string(name_str), .output = xcb_output, - .primary_mode = w->randr_modes.at(output_modes[0]), + .primary_mode = *mode_info, .display = VK_NULL_HANDLE, }; @@ -830,8 +818,6 @@ comp_window_direct_get_randr_outputs(struct comp_window_direct *w) xcb_randr_output_t *xcb_outputs = xcb_randr_get_screen_resources_outputs(resources_reply); - comp_window_direct_enumerate_randr_modes(w, resources_reply); - int count = xcb_randr_get_screen_resources_outputs_length(resources_reply); if (count < 1) { @@ -886,7 +872,8 @@ comp_window_direct_get_randr_outputs(struct comp_window_direct *w) uint8_t non_desktop = *xcb_randr_get_output_property_data(prop_reply); if (non_desktop == 1) - append_randr_display(w, output_reply, xcb_outputs[i]); + append_randr_display(w, output_reply, resources_reply, + xcb_outputs[i]); free(prop_reply); free(output_reply);