intel_extreme.accelerant: create display modes list from VBT using create_display_modes()

For cases when EDID is not available but VBT information was retrieved,
previous code generated display mode list manually, potentially
incorrectly, causing the black screen during boot. This commit
fixes this by using a dedicated function, used for the
case where EDID is available (or VBT is not available).

Fixes #14280.

Change-Id: I95cfc5313260f0b9a01a98ba78e300b4383b6e32
Reviewed-on: https://review.haiku-os.org/c/1370
Reviewed-by: waddlesplash <waddlesplash@gmail.com>
This commit is contained in:
SuperPrower 2019-04-04 23:46:15 +03:00 committed by Alex von Gluck IV
parent 26723de267
commit fe3375770e

View File

@ -315,6 +315,8 @@ set_frame_buffer_base()
status_t status_t
create_mode_list(void) create_mode_list(void)
{ {
CALLED();
for (uint32 i = 0; i < gInfo->port_count; i++) { for (uint32 i = 0; i < gInfo->port_count; i++) {
if (gInfo->ports[i] == NULL) if (gInfo->ports[i] == NULL)
continue; continue;
@ -324,37 +326,25 @@ create_mode_list(void)
gInfo->has_edid = true; gInfo->has_edid = true;
} }
display_mode* list;
uint32 count = 0;
// If no EDID, but have vbt from driver, use that mode // If no EDID, but have vbt from driver, use that mode
if (!gInfo->has_edid && gInfo->shared_info->got_vbt) { if (!gInfo->has_edid && gInfo->shared_info->got_vbt) {
// We could not read any EDID info. Fallback to creating a list with // We could not read any EDID info. Fallback to creating a list with
// only the mode set up by the BIOS. // only the mode set up by the BIOS.
// TODO: support lower modes via scaling and windowing // TODO: support lower modes via scaling and windowing
size_t size = (sizeof(display_mode) + B_PAGE_SIZE - 1) gInfo->mode_list_area = create_display_modes("intel extreme modes",
& ~(B_PAGE_SIZE - 1); NULL, &gInfo->shared_info->panel_mode, 1, NULL, 0, NULL,
&list, &count);
display_mode* list; } else {
area_id area = create_area("intel extreme modes", // Otherwise return the 'real' list of modes
(void**)&list, B_ANY_ADDRESS, size, B_NO_LOCK, gInfo->mode_list_area = create_display_modes("intel extreme modes",
B_READ_AREA | B_WRITE_AREA); gInfo->has_edid ? &gInfo->edid_info : NULL, NULL, 0, NULL, 0, NULL,
if (area < 0) &list, &count);
return area;
memcpy(list, &gInfo->shared_info->panel_mode, sizeof(display_mode));
gInfo->mode_list_area = area;
gInfo->mode_list = list;
gInfo->shared_info->mode_list_area = gInfo->mode_list_area;
gInfo->shared_info->mode_count = 1;
return B_OK;
} }
// Otherwise return the 'real' list of modes
display_mode* list;
uint32 count = 0;
gInfo->mode_list_area = create_display_modes("intel extreme modes",
gInfo->has_edid ? &gInfo->edid_info : NULL, NULL, 0, NULL, 0, NULL,
&list, &count);
if (gInfo->mode_list_area < B_OK) if (gInfo->mode_list_area < B_OK)
return gInfo->mode_list_area; return gInfo->mode_list_area;