From 444d7fef2e415ba7191a59c73565215db1657776 Mon Sep 17 00:00:00 2001 From: Hector Martin Date: Fri, 17 May 2024 10:17:40 +0900 Subject: [PATCH] display: Avoid placing FBs at IOVA 0 Also search harder for a matching dcp/disp iova, in case it matters. Fixes: #391 Signed-off-by: Hector Martin --- src/display.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/display.c b/src/display.c index a9ff8954b..bf58e5258 100644 --- a/src/display.c +++ b/src/display.c @@ -191,7 +191,7 @@ static uintptr_t display_map_fb(uintptr_t iova, u64 paddr, u64 size) u64 iova_dcp = 0; // start scanning for free iova space on vm-base - iova_dcp = dart_find_iova(dcp->dart_dcp, dart_vm_base(dcp->dart_dcp), size); + iova_dcp = dart_find_iova(dcp->dart_dcp, dart_vm_base(dcp->dart_dcp) + SZ_16K, size); if (DART_IS_ERR(iova_dcp)) { printf("display: failed to find IOVA for fb of %06zx bytes (dcp)\n", size); return iova_dcp; @@ -204,6 +204,16 @@ static uintptr_t display_map_fb(uintptr_t iova, u64 paddr, u64 size) return iova_disp0; } + // try to find the same IOVA on DCP again + if (iova_disp0 != iova_dcp) { + iova_dcp = + dart_find_iova(dcp->dart_dcp, iova_disp0, size); + if (DART_IS_ERR(iova_dcp)) { + printf("display: failed to find IOVA for fb of %06zx bytes (dcp)\n", size); + return iova_dcp; + } + } + // assume this results in the same IOVA, not sure if this is required but matches what iboot // does on other models. if (iova_disp0 != iova_dcp) { @@ -276,7 +286,7 @@ int display_start_dcp(void) // Find the framebuffer DVA fb_dva = dart_search(dcp->dart_disp, (void *)cur_boot_args.video.base); // framebuffer is not mapped on the M1 Ultra Mac Studio - if (DART_IS_ERR(fb_dva)) + if (DART_IS_ERR(fb_dva) || !fb_dva) fb_dva = display_map_fb(0, pa, size); if (DART_IS_ERR(fb_dva)) { printf("display: failed to find display DVA\n");