[dpdk-dev] DPDK Release Status Meeting 12/11/2020

David Marchand david.marchand at redhat.com
Thu Nov 12 12:57:45 CET 2020


On Thu, Nov 12, 2020 at 12:39 PM Ferruh Yigit <ferruh.yigit at intel.com> wrote:
>    * In suse build environment, there are some arm and PPC build error
>      * For arm the RHEL 7 compiler for arm is too old
>        * Can be possible to disable the failing driver and still test the rest

Luca also mentioned an issue on Centos 8.


Interestingly, I am not able to reproduce it in my OBS env.
https://build.opensuse.org/build/home:dmarchan/home_bluca_dpdk_CentOS_8/aarch64/dpdk/_log

[  135s] [118/2414] cc -Ilib/76b5a35@@rte_net at sta -Ilib -I../lib
-Ilib/librte_net -I../lib/librte_net -I. -I../ -Iconfig -I../config
-Ilib/librte_eal/include -I../lib/librte_eal/include
-Ilib/librte_eal/linux/include -I../lib/librte_eal/linux/include
-Ilib/librte_eal/arm/include -I../lib/librte_eal/arm/include
-Ilib/librte_eal/common -I../lib/librte_eal/common -Ilib/librte_eal
-I../lib/librte_eal -Ilib/librte_kvargs -I../lib/librte_kvargs
-Ilib/librte_telemetry/../librte_metrics
-I../lib/librte_telemetry/../librte_metrics -Ilib/librte_telemetry
-I../lib/librte_telemetry -Ilib/librte_mbuf -I../lib/librte_mbuf
-Ilib/librte_mempool -I../lib/librte_mempool -Ilib/librte_ring
-I../lib/librte_ring -fdiagnostics-color=always -pipe
-D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -O3 -include rte_config.h
-Wextra -Wcast-qual -Wdeprecated -Wmissing-declarations
-Wmissing-prototypes -Wnested-externs -Wold-style-definition
-Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef
-Wwrite-strings -Wno-packed-not-aligned
-Wno-missing-field-initializers -D_GNU_SOURCE -fcommon -Werror -fPIC
-march=armv8.1-a+crc+crypto -mcpu=thunderx2t99
-DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API -Wno-format-truncation
-DCC_ARM64_NEON_PMULL_SUPPORT  -MD -MQ
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o' -MF
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o.d' -o
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o' -c
../lib/librte_net/net_crc_neon.c

Looking at Luca env log:
https://build.opensuse.org/build/home:bluca:dpdk/CentOS_8/aarch64/dpdk/_log

[  290s] [117/2414] cc -Ilib/76b5a35@@rte_net at sta -Ilib -I../lib
-Ilib/librte_net -I../lib/librte_net -I. -I../ -Iconfig -I../config
-Ilib/librte_eal/include -I../lib/librte_eal/include
-Ilib/librte_eal/linux/include -I../lib/librte_eal/linux/include
-Ilib/librte_eal/arm/include -I../lib/librte_eal/arm/include
-Ilib/librte_eal/common -I../lib/librte_eal/common -Ilib/librte_eal
-I../lib/librte_eal -Ilib/librte_kvargs -I../lib/librte_kvargs
-Ilib/librte_telemetry/../librte_metrics
-I../lib/librte_telemetry/../librte_metrics -Ilib/librte_telemetry
-I../lib/librte_telemetry -Ilib/librte_mbuf -I../lib/librte_mbuf
-Ilib/librte_mempool -I../lib/librte_mempool -Ilib/librte_ring
-I../lib/librte_ring -fdiagnostics-color=always -pipe
-D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -O3 -include rte_config.h
-Wextra -Wcast-qual -Wdeprecated -Wmissing-declarations
-Wmissing-prototypes -Wnested-externs -Wold-style-definition
-Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef
-Wwrite-strings -Wno-packed-not-aligned
-Wno-missing-field-initializers -D_GNU_SOURCE -fcommon -Werror -fPIC
-mcpu=thunderxt88 -DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API
-Wno-format-truncation -DCC_ARM64_NEON_PMULL_SUPPORT  -MD -MQ
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o' -MF
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o.d' -o
'lib/76b5a35@@rte_net at sta/librte_net_net_crc_neon.c.o' -c
../lib/librte_net/net_crc_neon.c
...
[  290s] ../lib/librte_net/net_crc_neon.c: In function 'crcr32_folding_round':
[  290s] /usr/lib/gcc/aarch64-redhat-linux/8/include/arm_neon.h:26094:1:
error: inlining failed in call to always_inline 'vmull_p64': target
specific option mismatch
[  290s]  vmull_p64 (poly64_t a, poly64_t b)
[  290s]  ^~~~~~~~~


The difference is:
- for me -march=armv8.1-a+crc+crypto -mcpu=thunderx2t99 (working)
- for Luca -mcpu=thunderxt88 (*not* working)

Could you ARM guys have a look?
My gut feeling is that there is some check missing in
lib/librte_net/meson.build, maybe checking for __ARM_NEON in addition
to the check on __ARM_FEATURE_CRYPTO?


Thanks!

-- 
David Marchand



More information about the dev mailing list