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:
parent
26723de267
commit
fe3375770e
@ -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;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user