diff options
author | Adrian Gibanel Lopez <adrian.gibanel@btactic.com> | 2017-12-15 17:22:57 +0000 |
---|---|---|
committer | adrian15 <adrian15sgd@gmail.com> | 2019-03-14 23:06:31 +0100 |
commit | 80aa5ab61100b6b11ae47984bab9a2eb988074f5 (patch) | |
tree | ece51839c638892ebbdb2358200fd99268f90eaf /scripts/build | |
parent | a410b8345de730b947d949f387730109f902c6c8 (diff) | |
download | vyos-live-build-80aa5ab61100b6b11ae47984bab9a2eb988074f5.tar.gz vyos-live-build-80aa5ab61100b6b11ae47984bab9a2eb988074f5.zip |
Fixed foreign architecture package support to linux kernel flavours
Before Stretch there was an special amd64 kernel in the i386 arch repo.
So if you wanted to install an amd64 kernel alongside an i386 system
you did not need an additional arch repo.
Debian added multiarch support. That way you can install library packages
from multiple architectures on the same machine.
So there is no longer a need for having an amd64 kernel in i386 arch repo.
You can add an amd64 arch repo to an i386 arch system and fetch the amd64
kernel from the am64 arch repo.
live-build can be setup to use several linux kernel flavours in a single
image.
So in the days previous to this patch you could issue:
lb config --linux-flavours "486 amd64"
to use both 486 and amd64 kernel flavours.
Adding additional arch support to linux flavours poses two problems:
* Packages need to have its arch suffix (e.g. amd64:amd64).
If the suffix is not there apt-get insists on search amd64 kernel
package on i386 arch repo and, of course, fails to find it.
* The rest of the code which handles labels (bootloader config files)
or installed filenames (kernel images themselves) do not use the arch suffix.
This patch adds foreign architecture package support to
linux kernel flavours having taken those problems into account.
Practical example usage: i386 system and extra amd64 kernel.
First add amd64 foreign architecture in your i386 system
thanks to:
dpkg --add-architecture amd64
apt-get update
.
Finally enable amd64 kernel from amd64 arch alongside the
i386 system's 686 kernel thanks to:
lb config --architectures i386 --linux-flavours "686 amd64:amd64"
Diffstat (limited to 'scripts/build')
-rwxr-xr-x | scripts/build/chroot_linux-image | 2 | ||||
-rwxr-xr-x | scripts/build/config | 12 |
2 files changed, 11 insertions, 3 deletions
diff --git a/scripts/build/chroot_linux-image b/scripts/build/chroot_linux-image index a96c4e529..e34743c1c 100755 --- a/scripts/build/chroot_linux-image +++ b/scripts/build/chroot_linux-image @@ -48,7 +48,7 @@ Create_lockfile .lock # ;; #esac -for FLAVOUR in ${LB_LINUX_FLAVOURS} +for FLAVOUR in ${LB_LINUX_FLAVOURS_WITH_ARCH} do for PACKAGE in ${LB_LINUX_PACKAGES} do diff --git a/scripts/build/config b/scripts/build/config index 6c2ab3b7b..cbf52d015 100755 --- a/scripts/build/config +++ b/scripts/build/config @@ -453,7 +453,7 @@ Local_arguments () ;; -k|--linux-flavours) - LB_LINUX_FLAVOURS="${2}" + LB_LINUX_FLAVOURS_WITH_ARCH="${2}" shift 2 ;; @@ -1132,8 +1132,16 @@ LB_INTERACTIVE="${LB_INTERACTIVE}" LB_KEYRING_PACKAGES="${LB_KEYRING_PACKAGES}" # \$LB_LINUX_FLAVOURS: set kernel flavour to use +# This is kept for backwards compatibility # (Default: autodetected) -LB_LINUX_FLAVOURS="${LB_LINUX_FLAVOURS}" +if [ -n "${LB_LINUX_FLAVOURS}" ] +then + LB_LINUX_FLAVOURS_WITH_ARCH="${LB_LINUX_FLAVOURS}" +fi + +# \$LB_LINUX_FLAVOURS_WITH_ARCH: set kernel flavour to use (with arch) +# (Default: autodetected) +LB_LINUX_FLAVOURS_WITH_ARCH="${LB_LINUX_FLAVOURS_WITH_ARCH}" # \$LB_LINUX_PACKAGES: set kernel packages to use # (Default: autodetected) |