mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-09 01:18:35 +03:00
u-boot: Merge ostree's and systems uEnv.txt
This is a proper fix for: https://bugzilla.gnome.org/show_bug.cgi?id=755787 With this patch, an admin (system builder) can now: 1) Edit /usr/lib/ostree-boot/uEnv.txt 2) Deploy the new tree. OSTree will append system's uEnv.txt to the OSTree's managed uEnv.txt (loader/uEnv.txt). It is common for u-boot systems to read in an extra env from external /uEnv.txt. The same file OSTree uses to pass in its env. With this patch /uEnv.txt now contains OSTree's env + custom env added by system builders. Closes: #466 Approved by: cgwalters
This commit is contained in:
parent
47b0b4120a
commit
b6ec7526b5
@ -95,7 +95,45 @@ create_config_from_boot_loader_entries (OstreeBootloaderUboot *self,
|
|||||||
|
|
||||||
val = ostree_bootconfig_parser_get (config, "options");
|
val = ostree_bootconfig_parser_get (config, "options");
|
||||||
if (val)
|
if (val)
|
||||||
g_ptr_array_add (new_lines, g_strdup_printf ("bootargs=%s", val));
|
{
|
||||||
|
glnx_fd_close int uenv_fd = -1;
|
||||||
|
__attribute__((cleanup(_ostree_kernel_args_cleanup))) OstreeKernelArgs *kargs = NULL;
|
||||||
|
const char *uenv_path = NULL;
|
||||||
|
const char *ostree_arg = NULL;
|
||||||
|
|
||||||
|
g_ptr_array_add (new_lines, g_strdup_printf ("bootargs=%s", val));
|
||||||
|
|
||||||
|
/* Append system's uEnv.txt, if it exists in $deployment/usr/lib/ostree-boot/ */
|
||||||
|
kargs = _ostree_kernel_args_from_string (val);
|
||||||
|
ostree_arg = _ostree_kernel_args_get_last_value (kargs, "ostree");
|
||||||
|
if (!ostree_arg)
|
||||||
|
{
|
||||||
|
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||||
|
"No ostree= kernel argument found in boot loader configuration file");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
ostree_arg += 1;
|
||||||
|
uenv_path = glnx_strjoina (ostree_arg, "/usr/lib/ostree-boot/uEnv.txt");
|
||||||
|
uenv_fd = openat (self->sysroot->sysroot_fd, uenv_path, O_CLOEXEC | O_RDONLY);
|
||||||
|
if (uenv_fd != -1)
|
||||||
|
{
|
||||||
|
char *uenv = glnx_fd_readall_utf8 (uenv_fd, NULL, cancellable, error);
|
||||||
|
if (!uenv)
|
||||||
|
{
|
||||||
|
g_prefix_error (error, "Reading %s: ", uenv_path);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
g_ptr_array_add (new_lines, uenv);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (errno != ENOENT)
|
||||||
|
{
|
||||||
|
g_prefix_error (error, "openat %s: ", uenv_path);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
echo "1..16"
|
|
||||||
|
|
||||||
function validate_bootloader() {
|
function validate_bootloader() {
|
||||||
cd ${test_tmpdir};
|
cd ${test_tmpdir};
|
||||||
bootloader=""
|
bootloader=""
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
echo "1..16"
|
||||||
|
|
||||||
. $(dirname $0)/libtest.sh
|
. $(dirname $0)/libtest.sh
|
||||||
|
|
||||||
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
echo "1..16"
|
||||||
|
|
||||||
. $(dirname $0)/libtest.sh
|
. $(dirname $0)/libtest.sh
|
||||||
|
|
||||||
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
||||||
|
@ -20,9 +20,27 @@
|
|||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
echo "1..17"
|
||||||
|
|
||||||
. $(dirname $0)/libtest.sh
|
. $(dirname $0)/libtest.sh
|
||||||
|
|
||||||
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
# Exports OSTREE_SYSROOT so --sysroot not needed.
|
||||||
setup_os_repository "archive-z2" "uboot"
|
setup_os_repository "archive-z2" "uboot"
|
||||||
|
|
||||||
. $(dirname $0)/admin-test.sh
|
. $(dirname $0)/admin-test.sh
|
||||||
|
|
||||||
|
cd ${test_tmpdir}
|
||||||
|
ln -s ../../boot/ osdata/usr/lib/ostree-boot
|
||||||
|
cat << 'EOF' > osdata/boot/uEnv.txt
|
||||||
|
loaduimage=load mmc ${bootpart} ${loadaddr} ${kernel_image}
|
||||||
|
loadfdt=load mmc ${bootpart} ${fdtaddr} ${bootdir}${fdtfile}
|
||||||
|
loadramdisk=load mmc ${bootpart} ${rdaddr} ${ramdisk_image}
|
||||||
|
mmcargs=setenv bootargs $bootargs console=${console} ${optargs} root=${mmcroot} rootfstype=${mmcrootfstype}
|
||||||
|
mmcboot=run loadramdisk; echo Booting from mmc ....; run mmcargs; bootz ${loadaddr} ${rdaddr} ${fdtaddr}
|
||||||
|
EOF
|
||||||
|
${CMD_PREFIX} ostree --repo=testos-repo commit --tree=dir=osdata/ -b testos/buildmaster/x86_64-runtime
|
||||||
|
${CMD_PREFIX} ostree admin upgrade --os=testos
|
||||||
|
assert_file_has_content sysroot/boot/uEnv.txt "loadfdt="
|
||||||
|
assert_file_has_content sysroot/boot/uEnv.txt "kernel_image="
|
||||||
|
|
||||||
|
echo "ok merging uEnv.txt files"
|
||||||
|
Loading…
Reference in New Issue
Block a user