From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id E1B44A09E4; Thu, 21 Jan 2021 16:52:13 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 74769140D95; Thu, 21 Jan 2021 16:51:55 +0100 (CET) Received: from lb.pantheon.sk (lb.pantheon.sk [46.229.239.20]) by mails.dpdk.org (Postfix) with ESMTP id 5D77A140D20 for ; Thu, 21 Jan 2021 16:51:51 +0100 (CET) Received: from localhost (localhost [127.0.0.1]) by lb.pantheon.sk (Postfix) with ESMTP id 9B632BD2BE; Thu, 21 Jan 2021 16:51:50 +0100 (CET) X-Virus-Scanned: amavisd-new at siecit.sk Received: from lb.pantheon.sk ([127.0.0.1]) by localhost (lb.pantheon.sk [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Q06vogmTggzw; Thu, 21 Jan 2021 16:51:49 +0100 (CET) Received: from service-node1.lab.pantheon.local (unknown [46.229.239.141]) by lb.pantheon.sk (Postfix) with ESMTP id 6B775BFD8E; Thu, 21 Jan 2021 16:51:47 +0100 (CET) From: =?UTF-8?q?Juraj=20Linke=C5=A1?= To: thomas@monjalon.net, david.marchand@redhat.com, aconole@redhat.com, maicolgabriel@hotmail.com, jerinjacobk@gmail.com, ferruh.yigit@intel.com, Ruifeng.Wang@arm.com Cc: dev@dpdk.org, =?UTF-8?q?Juraj=20Linke=C5=A1?= Date: Thu, 21 Jan 2021 16:51:44 +0100 Message-Id: <1611244304-13773-4-git-send-email-juraj.linkes@pantheon.tech> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1611244304-13773-1-git-send-email-juraj.linkes@pantheon.tech> References: <1611045187-8097-1-git-send-email-juraj.linkes@pantheon.tech> <1611244304-13773-1-git-send-email-juraj.linkes@pantheon.tech> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Subject: [dpdk-dev] [PATCH v5 3/3] doc: add clang to aarch64 cross build guide X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Reorganize and update the aarch64 cross guide with clang cross compilation. Update the GNU toolchain version which clang also uses. Reorganize into common part, GNU part and clang part. Signed-off-by: Juraj Linkeš Acked-by: Ruifeng Wang --- .../linux_gsg/cross_build_dpdk_for_arm64.rst | 183 +++++++++++++----- 1 file changed, 132 insertions(+), 51 deletions(-) diff --git a/doc/guides/linux_gsg/cross_build_dpdk_for_arm64.rst b/doc/guides/linux_gsg/cross_build_dpdk_for_arm64.rst index d0d346c83..ed34cdb0f 100644 --- a/doc/guides/linux_gsg/cross_build_dpdk_for_arm64.rst +++ b/doc/guides/linux_gsg/cross_build_dpdk_for_arm64.rst @@ -1,104 +1,185 @@ .. SPDX-License-Identifier: BSD-3-Clause - Copyright(c) 2018 ARM Corporation. + Copyright(c) 2020 ARM Corporation. -Cross compile DPDK for ARM64 -============================ +Cross compiling DPDK for ARM64 +============================== This chapter describes how to cross compile DPDK for ARM64 from x86 build hosts. .. note:: Whilst it is recommended to natively build DPDK on ARM64 (just - like with x86), it is also possible to cross-build DPDK for ARM64. An - ARM64 cross compile GNU toolchain is used for this. + like with x86), it is also possible to cross compile DPDK for ARM64. + An ARM64 cross compiler GNU toolchain or an LLVM/clang toolchain + may be used for cross-compilation. -Obtain the cross tool chain ---------------------------- -The latest cross compile tool chain can be downloaded from: + +Prerequisites +------------- + +NUMA library +~~~~~~~~~~~~ + +NUMA is required by most modern machines, not needed for non-NUMA architectures. + +.. note:: + + For compiling the NUMA lib, run libtool --version to ensure the libtool version >= 2.2, + otherwise the compilation will fail with errors. + +.. code-block:: console + + git clone https://github.com/numactl/numactl.git + cd numactl + git checkout v2.0.13 -b v2.0.13 + ./autogen.sh + autoconf -i + ./configure --host=aarch64-linux-gnu CC= --prefix= + make install + +.. note:: + + The compiler above can be either aarch64-linux-gnu-gcc or clang. + See below for information on how to get the compiler of your choice. + +The numa header files and lib file is generated in the include and lib folder respectively under . + +Meson prerequisites +~~~~~~~~~~~~~~~~~~~ + +Meson depends on pkgconfig to find the dependencies. +The package ``pkg-config-aarch64-linux-gnu`` is required for aarch64. +To install it in Ubuntu:: + + sudo apt install pkg-config-aarch64-linux-gnu + + +GNU toolchain +------------- + +.. _obtain_GNU_toolchain: + +Obtain the cross toolchain +~~~~~~~~~~~~~~~~~~~~~~~~~~ +The latest GNU cross compiler toolchain can be downloaded from: https://developer.arm.com/open-source/gnu-toolchain/gnu-a/downloads. It is always recommended to check and get the latest compiler tool from the page and use -it to generate better code. As of this writing 8.3-2019.03 is the newest, the following +it to generate better code. As of this writing 9.2-2019.12 is the newest, the following description is an example of this version. .. code-block:: console - wget https://developer.arm.com/-/media/Files/downloads/gnu-a/8.3-2019.03/binrel/gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu.tar.xz + wget https://developer.arm.com/-/media/Files/downloads/gnu-a/9.2-2019.12/binrel/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu.tar.xz Unzip and add into the PATH ---------------------------- +~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. code-block:: console - tar -xvf gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu.tar.xz - export PATH=$PATH:/gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu/bin + tar -xvf gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu.tar.xz + export PATH=$PATH:/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/bin .. note:: For the host requirements and other info, refer to the release note section: https://releases.linaro.org/components/toolchain/binaries/ -.. _arm_cross_build_getting_the_prerequisite_library: +.. _augment_the_gnu_toolchain_with_numa_support: -Getting the prerequisite library --------------------------------- - -NUMA is required by most modern machines, not needed for non-NUMA architectures. +Augment the GNU toolchain with NUMA support +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. note:: - For compiling the NUMA lib, run libtool --version to ensure the libtool version >= 2.2, - otherwise the compilation will fail with errors. + This way is optional, an alternative is to use extra CFLAGS and LDFLAGS. + +Copy the NUMA header files and lib to the cross compiler's directories: .. code-block:: console - git clone https://github.com/numactl/numactl.git - cd numactl - git checkout v2.0.13 -b v2.0.13 - ./autogen.sh - autoconf -i - ./configure --host=aarch64-linux-gnu CC=aarch64-linux-gnu-gcc --prefix= - make install + cp /include/numa*.h /gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/aarch64-none-linux-gnu/libc/usr/include/ + cp /lib/libnuma.a /gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/lib/gcc/aarch64-none-linux-gnu/9.2.1/ + cp /lib/libnuma.so /gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/lib/gcc/aarch64-none-linux-gnu/9.2.1/ -The numa header files and lib file is generated in the include and lib folder respectively under . +Cross Compiling DPDK with GNU toolchain using Meson +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +To cross-compile DPDK on a desired target machine we can use the following +command:: + + meson cross-build --cross-file + ninja -C cross-build + +For example if the target machine is aarch64 we can use the following +command:: -.. _augment_the_cross_toolchain_with_numa_support: + meson aarch64-build-gcc --cross-file config/arm/arm64_armv8_linux_gcc + ninja -C aarch64-build-gcc -Augment the cross toolchain with NUMA support ---------------------------------------------- + +LLVM/Clang toolchain +-------------------- + +Obtain the cross tool chain +~~~~~~~~~~~~~~~~~~~~~~~~~~~ +The latest LLVM/Clang cross compiler toolchain can be downloaded from: +https://developer.arm.com/tools-and-software/open-source-software/developer-tools/llvm-toolchain. + +.. code-block:: console + + # Ubuntu binaries + wget https://github.com/llvm/llvm-project/releases/download/llvmorg-10.0.0/clang+llvm-10.0.0-x86_64-linux-gnu-ubuntu-18.04.tar.xz + +The LLVM/Clang toolchain does not implement the standard c library. The GNU toolchain +ships an implementation we can use. Refer to obtain_GNU_toolchain_ to get the +GNU toolchain. + +Unzip and add into the PATH +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +.. code-block:: console + + tar -xvf clang+llvm-10.0.0-x86_64-linux-gnu-ubuntu-18.04.tar.xz + export PATH=$PATH:/clang+llvm-10.0.0-x86_64-linux-gnu-ubuntu-18.04/bin + +Cross Compiling DPDK with LLVM/Clang toolchain using Meson +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. note:: - This way is optional, an alternative is to use extra CFLAGS and LDFLAGS. + To use the NUMA library follow the same steps as for + augment_the_gnu_toolchain_with_numa_support_. -Copy the NUMA header files and lib to the cross compiler's directories: +The paths to GNU stdlib must be specified in a cross file. Augmenting the default +cross-file's c_args and c_link_args config/arm/arm64_armv8_linux_clang_ubuntu1804 would look like this: .. code-block:: console - cp /include/numa*.h /gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu/aarch64-linux-gnu/libc/usr/include/ - cp /lib/libnuma.a /gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu/lib/gcc/aarch64-linux-gnu/8.3.0/ - cp /lib/libnuma.so /gcc-arm-8.3-2019.03-x86_64-aarch64-linux-gnu/lib/gcc/aarch64-linux-gnu/8.3.0/ + ... + c_args = ['-target', 'aarch64-linux-gnu', '--sysroot', '/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/aarch64-none-linux-gnu/libc'] + c_link_args = ['-target', 'aarch64-linux-gnu', '-fuse-ld=lld', '--sysroot', '/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/aarch64-none-linux-gnu/libc', '--gcc-toolchain=/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu'] -.. _configure_and_cross_compile_dpdk_build: +Assuming the file with augmented c_args and c_link_args is named arm64_armv8_linux_clang, +use the following command to cross-compile DPDK for your target machine:: -Cross Compiling DPDK --------------------- + meson aarch64-build-clang --cross-file config/arm/arm64_armv8_linux_clang + ninja -C aarch64-build-clang -Meson depends on pkgconfig to find the dependencies. -The package ``pkg-config-aarch64-linux-gnu`` is required for aarch64. -To install it in Ubuntu:: +Cross Compiling DPDK with LLVM/Clang toolchain using Meson on Ubuntu 18.04 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - sudo apt-get install pkg-config-aarch64-linux-gnu +On most popular Linux distribution it's not necessary to download +the toolchains, but rather use the packages provided by said distributions. +On Ubuntu 18.04, you'll need these packages: -To cross-compile DPDK on a desired target machine we can use the following -command:: +.. code-block:: console - meson cross-build --cross-file - ninja -C cross-build + sudo apt-get install pkg-config-aarch64-linux-gnu clang llvm llvm-dev lld + libc6-dev-arm64-cross libatomic1-arm64-cross libgcc-8-dev-arm64-cross -For example if the target machine is arm64 we can use the following -command:: +Use the following command to cross-compile DPDK for your target machine:: - meson arm64-build --cross-file config/arm/arm64_armv8_linux_gcc - ninja -C arm64-build + meson aarch64-build-clang --cross-file config/arm/arm64_armv8_linux_clang_ubuntu1804 + ninja -C aarch64-build-clang Supported cross-compilation targets ----------------------------------- -- 2.20.1