-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathNEWS.txt
2694 lines (2061 loc) · 121 KB
/
NEWS.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
0.14.3 (?/??/2024):
-------------------
- Fixed bug in refind-mkdefault that would cause it to crash if the
BootOrder variable contained a pointer to a non-exitent Boot#### entry.
- Added icon for ArcaOS (icons/os_aos.png).
- Make writes of LoaderDevicePartUUID EFI variable non-persistent, to
minimize wear-and-tear on NVRAM.
0.14.2 (4/6/2024):
------------------
- Fixed bugs in RPM & Debian packaging related to Secure Boot:
- The post-install script would sometimes fail to detect that Secure
Boot was enabled, thus creating a non-bootable installation.
- The post-install script assumed that all Secure Boot installations
used Shim or PreLoader, thus failing to correctly install without Shim
on systems that used custom db keys.
- Removed code in RPM & Debian packaging scripts that removed an existing
rEFInd efibootmgr entry. This is obviated by code added to refind-install
some time ago.
- Updated Debian packaging to require debhelper >= 11 rather than 9, since
the latter is deprecated.
- Restructured code to detect most disk-based tools. The result is simpler
code, and may slightly alter what tools are found, likely increasing the
selection on systems with multiple disks or when tool binaries are stored
in distribution directories.
- Removed EFI\tools\memtest86, EFI\tools\memtest, EFI\memtest86, and
EFI\memtest from directories to be scanned for tools. This was done for
performance reasons.
- Added also_scan_tool_dirs token, for specifying additional directories to
scan for tools.
- Added indication of whether rEFInd was booted via Shim ("via Shim") or not
("direct") to the Info/About screen, on the "Platform" line, after the
Secure Boot "active" vs. "inactive" indication. Note that "via Shim" may
be specified even if Secure Boot is inactive, if the system is configured
to boot rEFInd via Shim but Secure Boot is disabled. This information was
already written to the refind.log file, when log_level is set to 1 or
above.
- Fixed a typo in a message in refind-sb-healthcheck.
- Fixed a bug in logging LoadedSize and SignaturePos variables in
IsValidLoader() on IA32/x86. (The variables needed explicit casts on the
32-bit architecture.)
- Fixed a bug that prevented Apple-specific "fat" EFI binaries (those with
both 32- and 64-bit binaries in one file) from showing up in rEFInd's
menu.
- Worked around a change in the compilation options required to build ARM64
binaries on GNU-EFI 3.0.17 and later. The default build still works for
older versions of GNU-EFI but requires the GNUEFI_ARM64_TARGET_SUPPORT
variable be set to "y", either on the command line or in Make.common, if
building with the newer library. Setting this variable is NOT required
when building ARM64 binaries with the TianoCore EDK2 or when building
X64/AMD64/x86-64 or IA32/x86 binaries with any version of GNU-EFI.
- Worked around two problems with GNU-EFI 3.0.18 that caused rEFInd binaries
built with that version to fail to load or to crash immediately after
loading.
- Makefile changes to reduce the binary size of GNU-EFI builds and enable
older versions of the GCC toolchain to create the SBAT section.
0.14.1 (3/24/2024):
-------------------
- Fixed bug that caused JPEG decoding to produce garbled images when rEFInd
was compiled with most Linux toolchains. It happened to work fine when
compiled with Ubuntu (which I use) or Gentoo, but not with Arch, Debian,
Fedora, or openSUSE.
- Fixed a memory leak in JPEG handling code.
- Fixed a bug that could cause some EFI programs (notably Pete Batard's
drivers on ARM64 systems) to be incorrectly marked as invalid.
- Improved error checking of log file creation and rotation. Bugs in
Tow-Boot (aka Das U-Boot) 8225.40 on a Raspberry Pi were interacting with
rEFInd's minimal error checking on log file rotation, causing rEFInd to
crash when attempting to rotate the log file. This is now fixed.
- Excise most BIOS/CSM/legacy scanning and boot code from builds that are
not on x86/IA32 or x86-64/AMD64/X64. This code is useless without a CSM,
which is a component that is useful only on x86/x86-64 systems. Removing
this useless code reduces binary size and minimizes the risk of
BIOS/CSM/legacy-related bugs affecting ARM64/AARCH64 builds (and
conceivably others, in the future).
- Added linux_prefixes token, which specifies string(s) that, when present
at the start of a filename, denote a Linux kernel.
- Replaced "bzImage" with "Image" as a kernel identifier on ARM64 systems.
(This is unchanged on x86/x86-64 systems.) Some Linux distributions call
their Linux kernels Image, Image.gz, or something else that starts with
"Image".
- Worked around a bug in at least one UEFI that could cause rEFInd to freeze
when doing a self-install.
- Added code to Btrfs driver to properly detect RAID1C3/4 configurations.
Code was borrowed from GRUB 2 by Ilya Guterman.
- Added icon for EndeavourOS, as submitted by Jack Rubacha.
- Fixed bug in refind-install that caused --ownhfs option to fail.
- If Memtest is discovered in a boot loader location, move its entry to the
tools line, rather than keep it in the boot loader line, if "memtest" is
among the "showtools" options. This helps de-clutter the boot loader line
with recent versions of Ubuntu. (For some reason, though, it fails to
launch from some filesystems, with a "not found" error, in either menu
position; but it launches fine if copied to the ESP.)
- Added memtest86+x64.efi and memtest86+ia32.efi (for AMD64 and IA32
architectures, respectively) as valid memtest filenames; and removed
bootx64.efi (and related architecture-specific names) as valid names,
since the latter conflict with the new option to recognize memtest in a
boot loader directory.
- Remove duplicate directory names when scanning for tools. Duplicates can
happen because of misconfiguration or because of the new code to find
Memtest in regular boot loader locations, if they happen to be in matching
directories on different disks (as in multiple Linux distributions on one
computer, with Memtest in the /boot directory on each one).
- Updated LodePNG to the latest (version 20230410).
0.14.0 (3/4/2023):
------------------
- Added ability to launch gzip-compressed loaders. This is useful mainly on
ARM64 platforms.
- Added support for .sbat sections in rEFInd binaries. These are needed
for recent versions of Shim to launch follow-on programs, including
rEFInd.
- Added new refind-sb-healthcheck script, which helps manage Secure Boot
keys. See the docs/refind/secureboot.html documentation and
docs/man/refind-sb-healthcheck.8 man page for details.
- Added new follow_symlinks option. This causes rEFInd to read loaders that
are symbolic links on filesystems that support this feature. In most
cases, these symlinks are redundant; but in some cases (such as on
openSUSE) following the symlinks is necessary to read a kernel. Credit to
dakanji for adding this feature.
- Minor cleanup of mkrlconf and refind-install scripts; should not affect
functionality
- Adrien Destugues submitted a new icon for the Haiku OS, based on an
official Haiku OS icon.
- The ext4fs driver now ignores the metadata_csum_seed flag, which is being
set by default in e2fsprogs 1.47.0 and later. Thanks to Martin Whitaker
for the relevant patch.
- Added several new Secure Boot keys for Red Hat in the keys directory.
(This doesn't affect rEFInd functionality; they're just there for
convenience.)
- Fixed bug in refind-install that caused it to fail to install the
filesystem driver in some Linux distributions. (The output of blkid
changed somewhere along the line, breaking refind-install.)
- Fixed bug in mkcdimage that caused USB flash drive image to be
damaged.
- Fixed bug that could cause rEFInd since 0.11.5 to freeze on some
computers.
- Fixed bugs that could cause rEFInd to freeze when opening a new log file,
opening filesystems, installing itself, or even just scanning for boot
loaders on some systems.
- Fixed a bug that could cause rEFInd to freeze if refind_linux.conf was
of zero length or had certain types of malformed content.
- Fixed a bug that would cause important error messages (such as those about
loader files that are missing, despite being in menus) appearing for a
fraction of a second and then disappearing.
- Fixed a bug that could cause directories specified in also_scan_dirs to
not be scanned if a filesystem/partition name was used in addition to a
directory path.
- Fixed a bug that caused generated RPM file and Debian package derived from
it by alien to not be properly signed with a Secure Boot key.
- Change to how refind-install manages local keys, which makes accidentally
deleting symlinked keys less likely. Thanks to Das Menschy for this fix.
- Updated LodePNG library to the latest version (20221108).
- The ReiserFS driver is now deprecated; see docs/refind/drivers.html for
details.
- Disallow parallel builds of filesystem drivers with GNU-EFI, since this
can cause problems.
0.13.3.1 (4/12/2022):
---------------------
- Fixed bug that caused refind-install to not recognize already-mounted
ESP in Linux. This was causing installation failures on some systems.
- Fixed bug in refind-install that caused duplicate EFI boot manager
entries when updating a rEFInd installation that used Shim.
0.13.3 (4/10/2022):
-------------------
- Fixed compile problem introduced somewhere between GNU-EFI 3.0.9 and
3.0.13.
- Fixed bug that could cause rEFInd to freeze when processing keystrokes
in menus.
- Fixed bug that caused option to return from folded Linux kernel submenu to
be missing.
- Code cleanup in bash scripts.
- Removed a stray exit command from refind-install, which caused
premature termination of the script.
- Minimized reading of HiddenTools variable, which was being read
unnecessarily often.
- Fixed handling of timeout == -1 when no keyboard is attached.
- Fixed display of arrow icons when those icons are larger than the stock
size because of manual specification of icon size in refind.conf.
- Updated Ubuntu icon for its 22.04 revision.
- Introduced log file rotation -- if refind.log-old exists and logging is
enabled, that log file is deleted and the existing log file is renamed to
refind.log-old. This enables preservation of two log files, which is
useful in case rEFInd crashes; the crash log file will be available as
refind.log-old.
- I am officially deprecating the "tiano" target, which builds with
TianoCore UDK2014 using custom Makefile rules rather than the usual
TianoCore build process. I'm doing this because it's badly broken in my
current build environment (Ubuntu 20.04). Although it may still work in
older configurations, I'm not currently using or testing it, and I see
no advantage to keeping it working.
0.13.2 (3/13/2021):
-------------------
- Fixed memory management bugs that could cause rEFInd to hang under
certain unpredictable circumstances.
- Fixed potential memory management bugs that could cause HFS+, ext2fs, and
ext4fs drivers to misbehave.
- Fixed bug (introduced with version 0.13.1) that caused rEFInd to fail to
load properly signed EFI drivers when Secure Boot was enabled and used via
Shim.
- Fixed bug in mvrefind that would cause it to fail to create a new
NVRAM entry to point to the moved rEFInd.
- Fixed bug that caused mountesp script to fail in macOS 11.0 ("Big Sur").
- Improved Secure Boot support in refind-install script: The script can now
install a Secure Boot key using mokutil, which can slightly simplify the
MOK setup. It also now creates a backup NVRAM entry to boot directly,
rather than via a Shim, if installed with the --shim option. This should
help on systems with custom Secure Boot key sets that don't rely on Shim,
but with a stray Shim binary present on the ESP that a package script will
detect and pass as a --shim option to rEFInd. If this configuration causes
a Secure Boot failure on launching Shim, then it should fail over to the
direct boot and be fine. (Some EFIs will hang rather than fail over to the
next entry, though, and this change won't help with them.)
- More logging improvements, including bumping the maximum log_level from 3
to 4.
- Improved separation of filesystem name vs. partition name internally. This
can make for more accurate OS icon choices in some situations, such as if
both names are set but only the partition name contains useful
information.
- Previously, when setting "use_nvram false", rEFInd would use the "vars"
subdirectory of its own directory; and if that was unwritable (say, if it
was on an HFS+ volume), then rEFInd would not store its own variables,
such as PreviousBoot and HiddenTags. With this version, rEFInd will now
use the "vars" subdirectory of rEFInd's own directory; if that's not
available, it will use a directory called "refind-vars" in the root
directory of the first ESP that rEFInd can locate; and if neither is
available, rEFInd will use NVRAM storage instead, as if "use_nvram true"
had been set.
- Made rEFInd's self-install code less finicky about the success of
copying configuration, icons, and driver files. Previously it reported a
failure and did not modify NVRAM if any of these failed to copy. Now it
should register itself, although it does complain on screen and log
details (if logging is enabled). This can help if installing from a source
that lacks drivers for a detectable Linux filesystem (ext2/3/4fs,
ReiserFS, Btrfs, or HFS+).
- Adjusted reporting of SIP values; added back 0x77 as an interpreted value
for on-screen notification when rotating through values.
- rEFInd can now identify JFS volumes as such, if a third-party JFS driver
is installed.
- Added support for Booster initrd files, which are named "booster*", rather
than "init*". See https://github.com/anatol/booster and/or
https://wiki.archlinux.org/index.php/Booster for more on Booster.
- Added icon for Manjaro Linux.
- Swapped out expired CentOS Secure Boot keys for new ones.
- Fixed build problem with GNU-EFI 3.0.13.
0.13.1 (2/24/2021):
-------------------
- Removed MyLibLocateProtocol(), based on RefindPlus code, because it
caused at least one Mac to hang.
- Fixed bug that could cause rEFInd to misbehave or hang if a disabled
manual boot stanza referenced a volume with a name that existed but was
unreadable.
- Added logging feature, activated by the log_level token in refind.conf.
This takes a numeric log level (currently from 0 to 3), with 0 meaning no
logging and 1-3 meaning increasing levels of logging. This feature is
intended to be used only when debugging problems, as it can slow rEFInd
down, especially at higher log levels.
- Updated LodePNG library to version 20201017.
- Fixed bug that caused rEFInd to not record a reboot to an EFI NVRAM-based
boot option, thus preventing it from being made the default boot option on
the next boot, if "default_selection +" was used.
- Added ability to write to the LoaderDevicePartUUID EFI variable, which
systemd uses to identify the ESP that was used to boot the computer, and
to mount that partition at /boot if that directory is empty and has
nothing else mounted. This rEFInd feature is activated by the
write_systemd_vars token in refind.conf, and is enabled by default.
- Modified EfivarSetRaw(), which rEFInd uses to write system variables, to
save a variable only if it does not currently exist or does not match the
new value. This is intended to reduce wear and tear on NVRAM storage.
(Previously, rEFInd did this with its own PreviousBoot variable, but this
change expands this functionality to apply to all EFI variables that
rEFInd might write.)
- Uncommented use_nvram from refind.conf-sample and set it to false. This
change will cause new rEFInd installations to save rEFInd's own variables
(PreviousBoot, HiddenTags, and others) on disk rather than in NVRAM.
Existing installations won't be affected by this change. The point is to
try to save wear and tear on NVRAM storage; however, users who install
rEFInd to an HFS+ volume will need to comment out use_nvram or set it to
true in order to use features that rely on rEFInd's variable storage.
- Additional replacements of "which" with "command -v" in mvrefind.
0.13.0 (2/15/2021):
-------------------
- Fixed compile problem with GCC version 10.
- Fixed compile problems with GCC 9 and the Btrfs and HFS+ drivers under
EDK2.
- Replaced use of "which" with "command -v" in shell scripts.
- Fixed detection of UUID on ext2/3/4 filesystems; old code incorrectly
marked filesystems with different UUIDs but the same label as duplicates.
- Fixed bug that caused mouse pointer to disappear on 64-bit systems when
it was moved, when mouse pointer support was active.
- Fixed memory management bug that could cause rEFInd to hang in some
situations.
- Fixed bug that could cause EFI 1.x (UGA graphics) systems to hang if
the refind.conf "resolution" line specified only one parameter. (This
is valid for EFI 2.x/GOP graphics systems, but not for UGA graphics.)
This misconfiguration, if found, is now ignored.
- Imported improvements from RefindPlus
(https://github.com/dakanji/refindplus):
- Expand list of supported Apple SIP/CSR values
- Add support for EXT4_FEATURE_INCOMPAT_ENCRYPT flag to ext4fs driver
- Improved detection of video modes
- New "max" option to "resolution" parameter in refind.conf (is
default in RefindPlus, but configurable option in rEFInd)
- Implemented new feature enabling rEFInd to set the EFI BootNext variable
and reboot into an EFI-defined boot loader. Such options are
auto-scanned if the new "firmware" option to the "scanfor" token is used;
and manual boot stanzas can use the new "firmware_bootnum" token, which
takes a hexadecimal number corresponding to the Boot#### number shown by
efibootmgr in Linux or under the EFI boot order editor in rEFInd.
0.12.0 (3/13/2020):
-------------------
- Plugged several memory leaks -- but many more remain.
- Change internal identification of rEFInd's volume from a volume name to a
Partition GUID, which is more precise and less likely to result in
mis-identification for purposes of not scanning rEFInd's own directory.
- Improved FAT partition discovery by including the FAT serial number, which
should prevent two FAT partitions with the same volume name as being
mis-identified as RAID mirrors, and thus ignoring one of them.
- Added a new EFI boot order maintenance option. To use it, uncomment the
"showtools" option in refind.conf and add the "bootorder" option to the
list. The resulting tool enables you to move any item in the EFI's boot
list to the top of the list or to delete any item in the list. (Deleted
entries will be removed from the BootOrder list AND their Boot#### entries
in NVRAM will be deleted.) You cannot create new options from this tool or
otherwise edit them. Note that this feature adjusts the *EFI's* boot
order, NOT the order of icons shown on rEFInd's screen.
- Added a new self-installation feature. When activated (by setting the
"install" token on the "showtools" line in refind.conf), selecting the
install icon in the second row on the main rEFInd screen will enable the
user to select a target ESP and, once one is selected, rEFInd will be
installed to that ESP, an NVRAM variable for it will be created, and that
variable will be set to the top of the boot order. This option is disabled
by default, except on the USB flash drive and CD-R images I create, and
when using the --usedefault option to refind-install. The intent is that
this feature can be used on emergency recovery media or to install rEFInd
for the first time. It's not likely to be useful in day-to-day use.
- Previous versions of rEFInd have all passed the name of the program being
launched as a parameter to that program, just as the EFI shell does. This
is causing problems for a new unified kernel image format that combines a
Linux kernel, initrd, EFI stub loader, and some other elements into a
single file. Thus, I'm changing to NOT passing the follow-on program's
filename as an option. (Gummiboot/systemd-boot and GRUB 2 both work this
way, and unless you explicitly add the program filename to the options
list, so does launching a file directly via an EFI boot manager entry
created via efibootmgr.) Note that rEFInd continues adding a space to the
end of options lists passed to the macOS boot loader, since it ignores the
commands if this is not done. (No space is added to commands passed to
other programs, though.)
- The handling of screen resets on return from a program has been adjusted
to avoid problems with program error messages being erased by rEFInd's
screen clearing. If a program returns an error code, its output should
remain visible until the user presses a key in response to rEFInd's prompt
to do so.
- Fixed bug that caused gptsync to sometimes hang on launch.
- Improved identification of the ESP in the refind-install script in Linux.
Previously, NVMe devices and some corner cases were handled incorrectly.
This new code should fix these problems. This variant changes from a
dependency on parted to one on the gdisk package (the sgdisk program,
specifically).
- Re-structured source code to split former main.c across four files
(main.c, launch_efi.c, linux.c, and scan.c), since main.c was getting
ridiculously large.
- I'm officially deprecating the ELILO- and XOM-specific code in rEFInd.
ELILO hasn't seen development on its Sourceforge page since 2013, and XOM
was rendered obsolete by Boot Camp and seems to have faded into
non-existence. The deprecated code is located in rEFInd's scan.c file and
simply creates sub-menus that pass options to these boot loaders. If
anybody wants to experiment with obsolete boot loaders, they can achieve
the same effect with manual boot stanzas; and if they don't need to pass
options to these boot loaders, they'll still work fine from rEFInd as
"generic" boot loaders. For the moment, the code remains in place, but I
may remove it on no further notice in the future.
0.11.5 (2/12/2020):
-------------------
- Fixed bug that caused screen corruption when exiting the EFI shell
(and perhaps other programs) on some systems.
- Fixed bug that could cause rescan operations (including after hiding
or un-hiding loaders or when using a scan delay) to hang rEFInd. This
seemed to be a problem mostly with buggy filesystem drivers.
- Cleaned up excessive slashes ("/") in refind-install script
- Corrected incorrect display of "scanning for boot loaders" message
under some circumstances
- Minor formatting changes to man pages
- Renamed .der certificates to .cer, for better compatibility with
KeyTool.efi
- If "%v" is in the kernel options in refind_linux.conf, do NOT
automatically include the auto-detected initrd file. This gives the user
greater control of initrd options when specifying them via in
refind_linux.conf via "%v", since an inappropriate auto-detected initrd
won't be included.
- No longer build NTFS driver by default; it's just too buggy. The source
code is still available and can be built by typing "make ntfs" in the
filesystems subdirectory.
- Documentation scrub: Updated to remove out-of-date references that
have accumulated over time.
- Updated LodePNG to latest version (20200211).
0.11.4 (11/12/2018):
--------------------
- Fixed a problem with RefindPkg.dsc that caused compilation failures
with the latest git version of TianoCore when using the edk2 target.
- Fixed a refind-install bug that caused it to misidentify the ESP when
adding a rEFInd boot entry when autofs was in use.
- Updates to NTFS and btrfs driver, provided by Samuel Liao.
- The NTFS driver fixes bugs related to fragmented files and filesystems
with a cluster size of over 4KiB.
- The btrfs driver adds support for zstd decompression, which requires a
huge (537K) buffer; and it fixes RAID1 issues and adds RAID5/6 support.
- Added references to several new themes to themes.html, and fixed a
broken URL in that file.
- Reverted a change to refind-install and mountesp scripts, introduced in
0.11.3, that caused them to fail when run in macOS's Recovery environment.
- Fixed bug, introduced in 0.11.3, that caused the default of booting
to the previously-launched loader to be lost in favor of launching the
first loader found. Explicitly setting the option via default_selection
still worked.
0.11.3 (7/22/2018):
-------------------
- Changes to scripts for portability; should have no visible effects.
- Updated pointer support to work on some (many? Most?) 32-bit systems.
- Added shutdown_after_timeout feature. When set, this causes rEFInd to
attempt to shut down the computer rather than boot the default option when
the timeout value is reached. Note, however, that some computers will
instead hang or reboot when the timeout value is reached because they lack
support for the shutdown option.
- Fixed bug that caused portions of the "Pausing before disk scan; please
wait...." message displayed when scan_delay is set to a value over 1 to
remain on screen.
- Added support for JPEG images. These are most useful as background
(banner) images, since alpha/transparency is not supported. For that
matter, progressive, lossless, and other JPEG features are not supported,
either; see https://keyj.emphy.de/nanojpeg/ for details.
- Added new use_nvram token, which defaults to true to mimic the original
behavior. When set to false, this option tells rEFInd to store its
variables (PreviousBoot, HiddenTags, HiddenLegacy, and Hidden tools, used
to enable booting the the previously-booted OS and to manage hidden OS
tags) on the hard disk rather than in NVRAM. Note that this token does NOT
affect rEFInd's reading NVRAM for non-rEFInd-specific variables, such as
the one holding the Secure Boot status.
- The "+" symbol in default_selection may now be placed anywhere in the
default_selection string to refer to the previous boot. For instance,
"bzImage,+,vmlinuz" now works, prioritizing any bzImage files over the
previous boot, but the previous boot over vmlinuz files.
- Added icons for Void Linux, Ubuntu 17.10, and Ubuntu 18.04.
- Copied the gummiboot icon (os_gummiboot.png) to os_systemd.png, so
that systemd-boot has an icon.
- Eliminated "Scanning for boot loaders; please wait" message from
initial boot scan, which seems to be universally disliked.
- Fixed bug that caused rEFInd to ignore refind.conf if the first
line was empty.
0.11.2 (10/22/2017):
--------------------
- Fixed a bug that caused the hidden-tags feature to not work unless
it was explicitly set in refind.conf. (It should have been enabled by
default, and now it is.)
- Fixed a bug (introduced in 0.11.1) that caused setting volumes in
manual boot stanzas to fail.
0.11.1 (10/9/2017):
-------------------
- Modified refind-install to be smarter about modifying NVRAM entries under
Linux. It now re-creates existing rEFInd entries only if the existing
entries don't point to the same location that rEFInd will use.
- Modified the way rEFInd tracks boot loader files. This was made necessary
by macOS 10.13/APFS, which was confusing rEFInd's old tracking code when
it was compiled with GNU-EFI. Ideally, this will have no noticeable effect
to end users; however, it's possible that some loaders will appear or
disappear from the menu, or "file not found" errors when launching loaders
will go away, after upgrading to this version of rEFInd.
- Added support for new macOS boot loader locations used in macOS 10.13
("High Sierra").
- Fixed bug that could cause hidden-tag maintenance tool to hang.
- Fixed bug, introduced in 0.11.0, that caused the Apple and Microsoft
recovery tools to not be detected.
0.11.0 (8/13/2017):
-------------------
- Fixed lack of scaling of disk badges when other icons were properly scaled
on HiDPI/retina displays.
- Added new --encryptkeys option to refind-install, to improve the security
of locally-generated Secure Boot keys stored on your computer's hard disk.
- Fixed spoof_osx_version to work with newer Apple EFIs.
- Added new mouse support: Uncomment enable_mouse in refind.conf to activate
this support. You can select an OS to launch with this feature active, but
you cannot use submenus via the mouse. The mouse_size and mouse_speed
tokens control the mouse size in pixels and tracking speed, respectively.
Note that not all computers support mice in their EFIs, which is why this
feature is disabled by default.
- Fixed bug that caused specifying a full path to the fallback boot
loader (EFI/BOOT/bootx64.efi) in dont_scan_files to fail to work.
- Added dont_scan_tools refind.conf token to enable hiding EFI tools.
This feature overrides scantools -- if the latter includes, say, "shell",
but the former includes "shell.efi", any shell called "shell.efi" will be
ignored. As with dont_scan_files, you can specify a "bare" filename or a
complete path. The point is to enable hiding redundant tools -- say, if
multiple MokManager tools show up in the menu and you want just one.
- A new feature enables you to hide OSes and external tool tags from the
rEFInd main menu: Highlight the OS tag and hit "-" or the Delete key. The
OS tag should disappear, and remain gone between reboots. A new tool tag
(on the second row) with a recycling icon enables recovering OS tags
hidden in this way.
- You can now specify volumes by GUID number in dont_scan_dirs and
dont_scan_files specifications -- e.g., "dont_scan_files
2C17D5ED-850D-4F76-BA31-47A561740082:\EFI\badloader\badloader.efi" to keep
EFI\badloader\badloader.efi on the volume with a partition GUID value of
2C17D5ED-850D-4F76-BA31-47A561740082 off the menu.
- I've removed support for the previously-deprecated volume-number style
volume specifications (fs0:, fs1:, etc.).
- Fixed bug in mvrefind that caused it to not move the EFI/BOOT-rEFIndBackup
directory back to EFI/BOOT when renaming rEFInd in EFI/BOOT to something
else.
- The refind-install and mvrefind scripts now create a BOOT.CSV file in the
rEFInd installation directory. The fallback.efi (aka fbx64.efi) program
delivered with many distributions can use this file to re-create rEFInd's
NVRAM boot entry should it be lost. Some distributions (such as Fedora)
set up fallback.efi in the EFI/BOOT directory on the ESP, so it will run
automatically if NVRAM variables are lost. All this said, there's no
guarantee that rEFInd will be FIRST in the boot order should the NVRAM
entries be lost.
- Improved error messaging on Macs; most serious system errors should now
be reported on-screen in graphics mode.
- Fixed bug that caused Fedora/CentOS/RHEL "vmlinuz-0-rescue*" kernels to
not be sorted down in the kernel list if they happened to be the first
ones passed to rEFInd by the EFI.
0.10.9 (7/30/2017):
-------------------
- The PauseForKey() function now works on Macs in graphics mode, which can
help when some errors are encountered. (Most of the errors associated with
this function still rely on Print(), which still doesn't work on Macs; but
at least there will be a prompt to press a key.)
- rEFInd now displays its background and banner before scanning for boot
loaders, and displays a message that it's performing this scan.
- Added support for HiDPI/retina displays: rEFInd now automatically scales
icons and text to twice the normal size when the screen's horizontal
resolution is above 1920. This does not occur in text mode (you must still
select an appropriate text-mode resolution via the "textmode" option in
refind.conf), and it can be overridden by explicitly setting the
"small_icon_size", "big_icon_size", and "font" options in refind.conf.
Note that icons are resized from their originals and so may look a bit
chunky, by HiDPI standards; but rEFInd now embeds both 14- and 28-point
fonts, so the fonts will look better. If the screen is HiDPI but 1920
pixels wide or less, the default icon and font sizes are used, so
adjustment via refind.conf options may still be desirable.
- Added os_trusty.png, os_xenial.png and os_zesty.png icons, for those who
have multiple Ubuntu versions and want to distinguish them visually.
- Updated LodePNG, which is used to load PNG images, to the latest version
(20161127).
- A new "edk2" target to "make" is available, which builds in the standard
TianoCore way. This has the advantage over the "tiano" target of working
with newer versions of EDK2, including the recently-released UDK2017
. (The
"tiano" target maxes out at UDK2014.)
- Improved compatibility with standard TianoCore-style build process; can
now build rEFInd binary, gptsync, and drivers in the "TianoCore" way, in
addition to by using Linux Makefiles.
0.10.8 (5/21/2017):
-------------------
- Added shimx64.efi.signed as a valid Shim source filename, and
mm{arch}.efi.signed as a valid MokManager source filename, to
refind-install script. This enables users on Ubuntu to point to Ubuntu's
signed Shim and MokManager files, which are stored in /usr/lib/shim under
these odd filenames.
- Fixed compile problems with GNU-EFI 3.0.5.
- Added icon for Devuan GNU+Linux, based on the icon in the Devuan press kit
(https://devuan.org/os/press/).
- Minor code efficiency improvements.
- Added ability to specify volumes by partition unique GUIDs in
dont_scan_volumes.
- Renamed "Mac OS X" to "macOS" in assorted messages, per Apple's
re-branding with version 10.12 (Sierra). Unfortunately, I don't know of an
easy way to tell which macOS version a given macOS boot loader will load,
so it's one name or the other for everything.
0.10.7 (4/17/2017):
-------------------
- Update refind-install to recognize and copy mmx64.efi as alternative
name for MokManager.
- Hide volume name "Recovery HD," if that's what it is, from loader
description. This is done because some OS X users are getting confused and
even upset over this detail, even though it's accurate, at least from an
EFI/rEFInd point of view.
- Fixed memory management bug (introduced in 0.10.6) that caused error
messages to be displayed on some systems.
0.10.6 (4/16/2017):
-------------------
- Fixed bug in drivers that could cause filesystems to not be registered,
and perhaps other unknown problems. This manifested on 32-bit GNU-EFI
compiles, but in principle it could cause problems on 64-bit or TianoCore
builds, too.
- Fixed bug in mvrefind that could cause it to fail to move the rEFInd
installation because it incorrectly converted the target directory to an
empty string if the target directory did not (yet) exist.
- Added mm{arch}.efi as MokManager filename, and fb{arch}.efi to list
of boot loaders to be ignored.
- New refind.conf token: extra_kernel_version_strings, which sets strings
that are treated something like digits for purposes of matching Linux
kernel and initrd filenames.
- Don't set the video mode if the computer is already running in the
requested mode. This is a shot-in-the-dark attempt to fix problems with
Mac "retina" displays, which tend to get bumped down to a lower resolution
by rEFInd.
0.10.5 (3/4/2017):
------------------
- Two improvements to initrd detection for Linux kernels:
- If multiple initrd files match the kernel's version number, the file
with more matching characters after the version number is used, rather
than the first initrd file found.
- The "%v" string, if present in the refind_linux.conf file's second
field, will be replaced by the kernel version number. Thus, you can
specify options like:
"Boot with standard initrd" "ro root=/dev/sda2 initrd=initrd-%v-std"
"Boot with debug initrd" "ro root=/dev/sda2 initrd=initrd-%v-debug"
This enables using multiple initrd files per kernel, to be used for
different purposes.
- Minor code optimization.
- Add new key mappings: Backspace (Delete on Mac keyboards) works the same
as Esc, and Tab works the same as F2/Insert/+. This is done for the
benefit of new Apple laptops that lack physical Esc and function keys.
- Fix to refind-install to work better with disks other than /dev/sd? and
/dev/hd? devices.
- Fixes to touch/tablet support to improve reliability.
0.10.4 (10/9/2016):
-------------------
- Fixed compile problem for drivers with recent versions of GNU-EFI
(3.0.4, maybe 3.0.3).
- Fixed bug that could cause program crash on startup. (In practice, it
manifested with GNU-EFI starting with version 3.0.3 or 3.0.4.)
- An anonymous contributor has provided support for touch screens. This
support requires that the "enable_touch" token be used in refind.conf.
Note, however, that not all tablet computers have EFIs that provide the
necessary support in the firmware.
- Martin Whitaker contributed 64-bit support to the ext4fs driver, which
makes it compatible with ext4fs as written by some recent Linux
distributions.
- Tweaked refind-install to do a better job of detecting disks other
than /dev/sd? and /dev/hd? devices.
0.10.3 (4/24/2016):
-------------------
- Altered RPM & Debian installation scripts so as to NOT call sbsign if
Secure Boot is disabled. This is a response to Ubuntu bug #1574372
(https://bugs.launchpad.net/ubuntu/+source/sbsigntool/+bug/1574372): In
Ubuntu 16.04, the sbsign program is segfaulting randomly, which prevents
proper installation of the program. This change at least permits proper
installation IF Secure Boot is disabled.
- Changed description of BIOS/CSM/legacy OS loaders on Macs to include the
string "(Legacy)", so as to more easily identify BIOS/CSM/legacy-mode OSes
in the rEFInd main menu.
- Added recognition of the fwupx64.efi file as a firmware update tool.
This filename is excluded from the first-row launchers, and is instead
presented on the second row, controlled by the "fwupdate" item on the
"showtools" option line. It's enabled by default. Note that it's still a
bit unclear to me how this tool is supposed to be used. rEFInd launches it
with no options, but if it should take options, this will have to be
changed in the future.
- Tightened exclusion of shell binary filenames from boot loader scan.
Previously, any filename containing the substring "shell" was excluded
from scans. Now it's tighter; only files matching one of the filenames in
the constant SHELL_NAMES in main.c are excluded. This change will enable
programs with names that include "shell", but that aren't in rEFInd's
SHELL_NAMES list, such as "shelly.efi", to be shown in the rEFInd main
menu.
- Fixed bug in NTFS driver that caused it to hang (and thus hang the
computer) in some situations, particularly when a file on an NTFS volume
had many fragments and when the computer's CSM was activated. (Fix
courtesy of "S L.")
- Modified SIP/CSR rotation code: If the csr-active-config EFI variable is
missing AND the firmware is Apple (as identified by the string "Apple"
being present in the ST->FirmwareVendor string), rEFInd treats the
computer as one on which SIP is available and set to the "enabled" state
(0x10). The upshot is that the SIP/CSR tool will appear if the showtools
and csr_values options are set appropriately in refind.conf, even if the
csr-active-config variable is missing from the NVRAM. The point of this
change is that I've received reports of some Macs that run OS X 10.11 but
that lack this variable. OS X acts as if SIP were enabled, but rEFInd is
then unable to disable SIP. This change gives rEFInd the ability to
disable SIP on such systems. The drawback is that the variable might be
set on some systems that don't run OS X 10.11. This should be harmless
from a technical point of view, but the presence of SIP indicators in
rEFInd could be confusing.
- Added refind-mkdefault script to simplify resetting rEFInd as the default
boot program in Linux. The intent is to run this after GRUB, Windows, OS
X, or some other tool takes over as the primary boot manager. It can be
called from a startup script to handle this task automatically.
0.10.2 (1/26/2016):
-------------------
- Fixed bug in refind-install that caused mountesp to be installed as a FILE
called /usr/local/bin on OS X if the /usr/local/bin directory did not
already exist.
- Fixed bug in mvrefind that caused it to fail to move bootmgfw.efi in
some situations, and another that caused it to give the resulting NVRAM
entry the default rEFInd name of "rEFInd Boot Manager," rather than the
intended "Windows Boot Manager" (to work around bugs in some EFIs).
- Worked around bug/quirk in some EFIs (in HP ProBook 6470b laptop, at
least) that prevented EFI filesystem drivers from working. (Drivers would
load but not provide access to filesystems.)
- Fixed refind-install bug that caused --usedefault option to not work in OS
X. (This bug did not affect Linux.)
- Improved Secure Boot detection in refind-install in Linux.
- Fixed bug that caused custom volume badges (vol_*.png) to be read only
from default location ("icons" subdirectory), effectively eliminating the
ability to adjust them.
- Added centos.crt and centos.cer public key files.
0.10.1 (12/12/2015):
--------------------
- Change to PPA version: Installing the PPA now queries the user about
whether to install to the ESP. Upgrades will remember the initial
selection.
- Modified time-based sorting of loaders in a single directory to push
anything starting with "vmlinuz-0-rescue" to the end of the list. Fedora
gives its rescue kernels filenames that begin with that string, and if
such a kernel happens to be the most recent, treating it normally will
cause it to become the default when kernel folding is in use. This is
almost certainly undesirable, so this change keeps the rescue kernel at
the end of the list instead, which is saner.
- Significantly reworked the project's Makefiles. This should have no
impact on ordinary users, and even most developers should barely notice
it; but it should make future extensions to additional platforms or
building in different environments easier.
- Added workaround to gptsync for issue with some Macs' EFIs that caused
the program to skip through all prompts, thus accepting the default
option. This would normally cause gptsync to do nothing.
- Added type code 53746F72-6167-11AA-AA11-00306543ECAC (Apple Core Storage,
gdisk type AF05) to list of partition types recognized by gptsync.
- Removed Luxi Sans Mono font, since I discovered it was not open source;
and changed the default font from Nimbus Mono to Liberation Mono.
- Added support for compiling rEFInd for ARM64 (aka AARCH64 or aa64). This
works with both GNU-EFI and Tianocore UDK2014.SP1.P1. This support is
currently poorly tested. In particular, I used QEMU on an x86-64 computer
to create a virtualized ARM64 environment; I've not yet tested on a real
computer. I couldn't get QEMU to create a video card, so I used a serial
terminal, which means that the graphics features are untested -- I ran
rEFInd with "textonly" uncommented in refind.conf. I've tested the ext4fs
driver but no other drivers, although they all compile. (So does gptsync,
although it's unlikely to be useful on ARM64.) Some rEFInd features are
meaningless on ARM64, such as BIOS-mode boot support, anything geared
toward Macs (csr_values/csr_rotate, spoof_osx_version, etc.), and
enable_and_lock_vmx.
- Fixed bug that caused rEFInd to fail to scan EFI boot loaders on
removable media when rEFInd itself was launched from the fallback
filename.
- Moved detailed descriptions of refind-install from installing.html to
a refind-install man page. To keep this information Web-accessible, I've
also created HTML versions of the three man pages and linked them into
the HTML documentation.
- Updated LodePNG to latest version (20151024).
- Fixed bugs in mkrlconf and in refind-install that could cause some kernel
options to be excluded from refind_linux.conf. There were two trouble
conditions:
- Previously, these scripts assumed that the first option in
/proc/cmdline was the kernel's filename, but this isn't always the
case. (In particular, when gummiboot launches the kernel, this is not
true. It might be an incorrect assumption in some other cases, too.)
The fix involves checking for likely signs of a kernel filename before
discarding this first option.
- These scripts cut the "initrd=*" option from /proc/cmdline, but the
call to "sed" was overzealous and cut until the end of input. This
usually worked, since the initrd= option was usually last on the line;
but if it wasn't, any options following initrd= would be lost.
- Added "kernel*" as a matching pattern for Linux kernels, since this is
what Gentoo uses by default.
- The refind-install script can now be run as a symbolic link in Linux.
This enables creating a /usr/sbin/refind-install link in Linux packages,
with the binaries stashed wherever the package system likes them. This
feature does NOT work in OS X, but there's relatively little need for it
there.
0.10.0 (11/8/2015):
-------------------