source: trunk/Platforms/Test/Makefile @ 123

Last change on this file since 123 was 123, checked in by rosiere, 15 years ago

1) Fix performance
2) add auto generation to SPECINT2000
3) add reset in genMoore and genMealy

  • Property svn:keywords set to Id
File size: 9.3 KB
Line 
1
2#
3# $Id: Makefile 123 2009-06-08 20:43:30Z rosiere $
4#
5# [ Description ]
6#
7# Makefile
8#
9
10#----------------------------------------------------------
11#----------------------------------------------------------
12#-----[ Environment ]--------------------------------------
13#----------------------------------------------------------
14#----------------------------------------------------------
15ifeq ($(origin MORPHEO_TOPLEVEL), undefined)
16        $(error "variable MORPHEO_TOPLEVEL is undefined")
17else
18        include $(MORPHEO_TOPLEVEL)/Makefile.tools
19        include $(MORPHEO_TOPLEVEL)/Makefile.flags
20endif
21
22ifeq ($(origin MORPHEO_TMP), undefined)
23        $(error "variable MORPHEO_TMP is undefined")
24endif
25
26DATA_ALL                        = *
27ifeq ($(origin DATA), undefined)
28DATA                            = $(DATA_ALL)
29endif
30ifeq ($(origin PRIORITY), undefined)
31PRIORITY                        = 0
32endif
33
34ifeq ($(flavor CLEAN), undefined)
35CLEAN                           = 0
36endif
37
38#----------------------------------------------------------
39#----------------------------------------------------------
40#-----[ Directory ]----------------------------------------
41#----------------------------------------------------------
42#----------------------------------------------------------
43ENTITY                          =       Test
44
45DIR_TMP                         =       $(MORPHEO_TMP)
46DIR_INC                         =       include
47DIR_SRC                         =       src
48DIR_OBJ                         =       $(DIR_TMP)/obj
49DIR_LIB                         =       $(DIR_TMP)/lib
50DIR_BIN                         =       $(DIR_TMP)/bin
51DIR_LOG                         =       $(DIR_TMP)/log
52DIR_DATA                        =       ./data
53DIR_LOGS                        =       $(patsubst $(DIR_DATA)/%,$(DIR_LOG)/%,$(wildcard $(DIR_DATA)/*))
54
55DIR_SOFT                        =       $(MORPHEO_TOPLEVEL)/Softwares
56
57#MORPHEO                        -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
58#MORPHEO_DIR                    -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
59#MORPHEO_INCDIR                 -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
60#MORPHEO_LIBDIR                 -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
61#MORPHEO_LIBNAME                -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
62
63#ENVIRONMENT_DIR                -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/Environment/Makefile.deps
64#ENVIRONMENT_INCDIR             -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/Environment/Makefile.deps
65#ENVIRONMENT_LIBDIR             -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/Environment/Makefile.deps
66#ENVIRONMENT_LIBNAME            -       define in $(MORPHEO_TOPLEVEL)/IPs/systemC/Environment/Makefile.deps
67
68#----------------------------------------------------------
69#----------------------------------------------------------
70#-----[ Variables ]----------------------------------------
71#----------------------------------------------------------
72#----------------------------------------------------------
73SOURCES                         =       $(wildcard $(DIR_SRC)/*.cpp)
74OBJECTS                         =       $(patsubst $(DIR_SRC)/%.cpp,$(DIR_OBJ)/%.o,$(SOURCES))
75LOGS                            =       $(patsubst $(DIR_DATA)/%.cfg,$(DIR_LOG)/%.log,$(wildcard $(DIR_DATA)/$(DATA)/*.cfg))
76EXEC                            =       $(DIR_BIN)/soft.x
77EXEC_PREFIX                     =       $(NICE) -n $(PRIORITY) 
78#$(VALGRIND)
79
80#-----[ Compilation ]--------------------------------------
81INCDIR                          =       $(SYSTEMC_INCDIR_$(SIMULATOR_SYSTEMC))          \
82                                        $(MORPHEO_INCDIR)                       \
83                                        $(ENVIRONMENT_INCDIR)                   \
84                                        -I$(DIR_INC)                         
85
86#LIBDIR                         =       $(SYSTEMC_LIBDIR_$(SIMULATOR_SYSTEMC))          \
87#                                       $(ENVIRONMENT_LIBDIR)                   \
88#                                       $(MORPHEO_LIBDIR)                       
89
90LIBDIR                          =       $(SYSTEMC_LIBDIR_$(SIMULATOR_SYSTEMC))          \
91                                        -L$(DIR_LIB)
92
93LIBNAME                         =       $(ENVIRONMENT_LIBNAME)                  \
94                                        $(MORPHEO_LIBNAME)                      \
95                                        $(SYSTEMC_LIBNAME_$(SIMULATOR_SYSTEMC))
96
97FLAGS                           =       $(SYSTEMC_CFLAGS_$(SIMULATOR_SYSTEMC))
98
99PLATFORMS_CXX_FLAGS             =       $(MORPHEO_FLAGS) $(CXX_FLAGS) $(FLAGS) $(INCDIR)
100PLATFORMS_L_FLAGS               =       $(MORPHEO_FLAGS) $(CXX_FLAGS) $(FLAGS) $(LIBDIR)
101
102#----------------------------------------------------------
103#----------------------------------------------------------
104#-----[ Rules ]--------------------------------------------
105#----------------------------------------------------------
106#----------------------------------------------------------
107
108vpath   %.h     $(DIR_INC)
109vpath   %.cpp   $(DIR_SRC)
110vpath   %.o     $(DIR_OBJ)
111vpath   %.cfg   $(DIR_DATA)/*/
112
113.PRECIOUS                       : $(DIR_OBJ)/%.o $(DIR_BIN)/%.x $(DIR_LOG)/%.log
114
115all                             : $(EXEC)
116
117$(DIR_BIN)/%.x                  :  $(DIR_OBJ) $(DIR_BIN)
118                                @\
119                                $(ECHO) "Linkage            : $*";\
120                                case "${SIMULATOR_SYSTEMC}" in                                                          \
121                                    "modelsim")                                                                 \
122                                        $(MAKE) $(WORK_NAME);                                                   \
123                                        $(MODELTECH_SCCOM) $(PLATFORMS_CXX_FLAGS) $(SOURCES);                   \
124                                        $(MODELTECH_SCCOM) -link $(PLATFORMS_L_FLAGS) $(LIBNAME);               \
125                                        $(ECHO) "#!$(SHELL)"                                              > $@; \
126                                        $(ECHO) "cd $${PWD};"                                            >> $@; \
127                                        $(ECHO) "$(MODELTECH_VSIM) -sc_arg "'"$${*}"'" $(WORK_NAME).top;" >> $@;\
128                                        $(ECHO) "cd -;"                                                  >> $@; \
129                                        $(CHMOD) +x $@;                                                         \
130                                        ;;                                                                      \
131                                    *)                                                                          \
132                                        $(MAKE) $(OBJECTS);                                                     \
133                                        $(CXX) $(PLATFORMS_L_FLAGS) -o $@ $(OBJECTS) $(LIBNAME);                \
134                                        ;;                                                                      \
135                                esac;                                                                           \
136
137run                             :
138                                @\
139                                declare -i clean=$(CLEAN);                                                              \
140                                if $(TEST) $${clean} -ne 0 -a "$(DATA)" != "$(DATA_ALL)"; then                          \
141                                        $(RM) $(DIR_LOG)/$(DATA);                                                       \
142                                fi;                                                                                     \
143                                $(MAKE) $(DIR_LOGS);                                                                    \
144                                declare logs="$(LOGS)";                                                                 \
145                                $(MAKE) $${logs};                                                                       \
146                                declare -i nb_test=0;                                                                   \
147                                declare -i nb_test_ko=0;                                                                \
148                                for log in $${logs}; do                                                                 \
149                                        $(GREP) -q "Test OK" $$log;                                                     \
150                                        declare -i test_ok=$$?;                                                         \
151                                        $(GREP) -q "Test KO" $$log;                                                     \
152                                        declare -i test_ko=$$?;                                                         \
153                                        if $(TEST) $${test_ko} -eq 0 -o $${test_ok} -ne 0;                              \
154                                        then nb_test_ko=$$(($${nb_test_ko} + 1));                                       \
155                                        fi;                                                                             \
156                                        nb_test=$$(($${nb_test} + 1));                                                  \
157                                done;                                                                                   \
158                                if $(TEST) $${nb_test_ko} -ne 0;                                                        \
159                                then $(ECHO) "-------------------| Test KO !!! ($${nb_test_ko}/$${nb_test})"; exit 1;   \
160                                else $(ECHO) "-------------------| Test OK     ($${nb_test})"; exit 0;                  \
161                                fi;
162
163execute                         : run
164
165debug                           :
166                                @\
167                                $(MAKE) run DATA=debug CLEAN=1;
168
169bench                           :
170                                @\
171                                $(MAKE) run DATA=bench;
172
173$(DIR_LOG)/%.log                : $(DIR_DATA)/%.cfg $(EXEC)
174                                @\
175                                file=$$($(BASENAME) $<);                                \
176                                data=$$($(CAT) $<);                                     \
177                                log=$@;                                                 \
178                                $(ECHO) "Run                : $*";                      \
179                                $(EXEC_PREFIX) $(EXEC) $${data} &> $$log;               \
180                                $(GREP) -q "Test OK" $$log;                             \
181                                declare -i test_ok=$$?;                                 \
182                                $(GREP) -q "Test KO" $$log;                             \
183                                declare -i test_ko=$$?;                                 \
184                                declare timing=$$($(GREP) -h "Timing" $$log);           \
185                                if $(TEST) $${test_ko} -ne 0 -a $${test_ok} -eq 0;      \
186                                then test="... OK    ";                                 \
187                                else test="... KO !!!";                                 \
188                                fi;                                                     \
189                                $(ECHO) -e "                     $* $${test}\t$${timing}";\
190                                echo "{$$($(date))} $* $${test} $${timing}" >> $$($(DIRNAME) $*).res;\
191
192#-----[ Library + Software ]-------------------------------
193
194env                             : soft lib
195                                @$(MAKE) $(EXEC)
196
197lib                             :
198                                @\
199                                $(MAKE) --directory=$(ENVIRONMENT_DIR) --makefile=Makefile;\
200                                $(MAKE) --directory=$(MORPHEO_DIR)     --makefile=Makefile;
201
202soft                            :
203                                @\
204                                $(MAKE) --directory=$(DIR_SOFT)        --makefile=Makefile;
205
206#-----[ Rules ]--------------------------------------------
207
208$(DIR_OBJ)/%.o                  : %.cpp
209                                @\
210                                $(ECHO) "Compilation        : $*";\
211                                $(CXX) $(PLATFORMS_CXX_FLAGS) -c -o $@ $<;
212
213$(DIR_OBJ) $(DIR_BIN) $(DIR_LOGS) :
214                                @\
215                                $(ECHO) "Create directory   : $@";\
216                                $(MKDIR) $@
217
218#-----[ Clean + help ]-------------------------------------
219
220clean                           :
221                                @\
222                                $(ECHO) "Delete     temporary files in directory $(PWD)";\
223                                $(RM)   $(OBJECTS) $(EXEC) $(LOGS) \
224                                        *~ $(DIR_SRC)/*~ $(DIR_INC)/*~ $(DIR_DATA)/*/*~ *.res *.txt\
225                                        *core* \
226                                        tty* \
227                                        *.vhdl \
228                                        *.log \
229                                        *.stat \
230                                        *.pos \
231                                        modelsim.ini transcript *wlf* $(WORK_NAME)
232
233clean_all                       : clean
234                                @\
235                                $(ECHO) "Delete     generated files in directory $(PWD)";\
236                                $(RM) $(DIR_OBJ) $(DIR_BIN) $(DIR_LOG);\
237                                $(MAKE) --directory=$(DIR_SOFT)        --makefile=Makefile clean_all; \
238                                $(MAKE) --directory=$(ENVIRONMENT_DIR) --makefile=Makefile clean_all; \
239                                $(MAKE) --directory=$(MORPHEO_DIR)     --makefile=Makefile clean_all;
240
241
242help                            :
243                                @\
244                                $(ECHO) " -----[ Common ]-------------------------------------";\
245                                $(ECHO) "";\
246                                $(ECHO) " * all (default rules) : create software";\
247                                $(ECHO) " * run                 : execute platforms with test configuration";\
248                                $(ECHO) "                         set DATA     to select a specific directory in $(DIR_DATA) (default : all)";\
249                                $(ECHO) "                         set PRIORITY to nice the execution (default : 0)";\
250                                $(ECHO) "                         set CLEAN    to remove previous log (default : 0)";\
251                                $(ECHO) "                         example : make run DATA=debug PRIORITY=10 CLEAN";\
252                                $(ECHO) " * execute             : cf 'make run'";\
253                                $(ECHO) " * debug               : cf 'make run DATA=debug'";\
254                                $(ECHO) " * bench               : cf 'make run DATA=bench'";\
255                                $(ECHO) " * lib                 : make library";\
256                                $(ECHO) " * soft                : make software";\
257                                $(ECHO) " * clean               : erase temporary files";\
258                                $(ECHO) " * clean_all           : erase generated files";\
259                                $(ECHO) " * help                : print this message";\
260                                $(ECHO) "";
261
262include $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Behavioural/Makefile.Synthesis
263include $(MORPHEO_TOPLEVEL)/IPs/systemC/processor/Morpheo/Makefile.deps
264include $(MORPHEO_TOPLEVEL)/IPs/systemC/Environment/Makefile.deps
Note: See TracBrowser for help on using the repository browser.