[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 4/5] Add -k, --pubkey=FILE support to grub-install command
From: |
Jon McCune |
Subject: |
[PATCH v2 4/5] Add -k, --pubkey=FILE support to grub-install command |
Date: |
Fri, 6 Sep 2013 09:18:52 -0700 |
This simply passes along the public key to the grub-mkimage invocation
Signed-off-by: Jon McCune <address@hidden>
---
util/grub-install.in | 13 +++++++++----
util/grub-install_header | 6 ++++++
2 files changed, 15 insertions(+), 4 deletions(-)
diff --git a/util/grub-install.in b/util/grub-install.in
index 1816bb1..3df0087 100644
--- a/util/grub-install.in
+++ b/util/grub-install.in
@@ -650,10 +650,15 @@ case
"${grub_modinfo_target_cpu}-${grub_modinfo_platform}" in
*) imgext=img ;;
esac
+pubkey_file_arg=""
+if [ -e "$pubkey_file" ]; then
+ pubkey_file_arg="--pubkey=$pubkey_file"
+fi
+
if [ x"$config_opt_file" = x ]; then
- "$grub_mkimage" -d "${source_directory}" -O "${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/core.${imgext}"
--prefix="${prefix_drive}${relative_grubdir}" $grub_decompression_module
$modules || exit 1
+ "$grub_mkimage" "$pubkey_file_arg" -d "${source_directory}" -O
"${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/core.${imgext}"
--prefix="${prefix_drive}${relative_grubdir}" $grub_decompression_module
$modules || exit 1
else
- "$grub_mkimage" -c "${config_opt_file}" -d "${source_directory}" -O
"${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/core.${imgext}"
--prefix="${prefix_drive}${relative_grubdir}" $grub_decompression_module
$modules || exit 1
+ "$grub_mkimage" -c "${config_opt_file}" "$pubkey_file_arg" -d
"${source_directory}" -O "${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/core.${imgext}"
--prefix="${prefix_drive}${relative_grubdir}" $grub_decompression_module
$modules || exit 1
fi
# Backward-compatibility kludges
@@ -664,9 +669,9 @@ elif [
"${grub_modinfo_target_cpu}-${grub_modinfo_platform}" = "i386-ieee1275" ]
elif [ "${grub_modinfo_target_cpu}-${grub_modinfo_platform}" = "i386-efi" ] ||
[ "${grub_modinfo_target_cpu}-${grub_modinfo_platform}" = "x86_64-efi" ]; then
if [ x"$config_opt_file" = x ]; then
- "$grub_mkimage" -d "${source_directory}" -O "${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/grub.efi"
--prefix="" $grub_decompression_module $modules || exit 1
+ "$grub_mkimage" "$pubkey_file_arg" -d "${source_directory}" -O
"${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/grub.efi"
--prefix="" $grub_decompression_module $modules || exit 1
else
- "$grub_mkimage" -c "${config_opt_file}" -d "${source_directory}" -O
"${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/grub.efi"
--prefix="" $grub_decompression_module $modules || exit 1
+ "$grub_mkimage" -c "${config_opt_file}" "$pubkey_file_arg" -d
"${source_directory}" -O "${mkimage_target}"
--output="${grubdir}/${grub_modinfo_target_cpu}-$grub_modinfo_platform/grub.efi"
--prefix="" $grub_decompression_module $modules || exit 1
fi
fi
diff --git a/util/grub-install_header b/util/grub-install_header
index cf7fa9d..20a0321 100644
--- a/util/grub-install_header
+++ b/util/grub-install_header
@@ -156,6 +156,7 @@ grub_print_install_files_help () {
dir_msg="$(gettext_printf "use images and modules under DIR
[default=%s/<platform>]" "${libdir}/@PACKAGE@")"
print_option_help "-d, --directory=$(gettext "DIR")" "$dir_msg"
print_option_help "--grub-mkimage=$(gettext "FILE")" "$(gettext "use FILE
as grub-mkimage")"
+ print_option_help "-k, --pubkey=$(gettext "FILE")" "$(gettext "embed FILE
as public key for signature checking")"
print_option_help "-v, --version" "$(gettext "print the version
information and exit")"
}
@@ -168,6 +169,7 @@ grub_decompression_module=""
compressor=""
compressor_opts=""
source_directory=""
+pubkey_file=""
argument () {
opt=$1
@@ -245,6 +247,10 @@ grub_process_install_options () {
grub_mkimage=`argument $option "$@"`;
grub_process_install_options_consumed=2 ;;
--grub-mkimage=*)
grub_mkimage=`echo "$option" | sed
's/--grub-mkimage=//'`;grub_process_install_options_consumed=1 ;;
+ --pubkey | -k)
+ pubkey_file=`argument $option "$@"`;
grub_process_install_options_consumed=2 ;;
+ --pubkey=*)
+ pubkey_file=`echo "$option" | sed 's/--pubkey=//'`
grub_process_install_options_consumed=1;;
--modules)
modules=`argument $option "$@"`;
grub_process_install_options_consumed=2;;
--modules=*)
--
1.8.4
- [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, (continued)
- [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Jon McCune, 2013/09/06
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Andrey Borzenkov, 2013/09/06
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Jonathan McCune, 2013/09/06
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Andrey Borzenkov, 2013/09/07
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Jonathan McCune, 2013/09/09
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Andrey Borzenkov, 2013/09/19
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Jonathan McCune, 2013/09/19
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Vladimir 'φ-coder/phcoder' Serbinenko, 2013/09/19
- Re: [PATCH v2 2/5] load_env support for whitelisting which variables are read from an env file, even if check_signatures=enforce, Andrey Borzenkov, 2013/09/19
- [PATCH v2 3/5] save_env should work, even if check_signatures=enforce, Jon McCune, 2013/09/06
- [PATCH v2 4/5] Add -k, --pubkey=FILE support to grub-install command,
Jon McCune <=
- [PATCH v2 5/5] Additional security-relevant documentation, Jon McCune, 2013/09/06