diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index ba98290c48f4a0426720636d72e6756f552f6b0f..ca71fb23be0c1790b377165e8df820de94398792 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -102,7 +102,7 @@ build_openmp: - build - chameleon_openmp.log variables: - BUILD_OPTIONS: "-DCHAMELEON_SCHED_OPENMP=ON" + BUILD_OPTIONS: "-DCHAMELEON_SCHED_OPENMP=ON -DCMAKE_Fortran_COMPILER=gfortran -DCMAKE_C_COMPILER=gcc -DCMAKE_CXX_COMPILER=g++" VERSION: openmp test_starpu_branches: diff --git a/CMakeLists.txt b/CMakeLists.txt index cf5f355a57436969b35977c6575b8f23fc41235c..7b0d295a141fcb5058ce39a7c157984bf31616a0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -897,20 +897,14 @@ if( CHAMELEON_SCHED_QUARK ) endif() if( CHAMELEON_SCHED_OPENMP ) - - # create list of components in order to make a single call to find_package(starpu...) - set(OPENMP_COMPONENT_LIST "HWLOC") - if(CHAMELEON_USE_CUDA) - list(APPEND OPENMP_COMPONENT_LIST "CUDA") - endif() - - find_package(OpenMP COMPONENTS ${OPENMP_COMPONENT_LIST}) + find_package(OpenMP REQUIRED) if ( OPENMP_FOUND ) message("-- ${Blue}Add definition CHAMELEON_SCHED_OPENMP" " - Activate OpenMP in Chameleon${ColourReset}") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${OpenMP_C_FLAGS}") - set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${OpenMP_CXX_FLAGS}") + set(CMAKE_Fortran_FLAGS "${CMAKE_Fortran_FLAGS} ${OpenMP_Fortran_FLAGS}") + set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${OpenMP_C_FLAGS}") # TODO: check for compiler support for "_Pragma" else ( OPENMP_FOUND ) message(FATAL_ERROR "Something went wrong when finding OpenMP") diff --git a/runtime/openmp/CMakeLists.txt b/runtime/openmp/CMakeLists.txt index 6c0ea5ab5981b88b119f5b449186e4f8c6f57652..1a6c6da8437d02bffa810886b239edf4616e2f7b 100644 --- a/runtime/openmp/CMakeLists.txt +++ b/runtime/openmp/CMakeLists.txt @@ -85,6 +85,7 @@ precisions_rules_py(RUNTIME_SRCS_GENERATED "${ZSRC}" set(RUNTIME_SRCS ${RUNTIME_COMMON} ${RUNTIME_SRCS_GENERATED} + ${CODELETS_SRC} ) # Force generation of sources diff --git a/runtime/openmp/codelets/codelet_map.c b/runtime/openmp/codelets/codelet_map.c new file mode 100644 index 0000000000000000000000000000000000000000..57ee20db0e5a318dd35cb4ef42f67a5c292e1a45 --- /dev/null +++ b/runtime/openmp/codelets/codelet_map.c @@ -0,0 +1,30 @@ +/** + * + * @file quark/codelet_map.c + * + * @copyright 2018-2018 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria, + * Univ. Bordeaux. All rights reserved. + * + *** + * + * @brief Chameleon map Quark codelet + * + * @version 1.0.0 + * @author Mathieu Faverge + * @date 2018-09-24 + * + */ +#include "chameleon_openmp.h" + +void INSERT_TASK_map( const RUNTIME_option_t *options, + cham_uplo_t uplo, const CHAM_desc_t *A, int Am, int An, + cham_unary_operator_t operator, void *op_args ) +{ + char *ptrA = RTBLKADDR( A, char, Am, An ); + +#pragma omp task depend(inout: ptrA[0]) + { + operator( A, uplo, Am, An, ptrA, op_args ); + } + +} diff --git a/timing/time_zpotrf_tile.c b/timing/time_zpotrf_tile.c index 9707f44d608a4487a80d04dc1345c6cfb8d124bb..67e95738955c0575092566eeafbe94a21179f18c 100644 --- a/timing/time_zpotrf_tile.c +++ b/timing/time_zpotrf_tile.c @@ -37,7 +37,6 @@ RunTest( int *iparam, double *dparam, chameleon_time_t *t_ ) PASTE_CODE_ALLOCATE_MATRIX_TILE( descB, check, CHAMELEON_Complex64_t, ChamComplexDouble, LDB, N, NRHS ); PASTE_CODE_ALLOCATE_MATRIX_TILE( descAC, check, CHAMELEON_Complex64_t, ChamComplexDouble, LDA, N, N ); PASTE_CODE_ALLOCATE_MATRIX_TILE( descX, check, CHAMELEON_Complex64_t, ChamComplexDouble, LDB, N, NRHS ); - CHAMELEON_zplghe_Tile( (double)N, ChamUpperLower, descA, 51 ); /* Initialize data and save A if check */ if ( check ) { diff --git a/timing/timing.c b/timing/timing.c index 51eddd529510783b5df12547f29a540022e7dd2a..0b6037948f90839a8a9dddbab4ffe0ed9994dfce 100644 --- a/timing/timing.c +++ b/timing/timing.c @@ -728,6 +728,7 @@ CHAMELEON_Main(int *iparam, char *prog_name, int start, int stop, int step) { if (status != CHAMELEON_SUCCESS) return status; success += status; } + return success; } int