xref: /illumos-gate/usr/src/tools/smatch/src/Makefile (revision 1f5207b7)
1*1f5207b7SJohn LevonVERSION=0.5.1
2*1f5207b7SJohn Levon
3*1f5207b7SJohn Levon# Generating file version.h if current version has changed
4*1f5207b7SJohn LevonSPARSE_VERSION:=$(shell git describe 2>/dev/null || echo '$(VERSION)')
5*1f5207b7SJohn LevonVERSION_H := $(shell cat version.h 2>/dev/null)
6*1f5207b7SJohn Levonifneq ($(lastword $(VERSION_H)),"$(SPARSE_VERSION)")
7*1f5207b7SJohn Levon$(info $(shell echo '     GEN      'version.h))
8*1f5207b7SJohn Levon$(shell echo '#define SPARSE_VERSION "$(SPARSE_VERSION)"' > version.h)
9*1f5207b7SJohn Levonendif
10*1f5207b7SJohn Levon
11*1f5207b7SJohn LevonOS = linux
12*1f5207b7SJohn Levon
13*1f5207b7SJohn Levonifeq ($(CC),"")
14*1f5207b7SJohn LevonCC = gcc
15*1f5207b7SJohn Levonendif
16*1f5207b7SJohn Levon
17*1f5207b7SJohn LevonCFLAGS += -O2 -finline-functions -fno-strict-aliasing -g
18*1f5207b7SJohn LevonCFLAGS += -Wall -Wwrite-strings -Wno-switch
19*1f5207b7SJohn LevonLDFLAGS += -g -lm -lsqlite3 -lssl -lcrypto
20*1f5207b7SJohn LevonLD = gcc
21*1f5207b7SJohn LevonAR = ar
22*1f5207b7SJohn LevonPKG_CONFIG = pkg-config
23*1f5207b7SJohn LevonCOMMON_CFLAGS = -O2 -finline-functions -fno-strict-aliasing -g
24*1f5207b7SJohn LevonCOMMON_CFLAGS += -Wall -Wwrite-strings
25*1f5207b7SJohn Levon
26*1f5207b7SJohn LevonALL_CFLAGS = $(COMMON_CFLAGS) $(PKG_CFLAGS) $(CFLAGS)
27*1f5207b7SJohn Levon#
28*1f5207b7SJohn Levon# For debugging, put this in local.mk:
29*1f5207b7SJohn Levon#
30*1f5207b7SJohn Levon#     CFLAGS += -O0 -DDEBUG -g3 -gdwarf-2
31*1f5207b7SJohn Levon#
32*1f5207b7SJohn Levon
33*1f5207b7SJohn LevonHAVE_LIBXML:=$(shell $(PKG_CONFIG) --exists libxml-2.0 2>/dev/null && echo 'yes')
34*1f5207b7SJohn LevonHAVE_GCC_DEP:=$(shell touch .gcc-test.c && 				\
35*1f5207b7SJohn Levon		$(CC) -c -Wp,-MD,.gcc-test.d .gcc-test.c 2>/dev/null && \
36*1f5207b7SJohn Levon		echo 'yes'; rm -f .gcc-test.d .gcc-test.o .gcc-test.c)
37*1f5207b7SJohn Levon
38*1f5207b7SJohn LevonGTK_VERSION:=3.0
39*1f5207b7SJohn LevonHAVE_GTK:=$(shell $(PKG_CONFIG) --exists gtk+-$(GTK_VERSION) 2>/dev/null && echo 'yes')
40*1f5207b7SJohn Levonifneq ($(HAVE_GTK),yes)
41*1f5207b7SJohn Levon	GTK_VERSION:=2.0
42*1f5207b7SJohn Levon	HAVE_GTK:=$(shell $(PKG_CONFIG) --exists gtk+-$(GTK_VERSION) 2>/dev/null && echo 'yes')
43*1f5207b7SJohn Levonendif
44*1f5207b7SJohn Levon
45*1f5207b7SJohn LevonLLVM_CONFIG:=llvm-config
46*1f5207b7SJohn LevonHAVE_LLVM:=$(shell $(LLVM_CONFIG) --version >/dev/null 2>&1 && echo 'yes')
47*1f5207b7SJohn Levon
48*1f5207b7SJohn LevonGCC_BASE := $(shell $(CC) --print-file-name=)
49*1f5207b7SJohn LevonCOMMON_CFLAGS += -DGCC_BASE=\"$(GCC_BASE)\"
50*1f5207b7SJohn Levon
51*1f5207b7SJohn LevonMULTIARCH_TRIPLET := $(shell $(CC) -print-multiarch 2>/dev/null)
52*1f5207b7SJohn LevonCOMMON_CFLAGS += -DMULTIARCH_TRIPLET=\"$(MULTIARCH_TRIPLET)\"
53*1f5207b7SJohn Levon
54*1f5207b7SJohn Levonifeq ($(HAVE_GCC_DEP),yes)
55*1f5207b7SJohn LevonCOMMON_CFLAGS += -Wp,-MD,$(@D)/.$(@F).d
56*1f5207b7SJohn Levonendif
57*1f5207b7SJohn Levon
58*1f5207b7SJohn LevonDESTDIR=
59*1f5207b7SJohn LevonINSTALL_PREFIX ?=$(HOME)
60*1f5207b7SJohn LevonBINDIR=$(INSTALL_PREFIX)/bin
61*1f5207b7SJohn LevonLIBDIR=$(INSTALL_PREFIX)/lib
62*1f5207b7SJohn LevonMANDIR=$(INSTALL_PREFIX)/share/man
63*1f5207b7SJohn LevonMAN1DIR=$(MANDIR)/man1
64*1f5207b7SJohn LevonINCLUDEDIR=$(INSTALL_PREFIX)/include
65*1f5207b7SJohn LevonPKGCONFIGDIR=$(LIBDIR)/pkgconfig
66*1f5207b7SJohn LevonSMATCHDATADIR=$(INSTALL_PREFIX)/share/smatch
67*1f5207b7SJohn Levon
68*1f5207b7SJohn LevonSMATCH_FILES=smatch_flow.o smatch_conditions.o smatch_slist.o smatch_states.o \
69*1f5207b7SJohn Levon	smatch_helper.o smatch_type.o smatch_hooks.o smatch_function_hooks.o \
70*1f5207b7SJohn Levon	smatch_modification_hooks.o smatch_extra.o smatch_estate.o smatch_math.o \
71*1f5207b7SJohn Levon	smatch_sval.o smatch_ranges.o smatch_implied.o smatch_ignore.o smatch_project.o \
72*1f5207b7SJohn Levon	smatch_var_sym.o smatch_tracker.o smatch_files.o smatch_expression_stacks.o \
73*1f5207b7SJohn Levon	smatch_equiv.o smatch_buf_size.o smatch_strlen.o smatch_capped.o smatch_db.o \
74*1f5207b7SJohn Levon	smatch_expressions.o smatch_returns.o smatch_parse_call_math.o \
75*1f5207b7SJohn Levon	smatch_param_limit.o smatch_param_filter.o \
76*1f5207b7SJohn Levon	smatch_param_set.o smatch_comparison.o smatch_param_compare_limit.o smatch_local_values.o \
77*1f5207b7SJohn Levon	smatch_function_ptrs.o smatch_annotate.o smatch_string_list.o \
78*1f5207b7SJohn Levon	smatch_param_cleared.o smatch_start_states.o \
79*1f5207b7SJohn Levon	smatch_recurse.o smatch_data_source.o smatch_type_val.o \
80*1f5207b7SJohn Levon	smatch_common_functions.o smatch_struct_assignment.o \
81*1f5207b7SJohn Levon	smatch_unknown_value.o smatch_stored_conditions.o avl.o \
82*1f5207b7SJohn Levon	smatch_function_info.o smatch_links.o smatch_auto_copy.o \
83*1f5207b7SJohn Levon	smatch_type_links.o smatch_untracked_param.o smatch_impossible.o \
84*1f5207b7SJohn Levon	smatch_strings.o smatch_param_used.o smatch_container_of.o smatch_address.o \
85*1f5207b7SJohn Levon	smatch_buf_comparison.o smatch_real_absolute.o smatch_scope.o \
86*1f5207b7SJohn Levon	smatch_imaginary_absolute.o smatch_parameter_names.o \
87*1f5207b7SJohn Levon	smatch_return_to_param.o smatch_passes_array_size.o \
88*1f5207b7SJohn Levon	smatch_constraints.o smatch_constraints_required.o \
89*1f5207b7SJohn Levon	smatch_fn_arg_link.o smatch_about_fn_ptr_arg.o smatch_mtag.o \
90*1f5207b7SJohn Levon	smatch_mtag_map.o smatch_mtag_data.o \
91*1f5207b7SJohn Levon	smatch_param_to_mtag_data.o smatch_mem_tracker.o smatch_array_values.o \
92*1f5207b7SJohn Levon	smatch_nul_terminator.o smatch_assigned_expr.o smatch_kernel_user_data.o \
93*1f5207b7SJohn Levon	smatch_statement_count.o
94*1f5207b7SJohn Levon
95*1f5207b7SJohn LevonSMATCH_CHECKS=$(shell ls check_*.c | sed -e 's/\.c/.o/')
96*1f5207b7SJohn LevonSMATCH_DATA=smatch_data/kernel.allocation_funcs \
97*1f5207b7SJohn Levon	smatch_data/kernel.frees_argument smatch_data/kernel.puts_argument \
98*1f5207b7SJohn Levon	smatch_data/kernel.dev_queue_xmit smatch_data/kernel.returns_err_ptr \
99*1f5207b7SJohn Levon	smatch_data/kernel.dma_funcs smatch_data/kernel.returns_held_funcs \
100*1f5207b7SJohn Levon	smatch_data/kernel.no_return_funcs
101*1f5207b7SJohn Levon
102*1f5207b7SJohn LevonSMATCH_SCRIPTS=smatch_scripts/add_gfp_to_allocations.sh \
103*1f5207b7SJohn Levon	smatch_scripts/build_kernel_data.sh \
104*1f5207b7SJohn Levon	smatch_scripts/call_tree.pl smatch_scripts/filter_kernel_deref_check.sh \
105*1f5207b7SJohn Levon	smatch_scripts/find_expanded_holes.pl smatch_scripts/find_null_params.sh \
106*1f5207b7SJohn Levon	smatch_scripts/follow_params.pl smatch_scripts/gen_allocation_list.sh \
107*1f5207b7SJohn Levon	smatch_scripts/gen_bit_shifters.sh smatch_scripts/gen_dma_funcs.sh \
108*1f5207b7SJohn Levon	smatch_scripts/generisize.pl smatch_scripts/gen_err_ptr_list.sh \
109*1f5207b7SJohn Levon	smatch_scripts/gen_expects_err_ptr.sh smatch_scripts/gen_frees_list.sh \
110*1f5207b7SJohn Levon	smatch_scripts/gen_gfp_flags.sh smatch_scripts/gen_no_return_funcs.sh \
111*1f5207b7SJohn Levon	smatch_scripts/gen_puts_list.sh smatch_scripts/gen_returns_held.sh \
112*1f5207b7SJohn Levon	smatch_scripts/gen_rosenberg_funcs.sh smatch_scripts/gen_sizeof_param.sh \
113*1f5207b7SJohn Levon	smatch_scripts/gen_unwind_functions.sh smatch_scripts/kchecker \
114*1f5207b7SJohn Levon	smatch_scripts/kpatch.sh smatch_scripts/new_bugs.sh \
115*1f5207b7SJohn Levon	smatch_scripts/show_errs.sh smatch_scripts/show_ifs.sh \
116*1f5207b7SJohn Levon	smatch_scripts/show_unreachable.sh smatch_scripts/strip_whitespace.pl \
117*1f5207b7SJohn Levon	smatch_scripts/summarize_errs.sh smatch_scripts/test_kernel.sh \
118*1f5207b7SJohn Levon	smatch_scripts/trace_params.pl smatch_scripts/unlocked_paths.pl \
119*1f5207b7SJohn Levon	smatch_scripts/whitespace_only.sh smatch_scripts/wine_checker.sh \
120*1f5207b7SJohn Levon
121*1f5207b7SJohn LevonPROGRAMS=test-lexing test-parsing obfuscate compile graph sparse \
122*1f5207b7SJohn Levon	 test-linearize example test-unssa test-dissect ctags
123*1f5207b7SJohn LevonINST_PROGRAMS=smatch cgcc
124*1f5207b7SJohn Levon
125*1f5207b7SJohn LevonINST_MAN1=sparse.1 cgcc.1
126*1f5207b7SJohn Levon
127*1f5207b7SJohn Levonifeq ($(HAVE_LIBXML),yes)
128*1f5207b7SJohn LevonPROGRAMS+=c2xml
129*1f5207b7SJohn LevonINST_PROGRAMS+=c2xml
130*1f5207b7SJohn Levonc2xml_EXTRA_OBJS = `$(PKG_CONFIG) --libs libxml-2.0`
131*1f5207b7SJohn LevonLIBXML_CFLAGS := $(shell $(PKG_CONFIG) --cflags libxml-2.0)
132*1f5207b7SJohn Levonelse
133*1f5207b7SJohn Levon$(warning Your system does not have libxml, disabling c2xml)
134*1f5207b7SJohn Levonendif
135*1f5207b7SJohn Levon
136*1f5207b7SJohn Levonifeq ($(HAVE_GTK),yes)
137*1f5207b7SJohn LevonGTK_CFLAGS := $(shell $(PKG_CONFIG) --cflags gtk+-$(GTK_VERSION))
138*1f5207b7SJohn LevonGTK_LIBS := $(shell $(PKG_CONFIG) --libs gtk+-$(GTK_VERSION))
139*1f5207b7SJohn LevonPROGRAMS += test-inspect
140*1f5207b7SJohn LevonINST_PROGRAMS += test-inspect
141*1f5207b7SJohn Levontest-inspect_EXTRA_DEPS := ast-model.o ast-view.o ast-inspect.o
142*1f5207b7SJohn Levontest-inspect_OBJS := test-inspect.o $(test-inspect_EXTRA_DEPS)
143*1f5207b7SJohn Levon$(test-inspect_OBJS) $(test-inspect_OBJS:.o=.sc): PKG_CFLAGS += $(GTK_CFLAGS)
144*1f5207b7SJohn Levontest-inspect_EXTRA_OBJS := $(GTK_LIBS)
145*1f5207b7SJohn Levonelse
146*1f5207b7SJohn Levon$(warning Your system does not have gtk3/gtk2, disabling test-inspect)
147*1f5207b7SJohn Levonendif
148*1f5207b7SJohn Levon
149*1f5207b7SJohn Levonifeq ($(HAVE_LLVM),yes)
150*1f5207b7SJohn Levonifeq ($(shell uname -m | grep -q '\(i386\|x86\)' && echo ok),ok)
151*1f5207b7SJohn LevonLLVM_VERSION:=$(shell $(LLVM_CONFIG) --version)
152*1f5207b7SJohn Levonifeq ($(shell expr "$(LLVM_VERSION)" : '[3-9]\.'),2)
153*1f5207b7SJohn LevonLLVM_PROGS := sparse-llvm
154*1f5207b7SJohn Levon$(LLVM_PROGS): LD := g++
155*1f5207b7SJohn LevonLLVM_LDFLAGS := $(shell $(LLVM_CONFIG) --ldflags)
156*1f5207b7SJohn LevonLLVM_CFLAGS := $(shell $(LLVM_CONFIG) --cflags | sed -e "s/-DNDEBUG//g" | sed -e "s/-pedantic//g")
157*1f5207b7SJohn LevonLLVM_LIBS := $(shell $(LLVM_CONFIG) --libs)
158*1f5207b7SJohn LevonLLVM_LIBS += $(shell $(LLVM_CONFIG) --system-libs 2>/dev/null)
159*1f5207b7SJohn LevonPROGRAMS += $(LLVM_PROGS)
160*1f5207b7SJohn LevonINST_PROGRAMS += sparse-llvm sparsec
161*1f5207b7SJohn Levonsparse-llvm.o sparse-llvm.sc: PKG_CFLAGS += $(LLVM_CFLAGS)
162*1f5207b7SJohn Levonsparse-llvm_EXTRA_OBJS := $(LLVM_LIBS) $(LLVM_LDFLAGS)
163*1f5207b7SJohn Levonelse
164*1f5207b7SJohn Levon$(warning LLVM 3.0 or later required. Your system has version $(LLVM_VERSION) installed.)
165*1f5207b7SJohn Levonendif
166*1f5207b7SJohn Levonelse
167*1f5207b7SJohn Levon$(warning sparse-llvm disabled on $(shell uname -m))
168*1f5207b7SJohn Levonendif
169*1f5207b7SJohn Levonelse
170*1f5207b7SJohn Levon$(warning Your system does not have llvm, disabling sparse-llvm)
171*1f5207b7SJohn Levonendif
172*1f5207b7SJohn Levon
173*1f5207b7SJohn LevonLIB_H=    token.h parse.h lib.h symbol.h scope.h expression.h target.h \
174*1f5207b7SJohn Levon	  linearize.h bitmap.h ident-list.h compat.h flow.h allocate.h \
175*1f5207b7SJohn Levon	  storage.h ptrlist.h dissect.h
176*1f5207b7SJohn Levon
177*1f5207b7SJohn LevonLIB_OBJS= target.o parse.o tokenize.o pre-process.o symbol.o lib.o scope.o \
178*1f5207b7SJohn Levon	  expression.o show-parse.o evaluate.o expand.o inline.o linearize.o \
179*1f5207b7SJohn Levon	  char.o sort.o allocate.o compat-$(OS).o ptrlist.o \
180*1f5207b7SJohn Levon	  builtin.o \
181*1f5207b7SJohn Levon	  stats.o \
182*1f5207b7SJohn Levon	  flow.o cse.o simplify.o memops.o liveness.o storage.o unssa.o \
183*1f5207b7SJohn Levon	  dissect.o \
184*1f5207b7SJohn Levon	  macro_table.o token_store.o cwchash/hashtable.o
185*1f5207b7SJohn Levon
186*1f5207b7SJohn LevonLIB_FILE= libsparse.a
187*1f5207b7SJohn LevonSLIB_FILE= libsparse.so
188*1f5207b7SJohn Levon
189*1f5207b7SJohn Levon# If you add $(SLIB_FILE) to this, you also need to add -fpic to BASIC_CFLAGS above.
190*1f5207b7SJohn Levon# Doing so incurs a noticeable performance hit, and Sparse does not have a
191*1f5207b7SJohn Levon# stable shared library interface, so this does not occur by default.  If you
192*1f5207b7SJohn Levon# really want a shared library, you may want to build Sparse twice: once
193*1f5207b7SJohn Levon# without -fpic to get all the Sparse tools, and again with -fpic to get the
194*1f5207b7SJohn Levon# shared library.
195*1f5207b7SJohn LevonLIBS=$(LIB_FILE)
196*1f5207b7SJohn Levon
197*1f5207b7SJohn Levon#
198*1f5207b7SJohn Levon# Pretty print
199*1f5207b7SJohn Levon#
200*1f5207b7SJohn LevonV	      = @
201*1f5207b7SJohn LevonQ	      = $(V:1=)
202*1f5207b7SJohn LevonQUIET_CC      = $(Q:@=@echo    '     CC       '$@;)
203*1f5207b7SJohn LevonQUIET_CHECK   = $(Q:@=@echo    '     CHECK    '$<;)
204*1f5207b7SJohn LevonQUIET_AR      = $(Q:@=@echo    '     AR       '$@;)
205*1f5207b7SJohn LevonQUIET_GEN     = $(Q:@=@echo    '     GEN      '$@;)
206*1f5207b7SJohn LevonQUIET_LINK    = $(Q:@=@echo    '     LINK     '$@;)
207*1f5207b7SJohn Levon# We rely on the -v switch of install to print 'file -> $install_dir/file'
208*1f5207b7SJohn LevonQUIET_INST_SH = $(Q:@=echo -n  '     INSTALL  ';)
209*1f5207b7SJohn LevonQUIET_INST    = $(Q:@=@echo -n '     INSTALL  ';)
210*1f5207b7SJohn Levon
211*1f5207b7SJohn Levondefine INSTALL_EXEC
212*1f5207b7SJohn Levon	$(QUIET_INST)install -v $1 $(DESTDIR)$2/$1 || exit 1;
213*1f5207b7SJohn Levon
214*1f5207b7SJohn Levonendef
215*1f5207b7SJohn Levon
216*1f5207b7SJohn Levondefine INSTALL_FILE
217*1f5207b7SJohn Levon	$(QUIET_INST)install -v -m 644 $1 $(DESTDIR)$2/$1 || exit 1;
218*1f5207b7SJohn Levon
219*1f5207b7SJohn Levonendef
220*1f5207b7SJohn Levon
221*1f5207b7SJohn LevonSED_PC_CMD = 's|@version@|$(VERSION)|g;		\
222*1f5207b7SJohn Levon	      s|@prefix@|$(INSTALL_PREFIX)|g;		\
223*1f5207b7SJohn Levon	      s|@libdir@|$(LIBDIR)|g;		\
224*1f5207b7SJohn Levon	      s|@includedir@|$(INCLUDEDIR)|g'
225*1f5207b7SJohn Levon
226*1f5207b7SJohn Levon
227*1f5207b7SJohn Levon
228*1f5207b7SJohn Levon# Allow users to override build settings without dirtying their trees
229*1f5207b7SJohn Levon-include local.mk
230*1f5207b7SJohn Levon
231*1f5207b7SJohn Levon
232*1f5207b7SJohn Levonall: $(PROGRAMS) sparse.pc smatch
233*1f5207b7SJohn Levon
234*1f5207b7SJohn Levonall-installable: $(INST_PROGRAMS) $(LIBS) $(LIB_H) sparse.pc
235*1f5207b7SJohn Levon
236*1f5207b7SJohn Levoninstall: all-installable
237*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(BINDIR)
238*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(LIBDIR)
239*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(MAN1DIR)
240*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(INCLUDEDIR)/sparse
241*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(PKGCONFIGDIR)
242*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(SMATCHDATADIR)/smatch_data
243*1f5207b7SJohn Levon	$(Q)install -d $(DESTDIR)$(SMATCHDATADIR)/smatch_scripts
244*1f5207b7SJohn Levon	$(foreach f,$(INST_PROGRAMS),$(call INSTALL_EXEC,$f,$(BINDIR)))
245*1f5207b7SJohn Levon	$(foreach f,$(INST_MAN1),$(call INSTALL_FILE,$f,$(MAN1DIR)))
246*1f5207b7SJohn Levon	$(foreach f,$(LIBS),$(call INSTALL_FILE,$f,$(LIBDIR)))
247*1f5207b7SJohn Levon	$(foreach f,$(LIB_H),$(call INSTALL_FILE,$f,$(INCLUDEDIR)/sparse))
248*1f5207b7SJohn Levon	$(call INSTALL_FILE,sparse.pc,$(PKGCONFIGDIR))
249*1f5207b7SJohn Levon	$(foreach f,$(SMATCH_DATA),$(call INSTALL_FILE,$f,$(SMATCHDATADIR)))
250*1f5207b7SJohn Levon	$(foreach f,$(SMATCH_SCRIPTS),$(call INSTALL_EXEC,$f,$(SMATCHDATADIR)))
251*1f5207b7SJohn Levon
252*1f5207b7SJohn Levonsparse.pc: sparse.pc.in
253*1f5207b7SJohn Levon	$(QUIET_GEN)sed $(SED_PC_CMD) sparse.pc.in > sparse.pc
254*1f5207b7SJohn Levon
255*1f5207b7SJohn Levon
256*1f5207b7SJohn Levoncompile_EXTRA_DEPS = compile-i386.o
257*1f5207b7SJohn Levon
258*1f5207b7SJohn Levon$(foreach p,$(PROGRAMS),$(eval $(p): $($(p)_EXTRA_DEPS) $(LIBS)))
259*1f5207b7SJohn Levon$(PROGRAMS): % : %.o
260*1f5207b7SJohn Levon	$(QUIET_LINK)$(LD) -o $@ $^ $($@_EXTRA_OBJS) $(LDFLAGS)
261*1f5207b7SJohn Levon
262*1f5207b7SJohn Levonsmatch: smatch.o $(SMATCH_FILES) $(SMATCH_CHECKS) $(LIBS)
263*1f5207b7SJohn Levon	$(QUIET_LINK)$(LD) -o $@ $< $(SMATCH_FILES) $(SMATCH_CHECKS) $(LIBS) $(LDFLAGS)
264*1f5207b7SJohn Levon
265*1f5207b7SJohn Levon$(LIB_FILE): $(LIB_OBJS)
266*1f5207b7SJohn Levon	$(QUIET_AR)$(AR) rcs $@ $(LIB_OBJS)
267*1f5207b7SJohn Levon
268*1f5207b7SJohn Levon$(SLIB_FILE): $(LIB_OBJS)
269*1f5207b7SJohn Levon	$(QUIET_LINK)$(CC) -Wl,-soname,$@ -shared -o $@ $(LIB_OBJS) $(LDFLAGS)
270*1f5207b7SJohn Levon
271*1f5207b7SJohn Levoncheck_list_local.h:
272*1f5207b7SJohn Levon	touch check_list_local.h
273*1f5207b7SJohn Levon
274*1f5207b7SJohn Levonsmatch.o: smatch.c $(LIB_H) smatch.h check_list.h check_list_local.h
275*1f5207b7SJohn Levon	$(CC) $(CFLAGS) -c smatch.c -DSMATCHDATADIR='"$(SMATCHDATADIR)"'
276*1f5207b7SJohn Levon$(SMATCH_CHECKS): smatch.h smatch_slist.h smatch_extra.h avl.h
277*1f5207b7SJohn LevonDEP_FILES := $(wildcard .*.o.d)
278*1f5207b7SJohn Levon
279*1f5207b7SJohn Levonifneq ($(DEP_FILES),)
280*1f5207b7SJohn Levoninclude $(DEP_FILES)
281*1f5207b7SJohn Levonendif
282*1f5207b7SJohn Levon
283*1f5207b7SJohn Levonc2xml.o c2xml.sc: PKG_CFLAGS += $(LIBXML_CFLAGS)
284*1f5207b7SJohn Levon
285*1f5207b7SJohn Levonpre-process.sc: CHECKER_FLAGS += -Wno-vla
286*1f5207b7SJohn Levon
287*1f5207b7SJohn Levon%.o: %.c $(LIB_H)
288*1f5207b7SJohn Levon	$(QUIET_CC)$(CC) -o $@ -c $(ALL_CFLAGS) $<
289*1f5207b7SJohn Levon
290*1f5207b7SJohn Levon%.sc: %.c sparse
291*1f5207b7SJohn Levon	$(QUIET_CHECK) $(CHECKER) $(CHECKER_FLAGS) -c $(ALL_CFLAGS) $<
292*1f5207b7SJohn Levon
293*1f5207b7SJohn LevonALL_OBJS :=  $(LIB_OBJS) $(foreach p,$(PROGRAMS),$(p).o $($(p)_EXTRA_DEPS))
294*1f5207b7SJohn Levonselfcheck: $(ALL_OBJS:.o=.sc)
295*1f5207b7SJohn Levon
296*1f5207b7SJohn Levon
297*1f5207b7SJohn Levonclean: clean-check
298*1f5207b7SJohn Levon	rm -f *.[oa] .*.d *.so cwchash/*.o cwchash/.*.d cwchash/tester \
299*1f5207b7SJohn Levon		$(PROGRAMS) $(SLIB_FILE) pre-process.h sparse.pc version.h
300*1f5207b7SJohn Levon
301*1f5207b7SJohn Levondist:
302*1f5207b7SJohn Levon	@if test "$(SPARSE_VERSION)" != "v$(VERSION)" ; then \
303*1f5207b7SJohn Levon		echo 'Update VERSION in the Makefile before running "make dist".' ; \
304*1f5207b7SJohn Levon		exit 1 ; \
305*1f5207b7SJohn Levon	fi
306*1f5207b7SJohn Levon	git archive --format=tar --prefix=sparse-$(VERSION)/ HEAD^{tree} | gzip -9 > sparse-$(VERSION).tar.gz
307*1f5207b7SJohn Levon
308*1f5207b7SJohn Levoncheck: all
309*1f5207b7SJohn Levon	$(Q)cd validation && ./test-suite
310*1f5207b7SJohn Levon
311*1f5207b7SJohn Levonclean-check:
312*1f5207b7SJohn Levon	find validation/ \( -name "*.c.output.expected" \
313*1f5207b7SJohn Levon	                 -o -name "*.c.output.got" \
314*1f5207b7SJohn Levon	                 -o -name "*.c.output.diff" \
315*1f5207b7SJohn Levon	                 -o -name "*.c.error.expected" \
316*1f5207b7SJohn Levon	                 -o -name "*.c.error.got" \
317*1f5207b7SJohn Levon	                 -o -name "*.c.error.diff" \
318*1f5207b7SJohn Levon	                 \) -exec rm {} \;
319