xref: /illumos-gate/usr/src/tools/smatch/src/Makefile (revision b3263c98)
1*b3263c98SJohn LevonVERSION=0.6.1-rc1-il-6
21f5207b7SJohn Levon
3c85f09ccSJohn Levon########################################################################
4c85f09ccSJohn Levon# The following variables can be overwritten from the command line
51f5207b7SJohn LevonOS = linux
61f5207b7SJohn Levon
71f5207b7SJohn Levon
8c85f09ccSJohn LevonCC ?= gcc
9c85f09ccSJohn LevonLD = $(CC)
101f5207b7SJohn LevonAR = ar
111f5207b7SJohn Levon
12eb44bcc7SJohn LevonCFLAGS ?= -g
13c85f09ccSJohn Levon
14c85f09ccSJohn LevonDESTDIR ?=
15c85f09ccSJohn LevonPREFIX ?= $(HOME)
16c85f09ccSJohn LevonBINDIR ?= $(PREFIX)/bin
17c85f09ccSJohn LevonMANDIR ?= $(PREFIX)/share/man
18c85f09ccSJohn Levon
19c85f09ccSJohn LevonPKG_CONFIG ?= pkg-config
20c85f09ccSJohn Levon
21c85f09ccSJohn LevonCHECKER_FLAGS ?= -Wno-vla
22c85f09ccSJohn Levon
23c85f09ccSJohn Levon# Allow users to override build settings without dirtying their trees
241f5207b7SJohn Levon# For debugging, put this in local.mk:
251f5207b7SJohn Levon#
261f5207b7SJohn Levon#     CFLAGS += -O0 -DDEBUG -g3 -gdwarf-2
271f5207b7SJohn Levon#
28c85f09ccSJohn LevonSPARSE_LOCAL_CONFIG ?= local.mk
29c85f09ccSJohn Levon-include ${SPARSE_LOCAL_CONFIG}
30c85f09ccSJohn Levon########################################################################
31c85f09ccSJohn Levon
32c85f09ccSJohn Levon
33c85f09ccSJohn LevonLIB_OBJS :=
34c85f09ccSJohn LevonLIB_OBJS += allocate.o
35c85f09ccSJohn LevonLIB_OBJS += builtin.o
36c85f09ccSJohn LevonLIB_OBJS += char.o
37c85f09ccSJohn LevonLIB_OBJS += compat-$(OS).o
38c85f09ccSJohn LevonLIB_OBJS += cse.o
39c85f09ccSJohn LevonLIB_OBJS += dissect.o
40c85f09ccSJohn LevonLIB_OBJS += dominate.o
41c85f09ccSJohn LevonLIB_OBJS += evaluate.o
42c85f09ccSJohn LevonLIB_OBJS += expand.o
43c85f09ccSJohn LevonLIB_OBJS += expression.o
44c85f09ccSJohn LevonLIB_OBJS += flow.o
45c85f09ccSJohn LevonLIB_OBJS += flowgraph.o
46c85f09ccSJohn LevonLIB_OBJS += inline.o
47c85f09ccSJohn LevonLIB_OBJS += ir.o
48c85f09ccSJohn LevonLIB_OBJS += lib.o
49c85f09ccSJohn LevonLIB_OBJS += linearize.o
50c85f09ccSJohn LevonLIB_OBJS += liveness.o
51c85f09ccSJohn LevonLIB_OBJS += memops.o
52c85f09ccSJohn LevonLIB_OBJS += opcode.o
53c85f09ccSJohn LevonLIB_OBJS += optimize.o
54c85f09ccSJohn LevonLIB_OBJS += parse.o
55c85f09ccSJohn LevonLIB_OBJS += pre-process.o
56c85f09ccSJohn LevonLIB_OBJS += ptrlist.o
57c85f09ccSJohn LevonLIB_OBJS += ptrmap.o
58c85f09ccSJohn LevonLIB_OBJS += scope.o
59c85f09ccSJohn LevonLIB_OBJS += show-parse.o
60c85f09ccSJohn LevonLIB_OBJS += simplify.o
61c85f09ccSJohn LevonLIB_OBJS += sort.o
62c85f09ccSJohn LevonLIB_OBJS += ssa.o
63c85f09ccSJohn LevonLIB_OBJS += sset.o
64c85f09ccSJohn LevonLIB_OBJS += stats.o
65c85f09ccSJohn LevonLIB_OBJS += storage.o
66c85f09ccSJohn LevonLIB_OBJS += symbol.o
67c85f09ccSJohn LevonLIB_OBJS += target.o
68c85f09ccSJohn LevonLIB_OBJS += tokenize.o
69c85f09ccSJohn LevonLIB_OBJS += unssa.o
70c85f09ccSJohn LevonLIB_OBJS += utils.o
71c85f09ccSJohn LevonLIB_OBJS += macro_table.o
72c85f09ccSJohn LevonLIB_OBJS += token_store.o
73c85f09ccSJohn LevonLIB_OBJS += cwchash/hashtable.o
74c85f09ccSJohn Levon
75c85f09ccSJohn LevonPROGRAMS :=
76c85f09ccSJohn LevonPROGRAMS += compile
77c85f09ccSJohn LevonPROGRAMS += ctags
78c85f09ccSJohn LevonPROGRAMS += example
79c85f09ccSJohn LevonPROGRAMS += graph
80c85f09ccSJohn LevonPROGRAMS += obfuscate
81c85f09ccSJohn LevonPROGRAMS += sparse
82c85f09ccSJohn LevonPROGRAMS += test-dissect
83c85f09ccSJohn LevonPROGRAMS += test-lexing
84c85f09ccSJohn LevonPROGRAMS += test-linearize
85c85f09ccSJohn LevonPROGRAMS += test-parsing
86c85f09ccSJohn LevonPROGRAMS += test-unssa
87c85f09ccSJohn Levon
88c85f09ccSJohn LevonINST_PROGRAMS=smatch sparse cgcc
89c85f09ccSJohn LevonINST_MAN1=sparse.1 cgcc.1
901f5207b7SJohn Levon
911f5207b7SJohn Levon
92c85f09ccSJohn Levonall:
931f5207b7SJohn Levon
94c85f09ccSJohn Levon########################################################################
95c85f09ccSJohn Levon# common flags/options/...
96c85f09ccSJohn Levon
97c85f09ccSJohn Levoncflags = -fno-strict-aliasing
985a0e240fSJohn Levoncflags += -Wall -Wwrite-strings -Wno-switch -Wno-psabi
991f5207b7SJohn Levon
1001f5207b7SJohn LevonGCC_BASE := $(shell $(CC) --print-file-name=)
101c85f09ccSJohn Levoncflags += -DGCC_BASE=\"$(GCC_BASE)\"
1021f5207b7SJohn Levon
1031f5207b7SJohn LevonMULTIARCH_TRIPLET := $(shell $(CC) -print-multiarch 2>/dev/null)
104c85f09ccSJohn Levoncflags += -DMULTIARCH_TRIPLET=\"$(MULTIARCH_TRIPLET)\"
1051f5207b7SJohn Levon
1061f5207b7SJohn Levon
107c85f09ccSJohn Levonbindir := $(DESTDIR)$(BINDIR)
108c85f09ccSJohn Levonman1dir := $(DESTDIR)$(MANDIR)/man1
1091f5207b7SJohn Levon
110c85f09ccSJohn Levon########################################################################
111c85f09ccSJohn Levon# target specificities
1121f5207b7SJohn Levon
113c85f09ccSJohn Levoncompile: compile-i386.o
114c85f09ccSJohn LevonEXTRA_OBJS += compile-i386.o
1151f5207b7SJohn Levon
116c85f09ccSJohn Levon# Can we use GCC's generated dependencies?
117c85f09ccSJohn LevonHAVE_GCC_DEP:=$(shell touch .gcc-test.c && 				\
118c85f09ccSJohn Levon		$(CC) -c -Wp,-MP,-MMD,.gcc-test.d .gcc-test.c 2>/dev/null && \
119c85f09ccSJohn Levon		echo 'yes'; rm -f .gcc-test.d .gcc-test.o .gcc-test.c)
120c85f09ccSJohn Levonifeq ($(HAVE_GCC_DEP),yes)
121c85f09ccSJohn Levoncflags += -Wp,-MP,-MMD,$(@D)/.$(@F).d
122c85f09ccSJohn Levonendif
1231f5207b7SJohn Levon
124c85f09ccSJohn Levon# Can we use libxml (needed for c2xml)?
125c85f09ccSJohn LevonHAVE_LIBXML:=$(shell $(PKG_CONFIG) --exists libxml-2.0 2>/dev/null && echo 'yes')
1261f5207b7SJohn Levonifeq ($(HAVE_LIBXML),yes)
1271f5207b7SJohn LevonPROGRAMS+=c2xml
1281f5207b7SJohn LevonINST_PROGRAMS+=c2xml
129c85f09ccSJohn Levonc2xml-ldlibs := $(shell $(PKG_CONFIG) --libs libxml-2.0)
130c85f09ccSJohn Levonc2xml-cflags := $(shell $(PKG_CONFIG) --cflags libxml-2.0)
1311f5207b7SJohn Levonelse
1321f5207b7SJohn Levon$(warning Your system does not have libxml, disabling c2xml)
1331f5207b7SJohn Levonendif
1341f5207b7SJohn Levon
135c85f09ccSJohn Levon# Can we use gtk (needed for test-inspect)
136c85f09ccSJohn LevonGTK_VERSION:=3.0
137c85f09ccSJohn LevonHAVE_GTK:=$(shell $(PKG_CONFIG) --exists gtk+-$(GTK_VERSION) 2>/dev/null && echo 'yes')
138c85f09ccSJohn Levonifneq ($(HAVE_GTK),yes)
139c85f09ccSJohn LevonGTK_VERSION:=2.0
140c85f09ccSJohn LevonHAVE_GTK:=$(shell $(PKG_CONFIG) --exists gtk+-$(GTK_VERSION) 2>/dev/null && echo 'yes')
141c85f09ccSJohn Levonendif
1421f5207b7SJohn Levonifeq ($(HAVE_GTK),yes)
1431f5207b7SJohn LevonGTK_CFLAGS := $(shell $(PKG_CONFIG) --cflags gtk+-$(GTK_VERSION))
144c85f09ccSJohn Levonast-view-cflags := $(GTK_CFLAGS)
145c85f09ccSJohn Levonast-model-cflags := $(GTK_CFLAGS)
146c85f09ccSJohn Levonast-inspect-cflags := $(GTK_CFLAGS)
147c85f09ccSJohn Levontest-inspect-cflags := $(GTK_CFLAGS)
148c85f09ccSJohn Levontest-inspect-ldlibs := $(shell $(PKG_CONFIG) --libs gtk+-$(GTK_VERSION))
149c85f09ccSJohn Levontest-inspect: ast-model.o ast-view.o ast-inspect.o
150c85f09ccSJohn LevonEXTRA_OBJS += ast-model.o ast-view.o ast-inspect.o
1511f5207b7SJohn LevonPROGRAMS += test-inspect
1521f5207b7SJohn LevonINST_PROGRAMS += test-inspect
1531f5207b7SJohn Levonelse
1541f5207b7SJohn Levon$(warning Your system does not have gtk3/gtk2, disabling test-inspect)
1551f5207b7SJohn Levonendif
1561f5207b7SJohn Levon
157c85f09ccSJohn Levon# Can we use LLVM (needed for ... sparse-llvm)?
158c85f09ccSJohn LevonLLVM_CONFIG:=llvm-config
159c85f09ccSJohn LevonHAVE_LLVM:=$(shell $(LLVM_CONFIG) --version >/dev/null 2>&1 && echo 'yes')
1601f5207b7SJohn Levonifeq ($(HAVE_LLVM),yes)
161c85f09ccSJohn Levonarch := $(shell uname -m)
162c85f09ccSJohn Levonifeq (${MULTIARCH_TRIPLET},x86_64-linux-gnux32)
163c85f09ccSJohn Levonarch := x32
164c85f09ccSJohn Levonendif
165c85f09ccSJohn Levonifneq ($(filter ${arch},i386 i486 i586 i686 x86_64 amd64),)
1661f5207b7SJohn LevonLLVM_VERSION:=$(shell $(LLVM_CONFIG) --version)
1671f5207b7SJohn Levonifeq ($(shell expr "$(LLVM_VERSION)" : '[3-9]\.'),2)
1681f5207b7SJohn LevonLLVM_PROGS := sparse-llvm
1691f5207b7SJohn Levon$(LLVM_PROGS): LD := g++
1701f5207b7SJohn LevonLLVM_LDFLAGS := $(shell $(LLVM_CONFIG) --ldflags)
171c85f09ccSJohn LevonLLVM_CFLAGS := -I$(shell $(LLVM_CONFIG) --includedir)
1721f5207b7SJohn LevonLLVM_LIBS := $(shell $(LLVM_CONFIG) --libs)
1731f5207b7SJohn LevonLLVM_LIBS += $(shell $(LLVM_CONFIG) --system-libs 2>/dev/null)
174c85f09ccSJohn LevonLLVM_LIBS += $(shell $(LLVM_CONFIG) --cxxflags | grep -F -q -e '-stdlib=libc++' && echo -lc++)
1751f5207b7SJohn LevonPROGRAMS += $(LLVM_PROGS)
1761f5207b7SJohn LevonINST_PROGRAMS += sparse-llvm sparsec
177c85f09ccSJohn Levonsparse-llvm-cflags := $(LLVM_CFLAGS) -D__STDC_CONSTANT_MACROS -D__STDC_LIMIT_MACROS
178c85f09ccSJohn Levonsparse-llvm-ldflags := $(LLVM_LDFLAGS)
179c85f09ccSJohn Levonsparse-llvm-ldlibs := $(LLVM_LIBS)
1801f5207b7SJohn Levonelse
1811f5207b7SJohn Levon$(warning LLVM 3.0 or later required. Your system has version $(LLVM_VERSION) installed.)
1821f5207b7SJohn Levonendif
1831f5207b7SJohn Levonelse
184c85f09ccSJohn Levon$(warning sparse-llvm disabled on ${arch})
1851f5207b7SJohn Levonendif
1861f5207b7SJohn Levonelse
1871f5207b7SJohn Levon$(warning Your system does not have llvm, disabling sparse-llvm)
1881f5207b7SJohn Levonendif
1891f5207b7SJohn Levon
190c85f09ccSJohn Levon########################################################################
191c85f09ccSJohn LevonLIBS := libsparse.a
192c85f09ccSJohn LevonOBJS := $(LIB_OBJS) $(EXTRA_OBJS) $(PROGRAMS:%=%.o)
1931f5207b7SJohn Levon
1941f5207b7SJohn Levon# Pretty print
195c85f09ccSJohn LevonV := @
196c85f09ccSJohn LevonQ := $(V:1=)
1971f5207b7SJohn Levon
198c85f09ccSJohn Levon########################################################################
1991f5207b7SJohn Levon
200c85f09ccSJohn LevonSMATCHDATADIR=$(INSTALL_PREFIX)/share/smatch
2011f5207b7SJohn Levon
202c85f09ccSJohn LevonSMATCH_OBJS :=
203c85f09ccSJohn LevonSMATCH_OBJS += avl.o
204c85f09ccSJohn LevonSMATCH_OBJS += smatch_about_fn_ptr_arg.o
205c85f09ccSJohn LevonSMATCH_OBJS += smatch_address.o
206c85f09ccSJohn LevonSMATCH_OBJS += smatch_annotate.o
207c85f09ccSJohn LevonSMATCH_OBJS += smatch_array_values.o
208c85f09ccSJohn LevonSMATCH_OBJS += smatch_assigned_expr.o
209c85f09ccSJohn LevonSMATCH_OBJS += smatch_bits.o
210c85f09ccSJohn LevonSMATCH_OBJS += smatch_buf_comparison.o
211c85f09ccSJohn LevonSMATCH_OBJS += smatch_buf_size.o
212c85f09ccSJohn LevonSMATCH_OBJS += smatch_capped.o
213c85f09ccSJohn LevonSMATCH_OBJS += smatch_common_functions.o
214c85f09ccSJohn LevonSMATCH_OBJS += smatch_comparison.o
215c85f09ccSJohn LevonSMATCH_OBJS += smatch_conditions.o
216c85f09ccSJohn LevonSMATCH_OBJS += smatch_constraints.o
217c85f09ccSJohn LevonSMATCH_OBJS += smatch_constraints_required.o
218c85f09ccSJohn LevonSMATCH_OBJS += smatch_container_of.o
219c85f09ccSJohn LevonSMATCH_OBJS += smatch_data_source.o
220c85f09ccSJohn LevonSMATCH_OBJS += smatch_db.o
221c85f09ccSJohn LevonSMATCH_OBJS += smatch_equiv.o
222c85f09ccSJohn LevonSMATCH_OBJS += smatch_estate.o
223c85f09ccSJohn LevonSMATCH_OBJS += smatch_expressions.o
224c85f09ccSJohn LevonSMATCH_OBJS += smatch_expression_stacks.o
225c85f09ccSJohn LevonSMATCH_OBJS += smatch_extra.o
226c85f09ccSJohn LevonSMATCH_OBJS += smatch_files.o
227c85f09ccSJohn LevonSMATCH_OBJS += smatch_flow.o
228c85f09ccSJohn LevonSMATCH_OBJS += smatch_fn_arg_link.o
22931ad075eSJohn LevonSMATCH_OBJS += smatch_fresh_alloc.o
230c85f09ccSJohn LevonSMATCH_OBJS += smatch_function_hooks.o
231c85f09ccSJohn LevonSMATCH_OBJS += smatch_function_info.o
232c85f09ccSJohn LevonSMATCH_OBJS += smatch_function_ptrs.o
233c85f09ccSJohn LevonSMATCH_OBJS += smatch_helper.o
234c85f09ccSJohn LevonSMATCH_OBJS += smatch_hooks.o
235c85f09ccSJohn LevonSMATCH_OBJS += smatch_ignore.o
236c85f09ccSJohn LevonSMATCH_OBJS += smatch_imaginary_absolute.o
237c85f09ccSJohn LevonSMATCH_OBJS += smatch_implied.o
238c85f09ccSJohn LevonSMATCH_OBJS += smatch_impossible.o
239c85f09ccSJohn LevonSMATCH_OBJS += smatch_integer_overflow.o
240c85f09ccSJohn LevonSMATCH_OBJS += smatch_kernel_user_data.o
241c85f09ccSJohn LevonSMATCH_OBJS += smatch_links.o
242c85f09ccSJohn LevonSMATCH_OBJS += smatch_math.o
243c85f09ccSJohn LevonSMATCH_OBJS += smatch_mem_tracker.o
244c85f09ccSJohn LevonSMATCH_OBJS += smatch_modification_hooks.o
245c85f09ccSJohn LevonSMATCH_OBJS += smatch_mtag_data.o
246c85f09ccSJohn LevonSMATCH_OBJS += smatch_mtag_map.o
247c85f09ccSJohn LevonSMATCH_OBJS += smatch_mtag.o
248c85f09ccSJohn LevonSMATCH_OBJS += smatch_nul_terminator.o
249c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_cleared.o
250c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_compare_limit.o
251c85f09ccSJohn LevonSMATCH_OBJS += smatch_parameter_names.o
252c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_filter.o
253c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_limit.o
254c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_set.o
255c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_to_mtag_data.o
256c85f09ccSJohn LevonSMATCH_OBJS += smatch_param_used.o
257c85f09ccSJohn LevonSMATCH_OBJS += smatch_parse_call_math.o
2585a0e240fSJohn LevonSMATCH_OBJS += smatch_parsed_conditions.o
259c85f09ccSJohn LevonSMATCH_OBJS += smatch_passes_array_size.o
260c85f09ccSJohn LevonSMATCH_OBJS += smatch_project.o
261c85f09ccSJohn LevonSMATCH_OBJS += smatch_ranges.o
262c85f09ccSJohn LevonSMATCH_OBJS += smatch_real_absolute.o
263c85f09ccSJohn LevonSMATCH_OBJS += smatch_recurse.o
264c85f09ccSJohn LevonSMATCH_OBJS += smatch_returns.o
265c85f09ccSJohn LevonSMATCH_OBJS += smatch_return_to_param.o
266c85f09ccSJohn LevonSMATCH_OBJS += smatch_scope.o
267c85f09ccSJohn LevonSMATCH_OBJS += smatch_slist.o
268c85f09ccSJohn LevonSMATCH_OBJS += smatch_start_states.o
269c85f09ccSJohn LevonSMATCH_OBJS += smatch_statement_count.o
270c85f09ccSJohn LevonSMATCH_OBJS += smatch_states.o
271c85f09ccSJohn LevonSMATCH_OBJS += smatch_stored_conditions.o
272c85f09ccSJohn LevonSMATCH_OBJS += smatch_string_list.o
273c85f09ccSJohn LevonSMATCH_OBJS += smatch_strings.o
274c85f09ccSJohn LevonSMATCH_OBJS += smatch_strlen.o
275c85f09ccSJohn LevonSMATCH_OBJS += smatch_struct_assignment.o
276c85f09ccSJohn LevonSMATCH_OBJS += smatch_sval.o
277c85f09ccSJohn LevonSMATCH_OBJS += smatch_tracker.o
278c85f09ccSJohn LevonSMATCH_OBJS += smatch_type_links.o
279c85f09ccSJohn LevonSMATCH_OBJS += smatch_type.o
280c85f09ccSJohn LevonSMATCH_OBJS += smatch_type_val.o
281c85f09ccSJohn LevonSMATCH_OBJS += smatch_unknown_value.o
282c85f09ccSJohn LevonSMATCH_OBJS += smatch_untracked_param.o
283c85f09ccSJohn LevonSMATCH_OBJS += smatch_var_sym.o
2841f5207b7SJohn Levon
285c85f09ccSJohn LevonSMATCH_CHECKS=$(shell ls check_*.c | sed -e 's/\.c/.o/')
286c85f09ccSJohn LevonSMATCH_DATA=smatch_data/kernel.allocation_funcs \
287c85f09ccSJohn Levon	smatch_data/kernel.frees_argument smatch_data/kernel.puts_argument \
288c85f09ccSJohn Levon	smatch_data/kernel.dev_queue_xmit smatch_data/kernel.returns_err_ptr \
289c85f09ccSJohn Levon	smatch_data/kernel.dma_funcs smatch_data/kernel.returns_held_funcs \
290c85f09ccSJohn Levon	smatch_data/kernel.no_return_funcs
2911f5207b7SJohn Levon
292c85f09ccSJohn LevonSMATCH_SCRIPTS=smatch_scripts/add_gfp_to_allocations.sh \
293c85f09ccSJohn Levon	smatch_scripts/build_kernel_data.sh \
294c85f09ccSJohn Levon	smatch_scripts/call_tree.pl smatch_scripts/filter_kernel_deref_check.sh \
295c85f09ccSJohn Levon	smatch_scripts/find_expanded_holes.pl smatch_scripts/find_null_params.sh \
296c85f09ccSJohn Levon	smatch_scripts/follow_params.pl smatch_scripts/gen_allocation_list.sh \
297c85f09ccSJohn Levon	smatch_scripts/gen_bit_shifters.sh smatch_scripts/gen_dma_funcs.sh \
298c85f09ccSJohn Levon	smatch_scripts/generisize.pl smatch_scripts/gen_err_ptr_list.sh \
299c85f09ccSJohn Levon	smatch_scripts/gen_expects_err_ptr.sh smatch_scripts/gen_frees_list.sh \
300c85f09ccSJohn Levon	smatch_scripts/gen_gfp_flags.sh smatch_scripts/gen_no_return_funcs.sh \
301c85f09ccSJohn Levon	smatch_scripts/gen_puts_list.sh smatch_scripts/gen_returns_held.sh \
302c85f09ccSJohn Levon	smatch_scripts/gen_rosenberg_funcs.sh smatch_scripts/gen_sizeof_param.sh \
303c85f09ccSJohn Levon	smatch_scripts/gen_unwind_functions.sh smatch_scripts/kchecker \
304c85f09ccSJohn Levon	smatch_scripts/kpatch.sh smatch_scripts/new_bugs.sh \
305c85f09ccSJohn Levon	smatch_scripts/show_errs.sh smatch_scripts/show_ifs.sh \
306c85f09ccSJohn Levon	smatch_scripts/show_unreachable.sh smatch_scripts/strip_whitespace.pl \
307c85f09ccSJohn Levon	smatch_scripts/summarize_errs.sh smatch_scripts/test_kernel.sh \
308c85f09ccSJohn Levon	smatch_scripts/trace_params.pl smatch_scripts/unlocked_paths.pl \
309c85f09ccSJohn Levon	smatch_scripts/whitespace_only.sh smatch_scripts/wine_checker.sh \
3101f5207b7SJohn Levon
311c85f09ccSJohn LevonSMATCH_LDFLAGS := -lsqlite3  -lssl -lcrypto -lm
3121f5207b7SJohn Levon
313c85f09ccSJohn Levonsmatch: smatch.o $(SMATCH_OBJS) $(SMATCH_CHECKS) $(LIBS)
314c85f09ccSJohn Levon	$(Q)$(LD) -o $@ $< $(SMATCH_OBJS) $(SMATCH_CHECKS) $(LIBS) $(SMATCH_LDFLAGS)
3151f5207b7SJohn Levon
3161f5207b7SJohn Levoncheck_list_local.h:
3171f5207b7SJohn Levon	touch check_list_local.h
3181f5207b7SJohn Levon
3191f5207b7SJohn Levonsmatch.o: smatch.c $(LIB_H) smatch.h check_list.h check_list_local.h
3201f5207b7SJohn Levon	$(CC) $(CFLAGS) -c smatch.c -DSMATCHDATADIR='"$(SMATCHDATADIR)"'
3211f5207b7SJohn Levon
322c85f09ccSJohn Levon$(SMATCH_OBJS) $(SMATCH_CHECKS): smatch.h smatch_slist.h smatch_extra.h avl.h
3231f5207b7SJohn Levon
324c85f09ccSJohn Levon########################################################################
325c85f09ccSJohn Levonall: $(PROGRAMS) smatch
3261f5207b7SJohn Levon
327c85f09ccSJohn Levonldflags += $($(@)-ldflags) $(LDFLAGS)
328c85f09ccSJohn Levonldlibs  += $($(@)-ldlibs)  $(LDLIBS) -lm
329c85f09ccSJohn Levon$(PROGRAMS): % : %.o $(LIBS)
330c85f09ccSJohn Levon	@echo "  LD      $@"
331c85f09ccSJohn Levon	$(Q)$(LD) $(ldflags) $^ $(ldlibs) -o $@
3321f5207b7SJohn Levon
333c85f09ccSJohn Levonlibsparse.a: $(LIB_OBJS)
334c85f09ccSJohn Levon	@echo "  AR      $@"
335c85f09ccSJohn Levon	$(Q)$(AR) rcs $@ $^
3361f5207b7SJohn Levon
3371f5207b7SJohn Levon
338c85f09ccSJohn Levoncflags   += $($(*)-cflags) $(CPPFLAGS) $(CFLAGS)
339c85f09ccSJohn Levon%.o: %.c
340c85f09ccSJohn Levon	@echo "  CC      $@"
341c85f09ccSJohn Levon	$(Q)$(CC) $(cflags) -c -o $@ $<
3421f5207b7SJohn Levon
343c85f09ccSJohn Levon%.sc: %.c sparse
344c85f09ccSJohn Levon	@echo "  CHECK   $<"
345c85f09ccSJohn Levon	$(Q)CHECK=./sparse ./cgcc -no-compile $(CHECKER_FLAGS) $(cflags) -c $<
346c85f09ccSJohn Levon
347c85f09ccSJohn Levonselfcheck: $(OBJS:.o=.sc)
3481f5207b7SJohn Levon
3491f5207b7SJohn Levon
350c85f09ccSJohn LevonSPARSE_VERSION:=$(shell git describe --dirty 2>/dev/null || echo '$(VERSION)')
351c85f09ccSJohn Levonlib.o: version.h
352c85f09ccSJohn Levonversion.h: FORCE
353c85f09ccSJohn Levon	@echo '#define SPARSE_VERSION "$(SPARSE_VERSION)"' > version.h.tmp
354c85f09ccSJohn Levon	@if cmp -s version.h version.h.tmp; then \
355c85f09ccSJohn Levon		rm version.h.tmp; \
356c85f09ccSJohn Levon	else \
357c85f09ccSJohn Levon		echo "  GEN     $@"; \
358c85f09ccSJohn Levon		mv version.h.tmp version.h; \
3591f5207b7SJohn Levon	fi
360c85f09ccSJohn Levon
3611f5207b7SJohn Levon
3621f5207b7SJohn Levoncheck: all
3631f5207b7SJohn Levon	$(Q)cd validation && ./test-suite
364c85f09ccSJohn Levonvalidation/%.t: $(PROGRAMS)
365c85f09ccSJohn Levon	@validation/test-suite single $*.c
3661f5207b7SJohn Levon
367c85f09ccSJohn Levon
368c85f09ccSJohn Levonclean: clean-check
369c85f09ccSJohn Levon	@rm -f *.[oa] .*.d $(PROGRAMS) version.h smatch
3701f5207b7SJohn Levonclean-check:
371c85f09ccSJohn Levon	@echo "  CLEAN"
372c85f09ccSJohn Levon	@find validation/ \( -name "*.c.output.*" \
373c85f09ccSJohn Levon			  -o -name "*.c.error.*" \
374c85f09ccSJohn Levon			  -o -name "*.o" \
375c85f09ccSJohn Levon	                  \) -exec rm {} \;
376c85f09ccSJohn Levon
377c85f09ccSJohn Levon
378c85f09ccSJohn Levoninstall: install-bin install-man
379c85f09ccSJohn Levoninstall-bin: $(INST_PROGRAMS:%=$(bindir)/%)
380c85f09ccSJohn Levoninstall-man: $(INST_MAN1:%=$(man1dir)/%)
381c85f09ccSJohn Levon
382c85f09ccSJohn Levon$(bindir)/%: %
383c85f09ccSJohn Levon	@echo "  INSTALL $@"
384c85f09ccSJohn Levon	$(Q)install -D        $< $@ || exit 1;
385c85f09ccSJohn Levon$(man1dir)/%: %
386c85f09ccSJohn Levon	@echo "  INSTALL $@"
387c85f09ccSJohn Levon	$(Q)install -D -m 644 $< $@ || exit 1;
388c85f09ccSJohn Levon
389c85f09ccSJohn Levon.PHONY: FORCE
390c85f09ccSJohn Levon
391c85f09ccSJohn Levon# GCC's dependencies
392c85f09ccSJohn Levon-include $(OBJS:%.o=.%.o.d)
393