summaryrefslogtreecommitdiff
path: root/scripts/build
diff options
context:
space:
mode:
authorAdrian Gibanel Lopez <adrian.gibanel@btactic.com>2017-12-15 17:22:57 +0000
committeradrian15 <adrian15sgd@gmail.com>2019-03-14 23:06:31 +0100
commit80aa5ab61100b6b11ae47984bab9a2eb988074f5 (patch)
treeece51839c638892ebbdb2358200fd99268f90eaf /scripts/build
parenta410b8345de730b947d949f387730109f902c6c8 (diff)
downloadvyos-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-xscripts/build/chroot_linux-image2
-rwxr-xr-xscripts/build/config12
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)