compilation|FAILURE| pw(131232) sid(29449) job(PER_PATCH_BUILD8959)[v2, 2/2] random: make rte_rand() thread safe for non-EAL threads
    sys_stv at intel.com 
    sys_stv at intel.com
       
    Thu Sep  7 17:43:14 CEST 2023
    
    
  
Test-Label: Intel-compilation
Test-Status: FAILURE
http://dpdk.org/patch/131232
_Compilation issues_
Submitter: Stephen Hemminger <stephen at networkplumber.org>
Date: 2023-09-07 15:24:56
Reply_mail: <20230907152456.20570-3-stephen at networkplumber.org>
DPDK git baseline: Repo:dpdk, CommitID: e92ba1426914db1d224dd5e9a1743657681b8814
Meson Build Summary: 25 Builds Done, 21 Successful, 4 Failures, 0 Blocked
+-------------------+------------+--------------+------------+------------+-----------+----------+------------+
| os                | gcc-static | clang-static | icc-static | gcc-shared | gcc-debug | document | gcc-16byte |
+-------------------+------------+--------------+------------+------------+-----------+----------+------------+
| OpenAnolis8.8-64  | pass       |              |            |            |           |          |            |
| FreeBSD13-64      | pass       | pass         |            | pass       | pass      |          |            |
| RHEL92-64         | pass       | fail         |            | pass       | pass      |          |            |
| SUSE15-64         | pass       | fail         |            |            |           |          |            |
| CBL-Mariner2.0-64 | pass       |              |            |            |           |          |            |
| UB2004-64         | pass       |              |            |            |           |          |            |
| UB2204-32         | pass       |              |            |            |           |          |            |
| RHEL87-64         | pass       |              |            |            |           |          |            |
| UB2204-64         | pass       | fail         |            |            |           | pass     | pass       |
| CentOS79-64       | pass       |              |            |            |           |          |            |
| RHEL92-64Rt       | pass       |              |            |            |           |          |            |
| UB2304-64         | pass       |              |            |            |           |          |            |
| FC38-64           | pass       | fail         |            |            |           |          |            |
| UB2204-64Rt       | pass       |              |            |            |           |          |            |
+-------------------+------------+--------------+------------+------------+-----------+----------+------------+
Comments: 
Because of DPDK bug (https://bugs.dpdk.org/show_bug.cgi?id=928),
All the dpdk-next-* branch add `Ddisable_drivers=event/cnxk` option when build with ICC complier. 
 
Test environment and configuration as below:
OS: OpenAnolis8.8-64
	Kernel Version: 5.10.134-13.an8.x86_64
	GCC Version: gcc (GCC) 8.5.0 20210514 (Anolis 8.5.0-10.0.3)
	Clang Version: 13.0.1 (Anolis 13.0.1-2.0.2.module+an8.7.0+10996+1588f068)
	x86_64-native-linuxapp-gcc
OS: FreeBSD13-64
	Kernel Version: 13.2-RELEASE
	GCC Version: gcc (FreeBSD Ports Collection) 12.2.0
	Clang Version: 14.0.5 (https://github.com/llvm/llvm-project.git llvmorg-14.0.5-0-gc12386ae247c)
	x86_64-native-bsdapp-gcc
	x86_64-native-bsdapp-clang
	x86_64-native-bsdapp-gcc+shared
	x86_64-native-bsdapp-gcc+debug
OS: RHEL92-64
	Kernel Version: 5.14.0-284.11.1.el9_2.x86_64
	GCC Version: gcc (GCC) 11.3.1 20221121 (Red Hat 11.3.1-4)
	Clang Version: 15.0.7 (Red Hat 15.0.7-2.el9)
	x86_64-native-linuxapp-gcc
	x86_64-native-linuxapp-clang
	x86_64-native-linuxapp-gcc+shared
	x86_64-native-linuxapp-gcc+debug
OS: SUSE15-64
	Kernel Version: 5.14.21-150500.53-default
	GCC Version: gcc (SUSE Linux) 7.5.0
	Clang Version: 15.0.7
	x86_64-native-linuxapp-clang
	x86_64-native-linuxapp-gcc
OS: CBL-Mariner2.0-64
	Kernel Version: 5.15.55.1_2e9a4f9+
	GCC Version: gcc (GCC) 11.2.0
	Clang Version: NA
	x86_64-native-linuxapp-gcc
OS: UB2004-64
	Kernel Version: 5.8.0-48-generic
	GCC Version: gcc (Ubuntu 10.3.0-1ubuntu1~20.04) 10.3.0
	Clang Version: 10.0.0-4ubuntu1
	x86_64-native-linuxapp-gcc
OS: UB2204-32
	Kernel Version: 5.15.0-58-generic
	GCC Version: gcc (Ubuntu 11.4.0-1ubuntu1~22.04) 11.4.0
	Clang Version: NA
	i686-native-linuxapp-gcc
OS: RHEL87-64
	Kernel Version: 4.18.0-425.3.1.el8.x86_64
	GCC Version: gcc (GCC) 8.5.0 20210514 (Red Hat 8.5.0-15)
	Clang Version: NA
	x86_64-native-linuxapp-gcc
OS: UB2204-64
	Kernel Version: 5.15.0-58-generic
	GCC Version: gcc (Ubuntu 11.4.0-1ubuntu1~22.04) 11.4.0
	Clang Version: 14.0.0-1ubuntu1.1
	x86_64-native-linuxapp-gcc+16byte
	x86_64-native-linuxapp-gcc
	x86_64-native-linuxapp-clang
	x86_64-native-linuxapp-doc
OS: CentOS79-64
	Kernel Version: 3.10.0-1160.81.1.el7.x86_64
	GCC Version: gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-44)
	Clang Version: 3.4.2 (tags/RELEASE_34/dot2-final)
	x86_64-native-linuxapp-gcc
OS: RHEL92-64Rt
	Kernel Version: 5.14.0-284.11.1.rt14.296.el9_2.x86_64
	GCC Version: gcc (GCC) 11.3.1 20221121 (Red Hat 11.3.1-4)
	Clang Version: 15.0.7 (Red Hat 15.0.7-2.el9)
	x86_64-native-linuxapp-gcc
OS: UB2304-64
	Kernel Version: 6.2.0-20-generic
	GCC Version: gcc (Ubuntu 12.2.0-17ubuntu1) 12.2.0
	Clang Version: NA
	x86_64-native-linuxapp-gcc
OS: FC38-64
	Kernel Version: 6.2.9-300.fc38.x86_64
	GCC Version: gcc (GCC) 13.0.1 20230401 (Red Hat 13.0.1-0)
	Clang Version: 16.0.0 (Fedora 16.0.0-2.fc38)
	x86_64-native-linuxapp-gcc
	x86_64-native-linuxapp-clang
OS: UB2204-64Rt
	Kernel Version: 5.17.5-051705-generic
	GCC Version: gcc (Ubuntu 11.4.0-1ubuntu1~22.04) 11.4.0
	Clang Version: 14.0.0-1ubuntu1.1
	x86_64-native-linuxapp-gcc
*Build Failed #1:
OS: RHEL92-64
Target: x86_64-native-linuxapp-clang
FAILED: lib/librte_eal.a.p/eal_common_rte_random.c.o 
clang -Ilib/librte_eal.a.p -Ilib -I../lib -I. -I.. -Iconfig -I../config -Ilib/eal/include -I../lib/eal/include -Ilib/eal/linux/include -I../lib/eal/linux/include -Ilib/eal/x86/include -I../lib/eal/x86/include -Ilib/eal/common -I../lib/eal/common -Ilib/eal -I../lib/eal -Ilib/kvargs -I../lib/kvargs -Ilib/log -I../lib/log -Ilib/metrics -I../lib/metrics -Ilib/telemetry -I../lib/telemetry -fcolor-diagnostics -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wextra -Werror -std=c11 -O3 -include rte_config.h -Wcast-qual -Wdeprecated -Wformat -Wformat-nonliteral -Wformat-security -Wmissing-declarations -Wmissing-prototypes -Wnested-externs -Wold-style-definition -Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef -Wwrite-strings -Wno-address-of-packed-member -Wno-missing-field-initializers -D_GNU_SOURCE -fPIC -march=native -mrtm -DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API '-DABI_VERSION="24.0"' -DRTE_LOG_DEFAULT_LOGTYPE=lib.eal -DRTE_ANNOTATE_LOCKS -Wthread-safety -MD -MQ lib/librte_eal.a.p/eal_common_rte_random.c.o -MF lib/librte_eal.a.p/eal_common_rte_random.c.o.d -o lib/librte_eal.a.p/eal_common_rte_random.c.o -c ../lib/eal/common/rte_random.c
../lib/eal/common/rte_random.c:136:10: error: mutex 'rte_rand_lock' is not held on every path through here [-Werror,-Wthread-safety-analysis]
        return &rand_states[idx];
                ^
../lib/eal/common/rte_random.c:133:3: note: mutex acquired here
                rte_spinlock_lock(&rte_rand_lock);
                ^
../lib/eal/common/rte_random.c:143:3: error: releasing mutex 'rte_rand_lock' that was not held [-Werror,-Wthread-safety-analysis]
                rte_spinlock_unlock(&rte_rand_lock);
                ^
2 errors generated.
[47/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_options.c.o
[48/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_dynmem.c.o
[49/2716] Compiling C object lib/librte_eal.a.p/eal_common_rte_malloc.c.o
[50/2716] Compiling C object lib/librte_eal.a.p/eal_common_malloc_heap.c.o
[51/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_ctf.c.o
[52/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace.c.o
[53/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_proc.c.o
[54/2716] Compiling C object lib/librte_eal.a.p/eal_common_rte_service.c.o
[55/2716] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_utils.c.o
ninja: build stopped
*Build Failed #2:
OS: SUSE15-64
Target: x86_64-native-linuxapp-clang
FAILED: lib/librte_eal.a.p/eal_common_rte_random.c.o 
clang -Ilib/librte_eal.a.p -Ilib -I../lib -I. -I.. -Iconfig -I../config -Ilib/eal/include -I../lib/eal/include -Ilib/eal/linux/include -I../lib/eal/linux/include -Ilib/eal/x86/include -I../lib/eal/x86/include -Ilib/eal/common -I../lib/eal/common -Ilib/eal -I../lib/eal -Ilib/kvargs -I../lib/kvargs -Ilib/log -I../lib/log -Ilib/metrics -I../lib/metrics -Ilib/telemetry -I../lib/telemetry -fcolor-diagnostics -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wextra -Werror -std=c11 -O3 -include rte_config.h -Wcast-qual -Wdeprecated -Wformat -Wformat-nonliteral -Wformat-security -Wmissing-declarations -Wmissing-prototypes -Wnested-externs -Wold-style-definition -Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef -Wwrite-strings -Wno-address-of-packed-member -Wno-missing-field-initializers -D_GNU_SOURCE -fPIC -march=native -mrtm -DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API '-DABI_VERSION="24.0"' -DRTE_LOG_DEFAULT_LOGTYPE=lib.eal -DRTE_ANNOTATE_LOCKS -Wthread-safety -MD -MQ lib/librte_eal.a.p/eal_common_rte_random.c.o -MF lib/librte_eal.a.p/eal_common_rte_random.c.o.d -o lib/librte_eal.a.p/eal_common_rte_random.c.o -c ../lib/eal/common/rte_random.c
../lib/eal/common/rte_random.c:136:10: error: mutex 'rte_rand_lock' is not held on every path through here [-Werror,-Wthread-safety-analysis]
        return &rand_states[idx];
                ^
../lib/eal/common/rte_random.c:133:3: note: mutex acquired here
                rte_spinlock_lock(&rte_rand_lock);
                ^
../lib/eal/common/rte_random.c:143:3: error: releasing mutex 'rte_rand_lock' that was not held [-Werror,-Wthread-safety-analysis]
                rte_spinlock_unlock(&rte_rand_lock);
                ^
2 errors generated.
[42/2774] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_options.c.o
[43/2774] Generating symbol file lib/librte_log.so.24.0.p/librte_log.so.24.0.symbols
[44/2774] Compiling C object lib/librte_eal.a.p/eal_common_malloc_heap.c.o
[45/2774] Compiling C object lib/librte_eal.a.p/eal_common_rte_malloc.c.o
[46/2774] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace.c.o
[47/2774] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_dynmem.c.o
[48/2774] Compiling C object lib/librte_eal.a.p/eal_common_rte_service.c.o
[49/2774] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_ctf.c.o
[50/2774] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_proc.c.o
ninja: build stopped
*Build Failed #3:
OS: UB2204-64
Target: x86_64-native-linuxapp-clang
FAILED: lib/librte_eal.a.p/eal_common_rte_random.c.o 
clang -Ilib/librte_eal.a.p -Ilib -I../lib -I. -I.. -Iconfig -I../config -Ilib/eal/include -I../lib/eal/include -Ilib/eal/linux/include -I../lib/eal/linux/include -Ilib/eal/x86/include -I../lib/eal/x86/include -Ilib/eal/common -I../lib/eal/common -Ilib/eal -I../lib/eal -Ilib/kvargs -I../lib/kvargs -Ilib/log -I../lib/log -Ilib/metrics -I../lib/metrics -Ilib/telemetry -I../lib/telemetry -fcolor-diagnostics -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wextra -Werror -std=c11 -O3 -include rte_config.h -Wcast-qual -Wdeprecated -Wformat -Wformat-nonliteral -Wformat-security -Wmissing-declarations -Wmissing-prototypes -Wnested-externs -Wold-style-definition -Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef -Wwrite-strings -Wno-address-of-packed-member -Wno-missing-field-initializers -D_GNU_SOURCE -fPIC -march=native -mrtm -DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API '-DABI_VERSION="24.0"' -DRTE_LOG_DEFAULT_LOGTYPE=lib.eal -DRTE_ANNOTATE_LOCKS -Wthread-safety -MD -MQ lib/librte_eal.a.p/eal_common_rte_random.c.o -MF lib/librte_eal.a.p/eal_common_rte_random.c.o.d -o lib/librte_eal.a.p/eal_common_rte_random.c.o -c ../lib/eal/common/rte_random.c
../lib/eal/common/rte_random.c:136:10: error: mutex 'rte_rand_lock' is not held on every path through here [-Werror,-Wthread-safety-analysis]
        return &rand_states[idx];
                ^
../lib/eal/common/rte_random.c:133:3: note: mutex acquired here
                rte_spinlock_lock(&rte_rand_lock);
                ^
../lib/eal/common/rte_random.c:143:3: error: releasing mutex 'rte_rand_lock' that was not held [-Werror,-Wthread-safety-analysis]
                rte_spinlock_unlock(&rte_rand_lock);
                ^
2 errors generated.
[47/2802] Generating symbol file lib/librte_telemetry.so.24.0.p/librte_telemetry.so.24.0.symbols
[48/2802] Compiling C object lib/librte_eal.a.p/eal_common_rte_malloc.c.o
[49/2802] Compiling C object lib/librte_eal.a.p/eal_common_malloc_heap.c.o
[50/2802] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_dynmem.c.o
[51/2802] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace.c.o
[52/2802] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_utils.c.o
[53/2802] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_proc.c.o
[54/2802] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_ctf.c.o
[55/2802] Compiling C object lib/librte_eal.a.p/eal_common_rte_service.c.o
ninja: build stopped
*Build Failed #4:
OS: FC38-64
Target: x86_64-native-linuxapp-clang
FAILED: lib/librte_eal.a.p/eal_common_rte_random.c.o 
clang -Ilib/librte_eal.a.p -Ilib -I../lib -I. -I.. -Iconfig -I../config -Ilib/eal/include -I../lib/eal/include -Ilib/eal/linux/include -I../lib/eal/linux/include -Ilib/eal/x86/include -I../lib/eal/x86/include -Ilib/eal/common -I../lib/eal/common -Ilib/eal -I../lib/eal -Ilib/kvargs -I../lib/kvargs -Ilib/log -I../lib/log -Ilib/metrics -I../lib/metrics -Ilib/telemetry -I../lib/telemetry -fcolor-diagnostics -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wextra -Werror -std=c11 -O3 -include rte_config.h -Wcast-qual -Wdeprecated -Wformat -Wformat-nonliteral -Wformat-security -Wmissing-declarations -Wmissing-prototypes -Wnested-externs -Wold-style-definition -Wpointer-arith -Wsign-compare -Wstrict-prototypes -Wundef -Wwrite-strings -Wno-address-of-packed-member -Wno-missing-field-initializers -D_GNU_SOURCE -fPIC -march=native -mrtm -DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API '-DABI_VERSION="24.0"' -DRTE_LOG_DEFAULT_LOGTYPE=lib.eal -DRTE_ANNOTATE_LOCKS -Wthread-safety -MD -MQ lib/librte_eal.a.p/eal_common_rte_random.c.o -MF lib/librte_eal.a.p/eal_common_rte_random.c.o.d -o lib/librte_eal.a.p/eal_common_rte_random.c.o -c ../lib/eal/common/rte_random.c
../lib/eal/common/rte_random.c:136:10: error: mutex 'rte_rand_lock' is not held on every path through here [-Werror,-Wthread-safety-analysis]
        return &rand_states[idx];
                ^
../lib/eal/common/rte_random.c:133:3: note: mutex acquired here
                rte_spinlock_lock(&rte_rand_lock);
                ^
../lib/eal/common/rte_random.c:143:3: error: releasing mutex 'rte_rand_lock' that was not held [-Werror,-Wthread-safety-analysis]
                rte_spinlock_unlock(&rte_rand_lock);
                ^
2 errors generated.
[47/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_options.c.o
[48/2964] Compiling C object lib/librte_eal.a.p/eal_common_rte_malloc.c.o
[49/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_dynmem.c.o
[50/2964] Compiling C object lib/librte_eal.a.p/eal_common_malloc_heap.c.o
[51/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_ctf.c.o
[52/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace_utils.c.o
[53/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_trace.c.o
[54/2964] Compiling C object lib/librte_eal.a.p/eal_common_rte_service.c.o
[55/2964] Compiling C object lib/librte_eal.a.p/eal_common_eal_common_proc.c.o
ninja: build stopped
DPDK STV team
    
    
More information about the test-report
mailing list