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