diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index cbe01c1eaff3f5144b786d266e2e5e4c3647a837..f967d85fb135dcce03ab517fe5c75d45d9c22fb0 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -100,7 +100,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 c33308b2dbae7a5884454513e438d83fdfab4873..0d391fd641a6a4c704c2a55890fd2e91859130e0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -169,7 +169,7 @@ elseif(CHAMELEON_SCHED_OPENMP) " To use CHAMELEON with StarPU runtime: set CHAMELEON_SCHED_STARPU to ON\n" " To use CHAMELEON with Quark runtime: set CHAMELEON_SCHED_QUARK to ON\n" " To use CHAMELEON with PaRSEC runtime: set CHAMELEON_SCHED_PARSEC to ON\n" - " (CHAMELEON_SCHED_PARSEC will be disabled)${ColourReset}") + " (CHAMELEON_SCHED_OPENMP will be disabled)${ColourReset}") endif() # Check that one, and only one, SCHED option is set to ON @@ -932,20 +932,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 ); + } + +}