#/****************************************************************************** # * Copyright (c) 2011, Duane Merrill. All rights reserved. # * Copyright (c) 2011-2016, NVIDIA CORPORATION. All rights reserved. # * # * Redistribution and use in source and binary forms, with or without # * modification, are permitted provided that the following conditions are met: # * * Redistributions of source code must retain the above copyright # * notice, this list of conditions and the following disclaimer. # * * Redistributions in binary form must reproduce the above copyright # * notice, this list of conditions and the following disclaimer in the # * documentation and/or other materials provided with the distribution. # * * Neither the name of the NVIDIA CORPORATION nor the # * names of its contributors may be used to endorse or promote products # * derived from this software without specific prior written permission. # * # * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND # * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE # * DISCLAIMED. IN NO EVENT SHALL NVIDIA CORPORATION BE LIABLE FOR ANY # * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES # * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; # * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND # * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS # * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # * #******************************************************************************/ #------------------------------------------------------------------------------- # # Makefile usage # # make [sm=] [cdp=<0|1>] [force32=<0|1>] [abi=<0|1>] [open64=<0|1>] [verbose=<0|1>] [keep=<0|1>] [quicktest=<0|1>] [quickertest=<0|1>] # #------------------------------------------------------------------------------- include ../common.mk #------------------------------------------------------------------------------- # Commandline Options #------------------------------------------------------------------------------- # Testing mode option (quick/thorough) ifeq ($(quickertest), 1) NVCCFLAGS += -DQUICKER_TEST TEST_SUFFIX = quicker else ifeq ($(quicktest), 1) NVCCFLAGS += -DQUICK_TEST TEST_SUFFIX = quick else TEST_SUFFIX = thorough NPPI = endif # CUDA memcheck (enabled by default) ifeq ($(memcheck), 0) MEMCHECK = else MEMCHECK = cuda-memcheck endif #------------------------------------------------------------------------------- # Compiler and compilation platform #------------------------------------------------------------------------------- # Includes INC += -I$(CUB_DIR) -I$(CUB_DIR)test # Suffix to append to each binary SUFFIX = $(BIN_SUFFIX)_$(TEST_SUFFIX) # Define test arch DEFINES += -DTEST_ARCH=$(TEST_ARCH) #------------------------------------------------------------------------------- # Dependency Lists #------------------------------------------------------------------------------- rwildcard=$(foreach d,$(wildcard $1*),$(call rwildcard,$d/,$2) $(filter $(subst *,%,$2),$d)) DEPS = $(CUB_DEPS) \ $(CUB_DIR)test/Makefile \ $(CUB_DIR)test/test_util.h \ $(CUB_DIR)test/mersenne.h \ BLOCK_REDUCE = test_block_reduce_raking \ test_block_reduce_warp_reductions BLOCK_SCAN = test_block_scan_raking \ test_block_scan_raking_memoize \ test_block_scan_warp_scans BLOCK_RADIX_SORT = test_block_radix_sort_keys \ test_block_radix_sort_pairs ALL = link \ test_iterator \ test_allocator \ test_warp_scan \ test_warp_reduce \ $(BLOCK_REDUCE) \ $(BLOCK_SCAN) \ $(BLOCK_RADIX_SORT) \ test_block_load_store \ test_block_histogram \ test_device_reduce \ test_device_histogram \ test_device_scan \ test_device_radix_sort \ test_device_reduce_by_key\ test_device_run_length_encode\ test_device_select_unique \ test_device_select_if # test_grid_barrier \ fails on sm110 # test_device_seg_reduce #------------------------------------------------------------------------------- # make default #------------------------------------------------------------------------------- default: #------------------------------------------------------------------------------- # make clean #------------------------------------------------------------------------------- clean : rm -f bin/*$(CPU_ARCH_SUFFIX)* rm -f *.i* *.cubin *.cu.c *.cudafe* *.fatbin.c *.ptx *.hash *.cu.cpp *.o #------------------------------------------------------------------------------- # make all #------------------------------------------------------------------------------- all : $(ALL) #------------------------------------------------------------------------------- # make run #------------------------------------------------------------------------------- run : for i in $(ALL); do $(MEMCHECK) ./bin/$${i}_$(SUFFIX) --device=$(device) || exit 1; done run_block_reduce : for i in $(BLOCK_REDUCE); do $(MEMCHECK) ./bin/$${i}_$(SUFFIX) --device=$(device) || exit 1; done run_block_scan : for i in $(BLOCK_SCAN); do $(MEMCHECK) ./bin/$${i}_$(SUFFIX) --device=$(device) || exit 1; done run_block_radix_sort : for i in $(BLOCK_RADIX_SORT); do $(MEMCHECK) ./bin/$${i}_$(SUFFIX) --device=$(device) || exit 1; done #------------------------------------------------------------------------------- # make link #------------------------------------------------------------------------------- link : bin/link_$(SUFFIX) bin/link_$(SUFFIX) : link_a.cu link_b.cu link_main.cpp $(DEPS) mkdir -p bin $(NVCC) $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(DEFINES) $(SM_TARGETS) link_a.cu -c -o bin/link_a.obj $(NVCC) $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(DEFINES) $(SM_TARGETS) link_b.cu -c -o bin/link_b.obj $(NVCC) $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(DEFINES) $(SM_TARGETS) link_main.cpp bin/link_a.obj bin/link_b.obj -o bin/link_$(SUFFIX) #------------------------------------------------------------------------------- # make test_iterator #------------------------------------------------------------------------------- test_iterator: bin/test_iterator_$(SUFFIX) bin/test_iterator_$(SUFFIX) : test_iterator.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_iterator_$(SUFFIX) test_iterator.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_allocator #------------------------------------------------------------------------------- test_allocator: bin/test_allocator_$(SUFFIX) bin/test_allocator_$(SUFFIX) : test_allocator.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_allocator_$(SUFFIX) test_allocator.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_grid_barrier #------------------------------------------------------------------------------- test_grid_barrier: bin/test_grid_barrier_$(SUFFIX) bin/test_grid_barrier_$(SUFFIX) : test_grid_barrier.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_grid_barrier_$(SUFFIX) test_grid_barrier.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_warp_scan #------------------------------------------------------------------------------- test_warp_scan: bin/test_warp_scan_$(SUFFIX) bin/test_warp_scan_$(SUFFIX) : test_warp_scan.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_warp_scan_$(SUFFIX) test_warp_scan.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_warp_reduce #------------------------------------------------------------------------------- test_warp_reduce: bin/test_warp_reduce_$(SUFFIX) bin/test_warp_reduce_$(SUFFIX) : test_warp_reduce.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_warp_reduce_$(SUFFIX) test_warp_reduce.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_reduce_raking #------------------------------------------------------------------------------- test_block_reduce_raking: bin/test_block_reduce_raking_$(SUFFIX) bin/test_block_reduce_raking_$(SUFFIX) : test_block_reduce.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_RAKING $(SM_TARGETS) -o bin/test_block_reduce_raking_$(SUFFIX) test_block_reduce.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_reduce_warp_reductions #------------------------------------------------------------------------------- test_block_reduce_warp_reductions: bin/test_block_reduce_warp_reductions_$(SUFFIX) bin/test_block_reduce_warp_reductions_$(SUFFIX) : test_block_reduce.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_WARP_REDUCTIONS $(SM_TARGETS) -o bin/test_block_reduce_warp_reductions_$(SUFFIX) test_block_reduce.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_reduce #------------------------------------------------------------------------------- test_block_reduce: $(BLOCK_REDUCE) #------------------------------------------------------------------------------- # make test_block_scan_raking #------------------------------------------------------------------------------- test_block_scan_raking: bin/test_block_scan_raking_$(SUFFIX) bin/test_block_scan_raking_$(SUFFIX) : test_block_scan.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_RAKING $(SM_TARGETS) -o bin/test_block_scan_raking_$(SUFFIX) test_block_scan.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_scan_raking_memoize #------------------------------------------------------------------------------- test_block_scan_raking_memoize: bin/test_block_scan_raking_memoize_$(SUFFIX) bin/test_block_scan_raking_memoize_$(SUFFIX) : test_block_scan.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_RAKING_MEMOIZE $(SM_TARGETS) -o bin/test_block_scan_raking_memoize_$(SUFFIX) test_block_scan.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_scan_warp_scans #------------------------------------------------------------------------------- test_block_scan_warp_scans: bin/test_block_scan_warp_scans_$(SUFFIX) bin/test_block_scan_warp_scans_$(SUFFIX) : test_block_scan.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_WARP_SCANS $(SM_TARGETS) -o bin/test_block_scan_warp_scans_$(SUFFIX) test_block_scan.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_scan #------------------------------------------------------------------------------- test_block_scan: $(BLOCK_SCAN) #------------------------------------------------------------------------------- # make test_block_load_store #------------------------------------------------------------------------------- test_block_load_store: bin/test_block_load_store_$(SUFFIX) bin/test_block_load_store_$(SUFFIX) : test_block_load_store.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_block_load_store_$(SUFFIX) test_block_load_store.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_radix_sort_keys #------------------------------------------------------------------------------- test_block_radix_sort_keys: bin/test_block_radix_sort_keys_$(SUFFIX) bin/test_block_radix_sort_keys_$(SUFFIX) : test_block_radix_sort.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) -DTEST_KEYS_ONLY $(SM_TARGETS) -o bin/test_block_radix_sort_keys_$(SUFFIX) test_block_radix_sort.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_radix_sort_pairs #------------------------------------------------------------------------------- test_block_radix_sort_pairs: bin/test_block_radix_sort_pairs_$(SUFFIX) bin/test_block_radix_sort_pairs_$(SUFFIX) : test_block_radix_sort.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_block_radix_sort_pairs_$(SUFFIX) test_block_radix_sort.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_block_radix_sort #------------------------------------------------------------------------------- test_block_radix_sort : $(BLOCK_RADIX_SORT) #------------------------------------------------------------------------------- # make test_block_histogram #------------------------------------------------------------------------------- test_block_histogram: bin/test_block_histogram_$(SUFFIX) bin/test_block_histogram_$(SUFFIX) : test_block_histogram.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_block_histogram_$(SUFFIX) test_block_histogram.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_reduce #------------------------------------------------------------------------------- test_device_reduce: bin/test_device_reduce_$(SUFFIX) bin/test_device_reduce_$(SUFFIX) : test_device_reduce.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_reduce_$(SUFFIX) test_device_reduce.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_histogram #------------------------------------------------------------------------------- test_device_histogram: bin/test_device_histogram_$(SUFFIX) bin/test_device_histogram_$(SUFFIX) : test_device_histogram.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_histogram_$(SUFFIX) test_device_histogram.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) $(NPPI) -O3 #------------------------------------------------------------------------------- # make test_device_scan #------------------------------------------------------------------------------- test_device_scan: bin/test_device_scan_$(SUFFIX) bin/test_device_scan_$(SUFFIX) : test_device_scan.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_scan_$(SUFFIX) test_device_scan.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_radix_sort #------------------------------------------------------------------------------- test_device_radix_sort: bin/test_device_radix_sort_$(SUFFIX) bin/test_device_radix_sort_$(SUFFIX) : test_device_radix_sort.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_radix_sort_$(SUFFIX) test_device_radix_sort.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_select_unique #------------------------------------------------------------------------------- test_device_select_unique: bin/test_device_select_unique_$(SUFFIX) bin/test_device_select_unique_$(SUFFIX) : test_device_select_unique.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_select_unique_$(SUFFIX) test_device_select_unique.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_select_if #------------------------------------------------------------------------------- test_device_select_if: bin/test_device_select_if_$(SUFFIX) bin/test_device_select_if_$(SUFFIX) : test_device_select_if.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_select_if_$(SUFFIX) test_device_select_if.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_reduce_by_key #------------------------------------------------------------------------------- test_device_reduce_by_key: bin/test_device_reduce_by_key_$(SUFFIX) bin/test_device_reduce_by_key_$(SUFFIX) : test_device_reduce_by_key.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_reduce_by_key_$(SUFFIX) test_device_reduce_by_key.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_run_length_encode #------------------------------------------------------------------------------- test_device_run_length_encode: bin/test_device_run_length_encode_$(SUFFIX) bin/test_device_run_length_encode_$(SUFFIX) : test_device_run_length_encode.cu $(DEPS) mkdir -p bin $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_run_length_encode_$(SUFFIX) test_device_run_length_encode.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3 #------------------------------------------------------------------------------- # make test_device_seg_reduce #------------------------------------------------------------------------------- # #test_device_seg_reduce: bin/test_device_seg_reduce_$(SUFFIX) # #bin/test_device_seg_reduce_$(SUFFIX) : test_device_seg_reduce.cu $(DEPS) # mkdir -p bin # $(NVCC) $(DEFINES) $(SM_TARGETS) -o bin/test_device_seg_reduce_$(SUFFIX) test_device_seg_reduce.cu $(NVCCFLAGS) $(CPU_ARCH) $(INC) $(LIBS) -O3