]> git.droids-corp.org - dpdk.git/commitdiff
config/arm: add platform config option
authorJuraj Linkeš <juraj.linkes@pantheon.tech>
Wed, 14 Apr 2021 13:41:35 +0000 (15:41 +0200)
committerThomas Monjalon <thomas@monjalon.net>
Thu, 15 Apr 2021 20:34:37 +0000 (22:34 +0200)
Add Arm SoC configuration sets to Arm meson.build and add an arch
agnostic meson option, 'platform', to select from these SoC
configurations for meson native builds. This is preferable to
specifying a cross file when doing aarch64 -> aarch64 builds, since the
cross file specifies the toolchain as well.

Signed-off-by: Juraj Linkeš <juraj.linkes@pantheon.tech>
Reviewed-by: Honnappa Nagarahalli <honnappa.nagarahalli@arm.com>
Reviewed-by: Ruifeng Wang <ruifeng.wang@arm.com>
Tested-by: Pavan Nikhilesh <pbhagavatula@marvell.com>
16 files changed:
config/arm/arm64_armada_linux_gcc
config/arm/arm64_armv8_linux_clang_ubuntu1804
config/arm/arm64_armv8_linux_gcc
config/arm/arm64_bluefield_linux_gcc
config/arm/arm64_dpaa_linux_gcc
config/arm/arm64_emag_linux_gcc
config/arm/arm64_graviton2_linux_gcc
config/arm/arm64_n1sdp_linux_gcc
config/arm/arm64_n2_linux_gcc
config/arm/arm64_octeontx2_linux_gcc
config/arm/arm64_stingray_linux_gcc
config/arm/arm64_thunderx2_linux_gcc
config/arm/arm64_thunderxt88_linux_gcc
config/arm/meson.build
doc/guides/linux_gsg/cross_build_dpdk_for_arm64.rst
meson_options.txt

index 9958db6692f023f9fa4cfb6340e08c6d0738f473..301418949b00206b94d74aea86ba9ed343fde63a 100644 (file)
@@ -14,8 +14,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x56'
-part_number = '0xd08'
-max_lcores = 16
-max_numa_nodes = 1
-numa = false
+platform = 'armada'
index 57095c1304f229b361f8b8bca1f042f16410a6a1..db488d75f46b72a6fedb14aaa3b5a54a6a197bea 100644 (file)
@@ -14,7 +14,6 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = 'generic'
-part_number = 'generic'
+platform = 'generic'
 c_args = ['-target', 'aarch64-linux-gnu', '--sysroot', '/usr/aarch64-linux-gnu']
 c_link_args = ['-target', 'aarch64-linux-gnu', '-fuse-ld=lld', '--gcc-toolchain=/usr']
index 5451a01da1a912e0c7e8f7c9c4f363e1668ddf88..5391d353890ea54c61cde6160c87846374ccbdf4 100644 (file)
@@ -14,7 +14,4 @@ endian = 'little'
 
 [properties]
 # Generate binaries that are portable across all Armv8 machines
-implementer_id = 'generic'
-part_number = 'generic'
-max_lcores = 256
-max_numa_nodes = 4
+platform = 'generic'
index 6bef87fbd418d046d1df58e0f3ecbae4b80648d7..248a9f031a8f25116a719e355bec04d3d110d09a 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x41'
-part_number = '0xd08'
-max_lcores = 16
-max_numa_nodes = 1
-numa = false
+platform = 'bluefield'
index 37398c76289ba87c97511831527b48f57e98181f..e9d5fd31fc229d7f84252884551d3ff3da5238a9 100644 (file)
@@ -14,8 +14,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = 'dpaa'
-part_number = '0xd08'
-max_lcores = 16
-max_numa_nodes = 1
-numa = false
+platform = 'dpaa'
index 7cbb055106121e746347078fd519c9934b4a541f..9cdd931180b3dce3be91d6a9ccbe9278826d9afa 100644 (file)
@@ -13,7 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x50'
-part_number = '0x0'
-max_lcores = 32
-max_numa_nodes = 1
+platform = 'emag'
index edacb79497ad9d72f726aceff3caaa8c19df1e1e..8016fd236c65fb8469854975b1d358ec9f03a801 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x41'
-part_number = '0xd0c'
-max_lcores = 64
-max_numa_nodes = 1
-numa = false
+platform = 'graviton2'
index b00f2d1ef71073d7528ea6afe5c214da68503289..0df283e2f48d709e2cf923dfdf2b8155bf2a498a 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x41'
-part_number = '0xd0c'
-max_lcores = 4
-max_numa_nodes = 1
-numa = false
+platform = 'n1sdp'
index 817b8ee28ea30f051685729103240d3a74f8ac1e..036aee2b0a6682beb28b8020e369b37833ecfa8e 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x41'
-part_number = '0xd49'
-max_lcores = 64
-max_numa_nodes = 1
-numa = false
+platform = 'n2'
index 593769709832b4bc6f25e3b38a8e3e600a2a4c1a..9156ee5410682ae501ca857827ab52e2b8f9c727 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x43'
-part_number = '0xb2'
-max_lcores = 36
-max_numa_nodes = 1
-numa = false
+platform = 'octeontx2'
index 6bef87fbd418d046d1df58e0f3ecbae4b80648d7..319a4a151dded94c570f71e48b091a3aa66f11dc 100644 (file)
@@ -13,8 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x41'
-part_number = '0xd08'
-max_lcores = 16
-max_numa_nodes = 1
-numa = false
+platform = 'stingray'
index c06dcdc2b307a2277ce82e3c7f6ec104f305a363..69c71cbc829ca881b6f67881c1e2c9abc8edab88 100644 (file)
@@ -13,7 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x43'
-part_number = '0xaf'
-max_lcores = 256
-max_numa_nodes = 2
+platform = 'thunderx2'
index 3ba1528e48d14c9f81bc924d8aa818890a1af0d5..372097ba016d2fc731e687c55ff3eb7fe0638151 100644 (file)
@@ -13,7 +13,4 @@ cpu = 'armv8-a'
 endian = 'little'
 
 [properties]
-implementer_id = '0x43'
-part_number = '0xa1'
-max_lcores = 96
-max_numa_nodes = 1
+platform = 'thunderxt88'
index 2984ae2db357387c0992d35fbe7fd337b8a27089..7cd30388885cc61f82b0c287ec9c14b48c2a5105 100644 (file)
@@ -26,7 +26,7 @@ flags_common = [
 ## Part numbers are specific to Arm implementers
 # implementer specific aarch64 flags have middle priority
 #     (will overwrite common flags)
-# part number specific aarch64 flags have the highest priority
+# part number specific aarch64 flags have higher priority
 #     (will overwrite both common and implementer specific flags)
 implementer_generic = {
        'description': 'Generic armv8',
@@ -193,6 +193,106 @@ implementers = {
        'dpaa': implementer_dpaa
 }
 
+# SoC specific aarch64 flags have the highest priority
+#     (will overwrite all other flags)
+soc_generic = {
+       'description': 'Generic un-optimized build for all aarch64 machines',
+       'implementer': 'generic',
+       'part_number': 'generic'
+}
+
+soc_armada = {
+       'description': 'Marvell ARMADA',
+       'implementer': '0x56',
+       'part_number': '0xd08',
+       'numa': false
+}
+
+soc_bluefield = {
+       'description': 'NVIDIA BlueField',
+       'implementer': '0x41',
+       'part_number': '0xd08',
+       'numa': false
+}
+
+soc_dpaa = {
+       'description': 'NXP DPAA',
+       'implementer': 'dpaa',
+       'part_number': '0xd08',
+       'numa': false
+}
+
+soc_emag = {
+       'description': 'Ampere eMAG',
+       'implementer': '0x50',
+       'part_number': '0x0'
+}
+
+soc_graviton2 = {
+       'description': 'AWS Graviton2',
+       'implementer': '0x41',
+       'part_number': '0xd0c',
+       'numa': false
+}
+
+soc_n1sdp = {
+       'description': 'Arm Neoverse N1SDP',
+       'implementer': '0x41',
+       'part_number': '0xd0c',
+       'flags': [
+               ['RTE_MAX_LCORE', 4]
+       ],
+       'numa': false
+}
+
+soc_n2 = {
+       'description': 'Arm Neoverse N2',
+       'implementer': '0x41',
+       'part_number': '0xd49',
+       'numa': false
+}
+
+soc_octeontx2 = {
+       'description': 'Marvell OCTEON TX2',
+       'implementer': '0x43',
+       'part_number': '0xb2',
+       'numa': false
+}
+
+soc_stingray = {
+       'description': 'Broadcom Stingray',
+       'implementer': '0x41',
+       'part_number': '0xd08',
+       'numa': false
+}
+
+soc_thunderx2 = {
+       'description': 'Marvell ThunderX2 T99',
+       'implementer': '0x43',
+       'part_number': '0xaf'
+}
+
+soc_thunderxt88 = {
+       'description': 'Marvell ThunderX T88',
+       'implementer': '0x43',
+       'part_number': '0xa1'
+}
+
+socs = {
+       'generic': soc_generic,
+       'armada': soc_armada,
+       'bluefield': soc_bluefield,
+       'dpaa': soc_dpaa,
+       'emag': soc_emag,
+       'graviton2': soc_graviton2,
+       'n1sdp': soc_n1sdp,
+       'n2': soc_n2,
+       'octeontx2': soc_octeontx2,
+       'stingray': soc_stingray,
+       'thunderx2': soc_thunderx2,
+       'thunderxt88': soc_thunderxt88
+}
+
 dpdk_conf.set('RTE_ARCH_ARM', 1)
 dpdk_conf.set('RTE_FORCE_INTRINSICS', 1)
 
@@ -204,11 +304,19 @@ if dpdk_conf.get('RTE_ARCH_32')
        machine_args += '-mfpu=neon'
 else
        # aarch64 build
+       soc = get_option('platform')
+       soc_config = {}
        if not meson.is_cross_build()
                if machine == 'generic'
                        # generic build
+                       if soc != ''
+                               error('Building for a particular platform is ' +
+                                     'unsupported with generic build.')
+                       endif
                        implementer_id = 'generic'
                        part_number = 'generic'
+               elif soc != ''
+                       soc_config = socs.get(soc, {'not_supported': true})
                else
                        # native build
                        # The script returns ['Implementer', 'Variant', 'Architecture',
@@ -226,8 +334,27 @@ else
                endif
        else
                # cross build
-               implementer_id = meson.get_cross_property('implementer_id')
-               part_number = meson.get_cross_property('part_number')
+               soc = meson.get_cross_property('platform', '')
+               if soc == ''
+                       error('Arm SoC must be specified in the cross file.')
+               endif
+               soc_config = socs.get(soc, {'not_supported': true})
+       endif
+
+       soc_flags = []
+       if soc_config.has_key('not_supported')
+               error('SoC @0@ not supported.'.format(soc))
+       elif soc_config != {}
+               implementer_id = soc_config['implementer']
+               implementer_config = implementers[implementer_id]
+               part_number = soc_config['part_number']
+               soc_flags = soc_config.get('flags', [])
+               if not soc_config.get('numa', true)
+                       has_libnuma = 0
+               endif
+
+               disable_drivers += ',' + soc_config.get('disable_drivers', '')
+               enable_drivers += ',' + soc_config.get('enable_drivers', '')
        endif
 
        if implementers.has_key(implementer_id)
@@ -253,8 +380,8 @@ else
                      '(-Dmachine=generic) build.')
        endif
 
-       # use common flags with implementer flags
-       dpdk_flags = flags_common + implementer_config['flags'] + part_number_config.get('flags', [])
+       # add/overwrite flags in the proper order
+       dpdk_flags = flags_common + implementer_config['flags'] + part_number_config.get('flags', []) + soc_flags
 
        # apply supported machine args
        machine_args = [] # Clear previous machine args
index 9b9e8ef7046bccd5a55fec5f21c3f18f36242a41..3857cdefe9fbeb349f1f93a76e6342fe58f223ac 100644 (file)
@@ -187,58 +187,60 @@ Use the following command to cross-compile DPDK for the target machine::
    meson aarch64-build-clang --cross-file config/arm/arm64_armv8_linux_clang_ubuntu1804
    ninja -C aarch64-build-clang
 
-Supported cross-compilation targets
------------------------------------
-
-If you wish to build for a target which is not among the current cross-files,
-you may use various combinations of implementer/part number::
-
-   Supported implementers:
-      'generic': Generic armv8
-      '0x41':    Arm
-      '0x43':    Cavium
-      '0x50':    Ampere Computing
-      '0x56':    Marvell ARMADA
-      'dpaa':    NXP DPAA
-
-   Supported part_numbers for generic:
-      'generic': valid for all armv8-a architectures (unoptimized portable build)
-
-   Supported part_numbers for 0x41, 0x56, dpaa:
-      '0xd03':   cortex-a53
-      '0xd04':   cortex-a35
-      '0xd09':   cortex-a73
-      '0xd0a':   cortex-a75
-      '0xd0b':   cortex-a76
-      '0xd0c':   neoverse-n1
-
-   Supported part_numbers for 0x43:
-      '0xa1':    thunderxt88
-      '0xa2':    thunderxt81
-      '0xa3':    thunderxt83
-      '0xaf':    thunderx2t99
-      '0xb2':    octeontx2
-
-   Supported part_numbers for 0x50:
-      '0x0':     emag
-
-Other cross file options
-------------------------
-
-There are other options you may specify in a cross file to tailor the build::
-
-   Supported extra configuration
-      max_numa_nodes = n  # will set RTE_MAX_NUMA_NODES
-      max_lcores = n      # will set RTE_MAX_LCORE
-
-      numa = false        # set to false to force building for a non-NUMA system
-         # if not set or set to true, the build system will build for a NUMA
-         # system only if libnuma is installed
-
-      disable_drivers = 'bus/dpaa,crypto/*'  # add disabled drivers
-         # valid values are dir/subdirs in the drivers directory
-         # wildcards are allowed
-
-      enable_drivers = 'common/*,bus/*'  # build only these drivers
-         # valid values are dir/subdirs in the drivers directory
-         # wildcards are allowed
+Building for an aarch64 SoC on an aarch64 build machine
+-------------------------------------------------------
+
+If you wish to build on an aarch64 build machine for a different aarch64 SoC,
+you don't need a separate cross toolchain, just a different set of
+configuration options. To build for an aarch64 SoC, use the -Dplatform meson
+option::
+
+   meson soc_build -Dplatform=<target_soc>
+
+Substitute <target_soc> with one of the supported SoCs::
+
+   generic:     Generic un-optimized build for all aarch64 machines.
+   armada:      Marvell ARMADA
+   bluefield:   NVIDIA BlueField
+   dpaa:        NXP DPAA
+   emag:        Ampere eMAG
+   graviton2:   AWS Graviton2
+   n1sdp:       Arm Neoverse N1SDP
+   octeontx2:   Marvell OCTEON TX2
+   stingray:    Broadcom Stingray
+   thunderx2:   Marvell ThunderX2 T99
+   thunderxt88: Marvell ThunderX T88
+
+These SoCs are also used in cross files, e.g.::
+
+   [properties]
+   # Generate binaries that are portable across all Armv8 machines
+   platform = 'generic'
+
+Supported SoC configuration
+---------------------------
+
+The SoC configuration is a combination of implementer and CPU part number
+configuration and SoC-specific configuration::
+
+   soc_<name> = {
+      'description': 'SoC Description',  # mandatory
+      'implementer': <implementer_id>,   # mandatory
+      'part_number': <part_number>,      # mandatory
+      'numa': false,  # optional, specify for non-NUMA SoCs
+      'enable_drivers': 'common/*,bus/*',  # optional, comma-separated list of
+                              # drivers to build, wildcards are accepted
+      'disable_drivers': 'crypto/*',       # optional, comma-separated list of
+                              # drivers to disable, wildcards are accepted
+      'flags': [
+         ['RTE_MAX_LCORE', '16'],
+         ['RTE_MAX_NUMA_NODES', '1']
+      ]               # optional, list of DPDK options that will be added
+                      # or overwritten
+   }
+
+Where <implementer_id> is a key defined in the implementers dictionary
+in config/arm/meson.build (e.g. 0x41) and part_number is a key defined
+in implementers[<implementer_id>]['part_number_config'] dictionary
+(i.e. the part number must be defined for the implementer,
+e.g. for 0x41, a valid value is 0xd49, which is the neoverse-n2 SoC).
index e1dc351620f0504c1f0c52716ea3113d4777a979..b78f3bd9d510affa93726f9ca9189db8f05a78db 100644 (file)
@@ -34,6 +34,8 @@ option('max_lcores', type: 'integer', value: 128,
        description: 'maximum number of cores/threads supported by EAL')
 option('max_numa_nodes', type: 'integer', value: 32,
        description: 'maximum number of NUMA nodes supported by EAL')
+option('platform', type: 'string', value: '',
+       description: 'use configuration for a particular platform (such as a SoC).')
 option('enable_trace_fp', type: 'boolean', value: false,
        description: 'enable fast path trace points.')
 option('tests', type: 'boolean', value: true,