| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734 | # StarPU --- Runtime system for heterogeneous multicore architectures.## Copyright (C) 2009, 2010-2011  Université de Bordeaux 1# Copyright (C) 2010, 2011, 2012  Centre National de la Recherche Scientifique# Copyright (C) 2011  Télécom-SudParis# Copyright (C) 2012 INRIA## 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.AM_CFLAGS = $(MAGMA_CFLAGS) $(HWLOC_CFLAGS) -Wall $(STARPU_CUDA_CPPFLAGS) $(STARPU_OPENCL_CPPFLAGS)AM_CXXFLAGS = $(MAGMA_CFLAGS) $(HWLOC_CFLAGS) -Wall $(STARPU_CUDA_CPPFLAGS) $(STARPU_OPENCL_CPPFLAGS)LIBS = $(top_builddir)/src/libstarpu-@STARPU_EFFECTIVE_VERSION@.la $(MAGMA_LIBS) $(HWLOC_LIBS) @LIBS@AM_CPPFLAGS = -I$(top_srcdir)/include/ -I$(top_srcdir)/examples/ -I$(top_builddir)/includeAM_LDFLAGS = $(STARPU_CUDA_LDFLAGS) $(STARPU_OPENCL_LDFLAGS)SUBDIRS = stencilBUILT_SOURCES =if STARPU_USE_OPENCLnobase_STARPU_OPENCL_DATA_DATA =endifEXTRA_DIST = 					\	basic_examples/vector_scal_opencl_kernel.cl \	basic_examples/multiformat_opencl_kernel.cl  \	basic_examples/multiformat_conversion_codelets_opencl_kernel.cl \	common/blas_model.c			\	spmv/spmv_cuda.cu			\	spmv/spmv_opencl.cl			\	gordon/null_kernel_gordon.c		\	mult/xgemm.c				\	lu/xlu.c				\	lu/xlu_pivot.c				\	lu/xlu_implicit.c			\	lu/xlu_implicit_pivot.c			\	lu/xlu_kernels.c			\	lu/lu_example.c				\	incrementer/incrementer_kernels_opencl_kernel.cl 	\	basic_examples/variable_kernels_opencl_kernel.cl	\	matvecmult/matvecmult_kernel.cl				\	basic_examples/block_opencl_kernel.cl			\	openmp/vector_scal.c			\	filters/fblock_opencl_kernel.cl		\	filters/custom_mf/conversion_opencl.cl  \	filters/custom_mf/custom_opencl.clCLEANFILES = 					\	gordon/null_kernel_gordon.spuelfCLEANFILES += *.gcno *.gcda *.linkinfoif STARPU_USE_CUDANVCCFLAGS += --compiler-options -fno-strict-aliasing  -I$(top_srcdir)/include/ -I$(top_builddir)/include/ -I$(top_srcdir)/examples/  $(HWLOC_CFLAGS) -arch sm_13.cu.o:	$(NVCC) $< -c -o $@ $(NVCCFLAGS)endifif STARPU_USE_GORDONSPU_CC ?= spu-gccSPU_LD ?= spu-ldSPULDFLAGS =SPULIBS = -lblas #-lc -lgloss -lc.c.spuo:	$(MKDIR_P) `dirname $@`	$(SPU_CC) -c -fpic $< -o $@.spuo.spuelf:	$(MKDIR_P) `dirname $@`	$(SPU_LD) $(SPULDFLAGS) $< -o $@ $(SPULIBS)BUILT_SOURCES +=				\	gordon/null_kernel_gordon.spuelfendifif STARPU_HAVE_ICC.icc.o:	$(ICC) -x c $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \		$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) $< -c -o $@endifexamplebindir = $(libdir)/starpu/examples/examplebin_PROGRAMS =noinst_HEADERS = 				\	cg/cg.h					\	heat/lu_kernels_model.h			\	heat/dw_sparse_cg.h			\	heat/heat.h				\	heat/dw_factolu.h			\	lu/xlu.h				\	lu/xlu_kernels.h			\	lu/float.h				\	lu/double.h				\	lu/complex_float.h			\	lu/complex_double.h			\	lu/blas_complex.h			\	cholesky/cholesky.h			\	common/blas_model.h			\	common/blas.h				\	mult/simple.h				\	mult/double.h				\	gordon/null.h				\	fortran/bindings/StarPU_fortran.h	\	ppm_downscaler/ppm_downscaler.h		\	ppm_downscaler/yuv_downscaler.h		\	spmv/matrix_market/mmio.h		\	spmv/matrix_market/mm_to_bcsr.h		\	spmv/spmv.h				\	spmv/dw_block_spmv.h                    \	basic_examples/multiformat_types.h      \	filters/custom_mf/custom_interface.h    \	filters/custom_mf/custom_types.h###################################### What to install and what to check ######################################STARPU_EXAMPLES	=TESTS		=	$(STARPU_EXAMPLES)if STARPU_HAVE_WINDOWScheck_PROGRAMS	=	$(STARPU_EXAMPLES)elsecheck_PROGRAMS	=	$(LOADER) $(STARPU_EXAMPLES)endifif !STARPU_HAVE_WINDOWS## test loader programLOADER			=	loaderloader_CPPFLAGS =  $(AM_CFLAGS) $(AM_CPPFLAGS) -I$(top_builddir)/src/LOADER_BIN		=	$(abs_top_builddir)/examples/$(LOADER)loader_SOURCES		=	../tests/loader.cTESTS_ENVIRONMENT	=	$(LOADER_BIN)endifexamplebin_PROGRAMS +=				\	basic_examples/hello_world		\	basic_examples/vector_scal		\	basic_examples/mult			\	basic_examples/block			\	basic_examples/variable			\	basic_examples/multiformat              \	cpp/incrementer_cpp			\	filters/custom_mf/custom_mf_filter      \	filters/fvector				\	filters/fblock				\	filters/fmatrix				\	tag_example/tag_example			\	tag_example/tag_example3		\	tag_example/tag_example2		\	tag_example/tag_restartable		\	spmv/spmv				\	callback/callback			\	incrementer/incrementer			\	matvecmult/matvecmult			\	profiling/profiling			\	scheduler/dummy_sched			\	reductions/dot_product			\	reductions/minmax_reduction		\	mandelbrot/mandelbrot			\	ppm_downscaler/ppm_downscaler		\	ppm_downscaler/yuv_downscalerif STARPU_HAVE_F77_Hexamplebin_PROGRAMS +=				\	basic_examples/vector_scal_fortranendifif !NO_BLAS_LIBexamplebin_PROGRAMS +=				\	axpy/axpy				\	mult/sgemm 				\	mult/dgemm				\	cholesky/cholesky_tag			\	cholesky/cholesky_tile_tag		\	cholesky/cholesky_grain_tag		\	cholesky/cholesky_implicit		\	lu/lu_example_float			\	lu/lu_example_double			\	lu/lu_implicit_example_float		\	lu/lu_implicit_example_double		\	heat/heat				\	cg/cgendifif MKL_BLAS_LIBexamplebin_PROGRAMS +=				\	lu/lu_example_complex_float		\	lu/lu_example_complex_double		\	lu/lu_implicit_example_complex_float	\	lu/lu_implicit_example_complex_doubleendifif ATLAS_BLAS_LIBexamplebin_PROGRAMS +=				\	spmv/dw_block_spmvendifSTARPU_EXAMPLES +=				\	basic_examples/hello_world		\	basic_examples/vector_scal		\	basic_examples/mult			\	basic_examples/block			\	basic_examples/variable			\	basic_examples/multiformat              \	cpp/incrementer_cpp			\	filters/fvector				\	filters/fblock				\	filters/fmatrix				\	tag_example/tag_example			\	tag_example/tag_example3		\	tag_example/tag_example2		\	tag_example/tag_restartable		\	spmv/spmv				\	callback/callback			\	incrementer/incrementer			\	matvecmult/matvecmult			\	profiling/profiling			\	scheduler/dummy_sched			\	reductions/dot_product			\	reductions/minmax_reductionif STARPU_HAVE_F77_HSTARPU_EXAMPLES +=				\	basic_examples/vector_scal_fortranendifif !NO_BLAS_LIBSTARPU_EXAMPLES +=				\	axpy/axpy				\	mult/sgemm 				\	mult/dgemm				\	cholesky/cholesky_tag			\	cholesky/cholesky_tile_tag		\	cholesky/cholesky_grain_tag		\	cholesky/cholesky_implicit		\	lu/lu_example_float			\	lu/lu_example_double			\	lu/lu_implicit_example_float		\	lu/lu_implicit_example_double		\	heat/heat				\	cg/cgendifif MKL_BLAS_LIBSTARPU_EXAMPLES +=				\	lu/lu_example_complex_float		\	lu/lu_example_complex_double		\	lu/lu_implicit_example_complex_float	\	lu/lu_implicit_example_complex_doubleendifif ATLAS_BLAS_LIBSTARPU_EXAMPLES +=				\	spmv/dw_block_spmvendif################### Basic examples ###################basic_examples_vector_scal_SOURCES =		\	basic_examples/vector_scal.c		\	basic_examples/vector_scal_cpu.cif STARPU_HAVE_ICCbasic_examples_vector_scal_SOURCES +=		\	basic_examples/vector_scal_cpu_icc.iccbasic_examples/vector_scal_cpu_icc.o: CFLAGS += -Dscal_cpu_func=scal_cpu_func_icc -Dscal_sse_func=scal_sse_func_iccendifif STARPU_USE_CUDAbasic_examples_vector_scal_SOURCES +=		\	basic_examples/vector_scal_cuda.cuendifif STARPU_USE_OPENCLbasic_examples_vector_scal_SOURCES +=		\	basic_examples/vector_scal_opencl.cnobase_STARPU_OPENCL_DATA_DATA += \	basic_examples/vector_scal_opencl_kernel.clendifif STARPU_HAVE_F77_Hbasic_examples_vector_scal_fortran_SOURCES =	\	basic_examples/vector_scal_fortran.F	\	basic_examples/vector_scal_c.c		\	basic_examples/vector_scal_cpu.cif STARPU_USE_CUDAbasic_examples_vector_scal_fortran_SOURCES +=	\	basic_examples/vector_scal_cuda.cubasic_examples_vector_scal_fortran_LDADD =	\	$(STARPU_CUDA_FORTRAN_LDFLAGS)endifendif######################## Multiformat example ########################basic_examples_multiformat_SOURCES =                                    \	basic_examples/multiformat.c                                    \	basic_examples/multiformat_conversion_codelets.cif STARPU_USE_CUDAbasic_examples_multiformat_SOURCES+=                                     \	basic_examples/multiformat_cuda.cu                               \	basic_examples/multiformat_conversion_codelets_cuda.cuendifif STARPU_USE_OPENCLbasic_examples_multiformat_SOURCES+=                                     \	basic_examples/multiformat_opencl.c                              \	basic_examples/multiformat_conversion_codelets_opencl.c          nobase_STARPU_OPENCL_DATA_DATA+=                                         \	basic_examples/multiformat_opencl_kernel.cl                      \	basic_examples/multiformat_conversion_codelets_opencl_kernel.clendif################## block example ##################basic_examples_block_SOURCES =			\	basic_examples/block.c			\	basic_examples/block_cpu.cif STARPU_USE_CUDAbasic_examples_block_SOURCES +=			\	basic_examples/block_cuda.cuendifif STARPU_USE_OPENCLbasic_examples_block_SOURCES +=			\	basic_examples/block_opencl.cnobase_STARPU_OPENCL_DATA_DATA += 		\	basic_examples/block_opencl_kernel.clendif##################### Variable example #####################basic_examples_variable_SOURCES =		\	basic_examples/variable.c		\	basic_examples/variable_kernels_cpu.cif STARPU_USE_CUDAbasic_examples_variable_SOURCES +=		\	basic_examples/variable_kernels.cuendifif STARPU_USE_OPENCLbasic_examples_variable_SOURCES +=		\	basic_examples/variable_kernels_opencl.cnobase_STARPU_OPENCL_DATA_DATA += 		\	basic_examples/variable_kernels_opencl_kernel.clendif############ Filters ############filters_fblock_SOURCES =			\	filters/fblock.c			\	filters/fblock_cpu.cif STARPU_USE_CUDAfilters_fblock_SOURCES +=			\	filters/fblock_cuda.cuendifif STARPU_USE_OPENCLfilters_fblock_SOURCES +=			\	filters/fblock_opencl.cnobase_STARPU_OPENCL_DATA_DATA += \	filters/fblock_opencl_kernel.clendif############################## Custom multiformat filter ##############################filters_custom_mf_custom_mf_filter_SOURCES=\	filters/custom_mf/custom_mf_filter.c \	filters/custom_mf/custom_interface.c   \	filters/custom_mf/custom_conversion_codelets.cif STARPU_USE_CUDAfilters_custom_mf_custom_mf_filter_SOURCES+=\	filters/custom_mf/conversion.cu \	filters/custom_mf/cuda.cuendifif STARPU_USE_OPENCLfilters_custom_mf_custom_mf_filter_SOURCES+=\	filters/custom_mf/conversion_opencl.c \	filters/custom_mf/custom_opencl.cnobase_STARPU_OPENCL_DATA_DATA += \	filters/custom_mf/conversion_opencl.cl \	filters/custom_mf/custom_opencl.clendif################# AXPY example #################if !NO_BLAS_LIBaxpy_axpy_SOURCES =				\	axpy/axpy.c				\	common/blas.caxpy_axpy_LDADD =				\	$(STARPU_BLAS_LDFLAGS)endif################# Mult example #################if !NO_BLAS_LIBmult_sgemm_SOURCES = 				\	mult/sgemm.c				\	common/blas.cmult_sgemm_LDADD =				\	$(STARPU_BLAS_LDFLAGS)mult_dgemm_SOURCES = 				\	mult/dgemm.c				\	common/blas.cmult_dgemm_LDADD =				\	$(STARPU_BLAS_LDFLAGS)endif##################### Cholesky example #####################if !NO_BLAS_LIBcholesky_cholesky_tag_SOURCES =			\	cholesky/cholesky_tag.c			\	cholesky/cholesky_models.c		\	cholesky/cholesky_kernels.c		\	common/blas.ccholesky_cholesky_tag_LDADD =			\	$(STARPU_BLAS_LDFLAGS)cholesky_cholesky_tile_tag_SOURCES =		\	cholesky/cholesky_tile_tag.c		\	cholesky/cholesky_models.c		\	cholesky/cholesky_kernels.c		\	common/blas.ccholesky_cholesky_tile_tag_LDADD =		\	$(STARPU_BLAS_LDFLAGS)cholesky_cholesky_grain_tag_SOURCES =		\	cholesky/cholesky_grain_tag.c		\	cholesky/cholesky_models.c		\	cholesky/cholesky_kernels.c		\	common/blas.ccholesky_cholesky_grain_tag_LDADD =		\	$(STARPU_BLAS_LDFLAGS)cholesky_cholesky_implicit_SOURCES =		\	cholesky/cholesky_implicit.c		\	cholesky/cholesky_models.c		\	cholesky/cholesky_kernels.c		\	common/blas.ccholesky_cholesky_implicit_LDADD =		\	$(STARPU_BLAS_LDFLAGS)endif############### LU example ###############if !NO_BLAS_LIBlu_lu_example_float_SOURCES =			\	lu/lu_example_float.c			\	lu/slu.c				\	lu/slu_pivot.c				\	lu/slu_kernels.c			\	common/blas.clu_lu_example_float_LDADD =			\	$(STARPU_BLAS_LDFLAGS)lu_lu_example_double_SOURCES =			\	lu/lu_example_double.c			\	lu/dlu.c				\	lu/dlu_pivot.c				\	lu/dlu_kernels.c			\	common/blas.clu_lu_example_double_LDADD =			\	$(STARPU_BLAS_LDFLAGS)lu_lu_implicit_example_float_SOURCES =		\	lu/lu_example_float.c			\	lu/slu_implicit.c			\	lu/slu_implicit_pivot.c			\	lu/slu_kernels.c			\	common/blas.clu_lu_implicit_example_float_LDADD =		\	$(STARPU_BLAS_LDFLAGS)lu_lu_implicit_example_double_SOURCES =		\	lu/lu_example_double.c			\	lu/dlu_implicit.c			\	lu/dlu_implicit_pivot.c			\	lu/dlu_kernels.c			\	common/blas.clu_lu_implicit_example_double_LDADD =		\	$(STARPU_BLAS_LDFLAGS)if MKL_BLAS_LIBlu_lu_example_complex_float_SOURCES =		\	lu/lu_example_complex_float.c		\	lu/clu.c				\	lu/clu_pivot.c				\	lu/clu_kernels.c			\	lu/blas_complex.c			\	common/blas.clu_lu_example_complex_float_LDADD =		\	$(STARPU_BLAS_LDFLAGS)lu_lu_implicit_example_complex_float_SOURCES =	\	lu/lu_example_complex_float.c		\	lu/clu_implicit.c			\	lu/clu_implicit_pivot.c			\	lu/clu_kernels.c			\	lu/blas_complex.c			\	common/blas.clu_lu_implicit_example_complex_float_LDADD =	\	$(STARPU_BLAS_LDFLAGS)lu_lu_example_complex_double_SOURCES =		\	lu/lu_example_complex_double.c		\	lu/zlu.c				\	lu/zlu_pivot.c				\	lu/zlu_kernels.c			\	lu/blas_complex.c			\	common/blas.clu_lu_example_complex_double_LDADD =		\	$(STARPU_BLAS_LDFLAGS)lu_lu_implicit_example_complex_double_SOURCES =	\	lu/lu_example_complex_double.c		\	lu/zlu_implicit.c			\	lu/zlu_implicit_pivot.c			\	lu/zlu_kernels.c			\	lu/blas_complex.c			\	common/blas.clu_lu_implicit_example_complex_double_LDADD =	\	$(STARPU_BLAS_LDFLAGS)endifendif################# Heat example #################if !NO_BLAS_LIBheat_heat_SOURCES =				\	heat/heat.c				\	heat/dw_factolu.c			\	heat/dw_factolu_tag.c			\	heat/dw_factolu_grain.c			\	heat/dw_sparse_cg.c			\	heat/heat_display.c			\	heat/lu_kernels_model.c			\	heat/dw_sparse_cg_kernels.c		\	heat/dw_factolu_kernels.c		\	common/blas.cheat_heat_LDADD =				\	$(STARPU_OPENGL_RENDER_LDFLAGS)		\	$(STARPU_BLAS_LDFLAGS)endif############### CG example ###############if !NO_BLAS_LIBcg_cg_SOURCES =					\	cg/cg.c					\	cg/cg_kernels.c				\	common/blas.cif STARPU_USE_CUDAcg_cg_SOURCES +=				\	cg/cg_dot_kernel.cuendifcg_cg_LDADD =					\	$(STARPU_BLAS_LDFLAGS)endif################# SpMV example #################spmv_spmv_SOURCES = 				\	spmv/spmv.c				\	spmv/spmv_kernels.cif STARPU_USE_CUDAspmv_spmv_SOURCES +=				\	spmv/spmv_cuda.cuendifif ATLAS_BLAS_LIBspmv_dw_block_spmv_SOURCES =			\	spmv/dw_block_spmv.c			\	spmv/dw_block_spmv_kernels.c		\	spmv/matrix_market/mm_to_bcsr.c		\	spmv/matrix_market/mmio.cspmv_dw_block_spmv_LDADD =			\	$(STARPU_BLAS_LDFLAGS)endif############################ C++ Incrementer example ############################cpp_incrementer_cpp_SOURCES	=	\	cpp/incrementer_cpp.cpp#if STARPU_USE_CUDA#cpp_incrementer_cpp_SOURCES +=	\#	incrementer/incrementer_kernels.cu#endif######################## Incrementer example ########################incrementer_incrementer_SOURCES =	\	incrementer/incrementer.cif STARPU_USE_CUDAincrementer_incrementer_SOURCES +=	\	incrementer/incrementer_kernels.cuendifif STARPU_USE_OPENCLincrementer_incrementer_SOURCES +=	\	incrementer/incrementer_kernels_opencl.cnobase_STARPU_OPENCL_DATA_DATA += \	incrementer/incrementer_kernels_opencl_kernel.clendif####################### matVecMult example #######################if STARPU_USE_OPENCLnobase_STARPU_OPENCL_DATA_DATA += \	matvecmult/matvecmult_kernel.clendif######################## dot_product example ########################reductions_dot_product_SOURCES =		\	reductions/dot_product.cif STARPU_USE_CUDAreductions_dot_product_SOURCES +=		\	reductions/dot_product_kernels.cuendif################### Mandelbrot Set ###################mandelbrot_mandelbrot_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)if HAVE_X11mandelbrot_mandelbrot_CPPFLAGS += $(X_CFLAGS)mandelbrot_mandelbrot_LDADD = $(X_PRE_LIBS) -lX11 $(X_LIBS) $(X_EXTRA_LIBS)endif################# Top Examples #################examplebin_PROGRAMS +=				\	top/hello_world_toptop_hello_world_top_SOURCES =			\	top/hello_world_top.c
 |