3 ########################################################################
4 # The following variables can be overwritten from the command line
17 BINDIR ?
= $(PREFIX
)/bin
18 MANDIR ?
= $(PREFIX
)/share
/man
20 PKG_CONFIG ?
= pkg-config
22 CHECKER_FLAGS ?
= -Wno-vla
24 # Allow users to override build settings without dirtying their trees
25 # For debugging, put this in local.mk:
27 # CFLAGS += -O0 -DDEBUG -g3 -gdwarf-2
29 SPARSE_LOCAL_CONFIG ?
= local.mk
30 -include ${SPARSE_LOCAL_CONFIG}
31 ########################################################################
35 LIB_OBJS
+= allocate.o
38 LIB_OBJS
+= compat-
$(OS
).o
41 LIB_OBJS
+= dominate.o
42 LIB_OBJS
+= evaluate.o
44 LIB_OBJS
+= expression.o
46 LIB_OBJS
+= flowgraph.o
50 LIB_OBJS
+= linearize.o
51 LIB_OBJS
+= liveness.o
54 LIB_OBJS
+= optimize.o
57 LIB_OBJS
+= predefine.o
58 LIB_OBJS
+= pre-process.o
62 LIB_OBJS
+= show-parse.o
63 LIB_OBJS
+= simplify.o
71 LIB_OBJS
+= target-alpha.o
72 LIB_OBJS
+= target-arm.o
73 LIB_OBJS
+= target-arm64.o
74 LIB_OBJS
+= target-bfin.o
75 LIB_OBJS
+= target-default.o
76 LIB_OBJS
+= target-m68k.o
77 LIB_OBJS
+= target-microblaze.o
78 LIB_OBJS
+= target-mips.o
79 LIB_OBJS
+= target-nios2.o
80 LIB_OBJS
+= target-ppc.o
81 LIB_OBJS
+= target-riscv.o
82 LIB_OBJS
+= target-s390.o
83 LIB_OBJS
+= target-sparc.o
84 LIB_OBJS
+= target-x86.o
85 LIB_OBJS
+= tokenize.o
88 LIB_OBJS
+= macro_table.o
89 LIB_OBJS
+= token_store.o
90 LIB_OBJS
+= cwchash
/hashtable.o
99 PROGRAMS
+= test-dissect
100 PROGRAMS
+= test-lexing
101 PROGRAMS
+= test-linearize
102 PROGRAMS
+= test-parsing
103 PROGRAMS
+= test-show-type
104 PROGRAMS
+= test-unssa
106 INST_PROGRAMS
=smatch sparse cgcc
107 INST_MAN1
=sparse
.1 cgcc
.1
112 ########################################################################
113 # common flags/options/...
115 cflags = -fno-strict-aliasing
116 cflags += -Wall
-Wwrite-strings
-Wno-switch
-Wno-psabi
118 GCC_BASE
:= $(shell $(CC
) --print-file-name
=)
119 cflags += -DGCC_BASE
=\"$(GCC_BASE
)\"
121 MULTIARCH_TRIPLET
:= $(shell $(CC
) -print-multiarch
2>/dev
/null
)
122 cflags += -DMULTIARCH_TRIPLET
=\"$(MULTIARCH_TRIPLET
)\"
125 bindir := $(DESTDIR
)$(BINDIR
)
126 man1dir := $(DESTDIR
)$(MANDIR
)/man1
128 ########################################################################
129 # target specificities
131 compile
: compile-i386.o
132 EXTRA_OBJS
+= compile-i386.o
134 # Can we use GCC's generated dependencies?
135 HAVE_GCC_DEP
:=$(shell touch .gcc-test.c
&& \
136 $(CC
) -c
-Wp
,-MP
,-MMD
,.gcc-test.d .gcc-test.c
2>/dev
/null
&& \
137 echo
'yes'; rm -f .gcc-test.d .gcc-test.o .gcc-test.c
)
138 ifeq ($(HAVE_GCC_DEP
),yes
)
139 cflags += -Wp
,-MP
,-MMD
,$(@D
)/.
$(@F
).d
142 # Can we use libxml (needed for c2xml)?
143 HAVE_LIBXML
:=$(shell $(PKG_CONFIG
) --exists libxml-2.0
2>/dev
/null
&& echo
'yes')
144 ifeq ($(HAVE_LIBXML
),yes
)
147 c2xml-ldlibs
:= $(shell $(PKG_CONFIG
) --libs libxml-2.0
)
148 c2xml-cflags
:= $(shell $(PKG_CONFIG
) --cflags libxml-2.0
)
150 $(warning Your system does not have libxml
, disabling c2xml
)
153 HAVE_SQLITE
:= $(shell $(PKG_CONFIG
) --exists sqlite3
2>/dev
/null
&& echo
'yes')
154 ifeq ($(HAVE_SQLITE
),yes
)
155 SQLITE_VERSION
:=$(shell $(PKG_CONFIG
) --modversion sqlite3
)
156 SQLITE_VNUMBER
:=$(shell printf
'%d%02d%02d' $(subst .
, ,$(SQLITE_VERSION
)))
157 ifeq ($(shell expr
"$(SQLITE_VNUMBER)" '>=' 32400),1)
159 INST_PROGRAMS
+= sindex
160 INST_MAN1
+= sindex
.1
161 sindex-ldlibs
:= $(shell $(PKG_CONFIG
) --libs sqlite3
)
162 sindex-cflags
:= $(shell $(PKG_CONFIG
) --cflags sqlite3
)
163 sindex-cflags
+= -std
=gnu99
165 $(warning Your SQLite3 version
($(SQLITE_VERSION
)) is too old
, 3.24.0 or later is required.
)
168 $(warning Your system does not have sqlite3
, disabling sindex
)
171 # Can we use gtk (needed for test-inspect)
173 HAVE_GTK
:=$(shell $(PKG_CONFIG
) --exists gtk
+-$(GTK_VERSION
) 2>/dev
/null
&& echo
'yes')
174 ifneq ($(HAVE_GTK
),yes
)
176 HAVE_GTK
:=$(shell $(PKG_CONFIG
) --exists gtk
+-$(GTK_VERSION
) 2>/dev
/null
&& echo
'yes')
178 ifeq ($(HAVE_GTK
),yes
)
179 GTK_CFLAGS
:= $(shell $(PKG_CONFIG
) --cflags gtk
+-$(GTK_VERSION
))
180 ast-view-cflags
:= $(GTK_CFLAGS
)
181 ast-model-cflags
:= $(GTK_CFLAGS
)
182 ast-inspect-cflags
:= $(GTK_CFLAGS
)
183 test-inspect-cflags
:= $(GTK_CFLAGS
)
184 test-inspect-ldlibs
:= $(shell $(PKG_CONFIG
) --libs gtk
+-$(GTK_VERSION
))
185 test-inspect
: ast-model.o ast-view.o ast-inspect.o
186 EXTRA_OBJS
+= ast-model.o ast-view.o ast-inspect.o
187 PROGRAMS
+= test-inspect
188 INST_PROGRAMS
+= test-inspect
190 $(warning Your system does not have gtk3
/gtk2
, disabling test-inspect
)
193 # Can we use LLVM (needed for ... sparse-llvm)?
194 LLVM_CONFIG
:=llvm-config
195 HAVE_LLVM
:=$(shell $(LLVM_CONFIG
) --version
>/dev
/null
2>&1 && echo
'yes')
196 ifeq ($(HAVE_LLVM
),yes
)
197 arch
:= $(shell uname
-m
)
198 ifeq (${MULTIARCH_TRIPLET},x86_64-linux-gnux32
)
201 ifneq ($(filter ${arch},i386 i486 i586 i686 x86_64 amd64
),)
202 LLVM_VERSION
:=$(shell $(LLVM_CONFIG
) --version
)
203 LLVM_VERSION_MAJOR
:=$(firstword $(subst .
, ,$(LLVM_VERSION
)))
204 ifeq ($(shell expr
"$(LLVM_VERSION_MAJOR)" '>=' 3),1)
205 LLVM_PROGS
:= sparse-llvm
206 $(LLVM_PROGS
): LD
:= $(CXX
)
207 LLVM_LDFLAGS
:= $(shell $(LLVM_CONFIG
) --ldflags)
208 LLVM_CFLAGS
:= $(shell $(LLVM_CONFIG
) --cppflags)
209 LLVM_LIBS
:= $(shell $(LLVM_CONFIG
) --libs
)
210 LLVM_LIBS
+= $(shell $(LLVM_CONFIG
) --system-libs
2>/dev
/null
)
211 LLVM_LIBS
+= $(shell $(LLVM_CONFIG
) --cxxflags | grep
-F
-q
-e
'-stdlib=libc++' && echo
-lc
++)
212 PROGRAMS
+= $(LLVM_PROGS
)
213 INST_PROGRAMS
+= sparse-llvm sparsec
214 sparse-llvm-cflags
:= $(LLVM_CFLAGS
) -D__STDC_CONSTANT_MACROS
-D__STDC_LIMIT_MACROS
215 sparse-llvm-ldflags
:= $(LLVM_LDFLAGS
)
216 sparse-llvm-ldlibs
:= $(LLVM_LIBS
)
218 $(warning LLVM
3.0 or later required. Your system has version
$(LLVM_VERSION
) installed.
)
221 $(warning sparse-llvm disabled on
${arch})
224 $(warning Your system does not have llvm
, disabling sparse-llvm
)
227 ########################################################################
229 OBJS
:= $(LIB_OBJS
) $(EXTRA_OBJS
) $(PROGRAMS
:%=%.o
)
235 ########################################################################
237 SMATCHDATADIR
=$(INSTALL_PREFIX
)/share
/smatch
241 SMATCH_OBJS
+= smatch_about_fn_ptr_arg.o
242 SMATCH_OBJS
+= smatch_address.o
243 SMATCH_OBJS
+= smatch_annotate.o
244 SMATCH_OBJS
+= smatch_array_values.o
245 SMATCH_OBJS
+= smatch_assigned_expr.o
246 SMATCH_OBJS
+= smatch_bits.o
247 SMATCH_OBJS
+= smatch_buf_comparison.o
248 SMATCH_OBJS
+= smatch_buf_size.o
249 SMATCH_OBJS
+= smatch_capped.o
250 SMATCH_OBJS
+= smatch_common_functions.o
251 SMATCH_OBJS
+= smatch_comparison.o
252 SMATCH_OBJS
+= smatch_conditions.o
253 SMATCH_OBJS
+= smatch_constraints.o
254 SMATCH_OBJS
+= smatch_constraints_required.o
255 SMATCH_OBJS
+= smatch_container_of.o
256 SMATCH_OBJS
+= smatch_data_source.o
257 SMATCH_OBJS
+= smatch_db.o
258 SMATCH_OBJS
+= smatch_equiv.o
259 SMATCH_OBJS
+= smatch_estate.o
260 SMATCH_OBJS
+= smatch_expressions.o
261 SMATCH_OBJS
+= smatch_expression_stacks.o
262 SMATCH_OBJS
+= smatch_extra.o
263 SMATCH_OBJS
+= smatch_files.o
264 SMATCH_OBJS
+= smatch_flow.o
265 SMATCH_OBJS
+= smatch_fn_arg_link.o
266 SMATCH_OBJS
+= smatch_fresh_alloc.o
267 SMATCH_OBJS
+= smatch_function_hooks.o
268 SMATCH_OBJS
+= smatch_function_info.o
269 SMATCH_OBJS
+= smatch_function_ptrs.o
270 SMATCH_OBJS
+= smatch_helper.o
271 SMATCH_OBJS
+= smatch_hooks.o
272 SMATCH_OBJS
+= smatch_ignore.o
273 SMATCH_OBJS
+= smatch_imaginary_absolute.o
274 SMATCH_OBJS
+= smatch_implied.o
275 SMATCH_OBJS
+= smatch_impossible.o
276 SMATCH_OBJS
+= smatch_integer_overflow.o
277 SMATCH_OBJS
+= smatch_kernel_user_data.o
278 SMATCH_OBJS
+= smatch_links.o
279 SMATCH_OBJS
+= smatch_math.o
280 SMATCH_OBJS
+= smatch_mem_tracker.o
281 SMATCH_OBJS
+= smatch_modification_hooks.o
282 SMATCH_OBJS
+= smatch_mtag_data.o
283 SMATCH_OBJS
+= smatch_mtag_map.o
284 SMATCH_OBJS
+= smatch_mtag.o
285 SMATCH_OBJS
+= smatch_nul_terminator.o
286 SMATCH_OBJS
+= smatch_param_cleared.o
287 SMATCH_OBJS
+= smatch_param_compare_limit.o
288 SMATCH_OBJS
+= smatch_parameter_names.o
289 SMATCH_OBJS
+= smatch_param_filter.o
290 SMATCH_OBJS
+= smatch_param_limit.o
291 SMATCH_OBJS
+= smatch_param_set.o
292 SMATCH_OBJS
+= smatch_param_to_mtag_data.o
293 SMATCH_OBJS
+= smatch_param_used.o
294 SMATCH_OBJS
+= smatch_parse_call_math.o
295 SMATCH_OBJS
+= smatch_parsed_conditions.o
296 SMATCH_OBJS
+= smatch_passes_array_size.o
297 SMATCH_OBJS
+= smatch_project.o
298 SMATCH_OBJS
+= smatch_ranges.o
299 SMATCH_OBJS
+= smatch_real_absolute.o
300 SMATCH_OBJS
+= smatch_recurse.o
301 SMATCH_OBJS
+= smatch_returns.o
302 SMATCH_OBJS
+= smatch_return_to_param.o
303 SMATCH_OBJS
+= smatch_scope.o
304 SMATCH_OBJS
+= smatch_slist.o
305 SMATCH_OBJS
+= smatch_start_states.o
306 SMATCH_OBJS
+= smatch_statement_count.o
307 SMATCH_OBJS
+= smatch_states.o
308 SMATCH_OBJS
+= smatch_stored_conditions.o
309 SMATCH_OBJS
+= smatch_string_list.o
310 SMATCH_OBJS
+= smatch_strings.o
311 SMATCH_OBJS
+= smatch_strlen.o
312 SMATCH_OBJS
+= smatch_struct_assignment.o
313 SMATCH_OBJS
+= smatch_sval.o
314 SMATCH_OBJS
+= smatch_tracker.o
315 SMATCH_OBJS
+= smatch_type_links.o
316 SMATCH_OBJS
+= smatch_type.o
317 SMATCH_OBJS
+= smatch_type_val.o
318 SMATCH_OBJS
+= smatch_unknown_value.o
319 SMATCH_OBJS
+= smatch_untracked_param.o
320 SMATCH_OBJS
+= smatch_var_sym.o
322 SMATCH_CHECKS
=$(shell ls check_
*.c | sed
-e
's/\.c/.o/')
323 SMATCH_DATA
=smatch_data
/kernel.allocation_funcs \
324 smatch_data
/kernel.frees_argument smatch_data
/kernel.puts_argument \
325 smatch_data
/kernel.dev_queue_xmit smatch_data
/kernel.returns_err_ptr \
326 smatch_data
/kernel.dma_funcs smatch_data
/kernel.returns_held_funcs \
327 smatch_data
/kernel.no_return_funcs
329 SMATCH_SCRIPTS
=smatch_scripts
/add_gfp_to_allocations.sh \
330 smatch_scripts
/build_kernel_data.sh \
331 smatch_scripts
/call_tree.pl smatch_scripts
/filter_kernel_deref_check.sh \
332 smatch_scripts
/find_expanded_holes.pl smatch_scripts
/find_null_params.sh \
333 smatch_scripts
/follow_params.pl smatch_scripts
/gen_allocation_list.sh \
334 smatch_scripts
/gen_bit_shifters.sh smatch_scripts
/gen_dma_funcs.sh \
335 smatch_scripts
/generisize.pl smatch_scripts
/gen_err_ptr_list.sh \
336 smatch_scripts
/gen_expects_err_ptr.sh smatch_scripts
/gen_frees_list.sh \
337 smatch_scripts
/gen_gfp_flags.sh smatch_scripts
/gen_no_return_funcs.sh \
338 smatch_scripts
/gen_puts_list.sh smatch_scripts
/gen_returns_held.sh \
339 smatch_scripts
/gen_rosenberg_funcs.sh smatch_scripts
/gen_sizeof_param.sh \
340 smatch_scripts
/gen_unwind_functions.sh smatch_scripts
/kchecker \
341 smatch_scripts
/kpatch.sh smatch_scripts
/new_bugs.sh \
342 smatch_scripts
/show_errs.sh smatch_scripts
/show_ifs.sh \
343 smatch_scripts
/show_unreachable.sh smatch_scripts
/strip_whitespace.pl \
344 smatch_scripts
/summarize_errs.sh smatch_scripts
/test_kernel.sh \
345 smatch_scripts
/trace_params.pl smatch_scripts
/unlocked_paths.pl \
346 smatch_scripts
/whitespace_only.sh smatch_scripts
/wine_checker.sh \
348 SMATCH_LDFLAGS
:= -lsqlite3
-lssl
-lcrypto
-lm
350 smatch
: smatch.o
$(SMATCH_OBJS
) $(SMATCH_CHECKS
) $(LIBS
)
351 $(Q
)$(LD
) -o
$@
$< $(SMATCH_OBJS
) $(SMATCH_CHECKS
) $(LIBS
) $(SMATCH_LDFLAGS
)
354 touch check_list_local.h
356 smatch.o
: smatch.c
$(LIB_H
) smatch.h check_list.h check_list_local.h
357 $(CC
) $(CFLAGS
) -c smatch.c
-DSMATCHDATADIR
='"$(SMATCHDATADIR)"'
359 $(SMATCH_OBJS
) $(SMATCH_CHECKS
): smatch.h smatch_slist.h smatch_extra.h avl.h
361 ########################################################################
362 all: $(PROGRAMS
) smatch
364 ldflags += $($(@
)-ldflags) $(LDFLAGS
)
365 ldlibs
+= $($(@
)-ldlibs
) $(LDLIBS
) -lm
366 $(PROGRAMS
): % : %.o
$(LIBS
)
368 $(Q
)$(LD
) $(ldflags) $^
$(ldlibs
) -o
$@
370 libsparse.a
: $(LIB_OBJS
)
375 cflags += $($(*)-cflags) $(CPPFLAGS
) $(CFLAGS
)
378 $(Q
)$(CC
) $(cflags) -c
-o
$@
$<
382 $(Q
)CHECK
=.
/sparse .
/cgcc
-no-compile
$(CHECKER_FLAGS
) $(cflags) -c
$<
384 selfcheck
: $(OBJS
:.o
=.sc
)
386 SPARSE_VERSION
:=$(shell git describe
--dirty
2>/dev
/null || echo
'$(VERSION)')
389 @echo
'#define SPARSE_VERSION "$(SPARSE_VERSION)"' > version.h.tmp
390 @if cmp
-s version.h version.h.tmp
; then \
394 mv version.h.tmp version.h
; \
399 $(Q
)cd validation
&& .
/test-suite
400 validation
/%.t
: $(PROGRAMS
)
401 @validation
/test-suite single
$*.c
405 @
rm -f
*.
[oa
] .
*.d
$(PROGRAMS
) version.h smatch
408 @find validation
/ \
( -name
"*.c.output.*" \
409 -o
-name
"*.c.error.*" \
414 install: install-bin install-man
415 install-bin
: $(INST_PROGRAMS
:%=$(bindir)/%)
416 install-man
: $(INST_MAN1
:%=$(man1dir)/%)
420 $(Q
)install -D
$< $@ || exit
1;
423 $(Q
)install -D
-m
644 $< $@ || exit
1;
428 -include $(OBJS
:%.o
=.
%.o.d
)