summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThierry Vignaud <thierry.vignaud@gmail.com>2018-11-22 04:21:11 +0100
committerThierry Vignaud <thierry.vignaud@gmail.com>2018-11-22 08:24:21 +0100
commit9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0 (patch)
tree114137f24f6005d734b980f4b9a01abaab4ce0e4
parent1c97bdb720c166c3d44b50d414b38dea338c7f99 (diff)
downloaddrakx-9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0.tar
drakx-9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0.tar.gz
drakx-9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0.tar.bz2
drakx-9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0.tar.xz
drakx-9f3b9ebfdcebcfc9d202a9e2aa155278c83776f0.zip
doc: explain how to support a bootloader
-rw-r--r--perl-install/bootloader.pm46
1 files changed, 46 insertions, 0 deletions
diff --git a/perl-install/bootloader.pm b/perl-install/bootloader.pm
index 215e70f42..71d50eaa6 100644
--- a/perl-install/bootloader.pm
+++ b/perl-install/bootloader.pm
@@ -33,6 +33,50 @@ Example of usage:
(...)
bootloader::action($bootloader, 'write', $all_hds);
+A particular bootloader is handled in separate typical functions that can be called by action() by /sbin/bootloader-config:
+
+
+=head1 VFS aka how to support a bootloader
+
+Most of the code is generic.
+
+A particular bootloader implementation/support is done through a couple functions:
+
+=over 4
+
+=item * read_FOOBAR()
+
+read the config file(s) of the FOOBAR bootloader, returning a $bootloader object
+
+=item * install_FOOBAR($bootloader, $all_hds)
+
+usually call write_FOOBAR() & install_raw_FOOBAR() if existing, aka:
+
+=over 4
+
+=item * updating config files
+
+=item * then reinstalling the bootloader
+
+=back
+
+=item * install_raw_FOOBAR()
+
+Optionnal: Low level installation of the stage1 of the bootloader, usually embedding it in MBR or on ESP, ... (eg: running lilo or /boot/grub*/install.sh)
+
+=item * write_FOOBAR($bootloader, $all_hds)
+
+update the config files, ie when a kernel was installed or removed.
+when_config_changed_FOOBAR() is called right after in case something is needed when config is done (eg: lilo needs to be reinstalled)
+
+=item * when_config_changed_FOOBAR()
+
+Run needed action when config has changed or when initrds were regenerated, ...
+Usually nothing for intelligent bootloaders such as grub-legacy or grub2.
+But eg: lilo needs to rewrite its stage1 (thus it needs to rerun lilo).
+
+=back
+
=head1 Functions
=over
@@ -2419,6 +2463,8 @@ Calls the C<$action> function with @para parameters:
If needed, the function name will be resolved to call a boot loader specific function (eg: for LILO/GRUB/...)
+This Swiss army knife function is heavily used by eg /sbin/bootloader-config
+
=cut
sub action {