| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594 | # StarPU --- Runtime system for heterogeneous multicore architectures.## Copyright (C) 2009, 2010-2011  Université de Bordeaux 1# Copyright (C) 2010, 2011  Centre National de la Recherche Scientifique# Copyright (C) 2011  Télécom-SudParis## 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)LIBS = $(top_builddir)/src/libstarpu.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 = stencilif STARPU_USE_SOCLSUBDIRS += soclendifif STARPU_HAVE_FFTWif STARPU_HAVE_FFTWFSUBDIRS += starpufftendifendifBUILT_SOURCES =if STARPU_USE_OPENCLnobase_STARPU_OPENCL_DATA_DATA =endifEXTRA_DIST = 					\	basic_examples/vector_scal_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.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.spuelfendifexamplebindir = $(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				\	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###################################### 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_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/mult_impl                \	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 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			\	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 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_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################## 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################# 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)endif################# 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######################## 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
 |