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