forked from xt-sys/exectos
		
	Limit boot menu entry names to available menu width
This commit is contained in:
		| @@ -45,7 +45,7 @@ typedef LONG (*PBL_GET_MEMTYPE_ROUTINE)(IN EFI_MEMORY_TYPE EfiMemoryType); | |||||||
| /* Boot Loader protocol routine pointers */ | /* Boot Loader protocol routine pointers */ | ||||||
| typedef EFI_STATUS (*PBL_ALLOCATE_PAGES)(IN EFI_ALLOCATE_TYPE AllocationType, IN ULONGLONG Size, OUT PEFI_PHYSICAL_ADDRESS Memory); | typedef EFI_STATUS (*PBL_ALLOCATE_PAGES)(IN EFI_ALLOCATE_TYPE AllocationType, IN ULONGLONG Size, OUT PEFI_PHYSICAL_ADDRESS Memory); | ||||||
| typedef EFI_STATUS (*PBL_ALLOCATE_POOL)(IN UINT_PTR Size, OUT PVOID *Memory); | typedef EFI_STATUS (*PBL_ALLOCATE_POOL)(IN UINT_PTR Size, OUT PVOID *Memory); | ||||||
| typedef EFI_STATUS (*PBL_BOOTMENU_INITIALIZE_OS_LIST)(OUT PXTBL_BOOTMENU_ITEM *MenuEntries, OUT PULONG EntriesCount, OUT PULONG DefaultId); | typedef EFI_STATUS (*PBL_BOOTMENU_INITIALIZE_OS_LIST)(IN ULONG MaxNameLength, OUT PXTBL_BOOTMENU_ITEM *MenuEntries, OUT PULONG EntriesCount, OUT PULONG DefaultId); | ||||||
| typedef BOOLEAN (*PBL_BOOTUTIL_GET_BOOLEAN_PARAMETER)(IN CONST PWCHAR Parameters, IN CONST PWCHAR Needle); | typedef BOOLEAN (*PBL_BOOTUTIL_GET_BOOLEAN_PARAMETER)(IN CONST PWCHAR Parameters, IN CONST PWCHAR Needle); | ||||||
| typedef EFI_STATUS (*PBL_BUILD_PAGE_MAP)(IN PXTBL_PAGE_MAPPING PageMap, IN ULONG_PTR SelfMapAddress); | typedef EFI_STATUS (*PBL_BUILD_PAGE_MAP)(IN PXTBL_PAGE_MAPPING PageMap, IN ULONG_PTR SelfMapAddress); | ||||||
| typedef EFI_STATUS (*PBL_CLOSE_VOLUME)(IN PEFI_HANDLE VolumeHandle); | typedef EFI_STATUS (*PBL_CLOSE_VOLUME)(IN PEFI_HANDLE VolumeHandle); | ||||||
| @@ -153,6 +153,7 @@ typedef struct _XTBL_BOOT_PARAMETERS | |||||||
| typedef struct _XTBL_BOOTMENU_ITEM | typedef struct _XTBL_BOOTMENU_ITEM | ||||||
| { | { | ||||||
|     PWCHAR EntryName; |     PWCHAR EntryName; | ||||||
|  |     PWCHAR FullName; | ||||||
|     PWCHAR ShortName; |     PWCHAR ShortName; | ||||||
|     PLIST_ENTRY Options; |     PLIST_ENTRY Options; | ||||||
| } XTBL_BOOTMENU_ITEM, *PXTBL_BOOTMENU_ITEM; | } XTBL_BOOTMENU_ITEM, *PXTBL_BOOTMENU_ITEM; | ||||||
|   | |||||||
| @@ -197,7 +197,8 @@ BlInitializeBootLoader(); | |||||||
|  |  | ||||||
| XTCDECL | XTCDECL | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| BlInitializeBootMenuList(OUT PXTBL_BOOTMENU_ITEM *MenuEntries, | BlInitializeBootMenuList(IN ULONG MaxNameLength, | ||||||
|  |                          OUT PXTBL_BOOTMENU_ITEM *MenuEntries, | ||||||
|                          OUT PULONG EntriesCount, |                          OUT PULONG EntriesCount, | ||||||
|                          OUT PULONG DefaultId); |                          OUT PULONG DefaultId); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -34,18 +34,18 @@ BlDisplayBootMenu() | |||||||
|     LONG TimeOut; |     LONG TimeOut; | ||||||
|     PWCHAR TimeOutString; |     PWCHAR TimeOutString; | ||||||
|  |  | ||||||
|  |     /* Draw boot menu */ | ||||||
|  |     BlpDrawBootMenu(&Handle); | ||||||
|  |  | ||||||
|     /* Initialize boot menu list */ |     /* Initialize boot menu list */ | ||||||
|     TopVisibleEntry = 0; |     TopVisibleEntry = 0; | ||||||
|     Status = BlInitializeBootMenuList(&MenuEntries, &NumberOfEntries, &HighligtedEntryId); |     Status = BlInitializeBootMenuList(Handle.Width - 4, &MenuEntries, &NumberOfEntries, &HighligtedEntryId); | ||||||
|     if(Status != STATUS_EFI_SUCCESS) |     if(Status != STATUS_EFI_SUCCESS) | ||||||
|     { |     { | ||||||
|         /* Failed to initialize boot menu list, exit into XTLDR shell */ |         /* Failed to initialize boot menu list, exit into XTLDR shell */ | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* Draw boot menu */ |  | ||||||
|     BlpDrawBootMenu(&Handle); |  | ||||||
|  |  | ||||||
|     /* Calculate how many entries can be visible in the menu box */ |     /* Calculate how many entries can be visible in the menu box */ | ||||||
|     VisibleEntries = Handle.Height - 2; |     VisibleEntries = Handle.Height - 2; | ||||||
|  |  | ||||||
| @@ -175,7 +175,7 @@ BlDisplayBootMenu() | |||||||
|                     BlSetConsoleAttributes(Handle.DialogColor | Handle.TextColor); |                     BlSetConsoleAttributes(Handle.DialogColor | Handle.TextColor); | ||||||
|                     BlClearConsoleLine(Handle.PosY + Handle.Height + 4); |                     BlClearConsoleLine(Handle.PosY + Handle.Height + 4); | ||||||
|                     BlSetCursorPosition(4, Handle.PosY + Handle.Height + 4); |                     BlSetCursorPosition(4, Handle.PosY + Handle.Height + 4); | ||||||
|                     BlConsolePrint(L"Booting '%S' now...\n", MenuEntries[HighligtedEntryId].EntryName); |                     BlConsolePrint(L"Booting '%S' now...\n", MenuEntries[HighligtedEntryId].FullName); | ||||||
|  |  | ||||||
|                     /* Boot the highlighted (chosen) OS */ |                     /* Boot the highlighted (chosen) OS */ | ||||||
|                     Status = BlInvokeBootProtocol(MenuEntries[HighligtedEntryId].ShortName, |                     Status = BlInvokeBootProtocol(MenuEntries[HighligtedEntryId].ShortName, | ||||||
| @@ -184,7 +184,7 @@ BlDisplayBootMenu() | |||||||
|                     { |                     { | ||||||
|                         /* Failed to boot OS */ |                         /* Failed to boot OS */ | ||||||
|                         BlDebugPrint(L"ERROR: Failed to boot '%S' (Status Code: 0x%zX)\n", |                         BlDebugPrint(L"ERROR: Failed to boot '%S' (Status Code: 0x%zX)\n", | ||||||
|                                      MenuEntries[HighligtedEntryId].EntryName, Status); |                                      MenuEntries[HighligtedEntryId].FullName, Status); | ||||||
|                         BlDisplayErrorDialog(L"XTLDR", L"Failed to startup the selected Operating System."); |                         BlDisplayErrorDialog(L"XTLDR", L"Failed to startup the selected Operating System."); | ||||||
|                         RedrawBootMenu = TRUE; |                         RedrawBootMenu = TRUE; | ||||||
|                     } |                     } | ||||||
| @@ -356,7 +356,7 @@ BlDisplayBootMenu() | |||||||
|                     BlSetConsoleAttributes(Handle.DialogColor | Handle.TextColor); |                     BlSetConsoleAttributes(Handle.DialogColor | Handle.TextColor); | ||||||
|                     BlClearConsoleLine(Handle.PosY + Handle.Height + 4); |                     BlClearConsoleLine(Handle.PosY + Handle.Height + 4); | ||||||
|                     BlSetCursorPosition(4, Handle.PosY + Handle.Height + 4); |                     BlSetCursorPosition(4, Handle.PosY + Handle.Height + 4); | ||||||
|                     BlConsolePrint(L"Booting '%S' now...\n", MenuEntries[HighligtedEntryId].EntryName); |                     BlConsolePrint(L"Booting '%S' now...\n", MenuEntries[HighligtedEntryId].FullName); | ||||||
|  |  | ||||||
|                     /* Disable the timer just in case booting OS fails */ |                     /* Disable the timer just in case booting OS fails */ | ||||||
|                     TimeOut = -1; |                     TimeOut = -1; | ||||||
| @@ -368,7 +368,7 @@ BlDisplayBootMenu() | |||||||
|                     { |                     { | ||||||
|                         /* Failed to boot OS */ |                         /* Failed to boot OS */ | ||||||
|                         BlDebugPrint(L"ERROR: Failed to boot '%S' (Status Code: 0x%zX)\n", |                         BlDebugPrint(L"ERROR: Failed to boot '%S' (Status Code: 0x%zX)\n", | ||||||
|                                      MenuEntries[HighligtedEntryId].EntryName, Status); |                                      MenuEntries[HighligtedEntryId].FullName, Status); | ||||||
|                         BlDisplayErrorDialog(L"XTLDR", L"Failed to startup the selected Operating System."); |                         BlDisplayErrorDialog(L"XTLDR", L"Failed to startup the selected Operating System."); | ||||||
|                         RedrawBootMenu = TRUE; |                         RedrawBootMenu = TRUE; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -90,16 +90,17 @@ BlInitializeBootLoader() | |||||||
|  */ |  */ | ||||||
| XTCDECL | XTCDECL | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| BlInitializeBootMenuList(OUT PXTBL_BOOTMENU_ITEM *MenuEntries, | BlInitializeBootMenuList(IN ULONG MaxNameLength, | ||||||
|  |                          OUT PXTBL_BOOTMENU_ITEM *MenuEntries, | ||||||
|                          OUT PULONG EntriesCount, |                          OUT PULONG EntriesCount, | ||||||
|                          OUT PULONG DefaultId) |                          OUT PULONG DefaultId) | ||||||
| { | { | ||||||
|     EFI_GUID VendorGuid = XT_BOOT_LOADER_PROTOCOL_GUID; |     EFI_GUID VendorGuid = XT_BOOT_LOADER_PROTOCOL_GUID; | ||||||
|     PWCHAR DefaultMenuEntry, LastBooted, MenuEntryName; |     PWCHAR DefaultMenuEntry, LastBooted, MenuEntryName, VisibleName; | ||||||
|     PLIST_ENTRY MenuEntrySectionList, MenuEntryList; |     PLIST_ENTRY MenuEntrySectionList, MenuEntryList; | ||||||
|     PXTBL_CONFIG_SECTION MenuEntrySection; |     PXTBL_CONFIG_SECTION MenuEntrySection; | ||||||
|     PXTBL_CONFIG_ENTRY MenuEntryOption; |     PXTBL_CONFIG_ENTRY MenuEntryOption; | ||||||
|     ULONG DefaultOS, NumberOfEntries; |     ULONG DefaultOS, NameLength,NumberOfEntries; | ||||||
|     PXTBL_BOOTMENU_ITEM OsList; |     PXTBL_BOOTMENU_ITEM OsList; | ||||||
|     EFI_STATUS Status; |     EFI_STATUS Status; | ||||||
|  |  | ||||||
| @@ -177,10 +178,36 @@ BlInitializeBootMenuList(OUT PXTBL_BOOTMENU_ITEM *MenuEntries, | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         /* Add OS to the boot menu list */ |         /* Add OS to the boot menu list */ | ||||||
|         OsList[NumberOfEntries].EntryName = MenuEntryName; |         OsList[NumberOfEntries].FullName = MenuEntryName; | ||||||
|         OsList[NumberOfEntries].ShortName = MenuEntrySection->SectionName; |         OsList[NumberOfEntries].ShortName = MenuEntrySection->SectionName; | ||||||
|         OsList[NumberOfEntries].Options = &MenuEntrySection->Options; |         OsList[NumberOfEntries].Options = &MenuEntrySection->Options; | ||||||
|  |  | ||||||
|  |         /* Check if the menu entry name fits the maximum length */ | ||||||
|  |         NameLength = RtlWideStringLength(MenuEntryName, 0); | ||||||
|  |         if(NameLength > MaxNameLength) | ||||||
|  |         { | ||||||
|  |             /* Menu entry name is too long, allocate memory for shorter name visible in the boot menu */ | ||||||
|  |             Status = BlAllocateMemoryPool((MaxNameLength + 1) * sizeof(WCHAR), (PVOID*)&VisibleName); | ||||||
|  |             if(Status != STATUS_EFI_SUCCESS) | ||||||
|  |             { | ||||||
|  |                 /* Memory allocation failure */ | ||||||
|  |                 return STATUS_EFI_OUT_OF_RESOURCES; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             /* Copy shorter name and append "..." at the end */ | ||||||
|  |             RtlCopyMemory(VisibleName, MenuEntryName, (MaxNameLength - 3) * sizeof(WCHAR)); | ||||||
|  |             RtlCopyMemory(VisibleName + MaxNameLength - 3, L"...", 3 * sizeof(WCHAR)); | ||||||
|  |             VisibleName[MaxNameLength] = L'\0'; | ||||||
|  |  | ||||||
|  |             /* Set visible menu entry name */ | ||||||
|  |             OsList[NumberOfEntries].EntryName = VisibleName; | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             /* Menu entry name fits the maximum length, use it as is */ | ||||||
|  |             OsList[NumberOfEntries].EntryName = MenuEntryName; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         /* Get next menu entry */ |         /* Get next menu entry */ | ||||||
|         MenuEntrySectionList = MenuEntrySectionList->Flink; |         MenuEntrySectionList = MenuEntrySectionList->Flink; | ||||||
|         NumberOfEntries++; |         NumberOfEntries++; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user