123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- # StarPU --- Runtime system for heterogeneous multicore architectures.
- #
- # Copyright (C) 2009-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
- # Copyright (C) 2017 Guillaume Beauchamp
- #
- # StarPU is free software; you can redistribute it and/or modify
- # it under the terms of the GNU Lesser General Public License as published by
- # the Free Software Foundation; either version 2.1 of the License, or (at
- # your option) any later version.
- #
- # StarPU is distributed in the hope that it will be useful, but
- # WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- #
- # See the GNU Lesser General Public License in COPYING.LGPL for more details.
- #
- ACLOCAL_AMFLAGS=-I m4
- CLEANFILES = *.gcno *.gcda *.linkinfo
- SUBDIRS =
- if STARPU_USE_MIN_DGELS
- SUBDIRS += min-dgels
- endif
- SUBDIRS += src
- SUBDIRS += tools
- if STARPU_BUILD_TESTS
- SUBDIRS += tests
- endif
- SUBDIRS += doc
- if STARPU_USE_MPI
- SUBDIRS += mpi
- endif
- if STARPU_BUILD_EXAMPLES
- SUBDIRS += examples
- endif
- if STARPU_BUILD_SOCL
- SUBDIRS += socl
- endif
- if STARPU_BUILD_STARPUFFT
- SUBDIRS += starpufft
- endif
- if STARPU_BUILD_STARPURM
- SUBDIRS += starpurm
- endif
- if STARPU_USE_CPU
- if STARPU_BUILD_STARPUPY
- SUBDIRS += starpupy
- endif
- endif
- if STARPU_BUILD_SC_HYPERVISOR
- SUBDIRS += sc_hypervisor
- endif
- if STARPU_USE_JULIA
- SUBDIRS += julia
- endif
- if STARPU_BUILD_ECLIPSE_PLUGIN
- SUBDIRS += eclipse-plugin
- endif
- pkgconfigdir = $(libdir)/pkgconfig
- pkgconfig_DATA = libstarpu.pc starpu-1.0.pc starpu-1.1.pc starpu-1.2.pc starpu-1.3.pc
- versincludedir = $(includedir)/starpu/$(STARPU_EFFECTIVE_VERSION)
- versinclude_HEADERS = \
- include/starpu.h \
- include/starpu_helper.h \
- include/starpu_bitmap.h \
- include/starpu_data_filters.h \
- include/starpu_data_interfaces.h \
- include/starpu_worker.h \
- include/starpu_task.h \
- include/starpu_task_dep.h \
- include/starpu_task_bundle.h \
- include/starpu_task_list.h \
- include/starpu_task_util.h \
- include/starpu_data.h \
- include/starpu_perfmodel.h \
- include/starpu_util.h \
- include/starpu_fxt.h \
- include/starpu_cuda.h \
- include/starpu_opencl.h \
- include/starpu_fpga.h \
- include/starpu_openmp.h \
- include/starpu_sink.h \
- include/starpu_mpi_ms.h \
- include/starpu_expert.h \
- include/starpu_profiling.h \
- include/starpu_bound.h \
- include/starpu_scheduler.h \
- include/schedulers/starpu_heteroprio.h \
- include/starpu_sched_component.h \
- include/starpu_sched_ctx.h \
- include/starpu_sched_ctx_hypervisor.h \
- include/starpu_deprecated_api.h \
- include/starpu_hash.h \
- include/starpu_rand.h \
- include/starpu_disk.h \
- include/starpu_cublas.h \
- include/starpu_cublas_v2.h \
- include/starpu_cusparse.h \
- include/starpu_driver.h \
- include/starpu_stdlib.h \
- include/starpu_thread.h \
- include/starpu_thread_util.h \
- include/starpu_tree.h \
- include/starpu_simgrid_wrap.h \
- include/starpu_mod.f90 \
- include/fstarpu_mod.f90 \
- include/starpu_clusters.h \
- include/starpu_perf_monitoring.h \
- include/starpu_perf_steering.h
- nodist_versinclude_HEADERS = \
- include/starpu_config.h
- noinst_HEADERS = \
- include/pthread_win32/pthread.h \
- include/pthread_win32/semaphore.h
- if STARPU_DEVEL
- all-local:
- @if $(GREP) -r sys/time.h $$( find $(srcdir)/examples $(srcdir)/tests $(srcdir)/src $(srcdir)/mpi/src $(srcdir)/include -name \*.[ch] -a \! -name starpu_util.h -a \! -name timer.h -a \! -name loader.c ) ; \
- then \
- echo "Please do not include sys/time, it is not available on Windows, include starpu_util.h and use starpu_timing_now() instead" ; \
- false ; \
- fi
- @if $(GREP) -re '\<ssize_t' $$( find $(srcdir)/examples $(srcdir)/tests $(srcdir)/src $(srcdir)/mpi/src $(srcdir)/include -name \*.[ch] -a \! -name starpu_config.h ) ; \
- then \
- echo "Please do not use ssize_t, it is not available on Windows, use starpu_ssize_t instead"; \
- false ; \
- fi
- @if $(GREP) -re '\<getenv\>' $$( find $(srcdir)/src $(srcdir)/mpi/src $(srcdir)/include -name \*.[ch] -a \! -name starpu_util.h -a \! -name utils.c -a \! -name simgrid.h) ; \
- then \
- echo "Please do not use getenv, use starpu_getenv instead, which catches unsafe uses"; \
- false ; \
- fi
- # we count the number of files which include unistd.h
- # we count the number of files which properly include unistd.h i.e by first detecting if it's available
- # and then we check both numbers are the same ...a
- @UNISTD_ALL_LINES=$(shell $(GREP) -B1 -rs "^#include <unistd.h>" $(srcdir)/src/ $(srcdir)/include/ $(srcdir)/mpi/src $(srcdir)/mpi/include |$(GREP) -v dolib|$(GREP) -v -e "--" | tr '\012' '@' | $(SED) 's/unistd.h>@/unistd.h>\n/g' | wc -l) ;\
- UNISTD_CORRECT_LINES=$(shell $(GREP) -B1 -rs "^#include <unistd.h>" $(srcdir)/src/ $(srcdir)/include/ $(srcdir)/mpi/src $(srcdir)/mpi/include |$(GREP) -v dolib|$(GREP) -v -e "--" | tr '\012' '@' | $(SED) 's/unistd.h>@/unistd.h>\n/g' | $(GREP) '#ifdef .*HAVE_UNISTD_H.*:#include <unistd.h>' | wc -l) ;\
- if test $$UNISTD_ALL_LINES -ne $$UNISTD_CORRECT_LINES ; \
- then \
- echo "Please do not unconditionally include unistd.h, it is not available on Windows, include config.h and test for HAVE_UNISTD_H" ; \
- false ; \
- fi
- endif
- if STARPU_HAVE_WINDOWS
- txtdir = ${prefix}
- else
- txtdir = ${docdir}
- endif
- txt_DATA = AUTHORS COPYING.LGPL README README.dev STARPU-REVISION
- EXTRA_DIST = autogen.sh AUTHORS COPYING.LGPL README README.dev STARPU-VERSION STARPU-REVISION build-aux/svn2cl.xsl
- DISTCLEANFILES = STARPU-REVISION
- recheck:
- RET=0 ; \
- for i in $(SUBDIRS) ; do \
- $(MAKE) -C $$i recheck || RET=1 ; \
- done ; \
- exit $$RET
- showfailed:
- @RET=0 ; \
- for i in $(SUBDIRS) ; do \
- $(MAKE) -s -C $$i showfailed || RET=1 ; \
- done ; \
- exit $$RET
- showcheck:
- RET=0 ; \
- for i in $(SUBDIRS) ; do \
- $(MAKE) -C $$i showcheck || RET=1 ; \
- done ; \
- exit $$RET
- showsuite:
- RET=0 ; \
- for i in $(SUBDIRS) ; do \
- $(MAKE) -C $$i showsuite || RET=1 ; \
- done ; \
- exit $$RET
- ctags-local:
- cd $(top_srcdir) ; $(CTAGS) -R -I LIST_TYPE
- $(SED) -i $(top_srcdir)/tags -e '/^[^ ]* [^ ]* /d' -e '/^[^ ]*$$/d'
- # Cyclomatic complexity reports.
- # The pmccabe tool, see <http://www.parisc-linux.org/~bame/pmccabe/>.
- PMCCABE = pmccabe
- VC_URL = "https://gitlab.inria.fr/starpu/starpu/-/blob/master/%FILENAME%"
- # Generate a cyclomatic complexity report. Note that examples and tests are
- # excluded because they're not particularly relevant, and more importantly
- # they all have a function called `main', which clobbers the report.
- cyclomatic-complexity.html:
- $(PMCCABE) \
- `find \( -name examples -o -name tests -o -path ./tools/dev/experimental \) -prune -o -name \*.c` \
- | sort -nr \
- | $(AWK) -f ${top_srcdir}/build-aux/pmccabe2html \
- -v lang=html -v name="$(PACKAGE_NAME)" \
- -v vcurl=$(VC_URL) \
- -v url="$(PACKAGE_URL)" \
- -v css=${top_srcdir}/build-aux/pmccabe.css \
- -v cut_dir=${top_srcdir}/ \
- > $@-tmp
- mv $@-tmp $@
|