Remove the compiled binary files
[ti-machine-learning/ti-machine-learning.git] / src / test / makefile
1 ################################################################################
2 #
3 # makefile
4 #
5 # Copyright (C) 2015 Texas Instruments Incorporated - http://www.ti.com/
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
9 # are met:
10 #
11 #    Redistributions of source code must retain the above copyright
12 #    notice, this list of conditions and the following disclaimer.
13 #
14 #    Redistributions in binary form must reproduce the above copyright
15 #    notice, this list of conditions and the following disclaimer in the
16 #    documentation and/or other materials provided with the
17 #    distribution.
18 #
19 #    Neither the name of Texas Instruments Incorporated nor the names of
20 #    its contributors may be used to endorse or promote products derived
21 #    from this software without specific prior written permission.
22 #
23 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 #
35 ################################################################################
37 C_INCLUDE_PATH = ../common/api ../common/cnn ../common/util \
38 /usr/include
39 C_INCLUDE_PATH_FLAG = $(foreach d, $(C_INCLUDE_PATH), -I$d)
40 C_LIB =  timl cblas_armplusdsp blis OpenCL stdc++ rt jpeg m 
41 C_LIB_FLAG = $(foreach d, $(C_LIB), -l$d)
42 C_LIB_PATH = /usr/lib ../../bin
43 C_LIB_PATH_FLAG = $(foreach d, $(C_LIB_PATH), -L$d)
44 CC = gcc
45 CFLAGS += -g -O3 -fopenmp
47 CPPC = g++
49 AR = @ar
50 ARFLAGS = -rcs
51 RM = @rm
52 RMFLAGS += -fr
54 # TEST
55 TEST_SRC_DIR = .
57 # TEST CNN
58 TEST_CNN_BINS = $(TEST_SRC_DIR)/cnn/testCNN.bin
59 TEST_CNN_CFILES = $(shell find $(TEST_SRC_DIR)/cnn -name "*.c")
60 TEST_CNN_HFILES = $(shell find $(TEST_SRC_DIR)/util -name "*.h")
61 TEST_CNN_OBJS = $(patsubst %.c, %.o, $(TEST_CNN_CFILES))
63 # TEST UTIL
64 TEST_UTIL_BINS = $(TEST_SRC_DIR)/util/testUtil.bin
65 TEST_UTIL_CFILES = $(shell find $(TEST_SRC_DIR)/util -name "*.c")
66 TEST_UTIL_HFILES = $(shell find $(TEST_SRC_DIR)/util -name "*.h")
67 TEST_UTIL_OBJS = $(patsubst %.c, %.o, $(TEST_UTIL_CFILES))
69 TEST_BINS = $(TEST_CNN_BINS) $(TEST_UTIL_BINS)
70 TEST_OBJS = $(TEST_CNN_OBJS) $(TEST_UTIL_OBJS)
72 all: $(TEST_BINS)
74 clean:
75         $(RM) $(RMFLAGS) \
76         $(TEST_OBJS) \
77         $(TEST_BINS)
79 # testCNN bins
80 $(TEST_CNN_BINS): %.bin: %.o  $(TEST_CNN_OBJS)
81         $(CC) $(CFLAGS) -o $@ $^ \
82         $(C_LIB_FLAG) $(C_LIB_PATH_FLAG)
84 # testUtil bins
85 $(TEST_UTIL_BINS): %.bin: %.o  $(TEST_UTIL_OBJS)
86         $(CC) $(CFLAGS) -o $@ $^ \
87         $(C_LIB_FLAG) $(C_LIB_PATH_FLAG)
89 # testCNN objs
90 $(TEST_CNN_OBJS):%.o: %.c $(TEST_CNN_HFILES)
91         $(CC) -c $(CFLAGS) -o $@ $< \
92         $(C_INCLUDE_PATH_FLAG)
93         
94 # testUtil objs
95 $(TEST_UTIL_OBJS):%.o: %.c $(TEST_UTIL_HFILES)
96         $(CC) -c $(CFLAGS) -o $@ $< \
97         $(C_INCLUDE_PATH_FLAG)