Hello community, here is the log from the commit of package eigen3 for openSUSE:Factory checked in at 2020-10-27 18:59:47 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/eigen3 (Old) and /work/SRC/openSUSE:Factory/.eigen3.new.3463 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "eigen3" Tue Oct 27 18:59:47 2020 rev:21 rq:844059 version:3.3.8 Changes: -------- --- /work/SRC/openSUSE:Factory/eigen3/eigen3.changes 2020-10-23 12:19:38.300568475 +0200 +++ /work/SRC/openSUSE:Factory/.eigen3.new.3463/eigen3.changes 2020-10-27 19:00:14.818800081 +0100 @@ -1,0 +2,6 @@ +Sun Oct 25 21:45:11 UTC 2020 - Stefan BrĂ¼ns <[email protected]> + +- Fix compilation error when using Eigen3 with OpenMP: + * Remove-error-counting-in-OpenMP-parallelize_gemm.patch + +------------------------------------------------------------------- New: ---- Remove-error-counting-in-OpenMP-parallelize_gemm.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ eigen3.spec ++++++ --- /var/tmp/diff_new_pack.2RDSvC/_old 2020-10-27 19:00:15.690800714 +0100 +++ /var/tmp/diff_new_pack.2RDSvC/_new 2020-10-27 19:00:15.694800718 +0100 @@ -43,6 +43,8 @@ Patch4: eigen3-3.3.1-fixcmake.patch # PATCH-FIX-UPSTREAM eigen3-CastXML-support-for-aarch64.patch [email protected] -- Add CastXML support for ARM aarch64 [https://gitlab.com/libeigen/eigen/-/issues/1979] Patch5: eigen3-CastXML-support-for-aarch64.patch +# PATCH-FIX-UPSTREAM -- https://gitlab.com/libeigen/eigen/-/merge_requests/232 +Patch6: Remove-error-counting-in-OpenMP-parallelize_gemm.patch BuildRequires: adolc-devel BuildRequires: cmake BuildRequires: fftw3-devel @@ -103,6 +105,7 @@ %patch3 -p1 %patch4 -p1 %patch5 -p1 +%patch6 -p1 # Fix rpmlint warning "wrong-file-end-of-line-encoding" sed -i 's/\r$//' COPYING.MINPACK ++++++ Remove-error-counting-in-OpenMP-parallelize_gemm.patch ++++++ >From ef3cc72cb65e2d500459c178c63e349bacfa834f Mon Sep 17 00:00:00 2001 From: Luke Peterson <[email protected]> Date: Thu, 8 Oct 2020 12:16:53 -0700 Subject: [PATCH] Remove error counting in OpenMP parallelize_gemm This resolves a compilation error associated with Eigen::eigen_assert_exception. It also eliminates the counting of exceptions that may occur in the OpenMP parallel section. If an unhandled exception occurs in this section, the behavior is non-conforming according to the OpenMP specification. --- Eigen/src/Core/products/Parallelizer.h | 14 +++++--------- test/CMakeLists.txt | 2 +- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/Eigen/src/Core/products/Parallelizer.h b/Eigen/src/Core/products/Parallelizer.h index 67b2442b5..a3cc05b77 100644 --- a/Eigen/src/Core/products/Parallelizer.h +++ b/Eigen/src/Core/products/Parallelizer.h @@ -132,8 +132,7 @@ void parallelize_gemm(const Functor& func, Index rows, Index cols, Index depth, ei_declare_aligned_stack_constructed_variable(GemmParallelInfo<Index>,info,threads,0); - int errorCount = 0; - #pragma omp parallel num_threads(threads) reduction(+: errorCount) + #pragma omp parallel num_threads(threads) { Index i = omp_get_thread_num(); // Note that the actual number of threads might be lower than the number of request ones. @@ -152,14 +151,11 @@ void parallelize_gemm(const Functor& func, Index rows, Index cols, Index depth, info[i].lhs_start = r0; info[i].lhs_length = actualBlockRows; - EIGEN_TRY { - if(transpose) func(c0, actualBlockCols, 0, rows, info); - else func(0, rows, c0, actualBlockCols, info); - } EIGEN_CATCH(...) { - ++errorCount; - } + if(transpose) + func(c0, actualBlockCols, 0, rows, info); + else + func(0, rows, c0, actualBlockCols, info); } - if (errorCount) EIGEN_THROW_X(Eigen::eigen_assert_exception()); #endif } diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 0747aa6cb..b02577780 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -163,7 +163,7 @@ ei_add_test(constructor) ei_add_test(linearstructure) ei_add_test(integer_types) ei_add_test(unalignedcount) -if(NOT EIGEN_TEST_NO_EXCEPTIONS) +if(NOT EIGEN_TEST_NO_EXCEPTIONS AND NOT EIGEN_TEST_OPENMP) ei_add_test(exceptions) endif() ei_add_test(redux) -- GitLab
