mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-17 04:15:44 +00:00
c/direct_mode: Create append_nvidia_entry_on_match function.
This commit is contained in:
parent
f8c99b0230
commit
a449ed174a
|
@ -271,6 +271,31 @@ comp_window_direct_init_randr(struct comp_window *w)
|
|||
return true;
|
||||
}
|
||||
|
||||
static bool
|
||||
append_nvidia_entry_on_match(struct comp_window_direct *w,
|
||||
const char *wl_entry,
|
||||
struct VkDisplayPropertiesKHR *disp)
|
||||
{
|
||||
unsigned long wl_entry_length = strlen(wl_entry);
|
||||
unsigned long disp_entry_length = strlen(disp->displayName);
|
||||
if (disp_entry_length < wl_entry_length)
|
||||
return false;
|
||||
|
||||
if (strncmp(wl_entry, disp->displayName, wl_entry_length) != 0)
|
||||
return false;
|
||||
|
||||
// we have a match with this whitelist entry.
|
||||
w->base.c->settings.width = disp->physicalResolution.width;
|
||||
w->base.c->settings.height = disp->physicalResolution.height;
|
||||
comp_window_direct_nvidia_display d = {
|
||||
.name = std::string(disp->displayName),
|
||||
.display_properties = *disp,
|
||||
.display = disp->display};
|
||||
w->nv_displays.push_back(d);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool
|
||||
comp_window_direct_init_nvidia(struct comp_window *w)
|
||||
{
|
||||
|
@ -310,36 +335,14 @@ comp_window_direct_init_nvidia(struct comp_window *w)
|
|||
}
|
||||
|
||||
// TODO: what if we have multiple whitelisted HMD displays connected?
|
||||
|
||||
for (uint32_t i = 0; i < display_count; i++) {
|
||||
struct VkDisplayPropertiesKHR disp = *(display_props + i);
|
||||
// check this display against our whitelist
|
||||
for (uint32_t j = 0; j < ARRAY_SIZE(NV_DIRECT_WHITELIST); j++) {
|
||||
unsigned long wl_entry_length =
|
||||
strlen(NV_DIRECT_WHITELIST[j]);
|
||||
unsigned long disp_entry_length =
|
||||
strlen(disp.displayName);
|
||||
if (disp_entry_length >= wl_entry_length) {
|
||||
if (strncmp(NV_DIRECT_WHITELIST[j],
|
||||
disp.displayName,
|
||||
wl_entry_length) == 0) {
|
||||
// we have a match with this whitelist
|
||||
// entry.
|
||||
w->c->settings.width =
|
||||
disp.physicalResolution.width;
|
||||
w->c->settings.height =
|
||||
disp.physicalResolution.height;
|
||||
comp_window_direct_nvidia_display d = {
|
||||
.name =
|
||||
std::string(disp.displayName),
|
||||
.display_properties = disp,
|
||||
.display = disp.display};
|
||||
w_direct->nv_displays.push_back(d);
|
||||
for (uint32_t j = 0; j < ARRAY_SIZE(NV_DIRECT_WHITELIST); j++)
|
||||
if (append_nvidia_entry_on_match(
|
||||
w_direct, NV_DIRECT_WHITELIST[j], &disp))
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
free(display_props);
|
||||
|
||||
|
|
Loading…
Reference in a new issue