forked from dakanji/RefindPlus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
NEWS.txt
2521 lines (1963 loc) · 115 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.12.0.AR (Pre-Release):
-----------------------
- Renames "trim_force" Config Option back to "force_trim"
* This more accurately reflects the action taken
- Fixes Several Memory Management Issues
* These had largely been introduced after the v0.12.0.AN Release
* One outcome had been a failure to run on units some units (mainly laptops)
- Adds 'EnforceAPFS' Feature
* Allows booting Mac OS Big Sur when SIP is disabled.
* Allows booting FileVault encrypted volumes directly.
0.12.0.AQ (03 Feb 2021):
-----------------------
- Fixes Volume Scanning Bug
* Volumes were not scanned for boot loaders if at least one user provided driver was not present
* This bug appeared in v0.12.0.AM
- Fixes Hidden Items Bug
* Tags and Tools could not be hidden and those hidden could not be managed
* This bug appeared in v0.12.0.AP
0.12.0.AP (02 Feb 2021):
-----------------------
- Misc Improvements to CSR Configuration Options
- Misc Improvements to Limit Memory Leaks
- Renames "force_trim" Config Option to "trim_force"
- Adds 'SupplyAPFS' Feature
* This eliminates the need for manually adding APFS drivers when APFS is not supported
- Adds 'SuppressVerboseAPFS' Feature
* This suppresses the scrolling loading text that appears when loading APFS drivers
* Provided as a separate item as its action may impact other text output
- Adds 'AllowDuplicates' Feature
* This allows scanning of partitions with duplicate filesystem UUIDs if required
- Fixes Default Legacy UEFI Scan Types
- Fixes Boot Loading Screen Interface on all Units
* Allows Boot Loading Screen such as the Mac Stage 1 Loading Screen to display correctly
* This had been unknowing fixed on MacPro5,1 units earlier and now extended to all units
* Hence, 'OsxAptioFix' drivers are no longer required on Macs and are actively discouraged
- Fixes Device Handle Connection Bug
* Device handles were not connected if at least one user provided driver was not present
* This resulted in GOP not not being acquired/provided from RAM when required in such instances
* This bug appeared in v0.12.0.AM
- Fixes Permitted Qemu Memory Leak Wokaround Bug
* A permitted memory leak supposed to be limited to Qemu had been applied to all users
* Additionally, the scope was larger than required
* This bug appeared in v0.12.0.AM
0.12.0.AN (04 Jan 2021):
-----------------------
- Adds 'EXT4_FEATURE_INCOMPAT_ENCRYPT' Support to Ext4 Driver
- Maps deprecated 'HandleProtocol' calls to 'OpenProtocol'
- Drops ineffective attempt to detect timezones
- Fixes issue with disappearing Mouse on x64 Arch
- Fixes Bogus Bootable Windows BIOS Instances
- Changes default config filename to config.conf
* Retains support for refind.conf
- Loads 'OsxAptioFix' driver on OpenCore Boots if required and available
* Enables the Stage 1 Loading Screen on some Classic Macs
- Fixes ESP detection for saving screenshots
* ESP detection may have sometimes returned 'true' on other locations
- Implements "force_trim" config option
* Enables 'TRIM' on non-Apple SSDs when booting into Mac OS
- Implements "disable_mac_compat_check" config option
* Disables Mac OS compatibility checks to allow booting new Mac OS Versions on unsupported Macs
- Implements "disable_amfi" config option
* Disables the Apple Mobile File Integrity (AMFI) checks in Mac OS
* Disabling AMFI may further facilitate booting new Mac OS Versions on unsupported Macs
- Implements "protect_mac_nvram" config option
* Prevents UEFI Windows from saving certificates to the NVRAM on Macs
* These certificates damage Apple NVRAM and result in an inability to start Macs up
- Implements "set_mac_boot_args" config option
* Allows setting arbitrary boot arguments on Mac OS
0.12.0.AM (07 Dec 2020):
-----------------------
- Optimises search for graphics capabilities and overall boot speed
- Adds workaround for broken QEMU support in the upstream v0.12.0 release
- Reinstalls GOP from Random Access Memory to provide bootscreen on EFI 1.x devices such as Classic MacPros when running GPUs with strict UEFI 2.x Implementation (Mainly Nvidia)
* Hence RefindPlus can now provide bootscreen when running any GPU with GOP
* The bootscreen will also be available to other tools, such as OpenCore, when chain-loaded from RefindPlus.
- Clears buffered key strokes on main menu
* This prevents immediately booting into a selected option on return from tools such as the UEFI Shell
- Encodes screenshots as PNG files instead of the previous large BMP files
- Save screenshots to the RefindPlus ESP when RefindPlus is run from an ESP
* Previously saved to the first ESP found which could be a different ESP
* This ensures screeshots are saved to the same ESP RefindPlus is located in
* Still saves to the first ESP found when run from HFS+ or other "Non-FAT" directories
- Changes logged device handle indices to hex
* Displays actual hex indices to permit consistency with shell tools
- Changes HiDPI monitor detection threshold to QHD vertical dimension (1601px)
* Previous threshold of 1921px on the horizontal mistook WQHD for HiDPI
- Adds ScaleUI config token to allow flexibility in HiDPI detection
* HiDPI monitor detection can be switched on/off or automatically detected by using this token
- Embeds Bootscreen and Nvram icons
* Specfic icons will be displayed instead of a generic icon when activated and actual icons are not found
0.12.0.AL (03 Nov 2020):
-----------------------
- Fixes Regression on Console GOP Provision on MacPro5,1
0.12.0.AK (02 Nov 2020):
-----------------------
- Fixes 'Write Protected' error (USB Mode)
- Uses Largest UGA Resolution found on GPU Handles
- Fixes UGA Fallback when GOP is not found
- Finetunes Direct GOP Renderer Handling
- Switches Direct GOP Renderer off by default
- Customises Tool and Driver Paths
- Misc Optimisation
* Misc coding intervention
0.12.0.AJ (05 Oct 2020):
-----------------------
- Fixes on-screen notices
- Debug log improvements
* Optimises Bootlog routines
* Provides different log files per login and no longer places all logs in one file
* Itemises found bootloaders
* Discarded superfluous log items
* Logs screensaver
* Logs details of found Bootloaders
- Optimises device connection routines
- Increase Keyboard Shortcut Keys to cover 10 Bootloaders
- Enhances screensaver function
- Improves Direct GOP Renderer Implementation
- General Stability Fixes
0.12.0.AH (07 Sep 2020):
-----------------------
- Rebrands 'Refind-GOPFix' as 'RefindPlus'
* This is to reflect wider scope of interventions beyond fixing GOP Screens
- Restores on-screen notices on Apple Firmware
* This fixes a long standing rEFInd bug that meant most on-screen notices could not be displayed on Macs
- Implements "ContinueOnWarning" config option
* This allows users to set RefindPlus to automatically proceed after waiting for a while on screen notices
- Fixes UGAPassThrough Feature
* The UGAPassThrough feature was sometimes not activated
- Handles Invalid GOP Instances
* Validates GOP Instances before providing console GOP
- Optimises Device Handle Connection
* Improve connection reliability as well as boot speed
- Misc Optimisation
* Removes more redundant wrapper calls
* Improves logging scope and presentation
* General look and feel improvements
* Misc coding intervention
0.12.0.AG (11 Aug 2020):
-----------------------
- Fixes Bug that Removed UGA Support and Disabled the Boot Screen on Legacy Fully Compatible GPUs
* This bug appeared in v0.12.0.B
- Implements BootKicker Feature from OpenCore
* This allows loading the Apple Boot Screen directly from Refind which may be
useful in getting the environment for full EFI Shell support.
* Requires GOP Capable Fully Compatible GPUs
- Implements Clean NVRAM Feature from OpenCore
* Allows resetting the NVRAM Directly from Refind
- Improves Direct GOP Renderer Implementation
- Expands and Improves Debug Logging
0.12.0.AF (07 Aug 2020):
-----------------------
- Misc Performance Optimisation
- Expands Debug Logging Coverage
- Implements Direct GOP Renderer from OpenCore
- Changes Default 'text_renderer' Status to FALSE
- Forces 'text_renderer' Configuration Setting to 'True' on Switch To Text
- Permits Running EFI Shell from 'BOOT/tools_x64' folder
- Permits Running Memtest from standard locations
- Permits using 'Memtest.efi' filename in addition to existing 'Memtest86.efi'
0.12.0.AE (04 Aug 2020):
------------------------
- Fixes GOP Selection Bug Introduced in v0.12.0.D
0.12.0.AD (04 Aug 2020):
-----------------------
- Fixes Debug Output Issues from v0.12.0.C
- Expands Debug Log Coverage
- Adds "text_renderer" as Configuration Option
* This allows switching the TextRenderer Feature, introduced in v0.12.0.C,
"ON" or "OFF" in the configuration file. Default is "ON"
- Adds "uga_pass_through" as Configuration Option
* This allows switching the UGAPassThrough" Feature, introduced in v0.12.0.C,
"ON" or "OFF" in the configuration file. Default is "ON"
- Adds "provide_console_gop" as Configuration Option
* This allows switching the ProvideConsoleGOP" Feature, introduced in v0.12.0.C,
"ON" or "OFF" in the configuration file. Default is "ON"
- Optimises libeg/screen.c by removing redundant wrapper calls from libeg/screen.c
* Various function calls were previously routed through a wrapper but can be
called directly instead to save on processing cycles
- Broadens the scope of the search for available Graphics Protocols
* This reduces false negatives when locating GOP, UGA and ConsoleControl.
0.12.0.AC (03 Aug 2020):
-----------------------
- Implements ProvideConsoleGOP from OpenCore
* This allows Pre-Boot Configuration Screens (Boot Screen) on units with broken
GOP Implementation (such as Classic MacPro 4,1 and 5,1 Models) when running Semi Compatible GPUs.
* Units such as the Classic MacPro 3,1 Models running Semi Compatible GPUs
can still display Boot Screens as before.
- Implements UGAPassThrough from OpenCore
* This allows Boot Screen on Operating Systems such as Mac OS v10.4 (Tiger) that use old EFIBoot processes
- Implements BuiltinText Renderer from OpenCore
* This fixes Text Mode on units with broken text display implementations such as Classic MacPros.
* This allows running EFI Shell on such units.
- Includes all Mac OS SIP Values for CSR Rotation (Thanks, Github User @startergo)
* This implements the actual Mac OS default value of 877 in place of the previously defined value of 77.
* This allows disabling SIP on, and booting with caveats, pre-release versions of Mac OS v11.0 (Big Sur)
- Expands Debug Logging
- Improves Boot Speed
0.12.0.AB (19 Jul 2020):
-----------------------
- Adds debug version
- Expands GOPFix to Classic MacPro 4,1 and 5,1 Models
- Should also show the Refind boot screen on non-Mac units running modern AMD GPUs such as the RX580
- Enables UGA if GOP is not found in case supported
0.12.0.AA (18 Jul 2020):
-----------------------
- Shows boot screen on Classic MacPro 3,1 Models running Semi Compatible GPUs
(Compatible GPUs without Mac EFI)
- Does not yet apply to Classic MacPro 4,1 or 5,1 Models
- Does not include Debug Version
0.12.0 (3/13/2020): UPSTREAM RELEASE
-------------------
- 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 Mac OS 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
--------------------
- 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 Mac OS' 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
--------------------
- 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): UPSTREAM RELEASE
-------------------
- 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 Mac OS 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 Mac OS boot loader locations used in Mac OS 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
-------------------
- 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 "Mac OS" 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 Mac OS version a given Mac OS boot loader will load,
so it's one name or the other for everything.
0.10.7 (4/17/2017): UPSTREAM RELEASE
-------------------
- 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 Mac 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
------------------
- 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): UPSTREAM RELEASE
-------------------
- 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): UPSTREAM RELEASE
-------------------
- 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 gST->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 Mac OS X 10.11 but
that lack this variable. Mac 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 Mac 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): UPSTREAM RELEASE
-------------------
- Fixed bug in refind-install that caused mountesp to be installed as a FILE
called /usr/local/bin on Mac 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): UPSTREAM RELEASE
--------------------
- 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 Mac OS X, but there's relatively little need for it
there.
0.10.0 (11/8/2015): UPSTREAM RELEASE
-------------------
- Fixed bug that caused refind-install to not unmount the ESP when it
should under Mac OS X.
- Modified refind-install and mkrlconf scripts to use /proc/cmdline as
source for default boot options EXCEPT when refind-install receives the
--root option. In that case, refind-install continues to use
/etc/default/grub as the source of default options. The idea behind this
change is that it's more reliable to get boot options from /proc/cmdline
when the targeted system is the one that's booted; but --root would be
used from emergency disks or live CDs, in which case the current boot
options would be completely wrong, so extracting boot options from GRUB
files is the best bet for getting close to the right options.
- Added "@/boot" to default also_scan_dirs setting. This makes kernels
show up on Btrfs volumes under Ubuntu (and perhaps others), at least when
the Btrfs driver is loaded.
- Added new System Integrity Protection (SIP) rotation feature for Macs
running Mac OS X 10.11 or later. This feature is disabled by default, except
on CD-R and USB flash drive images, on which it's enabled. To enable it,
you must make TWO changes to refind.conf: Uncomment the new "csr_values"
item and add "csr_rotate" to the "showtools" line (uncommenting it, too,
if it's commented out). If desired, you can set more values on
"csr_values"; these are comma-delimited one-byte hexadecimal values that
define various SIP states. When SIP/CSR rotation is activated, a new
shield icon appears among the tools. Selecting it causes the next defined
value to be set and a confirmation message to appear for three seconds.
- Added display of current System Integrity Protection (SIP) mode to
"About" display.
- Added mountesp script for Mac OS X to (you guessed it!) mount the ESP.
- Renamed support scripts: install.sh to refind-install, mvrefind.sh to
mvrefind, and mkrlconf.sh to mkrlconf.
- New icons! The old ones were getting to be a jumbled mess of styles,
particularly for OS tags. I used the AwOken icon set
(http://alecive.deviantart.com/art/AwOken-163570862) for the core icons,
then expanded from there by creating my own icons and modifying icons for
Debian and Elementary OS. I'm also trying to keep better track of
copyrights and licenses on icons. Between that and some icons being for
OSes that probably see very little use (FreeDOS and eComstation, for
instance), a few OS icons have been lost. If you prefer the old icons,
you can continue to use them by upgrading rEFInd, renaming icons-backup
to something else (say, icons-classic), and then adding an "icons" line
in refind.conf to point to the old icons directory.
- Changed from .zip to .tar.gz as source code archive format. I did this
because Linux is the only officially-supported build platform, and
tarballs are a more natural fit to a Linux environment. I'm leaving .zip,
.deb, and .rpm files as the formats for binary packages.
- Added detection of System Integrity Protection (SIP; aka "rootless") mode
to Mac OS X portion of install.sh script. When detected, and if no existing
rEFInd installation is found, the script now prints a warning and brief
instructions of how to enter the Recovery mode to install rEFInd and
suggests aborting the installation. (The user can override and attempt
installation anyhow.) If SIP is detected along with an existing rEFInd
installation, the script moderates the warning and explains that an
update of a working rEFInd will probably succeed, but that re-installing
to fix a broken rEFInd will probably fail.
- Added new "spoof_osx_version" token, which takes an Mac OS X version number
(such as "10.9") as an option. This feature, when enabled, causes rEFInd
to tell a Mac's firmware that the specified version of Mac OS X is being
launched. This option is usually unnecessary, but it can help properly
initialize some hardware -- particularly secondary video devices. OTOH,
on some Macs it can cause hardware (notably keyboards and mice) to become
unresponsive, so you should not use this option unnecessarily.
- Worked around an EFI bug that affected my 32-bit Mac Mini: That system
seems to have a broken EFI, or possibly a buggy CPU, that causes some
(but not all) conversions from floating-point to integer numbers to hang
the computer. Such operations were performed only in rEFInd's
graphics-resizing code, and so would manifest only when icons or
background images were resized. My fix eliminates the use of
floating-point operations in the affected function, which eliminates the
crashes. There may be some degradation in the quality of resized images,
though, particularly on 32-bit systems. (64-bit systems use larger
integers, which enable greater precision in my floating-point
workaround.)
- Under Mac OS X, install.sh can now be run from the recovery system. This may
help work around Mac OS X 10.11's problems with System Integrity Protection,
since it should be possible to reboot into the recovery system to install
rEFInd without disabling SIP for the main installation, even for just one
boot.
0.9.2 (9/19/2015): UPSTREAM RELEASE
------------------
- Added "--keepname" option to install.sh. This option causes install.sh
to keep refind_x64.efi named as such rather than rename it as grubx64.efi
when using Shim. This option is meaningful only if the --shim option is
also used. This option passes the refind_x64.efi filename as an option to
Shim, which overrides the default filename of grubx64.efi. A big caveat:
Only Shim 0.7 and later supports this feature. (Shim 0.4 also works if a
refind_x64.efi is referred to as "\refind_x64.efi" on the command line,
but the need for a leading backslash to refer to a file in the same
directory as Shim is so confusing and wrong that I cannot in good
conscience support it.) I've not seen signed Shim binaries between 0.4
and 0.7, so I don't know if any of them might work.
- Implemented a workaround for a bug in Shim 0.8 that prevented
authentication of more than one binary. If any filesystem drivers were
installed, the first one would be verified, leaving rEFInd unable to
launch anything else unless it was signed by a key in the computer's main
Secure Boot db list.
0.9.1 (9/13/2015): UPSTREAM RELEASE
------------------
- When rEFInd identifies the root (/) partition via the Freedesktop.org
Discoverable Partitions Specification, it now checks two of the
partition's attributes, as per the DPS (see
http://www.freedesktop.org/wiki/Specifications/DiscoverablePartitionsSpec/):
- The partition's read-only attribute determines whether to pass a "rw"
or "ro" option to the kernel.
- If the partition's do-not-automount flag is set, rEFInd will not pass
it as a "root=" option to the kernel. This flag can be used to remove
all but one partition from consideration as a root (/) partition if a
system has more than one with the correct type code.
- Improved Freedesktop.org Discoverable Partitions Specification support:
Previously, if no refind_linux.conf file was present but an /etc/fstab
file was found, rEFInd ignored the Discoverable Partitions Specification
filesystem-type codes. This was fine if /etc/fstab contained a valid "/"
filesystem specification, but if that was absent, the result was no
"root=" specification being present. Under these circumstances
(refind_linux.conf absent, /etc/fstab present but lacking a "/" entry),
rEFInd now tries to identify a device to specify as "root=" via the
Discoverable Partitions Specification.
- Fixed bug that caused "Found match!" and a prompt to press a key to
continue to be printed if any partition used the Freedesktop.org
Discoverable Partitions Specification root-partition GUID. (This
was leftover debugging/testing code that I somehow missed deleting.)
- Added icon for Elementary OS.
- Added /etc/lsb-release to files scanned for clues about the Linux
distribution. This file differentiates Mint and Elementary OS from Ubuntu
better than does /etc/os-release, and may also help with other
closely-related distributions.
- Improvements to handling of case-insensitive string comparisons. These
are buggy on some EFIs, and such bugs affect things like dont_scan_*
blacklists, removal of rEFInd's own directory from scanning, matching of
keyword names in refind.conf, and even loading of icons. I've replaced
many calls to problematic functions with safer calls, which should help a
lot. There may still be problems on some systems with some computers,
though; as far as I can tell, the bugs are buried deep in some EFI
firmware, so I can only replace some of the most direct calls to
potentially buggy system calls.
0.9.0 (7/26/2015): UPSTREAM RELEASE
------------------
- New icon for Kali Linux, submitted by Francesco D'Eugenio.
- Minor code changes to ensure that rEFInd compiles with GCC 5.1. (Tested
with GNU-EFI on a Fedora 22 system; not yet tested with the TianoCore
EDK2.)
- Added new "fold_linux_kernels" token to refind.conf. This option, when
active (the default) "folds" all Linux kernels in a directory into a
single entry on the rEFInd menu. The kernel with the most recent time
stamp is launched by default. To launch another kernel, you must press F2
or Insert; additional kernels appear as options on the first kernel's
submenu. To see the pre-0.9.0 behavior, you must set "fold_linux_kernels
false" (or one of its synonyms, "off" or "0"). The point of this option