diff options
author | Christian Poessinger <christian@poessinger.com> | 2019-04-26 17:45:27 +0200 |
---|---|---|
committer | Christian Poessinger <christian@poessinger.com> | 2019-04-26 17:45:27 +0200 |
commit | 574bfb639918cc1f8217af4ee2eccaaf8c25b19a (patch) | |
tree | a2a38bd2806f1ac4b1bc1b635c47ee5c43cdc9c6 | |
parent | 3461366285233f2b3237f4a7c88c1da58f24a53d (diff) | |
parent | f8dbc8a37ff5935408a6a71907fea4fb0f5b5e46 (diff) | |
download | vyos-build-574bfb639918cc1f8217af4ee2eccaaf8c25b19a.tar.gz vyos-build-574bfb639918cc1f8217af4ee2eccaaf8c25b19a.zip |
Merge branch 'current' of github.com:vyos/vyos-build into buster
* 'current' of github.com:vyos/vyos-build:
Docker: fix pmacct build dependencies
Packages: support --blacklist option to not build individual packages
Packages: fix missing bytes stuck in the output buffer
Docker: add package requirements to build keepalived
Docker: Use close sections when working with jessie-backports
README: adjust chapters to new VyOS package build script
Packages: extract kernel version from defaults.json
Packages: use 'make kernelversion' instead of grep magic
Packages: add bgpq3 (debian/0.1.33-1) package to build procedure
Jenkins: archive ISO and build.log artifacts
Makefile: proper handle 'make iso' error codes
Packages: remove vyatta-quagga
Packages: add ethtool (debian/1%4.19-1) package to build procedure
Packages: define custom command for vyos-strongswan
intel: adjust URL for ixgbevf 4.5.2
Replace build-submodules with Python based package builder
Remove outdated/unmaintained submodules
75 files changed, 723 insertions, 864 deletions
@@ -3,4 +3,4 @@ build/* packer_build/* packer_cache/* key/* -packages/*.buildlog +packages/* diff --git a/.gitmodules b/.gitmodules index c470fb3b..e69de29b 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,252 +0,0 @@ -[submodule "packages/vyatta-bash"] - path = packages/vyatta-bash - url = https://github.com/vyos/vyatta-bash.git - branch = current -[submodule "packages/vyatta-cfg"] - path = packages/vyatta-cfg - url = https://github.com/vyos/vyatta-cfg.git - branch = current -[submodule "packages/vyatta-op"] - path = packages/vyatta-op - url = https://github.com/vyos/vyatta-op.git - branch = current -[submodule "packages/vyatta-cfg-system"] - path = packages/vyatta-cfg-system - url = https://github.com/vyos/vyatta-cfg-system.git - branch = current -[submodule "packages/vyatta-cfg-firewall"] - path = packages/vyatta-cfg-firewall - url = https://github.com/vyos/vyatta-cfg-firewall.git - branch = current -[submodule "packages/vyatta-op-firewall"] - path = packages/vyatta-op-firewall - url = https://github.com/vyos/vyatta-op-firewall.git - branch = current -[submodule "packages/vyatta-cfg-vpn"] - path = packages/vyatta-cfg-vpn - url = https://github.com/vyos/vyatta-cfg-vpn.git - branch = current -[submodule "packages/vyatta-op-vpn"] - path = packages/vyatta-op-vpn - url = https://github.com/vyos/vyatta-op-vpn.git - branch = current -[submodule "packages/vyatta-cfg-qos"] - path = packages/vyatta-cfg-qos - url = https://github.com/vyos/vyatta-cfg-qos.git - branch = current -[submodule "packages/vyatta-op-qos"] - path = packages/vyatta-op-qos - url = https://github.com/vyos/vyatta-op-qos.git - branch = current -[submodule "packages/vyatta-cfg-op-pppoe"] - path = packages/vyatta-cfg-op-pppoe - url = https://github.com/vyos/vyatta-cfg-op-pppoe.git - branch = current -[submodule "packages/vyatta-openvpn"] - path = packages/vyatta-openvpn - url = https://github.com/vyos/vyatta-openvpn.git - branch = current -[submodule "packages/vyatta-conntrack"] - path = packages/vyatta-conntrack - url = https://github.com/vyos/vyatta-conntrack.git - branch = current -[submodule "packages/vyatta-conntrack-sync"] - path = packages/vyatta-conntrack-sync - url = https://github.com/vyos/vyatta-conntrack-sync.git - branch = current -[submodule "packages/vyatta-nat"] - path = packages/vyatta-nat - url = https://github.com/vyos/vyatta-nat.git - branch = current -[submodule "packages/vyatta-config-mgmt"] - path = packages/vyatta-config-mgmt - url = https://github.com/vyos/vyatta-config-mgmt.git - branch = current -[submodule "packages/vyatta-config-migrate"] - path = packages/vyatta-config-migrate - url = https://github.com/vyos/vyatta-config-migrate.git - branch = current -[submodule "packages/vyatta-zone"] - path = packages/vyatta-zone - url = https://github.com/vyos/vyatta-zone.git - branch = current -[submodule "packages/vyatta-cluster"] - path = packages/vyatta-cluster - url = https://github.com/vyos/vyatta-cluster.git - branch = current -[submodule "packages/vyatta-eventwatch"] - path = packages/vyatta-eventwatch - url = https://github.com/vyos/vyatta-eventwatch.git - branch = current -[submodule "packages/vyatta-webproxy"] - path = packages/vyatta-webproxy - url = https://github.com/vyos/vyatta-webproxy.git - branch = current -[submodule "packages/vyatta-cfg-quagga"] - path = packages/vyatta-cfg-quagga - url = https://github.com/vyos/vyatta-cfg-quagga.git - branch = current -[submodule "packages/vyatta-op-quagga"] - path = packages/vyatta-op-quagga - url = https://github.com/vyos/vyatta-op-quagga.git - branch = current -[submodule "packages/vyatta-op-dhcp-server"] - path = packages/vyatta-op-dhcp-server - url = https://github.com/vyos/vyatta-op-dhcp-server.git - branch = current -[submodule "packages/vyatta-wireless"] - path = packages/vyatta-wireless - url = https://github.com/vyos/vyatta-wireless.git - branch = current -[submodule "packages/vyatta-wirelessmodem"] - path = packages/vyatta-wirelessmodem - url = https://github.com/vyos/vyatta-wirelessmodem.git - branch = current -[submodule "packages/vyatta-wanloadbalance"] - path = packages/vyatta-wanloadbalance - url = https://github.com/vyos/vyatta-wanloadbalance.git - branch = current -[submodule "packages/vyatta-netflow"] - path = packages/vyatta-netflow - url = https://github.com/vyos/vyatta-netflow.git - branch = current -[submodule "packages/vyatta-lldp"] - path = packages/vyatta-lldp - url = https://github.com/vyos/vyatta-lldp.git - branch = current -[submodule "packages/vyatta-ipv6-rtradv"] - path = packages/vyatta-ipv6-rtradv - url = https://github.com/vyos/vyatta-ipv6-rtradv.git - branch = current -[submodule "packages/vyatta-ravpn"] - path = packages/vyatta-ravpn - url = https://github.com/vyos/vyatta-ravpn.git - branch = current -[submodule "packages/vyos-nhrp"] - path = packages/vyos-nhrp - url = https://github.com/vyos/vyos-nhrp.git - branch = current -[submodule "packages/vyatta-util"] - path = packages/vyatta-util - url = https://github.com/vyos/vyatta-util.git - branch = current -[submodule "packages/vyos-world"] - path = packages/vyos-world - url = https://github.com/vyos/vyos-world.git - branch = current -[submodule "packages/vyos-kernel"] - path = packages/vyos-kernel - url = https://github.com/vyos/vyos-kernel.git - branch = linux-vyos-4.19.y -[submodule "packages/vyos-1x"] - path = packages/vyos-1x - url = https://github.com/vyos/vyos-1x.git - branch = current -[submodule "packages/mdns-repeater"] - path = packages/mdns-repeater - url = https://github.com/vyos/mdns-repeater.git - branch = current -[submodule "packages/udp-broadcast-relay"] - path = packages/udp-broadcast-relay - url = https://github.com/vyos/udp-broadcast-relay.git - branch = current -[submodule "packages/vyos-keepalived"] - path = packages/vyos-keepalived - url = https://github.com/vyos/vyos-keepalived.git - branch = current -[submodule "packages/vyatta-iproute"] - path = packages/vyatta-iproute - url = https://github.com/vyos/vyatta-iproute.git - branch = iproute2-vyos-4.18.y -[submodule "packages/vyatta-quagga"] - path = packages/vyatta-quagga - url = https://github.com/vyos/vyatta-quagga.git - branch = current -[submodule "packages/vyos-wireguard"] - path = packages/vyos-wireguard - url = https://github.com/vyos/vyos-wireguard.git - branch = current -[submodule "packages/pmacct"] - path = packages/pmacct - url = https://github.com/vyos/pmacct.git - branch = current -[submodule "packages/vyos-strongswan"] - path = packages/vyos-strongswan - url = https://github.com/vyos/vyos-strongswan.git - branch = current -[submodule "packages/vyos-accel-ppp"] - path = packages/vyos-accel-ppp - url = https://github.com/vyos/vyos-accel-ppp.git - branch = current -[submodule "packages/frr"] - path = packages/frr - url = https://github.com/FRRouting/frr.git - branch = master -[submodule "packages/conntrack-tools"] - path = packages/conntrack-tools - url = https://github.com/vyos/conntrack-tools.git - branch = current -[submodule "packages/eventwatchd"] - path = packages/eventwatchd - url = https://github.com/vyos/eventwatchd.git - branch = current -[submodule "packages/ddclient"] - path = packages/ddclient - url = https://github.com/vyos/ddclient.git - branch = current -[submodule "packages/vyatta-biosdevname"] - path = packages/vyatta-biosdevname - url = https://github.com/vyos/vyatta-biosdevname.git - branch = current -[submodule "packages/vyos-opennhrp"] - path = packages/vyos-opennhrp - url = https://github.com/vyos/vyos-opennhrp.git - branch = current -[submodule "packages/vyos-salt-minion"] - path = packages/vyos-salt-minion - url = https://github.com/vyos/vyos-salt-minion.git - branch = current -[submodule "packages/rtrlib"] - path = packages/rtrlib - url = https://github.com/rtrlib/rtrlib.git -[submodule "packages/libvyosconfig"] - path = packages/libvyosconfig - url = https://github.com/vyos/libvyosconfig.git - branch = master -[submodule "packages/vyos-vmwaretools-scripts"] - path = packages/vyos-vmwaretools-scripts - url = https://github.com/vyos/vyos-vmwaretools-scripts.git - branch = current -[submodule "packages/vyconf"] - path = packages/vyconf - url = https://github.com/vyos/vyconf.git - branch = master -[submodule "packages/vyos-netplug"] - path = packages/vyos-netplug - url = https://github.com/vyos/vyos-netplug.git - branch = current -[submodule "packages/vyos-xe-guest-utilities"] - path = packages/vyos-xe-guest-utilities - url = http://github.com/vyos/vyos-xe-guest-utilities.git - branch = current -[submodule "packages/igmpproxy"] - path = packages/igmpproxy - url = https://github.com/vyos/igmpproxy.git - branch = current -[submodule "packages/hvinfo"] - path = packages/hvinfo - url = https://github.com/dmbaturin/hvinfo.git - branch = master -[submodule "packages/libyang"] - path = packages/libyang - url = https://github.com/opensourcerouting/libyang.git - branch = debian -[submodule "packages/ipaddrcheck"] - path = packages/ipaddrcheck - url = https://github.com/vyos/ipaddrcheck.git -[submodule "packages/lldpd"] - path = packages/lldpd - url = https://github.com/vincentbernat/lldpd.git -[submodule "packages/pdns-recursor"] - path = packages/pdns-recursor - url = https://salsa.debian.org/dns-team/pdns-recursor.git diff --git a/Jenkinsfile b/Jenkinsfile index 4bc64b26..90c38d1c 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,22 +1,76 @@ #!/usr/bin/env groovy +// Copyright (C) 2018 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + @NonCPS + +def getGitBranchName() { + return scm.branches[0].name +} + +def getGitRepoURL() { + return scm.userRemoteConfigs[0].url +} + +// Returns true if this is a custom build launched on any project fork, +// returns false if this is build from git@github.com:vyos/vyos-build.git +def isCustomBuild() { + def gitURI = "git@github.com:vyos/vyos-build.git" + def httpURI = "https://github.com/vyos/vyos-build.git" + + return ! ((getGitRepoURL() == gitURI) || (getGitRepoURL() == httpURI)) +} + def setDescription() { def item = Jenkins.instance.getItemByFullName(env.JOB_NAME) - item.setDescription("VyOS image build using a\nPipeline build inside Docker container.") + + // build up the main description text + def description = "" + description += "<h2>Build VyOS ISO image</h2>" + description += "All required Vyatta/VyOS packages are build from source prior to assembling the ISO." + + if (isCustomBuild()) { + description += "<p style='border: 3px dashed red; width: 50%;'>" + description += "<b>Build not started from official Git repository!</b><br>" + description += "<br>" + description += "Repository: <font face = 'courier'>" + getGitRepoURL() + "</font><br>" + description += "Branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" + description += "</p>" + } else { + description += "Sources taken from Git branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" + } + + item.setDescription(description) item.save() } -setDescription() - /* Only keep the 10 most recent builds. */ def projectProperties = [ - [$class: 'BuildDiscarderProperty',strategy: [$class: 'LogRotator', numToKeepStr: '5']], + [$class: 'BuildDiscarderProperty',strategy: [$class: 'LogRotator', numToKeepStr: '1']], ] properties(projectProperties) +setDescription() pipeline { + options { + disableConcurrentBuilds() + timeout(time: 4, unit: 'HOURS') + parallelsAlwaysFailFast() + } agent { dockerfile { filename 'Dockerfile' @@ -27,23 +81,71 @@ pipeline { } stages { - stage('Submodule Init') { + stage('VyOS Packages') { steps { - sh ''' - git submodule update --init --recursive --remote - ''' + script { + def build = [:] + // get a list of available package from scripts/build-packages + packageList = sh( + script: "scripts/build-packages -l | grep '*' | sed -e 's/ \\* //'", + returnStdout: true + ).split("\r?\n") + + packageList.each { pkg -> + skipList = ['vyos-kernel', 'vyos-wireguard', 'vyos-accel-ppp'] + if (pkg in skipList) { + return + } + + // add each object from 'packageList' to the 'build' array + build[pkg] = { + // we're already in the script{} block, so do our advanced stuff here + sh( + script: "scripts/build-packages -vvv -b ${pkg}", + returnStdout: true + ) + } + } + // Still within the 'Script' block, run the parallel array object + parallel build + } } } - stage('Build Packages') { + + stage('Kernel') { steps { - sh ''' - #!/bin/sh - scripts/build-submodules --verbose - ''' + sh "scripts/build-packages -vvv -b vyos-kernel" + } + } + + stage('Kernel Modules') { + steps { + script { + def build = [:] + kernelModules = ['vyos-wireguard', 'vyos-accel-ppp'] + kernelModules.each { pkg -> + // add each object from 'packageList' to the 'build' array + build[pkg] = { + // we're already in the script{} block, so do our advanced stuff here + sh( + script: "scripts/build-packages -vvv -b ${pkg}", + returnStdout: true + ) + } + } + // Still within the 'Script' block, run the parallel array object + parallel build + } } } - stage('Build ISO') { + stage('Intel Drivers') { + steps { + sh "KSRC=\$(pwd)/packages/vyos-kernel scripts/build-intel-drivers" + } + } + + stage('ISO Image') { steps { sh ''' #!/bin/sh @@ -55,9 +157,6 @@ pipeline { # Configure the ISO ./configure --build-by="autobuild@vyos.net" --debian-mirror="http://ftp.us.debian.org/debian/" - # Debug to see which Debian packages we have so far - ls -al packages/*.deb - # Finally build our ISO sudo make iso ''' @@ -66,6 +165,12 @@ pipeline { } post { + always { + archiveArtifacts artifacts: 'build/build.log', fingerprint: true + } + success { + archiveArtifacts artifacts: 'build/vyos*.iso', fingerprint: true + } cleanup { echo 'One way or another, I have finished' // the 'build' directory got elevated permissions during the build @@ -28,9 +28,13 @@ prepare: .ONESHELL: iso: check_build_config clean prepare @set -e + @set -o pipefail @echo "It's not like I'm building this specially for you or anything!" cd $(build_dir) lb build 2>&1 | tee build.log + if [ "$?" != "0" ]; then + exit 1 + fi cd .. @scripts/copy-image @@ -13,7 +13,7 @@ VyOS is not new. It is a fork of Vyatta Core that was created when the open source version of it was discontinued. If you are a Vyatta Core user, you can upgrade your installation to VyOS. -# What is this repository? +# About this repository VyOS is a GNU/Linux distribution based on Debian. Just like any other distribution, it consists of multiple packages. @@ -28,23 +28,34 @@ This is the top level repository that contains links to repositories with VyOS specific packages (organized as Git submodules) and scripts and data that are used for building those packages and the installation image. -# Structure of this repository +# Repository Structure There are several directories with their own purpose: - build/ Used for temporary files used for the build and for build artifacts - scripts/ Scripts that are used for the build process - data/ Data required for building the ISO (such as boot splash) - tools/ Scripts that are used for maintainer's tasks automation and other - purposes, but not during ISO build process + * `build/` Used for temporary files used for the build and for build artifacts + * `scripts/` Scripts that are used for the build process + * `data/` Data required for building the ISO (e.g. boot splash/configs) + * `tools/` Scripts that are used for maintainer's tasks automation and other + purposes, but not during ISO build process -# Building VyOS installation images +# Building installation images ## Prerequisites To build a VyOS 1.2.0 image, you need Debian 8 "Jessie" environment (with jessie-backports repository). +If you are working on a Debian Jessie machine, no special preparation is needed, +you only need to enable jessie-backports and install build dependencies. + +If you are interested which individual packages are required please check our +[Dockerfile](docker/Dockerfile) which holds the most complete documentation +of required packages. Listing individual packages here tend to be always +outdated. We try to list required packages in groups through their inheritance +in the [Dockerfile](docker/Dockerfile). + +### Debootstrap + If you do not have a Debian Jessie machine, you may create a chroot environment with the [debootstrap](https://wiki.debian.org/Debootstrap) tool. @@ -56,97 +67,18 @@ $ sudo apt-get install debootstrap $ sudo debootstrap jessie vyos-chroot $ sudo chroot vyos-chroot -$ echo "deb http://deb.debian.org/debian jessie-backports main" >> /etc/apt/sources.list +$ echo "deb http://archive.debian.org/debian/ jessie-backports main" >> /etc/apt/sources.list $ apt-get update ``` -If you are working on a Debian Jessie machine, no special preparation is needed, -you only need to enable jessie-backports and install build dependencies. An -up-to-date dependency list can be found in our [Dockerfile](docker/Dockerfile). - -Several packages are required for building the ISO: -* `python3` -* `live-build` -* `pbuilder` -* `python3-pystache` - -The `./configure` script will warn you if any dependencies are missing. Individual -packages may have other build dependencies. If some dependencies are missing, -package build scripts will tell you. - -## Building the ISO image - -Before you can build an image, you need to configure your build. - -To build an image, use the following commands: - -```bash -$ ./configure -$ make iso -``` +**NOTE:** We recommend to use the Docker build method -The `./configure` script has a number of options that you can see by calling it -with `--help` - -## Building the images for virtualization platforms - -### QEMU - -Run following command after building the ISO image. - -```bash -$ make qemu -``` - -### VMware - -Run following command after building the QEMU image. - -```bash -$ make vmware -``` - -## Building the ISO image inside a docker container +### Docker Using our [Dockerfile](docker/Dockerfile) you create your own Docker container that is used to build a VyOS ISO image or other required VyOS packages. The [Dockerfile](docker/Dockerfile) contains some of the most used packages needed -to build a VyOS ISO, a qemu image, and several of the submodules. Please note -that this is not complete and only gives you a brief overview! - -``` -squashfs-tools # Required for squashfs file system -git # Required, for cloning the source -autoconf # Required, for generating build scripts -dpkg-dev # Required, used in build scripts -live-build # Required, for ISO build -syslinux # Required, for ISO build -genisoimage # Required, for ISO build -make # Required, for ISO build -lsb-release # Required, used by configure script -fakechroot # Required, for ISO build -devscripts # Optional, for building submodules (kernel etc) -kernel-package # Optional, for building the kernel -libtool # Optional, for building certain packages (vyatta-op-vpn) -libglib2.0-dev # Optional, for building vyatta-cfg -libboost-filesystem-dev # Optional, for building vyatta-cfg -libapt-pkg-dev # Optional, for building vyatta-cfg -flex # Optional, for building vyatta-cfg -bison # Optional, for building vyatta-cfg -libperl-dev # Optional, for building vyatta-cfg -libnfnetlink-dev # Optional, for building vyatta-cfg-vpn -vim # Optional, vim, vi, nano or other text editor -jq # Optional, for qemu build -qemu-system-x86 # Optional, for qemu build -qemu-utils # Optional, for qemu build -packer # Optional, for qemu build -quilt # Optional, for building vyos-1x -python3-lxml # Optional, for building vyos-1x -python3-setuptools # Optional, for building vyos-1x -python3-nose # Optional, for building vyos-1x -python3-coverage # Optional, for building vyos-1x -... -``` +to build a VyOS ISO, a qemu image, and several of the submodules. To build the docker image ensure you have a working [Docker](https://www.docker.com) environment and then run the following commands: @@ -155,7 +87,7 @@ environment and then run the following commands: $ docker build -t vyos-builder docker ``` -Run the newly built container: +Run newly built container: ```bash $ docker run --rm -it --privileged -v $(pwd):/vyos -w /vyos vyos-builder bash ``` @@ -181,34 +113,109 @@ Linux 948a2be7c52c 3.16.0-7-amd64 #1 SMP Debian 3.16.59-1 (2018-10-03) x86_64 GN After the Docker container is running you can follow up the instructions below in order to build the VyOS ISO image. -## Building subpackages inside Docker +## Building the ISO image + +The `./configure` script will warn you if any dependencies are missing. Individual +packages may have other build dependencies. If some dependencies are missing, +package build scripts will tell you. + +```bash +$ ./configure --help +usage: configure [-h] [--build-by BUILD_BY] [--version VERSION] + [--pbuilder-debian-mirror PBUILDER_DEBIAN_MIRROR] + [--debian-security-mirror DEBIAN_SECURITY_MIRROR] + [--architecture ARCHITECTURE] [--vyos-mirror VYOS_MIRROR] + [--build-type BUILD_TYPE] [--debian-mirror DEBIAN_MIRROR] + [--debug] [--custom-apt-entry CUSTOM_APT_ENTRY] + [--custom-apt-key CUSTOM_APT_KEY] + [--custom-package CUSTOM_PACKAGE] + +optional arguments: + -h, --help show this help message and exit + --build-by BUILD_BY Builder identifier (e.g. jrandomhacker@example.net) + --version VERSION Version number (release builds only) + --pbuilder-debian-mirror PBUILDER_DEBIAN_MIRROR + Debian repository mirror for pbuilder env bootstrap + --debian-security-mirror DEBIAN_SECURITY_MIRROR + Debian security updated mirror + --architecture ARCHITECTURE + Image target architecture (amd64 or i386 or armhf) + --vyos-mirror VYOS_MIRROR + VyOS package mirror + --build-type BUILD_TYPE + Build type, release or development + --debian-mirror DEBIAN_MIRROR + Debian repository mirror for ISO build + --debug Enable debug output + --custom-apt-entry CUSTOM_APT_ENTRY + Custom APT entry + --custom-apt-key CUSTOM_APT_KEY + Custom APT key file + --custom-package CUSTOM_PACKAGE + Custom package to install from repositories +``` -Prior to building packages you need to checkout and update the submodules you want to compile +Before you can build an image, you need to configure your build. + +Each build needs to run the `./configure` step first where you can extend your +ISO by additional packages (`--custom-package`) or specify who build this nice +ISO image (`--build-by`). If you have local Debian mirrors, you can select them +by `--debian-mirror` or `--debian-security-mirror`. ```bash -$ git submodule update --init packages/PACKAGENAME -$ cd packages/PACKAGENAME -$ git checkout BRANCH +$ ./configure --custom-package vim --build-by jrandom@hacker.com +$ sudo make iso ``` -`PACKAGENAME` is the name of the package you want to compile -`BRANCH` is `crux` for VyOS 1.2.x, latest rolling releases use `current` +After some time you will find the resulting ISO image in the `build` folder. + +### Building images for virtualization platforms -Fetching all submodules at once and update them to the recent remote branches -`HEAD` is done by calling: +#### QEMU + +Run following command after building the ISO image. ```bash -$ git submodule update --init --recursive -$ git submodule update --remote +$ make qemu ``` -### Building packages +#### VMware -The [scripts/build-submodules](scripts/build-submodules) script is used to -automate the process of building (in the future) all VyOS related packages that -are not part of the upstream Debian version. Execute it in the root of the -`vyos-build` directory to start compilation on all supported packages that are -checked out. +Run following command after building the QEMU image. + +```bash +$ make vmware +``` + +## Building subpackages inside Docker + +VyOS requires a bunch of packages which are VyOS specific and thus can not be +found in any Debian Upstream mirrror. Those packages can be found at the VyOS +GitHub project (https://github.com/vyos) and there is a nice helper script +available to build and list those individual packages. + +[scripts/build-packages](scripts/build-packages) provides an easy interface +to automate the process of building all VyOS related packages that are not part +of the upstream Debian version. Execute it in the root of the `vyos-build` +directory to start compilation. + +```bash +$ scripts/build-packages -h +usage: build-packages [-h] [-v] [-c] [-l] [-b BUILD [BUILD ...]] [-f] [-p] + +optional arguments: + -h, --help show this help message and exit + -v, --verbose Increase logging verbosity for each occurance + -c, --clean Re-clone required Git repositories + -l, --list-packages List all packages to build + -b BUILD [BUILD ...], --build BUILD [BUILD ...] + Whitespace separated list of packages to build + -f, --fetch Fetch sources only, no build + -p, --parallel Build on all CPUs +``` + +Git repositoriers are automatically fetched and build on demand. If you wan't to +work offline you can fetch all source code first with the `-f` option. The easiest way to compile is with the above mentioned [Docker](docker/Dockerfile) container, it includes all dependencies for compiling supported packages. @@ -216,8 +223,7 @@ container, it includes all dependencies for compiling supported packages. ```bash $ docker run --rm -it -v $(pwd):/vyos -w /vyos \ --sysctl net.ipv6.conf.lo.disable_ipv6=0 \ - vyos-builder \ - ./scripts/build-submodules + vyos-builder scripts/build-packages ``` **NOTE:** `--sysctl net.ipv6.conf.lo.disable_ipv6=0` is required to build the @@ -226,7 +232,7 @@ $ docker run --rm -it -v $(pwd):/vyos -w /vyos \ **NOTE:** Prior to executing this script you need to create or build the Docker container and checkout all packages you want to compile. -### Building a single package +### Building single package(s) The script above runs all package build inside the Docker container, this is also possible to do by hand using: @@ -236,30 +242,15 @@ Executed from the root of `vyos-build` ```bash $ docker run --rm -it -v $(pwd):/vyos -w /vyos/packages/PACKAGENAME \ --sysctl net.ipv6.conf.lo.disable_ipv6=0 \ - vyos-builder \ - dpkg-buildpackage -uc -us -tc -b + vyos-builder scripts/build-packages -b <package> ``` **NOTE:** `--sysctl net.ipv6.conf.lo.disable_ipv6=0` is only needed when building `vyos-strongswan` and can be ignored on other packages. -**NOTE:** Prior to executing this you need to checkout and update the submodules -you want to recompile! - **NOTE:** `vyos-strongswan` will only compile on a Linux system, running on macOS or Windows might result in a unittest deadlock (it never exits). -Packages that are known to not build using this procedure (as of now): - -``` -vyatta-util - Not needed anymore -vyatta-quagga - Not needed anymore -vyos-1x - Unmet build dependencies: whois libvyosconfig0 -vyos-frr - A lot of requirements, scary stuff... -vyos-kernel - Need special build instructions -vyos-wireguard - Needs special build instructions -``` - # Development process ## Git branches diff --git a/data/kernel_version b/data/kernel_version index 1a6cc42f..ab416d6c 100644 --- a/data/kernel_version +++ b/data/kernel_version @@ -1 +1 @@ -4.19.32-amd64-vyos +4.19.36-amd64-vyos diff --git a/docker/Dockerfile b/docker/Dockerfile index e43c6bbd..a7d18fef 100644 --- a/docker/Dockerfile +++ b/docker/Dockerfile @@ -68,7 +68,12 @@ RUN apt-get update && apt-get install -y \ pkg-config \ debhelper \ gosu \ - live-build + live-build \ + jq + +# Package needed for mdns-repeater +RUN apt-get update && apt-get install -y \ + dh-systemd # # Building libvyosconf requires a full configured OPAM/OCaml setup @@ -116,10 +121,6 @@ RUN eval $(opam env --root=/opt/opam --set-root) && \ dpkg-buildpackage -uc -us -tc -b && \ dpkg -i ../libvyosconfig0_*_amd64.deb -# Package needed for mdns-repeater -RUN apt-get update && apt-get install -y \ - dh-systemd - # Packages needed for vyatta-cfg RUN apt-get update && apt-get install -y \ libglib2.0-dev \ @@ -141,7 +142,7 @@ RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \ libpcap-dev \ libpq-dev \ - default-libmysqlclient-dev \ + libmysqlclient-dev \ libgeoip-dev \ librabbitmq-dev \ libjansson-dev \ @@ -181,6 +182,14 @@ RUN export RTRLIB_VERSION="0.6.3" && \ cd /tmp/rtrlib-${RTRLIB_VERSION} && dpkg-buildpackage -uc -us -tc -b && \ dpkg -i ../librtr*_amd64.deb ../librtr*_all.deb +# +# Setup VyOS Debian repository +# +COPY vyos-dev.key /tmp/vyos-dev.key +RUN apt-key add /tmp/vyos-dev.key +RUN echo "deb http://dev.packages.vyos.net/repositories/current/debian/ current main" \ + > /etc/apt/sources.list.d/vyos.list + # Packages needed to build frr itself # libyang-dev packages are hsoted on dev.packages.vyos.net see # https://github.com/FRRouting/frr/blob/master/doc/developer/building-libyang.rst @@ -196,6 +205,11 @@ RUN apt-get update && apt-get install -y \ python3-pytest \ texinfo +# +# Cleanup VyOS Debian Repository +# +RUN rm -f /etc/apt/sources.list.d/vyos.list + # Packages needed for conntrack-tools RUN apt-get update && apt-get install -y \ libnetfilter-conntrack-dev \ @@ -248,6 +262,7 @@ RUN apt-get update && apt-get install -y \ dh-apparmor \ gperf \ libsystemd-dev \ + python3-stdeb \ python-setuptools # Packages needed for vyos-opennhrp @@ -258,9 +273,14 @@ RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \ xmlto -# Install packer +# Packages needed for keepalived RUN apt-get update && apt-get install -y \ - jq + libnl-3-200 \ + libnl-3-dev \ + libnl-genl-3-200 \ + libnl-genl-3-dev + +# Install packer RUN export LATEST="$(curl -s https://checkpoint-api.hashicorp.com/v1/check/packer | \ jq -r -M '.current_version')"; \ echo "url https://releases.hashicorp.com/packer/"$LATEST"/packer_"$LATEST"_linux_amd64.zip" |\ diff --git a/packages/.gitignore b/packages/.gitignore deleted file mode 100644 index ed11cabe..00000000 --- a/packages/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -*.dsc -*.tar.gz -*.deb -*.build -*.changes diff --git a/packages/conntrack-tools b/packages/conntrack-tools deleted file mode 160000 -Subproject 77cf2ae1cfc281ab11d3fa5ddc73c11bcb60ccd diff --git a/packages/ddclient b/packages/ddclient deleted file mode 160000 -Subproject 869a613c81245678f1261034ff941fc047c2c15 diff --git a/packages/eventwatchd b/packages/eventwatchd deleted file mode 160000 -Subproject c3d8ae7352f3e9c65b0f05dda245d144252574c diff --git a/packages/frr b/packages/frr deleted file mode 160000 -Subproject c72622322df02e02cb9b6d01379052c1ddda2b5 diff --git a/packages/hvinfo b/packages/hvinfo deleted file mode 160000 -Subproject 6d15dff8eb5418a23035d18078f367bc799b702 diff --git a/packages/igmpproxy b/packages/igmpproxy deleted file mode 160000 -Subproject 1f87c675725bff8f380bf7364c3961ee5a5a9e4 diff --git a/packages/ipaddrcheck b/packages/ipaddrcheck deleted file mode 160000 -Subproject 8f0d655cc68995a0ef88dc905dc62db2af23ec9 diff --git a/packages/libvyosconfig b/packages/libvyosconfig deleted file mode 160000 -Subproject e75e4ae638c49e512a3013d1806e59a67978c5f diff --git a/packages/libyang b/packages/libyang deleted file mode 160000 -Subproject 179da47f2e8def1907372408a9df97a0dcbc134 diff --git a/packages/lldpd b/packages/lldpd deleted file mode 160000 -Subproject adbb26bc0a49d083472d24762255ff48bd001e4 diff --git a/packages/mdns-repeater b/packages/mdns-repeater deleted file mode 160000 -Subproject 051977458f4078a06008bb6c6fd338cd994cf56 diff --git a/packages/pdns-recursor b/packages/pdns-recursor deleted file mode 160000 -Subproject 28af51a3942875f0896fab2ea5945ded4a19197 diff --git a/packages/pmacct b/packages/pmacct deleted file mode 160000 -Subproject 313a010b72817a34348ad405ff911b10b923003 diff --git a/packages/rtrlib b/packages/rtrlib deleted file mode 160000 -Subproject db2d254d75b835abb169f2f9e4a8cfbe74a3c36 diff --git a/packages/udp-broadcast-relay b/packages/udp-broadcast-relay deleted file mode 160000 -Subproject 13127cbd62e69be2d186c9d76d112729ea95a1e diff --git a/packages/vyatta-bash b/packages/vyatta-bash deleted file mode 160000 -Subproject 001f9b1a9bd2b307bca94510ce05bc067e34f84 diff --git a/packages/vyatta-biosdevname b/packages/vyatta-biosdevname deleted file mode 160000 -Subproject 28ccb143a09e8a1fb8363757c9a82c3e732a552 diff --git a/packages/vyatta-cfg b/packages/vyatta-cfg deleted file mode 160000 -Subproject c56e20b98438e33822244315249e3edf0e35659 diff --git a/packages/vyatta-cfg-firewall b/packages/vyatta-cfg-firewall deleted file mode 160000 -Subproject 5248dbcc34eb6b041af928a0451ea866fc77488 diff --git a/packages/vyatta-cfg-op-pppoe b/packages/vyatta-cfg-op-pppoe deleted file mode 160000 -Subproject 2de6ecd6068e6a9debb032a074395398f2dc4df diff --git a/packages/vyatta-cfg-qos b/packages/vyatta-cfg-qos deleted file mode 160000 -Subproject 0a5049b38b0830b289d0052a1fa2ce64785bc6b diff --git a/packages/vyatta-cfg-quagga b/packages/vyatta-cfg-quagga deleted file mode 160000 -Subproject 82dd077c98131a8a4b3383139e782f534bc310a diff --git a/packages/vyatta-cfg-system b/packages/vyatta-cfg-system deleted file mode 160000 -Subproject 2f9b0ecaf33c8598dc1a74ac0fb4f34abaad97c diff --git a/packages/vyatta-cfg-vpn b/packages/vyatta-cfg-vpn deleted file mode 160000 -Subproject 5c1672341b33dc726da5d7845725bd74e3cc7cb diff --git a/packages/vyatta-cluster b/packages/vyatta-cluster deleted file mode 160000 -Subproject 1881e2ef2fb041e7836db90b12450d63c162847 diff --git a/packages/vyatta-config-mgmt b/packages/vyatta-config-mgmt deleted file mode 160000 -Subproject a47cd02bca9cb25125e14fe1b731029fb985d89 diff --git a/packages/vyatta-config-migrate b/packages/vyatta-config-migrate deleted file mode 160000 -Subproject 28f7ce91358975ba9b36ac2874f6b47482815aa diff --git a/packages/vyatta-conntrack b/packages/vyatta-conntrack deleted file mode 160000 -Subproject 362135271f8bd647d8fa772f775d26c1edcac7c diff --git a/packages/vyatta-conntrack-sync b/packages/vyatta-conntrack-sync deleted file mode 160000 -Subproject 4f6ae97660e512d90f1d4ac9822cdc1172f0fdf diff --git a/packages/vyatta-eventwatch b/packages/vyatta-eventwatch deleted file mode 160000 -Subproject ab07c835d1b09ab5424190dd240dfa65e77b81f diff --git a/packages/vyatta-iproute b/packages/vyatta-iproute deleted file mode 160000 -Subproject 90dd151e2a23aa9ca3d6a5ab4c9c97349e65f4a diff --git a/packages/vyatta-ipv6-rtradv b/packages/vyatta-ipv6-rtradv deleted file mode 160000 -Subproject 809508f4b3248e8dc4bfbcb527084d3bac4c78f diff --git a/packages/vyatta-lldp b/packages/vyatta-lldp deleted file mode 160000 -Subproject b7c70732793bfd88c23ffb424bf44fd65b0bf8b diff --git a/packages/vyatta-nat b/packages/vyatta-nat deleted file mode 160000 -Subproject 52fb9ab3f8a1d1aeda0149946b1e1b77617bc6c diff --git a/packages/vyatta-netflow b/packages/vyatta-netflow deleted file mode 160000 -Subproject 22b60a0e4dc9ff7d4001b55bf1f17e55e526738 diff --git a/packages/vyatta-op b/packages/vyatta-op deleted file mode 160000 -Subproject 6152bc3abd0cb1dc6c7717a653558a1c3393fe3 diff --git a/packages/vyatta-op-dhcp-server b/packages/vyatta-op-dhcp-server deleted file mode 160000 -Subproject 2c8c4ae26ea671cd48c80335b127bbac7ad0783 diff --git a/packages/vyatta-op-firewall b/packages/vyatta-op-firewall deleted file mode 160000 -Subproject 7ad3f22bedd1ce169b076fd3fabb32761082b66 diff --git a/packages/vyatta-op-qos b/packages/vyatta-op-qos deleted file mode 160000 -Subproject ec1c87ec516d0814d1f4b6115dd93b4287f3055 diff --git a/packages/vyatta-op-quagga b/packages/vyatta-op-quagga deleted file mode 160000 -Subproject 24189c4533bc9147ac3c780ce80bf49194beb67 diff --git a/packages/vyatta-op-vpn b/packages/vyatta-op-vpn deleted file mode 160000 -Subproject 0ec07e891b0191b24185ea09c6f33f6502597df diff --git a/packages/vyatta-openvpn b/packages/vyatta-openvpn deleted file mode 160000 -Subproject 5f754cd2c2660f3fd58210c92d5847225fc2b6b diff --git a/packages/vyatta-quagga b/packages/vyatta-quagga deleted file mode 160000 -Subproject b721e84e0915406cb5458fea7f444b45b5d1196 diff --git a/packages/vyatta-ravpn b/packages/vyatta-ravpn deleted file mode 160000 -Subproject 6fb662b78e2b688d2a00d0221821904ef841b39 diff --git a/packages/vyatta-util b/packages/vyatta-util deleted file mode 160000 -Subproject 22ee60e33a9e5fc4dc372ae8798b4f05d1b520c diff --git a/packages/vyatta-wanloadbalance b/packages/vyatta-wanloadbalance deleted file mode 160000 -Subproject c4ad578e0d82b688d5ed60b649604982eae8350 diff --git a/packages/vyatta-webproxy b/packages/vyatta-webproxy deleted file mode 160000 -Subproject 4a86d4a3f886b8b42311dabd0ddceabdf8cdd51 diff --git a/packages/vyatta-wireless b/packages/vyatta-wireless deleted file mode 160000 -Subproject 5b92a6e5a446b3b74ad78832ea82f977d6bba32 diff --git a/packages/vyatta-wirelessmodem b/packages/vyatta-wirelessmodem deleted file mode 160000 -Subproject 8022e5ca50591afa2db948fd9454ce4f4cfb406 diff --git a/packages/vyatta-zone b/packages/vyatta-zone deleted file mode 160000 -Subproject f8f40ba6bf5a95a5b147f9cd0e7e425cdb9c015 diff --git a/packages/vyconf b/packages/vyconf deleted file mode 160000 -Subproject 1ebea2e6914e5d2c4f07654bdbd489aa2c1ce16 diff --git a/packages/vyos-1x b/packages/vyos-1x deleted file mode 160000 -Subproject 81e1cf8dbf02b95a89caa180f483a66655591d1 diff --git a/packages/vyos-accel-ppp b/packages/vyos-accel-ppp deleted file mode 160000 -Subproject df95d6b78be568cbce40fe7b2632dfb9697d207 diff --git a/packages/vyos-keepalived b/packages/vyos-keepalived deleted file mode 160000 -Subproject dc8ade02407f836873e78887f4b3c94b6540a57 diff --git a/packages/vyos-kernel b/packages/vyos-kernel deleted file mode 160000 -Subproject 615786a28e0ea6234ba8b02e457bcac48ab0718 diff --git a/packages/vyos-netplug b/packages/vyos-netplug deleted file mode 160000 -Subproject 2aa80a57a1ee2dfa8955b520d3aaec754315866 diff --git a/packages/vyos-nhrp b/packages/vyos-nhrp deleted file mode 160000 -Subproject aae14502e55b41e822d890ba08e3460609454cd diff --git a/packages/vyos-opennhrp b/packages/vyos-opennhrp deleted file mode 160000 -Subproject 41f0852dd0b8d4900a1a743334d88afe490ee58 diff --git a/packages/vyos-salt-minion b/packages/vyos-salt-minion deleted file mode 160000 -Subproject c64e526a98d4ea8ee3a300bf36cd4348cd46a56 diff --git a/packages/vyos-strongswan b/packages/vyos-strongswan deleted file mode 160000 -Subproject 0d4aee5440ebef1042bb8d9e65ee3dc127257df diff --git a/packages/vyos-vmwaretools-scripts b/packages/vyos-vmwaretools-scripts deleted file mode 160000 -Subproject b41f886f59997f28a19e541e6a40b9d39ac43f6 diff --git a/packages/vyos-wireguard b/packages/vyos-wireguard deleted file mode 160000 -Subproject 9c6555a20b4b8ff5d92fae2f843439b136448c8 diff --git a/packages/vyos-world b/packages/vyos-world deleted file mode 160000 -Subproject 69570ca927a1dc87f0f1eb778aaaa33df754171 diff --git a/packages/vyos-xe-guest-utilities b/packages/vyos-xe-guest-utilities deleted file mode 160000 -Subproject a31c092661c65e177967535e8c53dc5b7a04b5c diff --git a/scripts/build-intel-drivers b/scripts/build-intel-drivers new file mode 100755 index 00000000..ef039e4c --- /dev/null +++ b/scripts/build-intel-drivers @@ -0,0 +1,79 @@ +#!/bin/bash -x + +basedir=$(pwd) +if [ -z "$KSRC" ]; then + echo "Kernel source KSRC= not specified" + exit 1 +fi + +VERSION=$(grep "^VERSION" $KSRC/Makefile | grep -Eo '[0-9]{1,4}') +PATCHLEVEL=$(grep "^PATCHLEVEL" $KSRC/Makefile | grep -Eo '[0-9]{1,4}') +SUBLEVEL=$(grep "^SUBLEVEL" $KSRC/Makefile | grep -Eo '[0-9]{1,4}') +KERNEL_VER="$VERSION.$PATCHLEVEL.$SUBLEVEL-amd64-vyos" + +pkgdir="$basedir/packages" +if [ ! -d "$basedir/packages" ]; then + mkdir $basedir/packages +fi + +URLS=" \ + https://downloadmirror.intel.com/14687/eng/ixgbe-5.5.5.tar.gz \ + https://downloadmirror.intel.com/13663/eng/igb-5.3.5.22.tar.gz \ + https://downloadmirror.intel.com/15817/eng/e1000e-3.4.2.1.tar.gz \ + https://downloadmirror.intel.com/24411/eng/i40e-2.7.29.tar.gz \ + https://downloadmirror.intel.com/28725/eng/ixgbevf-4.5.2.tar.gz + https://downloadmirror.intel.com/24693/eng/i40evf-3.6.15.tar.gz \ +" + +# The intel IGBVF driver can't be compiled with recent Kernel versions +# due to interlanl API changes. Driver is from 10.09.2015 +# Source code is here: https://downloadmirror.intel.com/18298/eng/igbvf-2.3.9.6.tar.gz +for URL in $URLS +do + cd $pkgdir + filename=${URL##*/} + dirname_full=$(echo $filename | awk -F".tar.gz" '{print $1}') + dirname=$(echo $dirname_full | awk -F- '{print $1}') + version="$(echo $dirname_full | awk -F- '{print $2}')-0" + deb_pkg=${dirname}_${version}_amd64 + deb_pkg_dir=$pkgdir/vyos-intel-${deb_pkg} + + if [ -d "$dirname_full" ]; then + rm -rf $dirname_full + fi + if [ -d "$deb_pkg_dir" ]; then + rm -rf $deb_pkg_dir + fi + if [ ! -f "$filename" ]; then + wget ${URL} + ret=$? + if [ "$ret" != "0" ]; then + echo "Download of ${URL} failed!" + exit $ret + fi + fi + + tar xf $filename + cd $dirname_full/src + + KSRC=$KSRC INSTALL_MOD_PATH=$deb_pkg_dir \ + make -j $(cat /proc/cpuinfo | grep processor | wc -l) install + + mkdir -p $deb_pkg_dir/DEBIAN + echo "Package: vyos-intel-$dirname" >$deb_pkg_dir/DEBIAN/control + echo "Version: $version" >>$deb_pkg_dir/DEBIAN/control + echo "Section: kernel" >>$deb_pkg_dir/DEBIAN/control + echo "Priority: extra" >>$deb_pkg_dir/DEBIAN/control + echo "Architecture: amd64" >>$deb_pkg_dir/DEBIAN/control + echo "Maintainer: VyOS Package Maintainers <maintainers@vyos.net>" >>$deb_pkg_dir/DEBIAN/control + echo "Installed-Size: 9" >>$deb_pkg_dir/DEBIAN/control + echo "Depends: linux-image" >>$deb_pkg_dir/DEBIAN/control + echo "Description: Intel Vendor driver for $dirname" >>$deb_pkg_dir/DEBIAN/control + echo " Replacement for the in Kernel drivers" >>$deb_pkg_dir/DEBIAN/control + + # Cleanup files which might also be present in linux-image-4.19.20-amd64-vyos + rm -rf $deb_pkg_dir/usr $deb_pkg_dir/lib/modules/$KERNEL_VER/modules.* + + cd $pkgdir + dpkg-deb --build $(basename $deb_pkg_dir) +done diff --git a/scripts/build-packages b/scripts/build-packages new file mode 100755 index 00000000..3917e84d --- /dev/null +++ b/scripts/build-packages @@ -0,0 +1,369 @@ +#!/usr/bin/env python3 + +import os +import subprocess +import sys +import shutil +import argparse +import logging + +current_working_directory = os.getcwd() +repo_root = subprocess.check_output('git rev-parse --show-toplevel', shell=True, universal_newlines=True).rstrip('\n') +repo_sha = subprocess.check_output('git rev-parse --short=12 HEAD', shell=True, universal_newlines=True).rstrip('\n') + +def add_package(name, url=None, commit='HEAD', branch='current', tag=None, custombuild_cmd=None): + """ + Build up source package with URL and build commands executed during the later + called build_package step. + + If no additional information is passed we will use the latest commit from current + branch + + If no URL is passed we assume it's a regular VyOS package from the VyOS Github + namespace at https://github.com/vyos + """ + + if not url: + url = 'https://github.com/vyos/' + name + '.git' + + package = { + 'name': name, + 'url': url, + 'commit': commit, + 'tag': tag, + 'branch': branch, + 'path': repo_root + '/packages/' + name, + 'custombuild_cmd': custombuild_cmd + } + + return package + + + +def call(bashCommand, log, **kwargs): + """ + Run command with arguments. Wait for command to complete. + + Send output to logging module passed as 'log'. + """ + + from subprocess import Popen, PIPE, STDOUT, check_output, CalledProcessError + from tempfile import TemporaryFile + from time import sleep + + log.debug("Executing '{}'".format(bashCommand)) + + # code borrowsed from: + # https://stackoverflow.com/questions/38374063/python-can-we-use-tempfile-with-subprocess-to-get-non-buffering-live-output-in-p + # the temp file will be automatically cleaned up + output = TemporaryFile() + error = TemporaryFile() + + kwargs['stdout'] = output + kwargs['stderr'] = error + kwargs['shell'] = True + kwargs['universal_newlines'] = True + + sub = Popen(bashCommand, **kwargs) + while sub.poll() is None: + where = output.tell() + lines = output.readline() + if not lines: + sleep(0.3) + output.seek(where) + else: + log.debug(lines.decode().rstrip('\n')) + + where = error.tell() + lines = error.readline() + if not lines: + sleep(0.3) + error.seek(where) + else: + log.info(lines.decode().rstrip('\n')) + + + # A last write needed after subprocess ends + log.debug(output.read().decode().rstrip('\n')) + log.info(error.read().decode().rstrip('\n')) + + error.close() + output.close() + return sub.returncode + +def clone_package(pkg, log): + """ + Clone Git repository from URL embedded in pkg to local disk + + First cleanup any possible leftovers from previous builds + """ + + if args.clean: + # delete repository from disk + if os.path.isdir(pkg['path']): + log.debug("Cleaning '{}'".format(pkg['path'])) + shutil.rmtree(pkg['path']) + else: + if os.path.isdir(pkg['path']): + # Change current directory into Git repo for this package + os.chdir(pkg['path']) + + bashCommand = 'git clean -d -x --force && git reset --hard ' + pkg['commit'] + return call(bashCommand, log) + + # resolve given tag to commit id to use shallow clone + bashCommand = 'git clone ' + pkg['url'] + if pkg['tag']: + bashCommand += ' --branch ' + pkg['tag'] + elif pkg['branch']: + bashCommand += ' --depth 1 --branch ' + pkg['branch'] + + bashCommand += ' ' + pkg['path'] + return call(bashCommand, log) + + +def build_package(pkg, log=None): + """ + Generate Debian package from passed 'pkg' + """ + + # Change current directory into Git repo for this package + os.chdir(pkg['path']) + + # Overwrite custom build command if required, e.g. libyang + bashCommand = '' + if pkg['custombuild_cmd']: + bashCommand = pkg['custombuild_cmd'] + else: + # Build package + bashCommand = 'dpkg-buildpackage -uc -us -tc -b' + if args.parallel: + bashCommand += ' -j' + str(os.cpu_count()) + + return call(bashCommand, log) + +# a List of all Vyatta/VyOS based packages +vyos_packages = ['vyatta-bash', + 'vyatta-cfg', + 'vyatta-op', + 'vyatta-cfg-system', + 'vyatta-cfg-firewall', + 'vyatta-op-firewall', + 'vyatta-cfg-vpn', + 'vyatta-op-vpn', + 'vyatta-cfg-qos', + 'vyatta-op-qos', + 'vyatta-cfg-op-pppoe', + 'vyatta-openvpn', + 'vyatta-conntrack', + 'vyatta-conntrack-sync', + 'vyatta-nat', + 'vyatta-config-mgmt', + 'vyatta-config-migrate', + 'vyatta-zone', + 'vyatta-cluster', + 'vyatta-eventwatch', + 'vyatta-webproxy', + 'vyatta-cfg-quagga', + 'vyatta-op-quagga', + 'vyatta-op-dhcp-server', + 'vyatta-wireless', + 'vyatta-wirelessmodem', + 'vyatta-wanloadbalance', + 'vyatta-netflow', + 'vyatta-lldp', + 'vyatta-ipv6-rtradv', + 'vyatta-ravpn', + 'vyos-nhrp', + 'vyos-world', + 'vyos-1x', + 'vyatta-iproute', + 'vyos-vmwaretools-scripts', + 'vyos-netplug', + 'vyos-xe-guest-utilities', + 'vyatta-biosdevname', + 'vyos-opennhrp', + 'vyos-salt-minion', + 'xl2tpd', + 'mdns-repeater', + 'udp-broadcast-relay', + 'pmacct', + 'ddclient', + 'igmpproxy', + 'eventwatchd', + 'conntrack-tools'] + +# Special packages mean packages which are located no in the VyOS namespace +# or require fancy build instructions +pkg_special = [] + +# libvyosconfig/ipaddrcheck uses a different default branch +libvyosconfig_build_cmd = "eval $(opam env --root=/opt/opam --set-root) && " \ + "dpkg-buildpackage -b -us -uc -tc" +pkg_special.append( add_package('libvyosconfig', branch='master', custombuild_cmd=libvyosconfig_build_cmd)) +pkg_special.append( add_package('ipaddrcheck', branch='master')) + +# Packages where we directly build the upstream source +pkg_special.append( add_package('hvinfo', url='https://github.com/dmbaturin/hvinfo.git', branch='master') ) +pkg_special.append( add_package('lldpd', url='https://github.com/vincentbernat/lldpd.git', branch='master', tag='1.0.3') ) +pkg_special.append( add_package('ethtool', url='https://salsa.debian.org/kernel-team/ethtool.git', branch='master', tag='debian/1%4.19-1') ) +pkg_special.append( add_package('bgpq3', url='https://salsa.debian.org/debian/bgpq3.git', branch='master', tag='debian/0.1.33-1') ) + +# VyOS strongswan ships additional python3-vici packages required by vyos-1x and this is not build by default +vyos_strongswan_build_cmd = "dpkg-buildpackage -b -us -uc -tc && " \ + "autoreconf -i && ./configure --enable-python-eggs && " \ + "cd src/libcharon/plugins/vici/python && make && " \ + "python3 setup.py --command-packages=stdeb.command bdist_deb && " \ + "mv ./deb_dist/*.deb " + repo_root + "/packages" +pkg_special.append( add_package('vyos-strongswan', custombuild_cmd=vyos_strongswan_build_cmd) ) + +# +# FreeRangeRouting (FRR) packages +# +pkg_special.append( add_package('rtrlib', url='https://github.com/rtrlib/rtrlib.git', branch='master', tag='v0.6.3') ) + +frr_build_cmd = './tools/tarsource.sh -V && dpkg-buildpackage -us -uc -Ppkg.frr.rtrlib -d' +pkg_special.append( add_package('frr', url='https://github.com/FRRouting/frr.git', branch='master', tag='frr-7.0', custombuild_cmd=frr_build_cmd) ) +#libyang_build_cmd = 'mkdir build && cd build && cmake .. && make build-deb && mv debs/* ' + repo_root + '/packages' +#pkg_special.append( add_package('libyang', url='https://github.com/opensourcerouting/libyang.git', commit='179da47', branch='master', custombuild_cmd=libyang_build_cmd) ) + + +# +# Linux (VyOS) Kernel +# +kernel_build_cmd = "make x86_64_vyos_defconfig && " \ + "echo $(make kernelversion)-amd64-vyos > " + repo_root + "/data/kernel_version && " \ + "sed -i 's/\"kernel_version\": \"[0-9].[0-9][0-9].[0-9]*\"/\"kernel_version\": \"'$(make kernelversion)'\"/' " + repo_root + "/data/defaults.json && " \ + "LOCALVERSION='' make-kpkg --rootcmd fakeroot --initrd --append_to_version -amd64-vyos " \ + " --revision=$(make kernelversion)-1 kernel_headers kernel_image -j" + str(os.cpu_count()) +pkg_special.append( add_package('vyos-kernel', branch='linux-vyos-4.19.y', custombuild_cmd=kernel_build_cmd) ) + + + +# +# WireGuard Kernel Module +# +wireguard_build_cmd = "echo 'src/wireguard.ko /lib/modules/'$(cat " + repo_root + "/data/defaults.json | jq '.kernel_version' | tr -d \\\") > debian/wireguard-modules.install && " \ + "KERNELDIR=" + repo_root + "/packages/vyos-kernel dpkg-buildpackage -b -us -uc -tc -j" + str(os.cpu_count()) +pkg_special.append( add_package('vyos-wireguard', custombuild_cmd=wireguard_build_cmd) ) + + + +# +# Accell-PPP Package and Kernel Module +# +accel_ppp_build_cmd = "echo 'lib/modules/'$(cat " + repo_root + "/data/defaults.json | jq '.kernel_version' | tr -d \\\")'/extra/*.ko' > debian/vyos-accel-ppp-ipoe-kmod.install && " \ + "sed -i 's#[0-9].[0-9][0-9].[0-9]*-amd64-vyos#'$(cat " + repo_root + "/data/defaults.json | jq '.kernel_version' | tr -d \\\")'#g' debian/rules && " \ + "KERNELDIR=" + repo_root + "/packages/vyos-kernel dpkg-buildpackage -b -us -uc -tc -j" + str(os.cpu_count()) +pkg_special.append( add_package('vyos-accel-ppp', custombuild_cmd=accel_ppp_build_cmd) ) + + +# A list of all packages we will build in the end +pkg_build = [] + + + + +if __name__ == '__main__': + parser = argparse.ArgumentParser() + parser.add_argument('-v', '--verbose', action='count', default=0, help='Increase logging verbosity for each occurance') + parser.add_argument('-c', '--clean', action='store_true', help='Re-clone required Git repositories') + parser.add_argument('-l', '--list-packages', action='store_true', help='List all packages to build') + parser.add_argument('-b', '--build', nargs='+', help='Whitespace separated list of packages to build') + parser.add_argument('-f', '--fetch', action='store_true', help='Fetch sources only, no build') + parser.add_argument('-p', '--parallel', action='store_true', help='Build on all CPUs') + parser.add_argument('--blacklist', nargs='+', help='Do not build/report packages when calling --list') + + + args = parser.parse_args() + + levels = [ logging.INFO, logging.WARNING, logging.DEBUG ] + level = levels[min(len(levels)-1,args.verbose)] # capped to number of levels + logging.basicConfig(level=level, format="%(asctime)s %(name)s %(message)s") + + print("Using vyos-build repository ('{}') commit '{}'\n".format(repo_root, repo_sha)) + + # + # Exclude packages from build process, + # also do not list them on --list + # + if args.blacklist: + for exclude in args.blacklist: + if exclude in vyos_packages: + vyos_packages.remove(exclude) + continue + + found = False + for pkg in pkg_special: + if exclude == pkg['name']: + found = True + # package already formed + pkg_special.remove(pkg) + break + + if not found: + print("Invalid choice '" + exclude + "', --list-packages for complete list!") + sys.exit(1) + + # + # List all available (to be build) packages + # + if args.list_packages: + print("Individual packages available for build:") + for pkg in vyos_packages: + print(' * ' + pkg) + for pkg in pkg_special: + print(' * ' + pkg['name']) + + sys.exit(0) + + # + # Only add selective packages to the build list + # + if args.build: + # NOTE: remove double added packages from list + for target in args.build: + if target in vyos_packages: + pkg_build.append(add_package( target )) + continue + + found = False + for pkg in pkg_special: + if target == pkg['name']: + found = True + # package already formed + pkg_build.append( pkg ) + break + + if not found: + print("Invalid choice '" + target + "', for -b/--build use --list-packages for complete list!") + sys.exit(1) + + else: + # Add all VyOS packages to the package list + for pkg in vyos_packages: + pkg_build.append(add_package( pkg )) + + # We also wan't to build all of our special packages + for pkg in pkg_special: + pkg_build.append( pkg ) + + # Build all VyOS packages (packages found on https://github.com/vyos + # and referenced in vyos_packages) + for pkg in pkg_build: + # Create a logging instance per package + log = logging.getLogger(pkg['name']) + + ret = clone_package(pkg, log) + if ret: + log.error("ERROR cloning source") + sys.exit(1) + else: + # only build packages if fetch flag is not set + if not args.fetch: + ret = build_package(pkg, log) + if ret: + log.error("ERROR building source") + sys.exit(1) + + sys.exit(0) diff --git a/scripts/build-submodules b/scripts/build-submodules deleted file mode 100755 index fc8fdf83..00000000 --- a/scripts/build-submodules +++ /dev/null @@ -1,452 +0,0 @@ -#!/bin/bash - -if [ ! -d "packages" ]; then - echo "This script needs to be executed inside the top root of vyos-build" - exit 1 -fi - -print_help() { - echo "Script for building all subpackages to vyos" - echo "Execute this sctipt from the root of the vyos-build directory" - echo "" - echo "This script could be executed from a Debian Jessie installation with all dependencies" - echo "or from the vyos-builder docker container." - echo "" - echo "Build the container:" - echo " docker build -t vyos-builder ." - echo "Compile packages:" - echo " docker run --rm -it -v $(pwd):/vyos -w /vyos --sysctl net.ipv6.conf.lo.disable_ipv6=0 vyos-builder scripts/build-submodules" - echo "" - echo "Parameters:" - echo " --init-packages - Initiate all subpackages before building" - echo " --verbose - Enable verbose output" - echo " --build-[packagename] - build only selected packages" -} - -BUILDLIST="" -VERBOSE=0 - -while test $# -gt 0 -do - case "$1" in - -h|-?|--help) - print_help - exit 0 - ;; - --init-packages) - INIT_PACKAGES=1 - ;; - --verbose) - VERBOSE=1 - ;; - --build-*) - VAL=$(sed s/^--build-//g <<< $1) - BUILDLIST="$BUILDLIST $VAL" - ;; - *) - (>&2 echo "Error: Argument $1 is not valid") - echo "" - print_help - exit 1 - ;; - esac - shift -done - -status_start() { - echo -ne "[ ] $1" -} -status_ok() { - echo -ne "\r[\e[32m OK \e[39m]\n" -} - -status_fail() { - echo -ne "\r[\e[31mFAIL\e[39m]\n" -} - -status_skip() { - echo -ne "\r[SKIP] $1\033[K\n" -} - -error_msg() { - echo -ne " $1\n" -} - -verbose_msg() { - if [ $VERBOSE -ne 0 ]; then - echo "Current Environment:" - env - - if [ ! -z "$1" ]; then - echo "Logfile:" - cat $1 - fi - fi -} - -ROOTDIR="$(pwd)" -PKGDIR="$ROOTDIR/packages" -SCRIPTDIR="$ROOTDIR/scripts" - -# Source OPAM environment if not already set -if [ -z "$OPAMROOT" ]; then - if [ -x "$(command -v opam)" ]; then - eval $(opam env --root=/opt/opam --set-root) - else - echo "WARNING: 'opam' not installed, can't build VyConf and libvyosconfig" - fi -fi - -package_in_buildlist() { - # Return true if buildlist is not set - if [ -z "$BUILDLIST" ]; then - return 0 - fi - - if [[ $BUILDLIST =~ (^|[[:space:]])$1($|[[:space:]]) ]]; then - return 0 - fi - - return 1 -} - -build_package() { - PKG=$1 - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - if ! package_in_buildlist $1; then - return 0 - fi - status_start "Building package: $PKG Commit id: $COMMITID" - if [ ! -d "$PKGDIR/$PKG/debian" ]; then - status_skip "No source for: $PKG" - return 1 - fi - ( set -e; set -x - cd $PKGDIR/$PKG - dpkg-buildpackage -uc -us -tc -b -j$(cat /proc/cpuinfo | grep processor | wc -l) - ) >>$PKGDIR/$PKG.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - verbose_msg "$PKGDIR/$PKG.buildlog" - error_msg "Failed to build package $PKG, look in $PKG.buildlog to examine the fault\n" - return 2 - fi - status_ok -} - -echo "Cleaning up buildfiles..." -rm -rf $PKGDIR/*.deb -rm -rf $PKGDIR/*.changes -rm -rf $PKGDIR/*.buildlog -COMMITID=$(cd $PKGDIR; git rev-parse --short=10 HEAD) -echo "-----------------------------------------------------" -echo "Starting build process for all packages" -echo "vyos-build Commit ID: $COMMITID" - -initialize_packages() { - status_start "Initializing packages" - ( - set -x - git submodule update --init --recursive - git submodule update --remote - ) >>$PKGDIR/init-packages.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - verbose_msg "$PKGDIR/init-packages.buildlog" - error_msg "Failed to update all package, look in init-packages.buildlog to examine the fault\n" - return 1 - fi - status_ok -} -if [ $INIT_PACKAGES ]; then - initialize_packages -fi - -build_libyang() { - PKG=libyang - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - if ! package_in_buildlist $1; then - return 0 - fi - status_start "Building package: $PKG Commit id: $COMMITID" - if [ ! -f "$PKGDIR/$PKG/README.md" ]; then - status_skip "No source for: $PKG" - return 1 - fi - - ( set -e; set -x - cd $PKGDIR/$PKG - git checkout 179da47f2e8de - - git clean -dxf - git reset --hard - - mkdir build - cd build - - cmake .. - make build-deb - - cp debs/* $PKGDIR - - ) >>$PKGDIR/$PKG.buildlog 2>&1 - - if [ $? -ne 0 ]; then - status_fail - error_msg "Failed to build package $PKG, look in $PKG.buildlog to examine the fault\n" - return 2 - fi - status_ok -} -build_libyang - -build_frr() { - PKG=frr - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - if ! package_in_buildlist $1; then - return 0 - fi - status_start "Building package: $PKG Commit id: $COMMITID" - if [ ! -f "$PKGDIR/$PKG/README.md" ]; then - status_skip "No source for: $PKG" - return 1 - fi - - ( set -e; set -x - cd $PKGDIR/$PKG - git clean -dxf - git reset --hard - - # Run bootstrap.sh and make a dist tarball - # http://docs.frrouting.org/projects/dev-guide/en/latest/packaging-debian.html - ./bootstrap.sh - ./configure --with-pkg-extra-version=-vyos - make dist - - # Create backports debian sources - mv debianpkg debian - make -f debian/rules backports - - # Create a new directory to build the package and populate with package source. - mkdir frrpkg - cd frrpkg - tar xf ../frr_*.orig.tar.gz - cd frr* - source /etc/os-release - tar xf ../../frr_*${ID}${VERSION_ID}*.debian.tar.xz - - # Build Debian Package - debuild --no-lintian --set-envvar=WANT_SNMP=1 --set-envvar=WANT_RPKI=1 \ - --set-envvar=WANT_CUMULUS_MODE=0 -b -uc -us \ - -j$(cat /proc/cpuinfo | grep processor | wc -l) - - mv ../frr_*.deb $PKGDIR - ) >>$PKGDIR/$PKG.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - error_msg "Failed to build package $PKG, look in $PKG.buildlog to examine the fault\n" - return 2 - fi - status_ok -} -build_frr - -for PKG in mdns-repeater \ - pmacct \ - udp-broadcast-relay \ - conntrack-tools \ - eventwatchd \ - ddclient \ - rtrlib \ - hvinfo \ - igmpproxy \ - ipaddrcheck \ - lldpd \ - libvyosconfig \ - vyatta-bash \ - vyatta-biosdevname \ - vyatta-cfg \ - vyatta-cfg-firewall \ - vyatta-cfg-op-pppoe \ - vyatta-cfg-qos \ - vyatta-cfg-quagga \ - vyatta-cfg-system \ - vyatta-cfg-vpn \ - vyatta-cluster \ - vyatta-config-mgmt \ - vyatta-config-migrate \ - vyatta-conntrack \ - vyatta-conntrack-sync \ - vyatta-eventwatch \ - vyatta-iproute \ - vyatta-ipv6-rtradv \ - vyatta-lldp \ - vyatta-nat \ - vyatta-netflow \ - vyatta-op \ - vyatta-op-dhcp-server \ - vyatta-op-firewall \ - vyatta-op-qos \ - vyatta-op-quagga \ - vyatta-op-vpn \ - vyatta-openvpn \ - vyatta-ravpn \ - vyatta-wanloadbalance \ - vyatta-webgui \ - vyatta-webproxy \ - vyatta-wireless \ - vyatta-wirelessmodem \ - vyatta-zone \ - vyos-xe-guest-utilities \ - vyos-keepalived \ - vyos-netplug \ - vyos-nhrp \ - vyos-opennhrp \ - vyos-salt-minion \ - vyos-strongswan \ - vyos-vmwaretools-scripts \ - vyos-world \ - vyos-1x \ - ; do - build_package "$PKG" - ERRCODE=$? - if [ "$ERRCODE" -ne "0" ]; then - exit $ERRCODE - fi -done - -# KERNEL -build_kernel() { - PKG="vyos-kernel" - if ! package_in_buildlist "vyos-kernel"; then - return 0 - fi - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - status_start "Building-package: vyos-kernel Commit ID:$COMMITID" - if [ ! -f "$PKGDIR/vyos-kernel/Makefile" ]; then - status_skip "No source for: vyos-kernel" - return 0 - fi - - ( set -e; set -x - cd $PKGDIR/vyos-kernel > /dev/null - bash -c "$SCRIPTDIR/build-kernel" - ) >>$PKGDIR/vyos-kernel.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - verbose_msg "$PKGDIR/vyos-kernel.buildlog" - error_msg "Failed to build package vyos-kernel, look in vyos-kernel.buildlog to examine the fault\n" - return 1 - fi - - VERSION=$(grep "^VERSION" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - PATCHLEVEL=$(grep "^PATCHLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - SUBLEVEL=$(grep "^SUBLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - ARCH=$(dpkg --print-architecture) - status_ok -} -build_kernel -ERRCODE=$? -if [ "$ERRCODE" -ne "0" ]; then - exit $ERRCODE -fi - - -# WIREGUARD -build_wireguard() { - PKG="vyos-wireguard" - if ! package_in_buildlist "vyos-wireguard"; then - return 0 - fi - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - status_start "Building package: vyos-wireguard Commit ID:$COMMITID" - - if [ ! -d "$PKGDIR/vyos-wireguard/debian" ]; then - status_skip "No source for: vyos-wireguard" - return 0 - fi - - if [ ! -f "$PKGDIR/vyos-kernel/Makefile" ]; then - status_fail - error_msg "No Makefile found in kernel package" - return 1 - fi - - if ! grep -q "KBUILD_OUTPUT" $PKGDIR/vyos-kernel/Makefile; then - status_fail - error_msg "Failed to build package vyos-wireguard, no kernel source found\n" - return 1 - fi - - VERSION=$(grep "^VERSION" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - PATCHLEVEL=$(grep "^PATCHLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - SUBLEVEL=$(grep "^SUBLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - ARCH=$(dpkg --print-architecture) - # Collect kernel information - ( set -e; set -x - cd $PKGDIR/vyos-wireguard - echo "src/wireguard.ko /lib/modules/$VERSION.$PATCHLEVEL.$SUBLEVEL-$ARCH-vyos/extra" | tee debian/wireguard-modules.install - KERNELDIR=$PKGDIR/vyos-kernel dpkg-buildpackage -uc -us -tc -b -j$(cat /proc/cpuinfo | grep processor | wc -l) - ) >>$PKGDIR/vyos-wireguard.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - verbose_msg "$PKGDIR/vyos-wireguard.buildlog" - error_msg "Failed to build package vyos-wireguard, look in vyos-wireguard.buildlog to examine the fault\n" - return 2 - fi - status_ok -} -build_wireguard -ERRCODE=$? -if [ "$ERRCODE" -ne "0" ]; then - exit $ERRCODE -fi - -# ACCEL-PPP -build_accel-ppp() { - PKG="vyos-accel-ppp" - if ! package_in_buildlist "accel-ppp"; then - return 0 - fi - COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD) - status_start "Building package: vyos-accel-ppp Commit ID: $COMMITID" - if [ ! -d "$PKGDIR/vyos-accel-ppp/debian" ]; then - status_skip "No source for: vyos-accel-ppp" - return 0 - fi - - if [ ! -f "$PKGDIR/vyos-kernel/Makefile" ]; then - status_fail - error_msg "No Makefile found in kernel package" - return 1 - fi - - if ! grep -q "KBUILD_OUTPUT" $PKGDIR/vyos-kernel/Makefile; then - status_fail - error_msg "Failed to build package vyos-accel-ppp, no kernel source found\n" - fi - # Collect kernel information - VERSION=$(grep "^VERSION" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - PATCHLEVEL=$(grep "^PATCHLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - SUBLEVEL=$(grep "^SUBLEVEL" $PKGDIR/vyos-kernel/Makefile | grep -Eo '[0-9]{1,4}') - ARCH=$(dpkg --print-architecture) - - ( set -e; set -x - cd $PKGDIR/vyos-accel-ppp - echo "lib/modules/$VERSION.$PATCHLEVEL.$SUBLEVEL-$ARCH-vyos/extra/*.ko" | tee debian/vyos-accel-ppp-ipoe-kmod.install - sed -i "s#[0-9].[0-9][0-9].[0-9]-amd64-vyos#$VERSION.$PATCHLEVEL.$SUBLEVEL-$ARCH-vyos#g" debian/rules - KERNELDIR=$PKGDIR/vyos-kernel dpkg-buildpackage -uc -us -tc -b -j$(cat /proc/cpuinfo | grep processor | wc -l) - ) >>$PKGDIR/vyos-accel-ppp.buildlog 2>&1 - if [ $? -ne 0 ]; then - status_fail - verbose_msg "$PKGDIR/vyos-accel-ppp.buildlog" - error_msg "Failed to build package vyos-accel-ppp, look in vyos-accel-ppp.buildlog to examine the fault\n" - return 1 - fi - status_ok -} -build_accel-ppp -ERRCODE=$? -if [ "$ERRCODE" -ne "0" ]; then - exit $ERRCODE -fi |