]> code.delx.au - refind/blob - NEWS.txt
More refinement to the UEFI legacy boot code
[refind] / NEWS.txt
1 0.4.6 (10/??/2012):
2 -------------------
3
4 - Added new "scan_delay" feature to impose a delay before scanning
5 for disks.
6
7 - Changed default "scanfor" option from internal-external-optical to
8 internal-external-optical-manual. This will have no effect with the
9 standard refind.conf file, which has no manual stanzas defined; but some
10 users seem to overlook this setting, and think that adding manual stanzas
11 is enough to activate them. This will make it so.
12
13 - Added new legacy (BIOS) boot support for UEFI-based PCs.
14
15 0.4.5 (8/12/2012):
16 ------------------
17
18 - Fixed bug that caused a failure to boot BIOS-based OSes on Macs.
19
20 - Fixed bug in install.sh that caused it to fail to detect rEFItBlesser.
21
22 0.4.4 (6/23/2012):
23 ------------------
24
25 - Fixed bug that caused filesystem labels to be corrupted by rEFInd on
26 32-bit systems.
27
28 - Fixed bug that caused filesystem labels to be truncated in the drivers
29 on 32-bit systems.
30
31 - Fixed bug in use_graphics_for option parsing that caused most options
32 to set graphics mode for OS X and/or Linux but not other boot
33 loaders/OSes.
34
35 - Tweaked install script to better isolate the ESP under OS X.
36
37 0.4.3 (6/21/2012):
38 ------------------
39
40 - rEFInd now supports compilation using the TianoCore UDK2010/EDK2
41 development kit in addition to GNU-EFI.
42
43 - Added new "use_graphics_for" option to control which OSes to boot in
44 graphics mode. (This effect lasts for a fraction of a second on most
45 systems, since the boot loader that rEFInd launches is likely to set
46 graphics or text mode itself.)
47
48 - Graphics-mode booting now clears the screen to the current rEFInd
49 background color (rather than black) and does NOT display boot messages.
50 The intent is for a smoother transition when booting OS X, or perhaps
51 other OSes that don't display boot loader messages. In practice, this
52 effect will be tiny for many OSes, since the boot loader generally clears
53 the screen within a fraction of a second of being launched; but the
54 "flicker" of a rEFInd message in that time can sometimes be distracting.
55
56 - Filesystem drivers now work on EFI 1.x systems, such as Macs.
57
58 - Removed "linux.conf" as a valid alternative name for "refind_linux.conf"
59 for holding Linux kernel options. The kernel developers plan to use
60 "linux.conf" themselves.
61
62 0.4.2 (6/3/2012):
63 -----------------
64
65 - Added a message to install.sh when run on Macs to remind users to update
66 the "scanfor" line in refind.conf if they need to boot BIOS-based OSes
67 via rEFInd.
68
69 - Modified install.sh script to be smarter about running efibootmgr on
70 Linux. It now uses the whole path to the rEFInd binary as a key to
71 determine whether an existing entry exists, rather than just the filename
72 portion. If an entry exists and is the first entry in the boot order, the
73 script does nothing to the NVRAM entries. If such an entry exists but is
74 not the default, the script deletes that entry and creates a new one
75 (implicitly making it the first in the boot order). If such an entry does
76 not exist, the script creates a new one (again, making it the first in
77 the boot order).
78
79 - Added "dont_scan_dirs" configuration file option, which adds directories
80 to a "blacklist" of directories that are NOT scanned for boot loaders.
81
82 0.4.1 (5/25/2012):
83 ------------------
84
85 - Added "scanning for new boot loaders" message to the re-scan function
86 (hitting Esc at the main menu). It usually flashes up too quickly to
87 be of importance, but if the scan function takes a while because of
88 access to a CD that must be spun up, it should make it clear that the
89 system hasn't hung.
90
91 - Modified install.sh script to detect rEFItBlesser on Macs, and if
92 present, to ask the user if it should be removed.
93
94 - Cleaned up the Make.common file for the filesystem drivers.
95
96 - Changed HFS+ driver to return volume label of "HFS+ volume" rather than
97 an empty label. (The driver doesn't currently read the real volume
98 label.)
99
100 - Fixed bug that could cause rEFInd to appear in its own menu after
101 running a shell and then re-scanning for boot loaders.
102
103 0.4.0 (5/20/2012):
104 ------------------
105
106 - Inclusion of drivers for ISO-9660, HFS+, ReiserFS, and ext2fs. Most of
107 these drivers originated with rEFIt, although the HFS+ driver seems to
108 have come from Oracle's VirtualBox, with some files from Apple. I hadn't
109 included these drivers previously because the build process proved
110 challenging. As it is, they don't work on my Mac Mini, I suspect because
111 the build process with the UDK2010 development kit may not work with the
112 EFI 1.x that Apple uses.
113
114 - Addition of support for drivers in the "drivers_{arch}" subdirectory of
115 the main rEFInd binary directory (e.g., "drivers_x64" or "drivers_ia32").
116 Drivers may continue to be placed in the "drivers" subdirectory.
117
118 - Added new feature to eject CDs (and other removable media): Press F12 to
119 eject all such media. This function works only on some Macs, though (it
120 relies on an Apple-specific EFI extension, and this extension isn't even
121 implemented on all Macs, much less on UEFI-based PCs).
122
123 - Fixed a problem that could cause GRUB 2 to fail to read its configuration
124 file when launched from rEFInd.
125
126 0.3.5 (5/15/2012):
127 ------------------
128
129 - Removed the GRUB 2 detection "reciped" added with 0.3.2, since I've
130 received reports that it's not working as intended.
131
132 - Added re-scan feature: Press the Esc key to have rEFInd re-read its
133 configuration file, tell the EFI to scan for new filesystems, and re-scan
134 those filesystems for boot loaders. The main purpose is to enable
135 scanning a new removable medium that you insert after launching rEFInd;
136 however, it can also be used to immediately implement changes to the
137 configuration file or new drivers you load from an EFI shell.
138
139 - Fixed a bug that could cause the scroll-right arrow to be replaced by the
140 scroll-left arrow under some circumstances.
141
142 0.3.4 (5/9/2012):
143 -----------------
144
145 - Added new configuration file option: "icons_dir", which sets the name
146 of the subdirectory in which icons are found. See the documentation or
147 sample configuration file for a full description.
148
149 - Modified Makefile to generate rEFInd binary that includes architecture
150 code -- refind_ia32.efi or refind_x64.efi, rather than the generic
151 refind.efi. This is done mainly to help the install.sh script. The
152 program can be named anything you like on the disk. (The generic name
153 refind.efi is used on unknown architectures.)
154
155 - Improved install.sh script: Fixed bug on OS X 10.7 and enable it to be
156 used after building from source code (or via new "make install" Makefile
157 target).
158
159 - Improved screen redraws to produce less flicker when moving among the
160 second-row tags or to the last tag on the first row.
161
162 0.3.3 (5/6/2012):
163 -----------------
164
165 - Improved menu navigation:
166 - In graphics mode, left & right arrow keys move left & right, while up &
167 down arrows move between rows.
168 - Page Up and Page Down now move through chunks of visible tags (in both
169 text & graphics modes), jumping from one row to another only when at
170 the edge of the row. In text mode, the "rows" are broken down as in
171 graphics mode, but they aren't visibly distinguished on the screen.
172
173 - Improved text-mode use: rEFInd now displays the proper number of entries
174 when first started in text mode and scrolling is done sensibly when too
175 many entries exist to fit on the screen.
176
177 0.3.2 (5/4/2012):
178 -----------------
179
180 - Added the install.sh script to install rEFInd on Linux and Mac OS X
181 systems. This script must be run as root (or via sudo). It requires
182 no options, but on Mac OS X, passing it the "esp" option causes it
183 to install rEFInd on the computer's ESP rather than the default of the
184 currently OS X boot partition. (Under Linux, the default is to install to
185 the ESP.) Note that there may be some unusual cases in which this script
186 will fail to work.
187
188 - Does a better job of clearing the screen when launching OSes in text
189 mode.
190
191 - Added detection "recipe" for GRUB 2's BIOS Boot Partition.
192
193 - Fixed bogus detection of ESPs created by Linux's mkdosfs utility or
194 Windows as bootable partitions when "scanfor" includes BIOS scanning
195 options.
196
197
198 0.3.1 (4/27/2012):
199 ------------------
200
201 - Fixed bug that caused spurious "Unsupported while scanning the root
202 directory" messages under some conitions on Macs.
203
204 - Modified loader scanning code to sort boot loader entries within a
205 directory by modification time, so that the most recently-modified loader
206 is first among those in a given directory. Thus, if you specify a
207 directory name (or volume name, for loaders stored in the root directory
208 of a volume) as the default_selection, the most recent of those loaders
209 will be the default. This is intended to help with Linux kernel
210 maintenance when using the EFI stub loader; set up this way, the most
211 recent kernel copied to your kernel directory will be the default,
212 obviating the need to adjust the refind.conf file when adding a new
213 kernel. If you want to change the default among those in the default
214 directory, you can use "touch" to adjust the modification timestamp.
215
216 - Tweaked code to find loader-specific .icns file so that it finds files
217 for Linux kernels without .efi extensions. In this case, files should be
218 named the same as the kernels they match, but with .icns extensions. For
219 instance, bzImage-3.3.2 should have an icon called bzImage-3.3.2.icns.
220 (The old code would have looked for an icon called bzImage-3.3.icns.)
221
222 - Eliminated bogus OS loader tags for filenames that end in ".icns" when
223 the scan_all_linux_kernels option is set.
224
225 0.3.0 (4/22/2012):
226 ------------------
227
228 - I'm officially upgrading this project's status from "alpha" to "beta" and
229 giving it a bump from 0.2.x to 0.3.0. This doesn't reflect any major
230 milestone with this version; rather, it reflects my sense that rEFInd has
231 been "out there" for a while, and although I've gotten bug reports,
232 they've been minor and/or have been fixed. The program still has known
233 bugs, but my impression is that it is, overall, usable by ordinary users.
234
235 - Added "resolution" option to refind.conf, which enables setting the video
236 resolution. To use it, pass two numeric values, as in "resolution 1024
237 768" to use a 1024x768 video mode. Note that not all modes are supported.
238 If you specify a non-supported video mode on a UEFI system, a message
239 appears listing the supported video modes and you must then press a key
240 to continue, using the default video mode (usually 800x600).
241 Unfortunately, I don't know the calls to get a list of supported video
242 modes on older EFI 1.x systems (including Macs), so on Macs setting an
243 incorrect video mode silently fails (you keep using the default mode).
244 This makes changing your video mode a hit-or-miss proposition on Macs.
245 CAUTION: It's possible to set a legal video mode that your monitor can't
246 handle, in which case you'll get a blank display until you boot an OS
247 that resets the video mode.
248
249 - Fixed (maybe) a bug that caused rEFInd to crash when returning from an
250 EFI shell or other programs on Macs, particularly when rEFInd used
251 graphical mode. I'm not 100% sure this bug is squashed because I still
252 don't understand the cause and I only have one Mac for testing. See
253 comments in the ReinitRefitLib() function in refit/lib.c for more
254 details.
255
256 - Added new refind.conf option: scan_all_linux_kernels, which causes Linux
257 kernels that lack ".efi" extensions to be included in scans for EFI boot
258 loaders. This may help integration with Linux distributions that don't
259 give their kernels such names by default. Beware, though: It can detect
260 unwanted files, such as older non-stub-loader kernels or .icns files used
261 to give kernels with .efi extensions custom icons.
262
263 - Improved EFI boot loader detection on boards with Gigabyte's Hybrid EFI,
264 and perhaps other EFIs with a buggy StriCmp() function. Files with both
265 ".efi" and ".EFI" extensions should now be detected as boot loaders.
266
267 - Fixed a bug that caused rEFInd to fail to scan for drivers if the
268 filesystem driver didn't set a volume name (that is, if the relevant
269 field was set to NULL rather than even an empty string). In such
270 situations, rEFInd now reports the volume name as "Unknown".
271
272 0.2.7 (4/19/2012):
273 ------------------
274
275 - After much trial and tribulation, I've overcome a GNU-EFI limitation and
276 enabled rEFInd to load EFI drivers. This feature was present in the
277 original build of rEFIt but was removed in the versions that could
278 compile under Linux, but now it's back -- and still being compiled under
279 Linux! To use it, you should place your drivers in a convenient directory
280 on the ESP (or whatever partition you use to launch rEFInd) and add a
281 "scan_driver_dirs" entry to refind.conf to tell rEFInd where to look. (As
282 always, you should specify the driver directory relative to the root of
283 the filesystem.) Note that you can't launch drivers from another
284 filesystem; they must be on the same volume that holds rEFInd. Those who
285 compile from source code should note that implementing this feature
286 necessitated using a more recent version of the GNU-EFI library. I'm
287 currently using version 3.0p, and version 3.0i does NOT work. I don't
288 know where the change occurred, but you may need to upgrade your GNU-EFI
289 installation.
290
291 - Fixed bug that caused rEFInd to show up in its own menu sometimes.
292
293 - Added new refind.conf token: also_scan_dirs. When scanning volumes for
294 EFI boot loaders, rEFInd always scans the root directory and every
295 subdirectory of the /EFI directory, but it doesn't recurse into these
296 directories. The also_scan_dirs token adds more directories to the scan
297 list. It defaults to "elilo,boot", but you can set it to any directory or
298 directories you like.
299
300 0.2.6 (4/14/2012):
301 ------------------
302
303 - Added "volume" keyword to configuration file's stanza options. This
304 option changes the volume from which subsequent files (specified by
305 "loader" and "icon") are loaded. You pass "volume" the name/label of the
306 FILESYSTEM you want to use (not the GPT partition name), or a number
307 followed by a colon (e.g., "1:"). The former should reliably identify a
308 filesystem, assuming the name is unique. The latter assigns numbers based
309 on the order in which they're scanned, which may not be as reliable but
310 should work when a volume is unnamed.
311
312 - Fixed bug in 0.2.5 that caused failure of Linux initial RAM disk
313 mapping on some (but not all) systems. Affected computers include at
314 least some Intel motherboards, maybe others.
315
316 0.2.5 (4/9/2012):
317 -----------------
318
319 - Fixed bug that caused an inability to associate initial RAM disks with
320 Linux kernels stored in a volume's root directory.
321
322 - Volume badges (that override default badges) are now stored in
323 .VolumeBadge.icns. Although undocumented, rEFInd formerly loaded custom
324 volume badges from .VolumeIcon.icns. This carryover from rEFIt was a
325 confusing name, given the next (new) feature, so I've changed and
326 documented the name....
327
328 - Added ability to set a default icon for a loader stored in the root
329 directory of a volume: The icon is stored in .VolumeIcon.icns. This icon
330 is also used for Mac OS X volumes booted from the standard location.
331
332 - Fixed bug that caused icons to drop back to generic icons when rEFInd
333 was launched in certain ways (such as from an EFI shell in rEFInd's
334 directory) on certain systems.
335
336 - Fixed bug that caused "unknown disable flag" to be shown (very briefly)
337 instead of "unknown hideui flag" when an improper hideui flag was set.
338
339 0.2.4 (4/5/2012):
340 -----------------
341
342 - Created new refind.conf entry: "showtools". This entry takes options of
343 "shell", "gptsync", "about", "exit", "reboot", and "shutdown". This
344 option is in some respects an affirmative version of portions of the old
345 "disable" and "hideui" options; however, it enables users to specify the
346 order in which these options appear on the screen. Also, the "exit"
347 option is new; it terminates the program. The effect is usually to return
348 to whatever tool launched it or to launch a default OS; however, this is
349 somewhat unpredictable. The default therefore omits the "exit" option, as
350 well as "gptsync", which has always been dangerous (but necessary on most
351 MacOS/Windows dual-boot setups on Macs). As part of this reconfiguration,
352 I've eliminated the "rescue Linux" option, which always seemed pointless
353 to me.
354
355 - Folded "disable" and "hideui" refind.conf entries into one ("disable"),
356 and reduced the number of options to six: "banner", "label",
357 "singleuser", "hwtest", "arrows", and "all". ("arrows" is new and
358 disables the scroll arrows when a system has too many tags to display
359 simultaneously.)
360
361 - Added max_tags option to the refind.conf file, enabling users to reduce
362 the maximum number of OS loader tags that can be displayed at once.
363
364 - Updated rEFIt icon, based on the 128x128 volume label from the rEFIt CD
365 image.
366
367 - Added x86 and x86-64 EFI shells to the CD image version of the binary,
368 but NOT to the binary zip file. The logic is that the CD image is more
369 likely to be used directly as an emergency disc and so may need this
370 feature, even though the source isn't part of the rEFInd project. (The
371 source is readily available from the TianoCore project.)
372
373 - EFI shells may now be stored at /shellx64.efi for x86-64 systems or at
374 /shellia32.efi for x86 systems. The /EFI/tools/shell.efi name is also
375 recognized; however, if both files are present, two EFI shell icons will
376 appear on the main menu. The /efi/{refind-path/apps/shell.efi filename,
377 which was never officially documented but worked as a carryover from
378 rEFIt, is no longer valid.
379
380 0.2.3 (3/26/2012):
381 ------------------
382
383 - Fixed (maybe) a bug that caused hangs when launching a second program
384 after returning from a first. There are some weird system-to-system
385 differences, though, and this fix causes (apparently harmless) error
386 messages about "(re)opening our installation volume" on at least one
387 system (a 32-bit Mac Mini). I'm committing this change because, imperfect
388 though it is, it's preferable to the earlier version, at least on my
389 small sample of computers.
390
391 - Because of news that the Linux kernel developers are planning to use the
392 filename linux.conf to hold Linux kernel configuration data for EFI
393 booting, I'm transitioning rEFInd away from that name and to
394 refind_linux.conf to avoid a conflict. This version can use either name,
395 with refind_linux.conf taking precedence if both are present.
396
397 - Added logo for Arch Linux.
398
399 0.2.2 (3/23/2012):
400 ------------------
401
402 - Fixed bug that caused program failure when Linux kernels with EFI stub
403 support were detected with no associated version numbers. rEFInd now
404 permits automatic linking of *ONE* versionless kernel to *ONE*
405 versionless initrd file.
406
407 - Fixed bug that caused program hangs when a boot loader filename or label
408 was too long. Such names are now properly truncated and program execution
409 continues.
410
411 - Fixed bug that caused no text to appear in submenus on UEFI systems with
412 small screens (800x600). NOTE: Problem still occurs on screens smaller
413 than this, but such systems are very rare.
414
415 0.2.1 (3/19/2012):
416 ------------------
417
418 - Added ability to set a "default_selection" that's a title or a substring
419 of one -- the name given to a stanza in a "menuentry" or the boot
420 loader's filename, in most cases, although "Mac OS X", "Windows XP
421 (XoM)", and "Microsoft EFI boot" are also titles.
422
423 - Added support for semi-automatic scans of Linux kernels with EFI stub
424 loader support. The program auto-detects matching initial RAM disk files
425 and loads additional options from the "linux.conf" file in the same
426 directory as the kernel.
427
428 - Added support for "submenuentry" keyword and associated sub-stanza
429 entries in refind.conf file.
430
431 - Renamed icons/os_mint.icns to icons/os_linuxmint.icns to match the
432 filename Linux Mint ACTUALLY uses for its ESP boot loader directory.
433
434
435 0.2.0 (3/14/2012):
436 ------------------
437
438 - Initial public release