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