From fee69c5c7cafb2959b8b46b22c105b9c1eb82176 Mon Sep 17 00:00:00 2001 From: zsdc Date: Tue, 20 Jun 2023 15:58:56 +0300 Subject: VPP: T1797: Added build scripts for VPP --- packages/vpp/Jenkinsfile | 33 +++++++ packages/vpp/build.py | 104 +++++++++++++++++++++ packages/vpp/build_vpp.json | 14 +++ .../vpp/0001-Debian-12-compatible-build.patch | 54 +++++++++++ 4 files changed, 205 insertions(+) create mode 100644 packages/vpp/Jenkinsfile create mode 100755 packages/vpp/build.py create mode 100644 packages/vpp/build_vpp.json create mode 100644 packages/vpp/patches/vpp/0001-Debian-12-compatible-build.patch (limited to 'packages') diff --git a/packages/vpp/Jenkinsfile b/packages/vpp/Jenkinsfile new file mode 100644 index 00000000..097f4da1 --- /dev/null +++ b/packages/vpp/Jenkinsfile @@ -0,0 +1,33 @@ +// Copyright (C) 2023 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 . + +@NonCPS + +// Using a version specifier library, use 'current' branch. The underscore (_) +// is not a typo! You need this underscore if the line immediately after the +// @Library annotation is not an import statement! +@Library('vyos-build@current')_ + +def package_name = 'vpp' + +def pkgList = [ + ['name': 'vpp', + 'scmCommit': 'stable/2306', + 'scmUrl': 'https://gerrit.fd.io/r/vpp', + 'buildCmd': '../build.py --package vpp'], +] + +// Start package build using library function from https://github.com/vyos/vyos-build +buildPackage("${package_name}", pkgList, null, true, "**/packages/${package_name}/**") diff --git a/packages/vpp/build.py b/packages/vpp/build.py new file mode 100755 index 00000000..d1dd54b1 --- /dev/null +++ b/packages/vpp/build.py @@ -0,0 +1,104 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2023 VyOS maintainers and contributors +# +# This program is free software; you can redistribute it and/or modify +# 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 . + +from argparse import ArgumentParser +from pathlib import Path +from subprocess import run +from sys import exit +from json import load as json_load + + +def check_args(args) -> bool: + """Check command arguments + + Args: + args (Namespace): Namespace with arguments + + Returns: + bool: check result + """ + sources_dir = Path(f'../{args.package}') + if not sources_dir.exists(): + print(f'Sourced directory {sources_dir.as_posix()} does not exist') + return False + return True + + +# apply patches +def apply_patches(package_name: str) -> bool: + """Apply patches to sources directory + + Args: + package_name (str): package name (the same as sources directory) + """ + patches_dir = Path(f'../patches/{package_name}') + if patches_dir.exists(): + for patch_file in patches_dir.iterdir(): + patch_cmd: list[str] = [ + 'git', '-c', 'user.email=support@vyos.io', '-c', + 'user.name=vyos', 'am', + patch_file.as_posix() + ] + print(f'Applying patch: {patch_file.name}') + if run(patch_cmd).returncode != 0: + return False + return True + + +def build_package(package_name: str) -> bool: + """Build a package using commands from external file + + Args: + package_name (str): package name + + Returns: + bool: build status + """ + build_config_path: str = f'../build_{package_name}.json' + with open(build_config_path, 'r') as openfile: + try: + build_params = json_load(openfile) + except Exception as err: + print(f'Error parsing config file {build_config_path}: {err}') + return False + + for cmd in build_params.get('build_commands', []): + print(f'Building: {cmd}') + if run(cmd).returncode != 0: + return False + + return True + + +# build a package +if __name__ == '__main__': + # prepare argument parser + arg_parser = ArgumentParser() + arg_parser.add_argument('--package', + required=True, + help='Package name to build') + args = arg_parser.parse_args() + + if not check_args(args): + exit(1) + + if not apply_patches(args.package): + exit(1) + + if not build_package(args.package): + exit(1) + + exit() diff --git a/packages/vpp/build_vpp.json b/packages/vpp/build_vpp.json new file mode 100644 index 00000000..8e0fde5b --- /dev/null +++ b/packages/vpp/build_vpp.json @@ -0,0 +1,14 @@ +{ + "build_commands": [ + [ + "sudo", + "make", + "UNATTENDED=yes", + "install-dep" + ], + [ + "make", + "pkg-deb" + ] + ] +} \ No newline at end of file diff --git a/packages/vpp/patches/vpp/0001-Debian-12-compatible-build.patch b/packages/vpp/patches/vpp/0001-Debian-12-compatible-build.patch new file mode 100644 index 00000000..786e4556 --- /dev/null +++ b/packages/vpp/patches/vpp/0001-Debian-12-compatible-build.patch @@ -0,0 +1,54 @@ +From 3a4e62ad4844e84e93367a19cf1fae0191e677c6 Mon Sep 17 00:00:00 2001 +From: zsdc +Date: Mon, 19 Jun 2023 16:39:04 +0300 +Subject: [PATCH] Debian 12 compatible build + +--- + Makefile | 4 ++++ + build/external/Makefile | 3 +-- + src/plugins/af_xdp/{CMakeLists.txt => CMakeLists.txt.disable} | 0 + 3 files changed, 5 insertions(+), 2 deletions(-) + rename src/plugins/af_xdp/{CMakeLists.txt => CMakeLists.txt.disable} (100%) + +diff --git a/Makefile b/Makefile +index 88d42dfe4..9c10b62c6 100644 +--- a/Makefile ++++ b/Makefile +@@ -103,6 +103,10 @@ else ifeq ($(OS_ID)-$(OS_VERSION_ID),debian-11) + DEB_DEPENDS += virtualenv + DEB_DEPENDS += clang clang-format-11 + LIBFFI=libffi7 ++else ifeq ($(OS_ID)-$(OS_VERSION_ID),debian-12) ++ DEB_DEPENDS += virtualenv ++ DEB_DEPENDS += clang clang-format ++ LIBFFI=libffi8 + else + DEB_DEPENDS += clang-11 clang-format-11 + LIBFFI=libffi7 +diff --git a/build/external/Makefile b/build/external/Makefile +index d648f4fa1..8a4d8e115 100644 +--- a/build/external/Makefile ++++ b/build/external/Makefile +@@ -40,14 +40,13 @@ include packages/ipsec-mb.mk + include packages/quicly.mk + include packages/rdma-core.mk + include packages/dpdk.mk +-include packages/xdp-tools.mk + + .PHONY: clean + clean: + @rm -rf $(B) $(I) + + .PHONY: install +-install: $(if $(ARCH_X86_64), ipsec-mb-install) dpdk-install rdma-core-install quicly-install xdp-tools-install ++install: $(if $(ARCH_X86_64), ipsec-mb-install) dpdk-install rdma-core-install quicly-install + + .PHONY: config + config: $(if $(ARCH_X86_64), ipsec-mb-config) dpdk-config rdma-core-config quicly-build +diff --git a/src/plugins/af_xdp/CMakeLists.txt b/src/plugins/af_xdp/CMakeLists.txt.disable +similarity index 100% +rename from src/plugins/af_xdp/CMakeLists.txt +rename to src/plugins/af_xdp/CMakeLists.txt.disable +-- +2.34.1 + -- cgit v1.2.3