Skip to content

Commit

Permalink
improve mkl and mpi4py search
Browse files Browse the repository at this point in the history
  • Loading branch information
dkavolis committed Nov 25, 2019
1 parent 69e9000 commit 26937ff
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 42 deletions.
14 changes: 4 additions & 10 deletions SU2_PY/pySU2/meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,9 @@ swig = find_program('swig')

# add mpi4py include
if mpi_dep[0].found() and mpi_dep[1].found()
if get_option('python_path') != ''
python_dir = get_option('python_path')
else
python_dir = run_command(python, '-c', 'from distutils.sysconfig import get_python_lib; print(get_python_lib())').stdout().strip()
message ('Looking for mpi4py in ' + python_dir)
endif
mpi4py_include = python_dir + '/mpi4py/include'
else
mpi4py_include = ''
mpi4py_include = run_command(python, '-c', 'import mpi4py; print(mpi4py.get_include())').stdout().strip()
assert(not mpi4py_include.contains('Traceback'), 'python does not have mpi4py module')
message('Using mpi4py from ' + mpi4py_include)
endif

swig_gen = generator(
Expand All @@ -23,7 +17,7 @@ swig_gen = generator(
)

wrapper_deps = [
dependency('python3'),
dependency('python3'),
]

if get_option('enable-normal')
Expand Down
76 changes: 44 additions & 32 deletions meson.build
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
project('SU2', 'c', 'cpp',
version: '6.2.0',
project('SU2', 'c', 'cpp',
version: '6.2.0',
license: 'LGPL2',
default_options: ['buildtype=release',
'warning_level=0',
default_options: ['buildtype=release',
'warning_level=0',
'cpp_std=c++11'])


Expand Down Expand Up @@ -34,7 +34,7 @@ if get_option('custom-mpi')
mpi = true
# Otherwise they are automatically determined
else
mpi_dep = [dependency('mpi', language:'c', required : get_option('with-mpi')),
mpi_dep = [dependency('mpi', language:'c', required : get_option('with-mpi')),
dependency('mpi', language:'cpp', required : get_option('with-mpi'))]
if mpi_dep[0].found() or mpi_dep[1].found()
mpi = true
Expand Down Expand Up @@ -62,24 +62,24 @@ endif
# check if MPI dependencies are found and add them
if mpi

# add MPI dependency
# add MPI dependency
su2_deps += mpi_dep
su2_cpp_args += '-DHAVE_MPI'

# compile metis
subdir('externals/metis')

# add metis dependency
su2_deps += metis_dep
su2_cpp_args += '-DHAVE_METIS'
su2_cpp_args += '-DHAVE_METIS'

# compile parmetis
subdir('externals/parmetis')

# add parmetis dependency
su2_deps += parmetis_dep
su2_cpp_args += '-DHAVE_PARMETIS'
su2_cpp_args += '-DHAVE_PARMETIS'

# add medi dependency
if get_option('enable-autodiff') or get_option('enable-directdiff')
codi_dep += declare_dependency(include_directories: ['externals/medi/include', 'externals/medi/src'])
Expand All @@ -99,22 +99,34 @@ if get_option('enable-pastix')

su2_cpp_args += '-DHAVE_PASTIX'

pastix_root = get_option('pastix_root')+'/install'
scotch_root = get_option('scotch_root')+'/lib'
pastix_dep = declare_dependency(include_directories: pastix_root,
link_args: [ '-L../'+pastix_root, '-L../'+scotch_root,
'-lpastix', '-lscotch', '-lptscotch', '-lptscotcherr',
'-lm', '-lrt', '-lpthread'])
pastix_dep = dependency('pastix', required: false)

if not pastix_dep.found()
pastix_root = get_option('pastix_root')+'/install'
scotch_root = get_option('scotch_root')+'/lib'
pastix_dep = declare_dependency(include_directories: pastix_root,
link_args: [ '-L../'+pastix_root, '-L../'+scotch_root,
'-lpastix', '-lscotch', '-lptscotch', '-lptscotcherr',
'-lm', '-lrt', '-lpthread'])
endif
su2_deps += pastix_dep
endif

# blas-type dependencies
if get_option('enable-mkl')

su2_cpp_args += '-DHAVE_MKL'
mkl_root = get_option('mkl_root')
mkl_dep = declare_dependency(include_directories: mkl_root+'/include', compile_args: '-m64',
link_args: ['-L'+mkl_root+'/lib/intel64','-lmkl_intel_lp64','-lmkl_sequential','-lmkl_core','-lpthread','-lm','-ldl'])

# the following mkl name matches the linked libs in manual dependency
# see https://software.intel.com/en-us/articles/intel-math-kernel-library-intel-mkl-and-pkg-config-tool
# should probably switch to iomp if Intel OpenMP is used
mkl_dep = dependency('mkl-static-lp64-seq', required: false)

if not mkl_dep.found()
mkl_root = get_option('mkl_root')
mkl_dep = declare_dependency(include_directories: mkl_root+'/include', compile_args: '-m64',
link_args: ['-L'+mkl_root+'/lib/intel64','-lmkl_intel_lp64','-lmkl_sequential','-lmkl_core','-lpthread','-lm','-ldl'])
endif
su2_deps += mkl_dep

elif get_option('enable-openblas')
Expand Down Expand Up @@ -148,13 +160,13 @@ if get_option('enable-pywrapper')
endif

message('''-------------------------------------------------------------------------
| ___ _ _ ___ |
| / __| | | |_ ) Release 6.2.0 'Falcon' |
| \__ \ |_| |/ / |
| |___/\___//___| Configuration Summary |
| |
-------------------------------------------------------------------------
| ___ _ _ ___ |
| / __| | | |_ ) Release 6.2.0 'Falcon' |
| \__ \ |_| |/ / |
| |___/\___//___| Configuration Summary |
| |
-------------------------------------------------------------------------
Option Value
---------------------
TecIO: @2@
Expand All @@ -170,14 +182,14 @@ message('''---------------------------------------------------------------------
and update your $PATH (and $PYTHONPATH if applicable) with $SU2_RUN
Based on the input to this configuration, add these lines to your .bashrc file:
export SU2_RUN=@0@
export SU2_HOME=@1@
export PATH=$PATH:$SU2_RUN
export PYTHONPATH=$PYTHONPATH:$SU2_RUN
Use './ninja -C @10@ install' to compile and install SU2
'''.format(get_option('prefix')+'/bin', meson.source_root(), get_option('enable-tecio'), get_option('enable-cgns'),
'''.format(get_option('prefix')+'/bin', meson.source_root(), get_option('enable-tecio'), get_option('enable-cgns'),
get_option('enable-autodiff'), get_option('enable-directdiff'), get_option('enable-pywrapper'), get_option('enable-mkl'),
get_option('enable-openblas'), get_option('enable-pastix'), meson.build_root().split('/')[-1]))

0 comments on commit 26937ff

Please sign in to comment.