5 * Copyright (c) 2006-2009 Christoph Pfisterer
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
15 * * Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the
20 * * Neither the name of Christoph Pfisterer nor the names of the
21 * contributors may be used to endorse or promote products derived
22 * from this software without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
27 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
28 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 * Modifications copyright (c) 2012 Roderick W. Smith
39 * Modifications distributed under the terms of the GNU General Public
40 * License (GPL) version 3 (GPLv3), a copy of which must be distributed
41 * with this source code or binaries made from it.
53 #define REFIT_DEBUG (0)
55 // Tag classifications; used in various ways.
57 #define TAG_REBOOT (2)
58 #define TAG_SHUTDOWN (3)
60 #define TAG_LOADER (5)
61 #define TAG_LEGACY (6)
64 #define TAG_GPTSYNC (9)
67 #define NUM_SCAN_OPTIONS 10
69 #define DEFAULT_ICONS_DIR L"icons"
91 EFI_DEVICE_PATH
*DevicePath
;
92 EFI_HANDLE DeviceHandle
;
95 EG_IMAGE
*VolIconImage
;
96 EG_IMAGE
*VolBadgeImage
;
98 BOOLEAN IsAppleLegacy
;
102 BOOLEAN IsMbrPartition
;
103 UINTN MbrPartitionIndex
;
104 EFI_BLOCK_IO
*BlockIO
;
105 UINT64 BlockIOOffset
;
106 EFI_BLOCK_IO
*WholeDiskBlockIO
;
107 EFI_DEVICE_PATH
*WholeDiskDevicePath
;
108 MBR_PARTITION_INFO
*MbrPartitionTable
;
112 typedef struct _refit_menu_entry
{
116 CHAR16 ShortcutDigit
;
117 CHAR16 ShortcutLetter
;
119 EG_IMAGE
*BadgeImage
;
120 struct _refit_menu_screen
*SubScreen
;
123 typedef struct _refit_menu_screen
{
125 EG_IMAGE
*TitleImage
;
128 UINTN EntryCount
; // total number of entries registered
129 REFIT_MENU_ENTRY
**Entries
;
130 UINTN TimeoutSeconds
;
139 EFI_DEVICE_PATH
*DevicePath
;
140 BOOLEAN UseGraphicsMode
;
143 CHAR16
*InitrdPath
; // Linux stub loader only
149 REFIT_VOLUME
*Volume
;
156 BOOLEAN ScanAllLinux
;
157 UINTN RequestedScreenWidth
;
158 UINTN RequestedScreenHeight
;
161 UINTN MaxTags
; // max. number of OS entries to show simultaneously in graphics mode
162 CHAR16
*BannerFileName
;
163 CHAR16
*SelectionSmallFileName
;
164 CHAR16
*SelectionBigFileName
;
165 CHAR16
*DefaultSelection
;
169 UINTN ShowTools
[NUM_TOOLS
];
170 CHAR8 ScanFor
[NUM_SCAN_OPTIONS
]; // codes of types of loaders for which to scan
175 extern EFI_HANDLE SelfImageHandle
;
176 extern EFI_LOADED_IMAGE
*SelfLoadedImage
;
177 extern EFI_FILE
*SelfRootDir
;
178 extern EFI_FILE
*SelfDir
;
179 extern CHAR16
*SelfDirPath
;
181 extern REFIT_VOLUME
*SelfVolume
;
182 extern REFIT_VOLUME
**Volumes
;
183 extern UINTN VolumesCount
;
185 extern REFIT_CONFIG GlobalConfig
;
187 LOADER_ENTRY
*InitializeLoaderEntry(IN LOADER_ENTRY
*Entry
);
188 REFIT_MENU_SCREEN
*InitializeSubScreen(IN LOADER_ENTRY
*Entry
);
189 VOID
GenerateSubScreen(LOADER_ENTRY
*Entry
, IN REFIT_VOLUME
*Volume
);
190 LOADER_ENTRY
* MakeGenericLoaderEntry(VOID
);
191 LOADER_ENTRY
* AddLoaderEntry(IN CHAR16
*LoaderPath
, IN CHAR16
*LoaderTitle
, IN REFIT_VOLUME
*Volume
);
192 VOID
SetLoaderDefaults(LOADER_ENTRY
*Entry
, CHAR16
*LoaderPath
, IN REFIT_VOLUME
*Volume
);
193 LOADER_ENTRY
* AddPreparedLoaderEntry(LOADER_ENTRY
*Entry
);