riscv: asm: implement `j offset`
[tinycc.git] / Makefile
blob2b247ea77fc5662e9d3b8147c5dbc5bfef780aca
1 # --------------------------------------------------------------------------
3 # Tiny C Compiler Makefile
6 ifndef TOP
7 TOP = .
8 INCLUDED = no
9 endif
11 ifeq ($(findstring $(MAKECMDGOALS),clean distclean),)
12 include $(TOP)/config.mak
13 endif
15 ifeq (-$(GCC_MAJOR)-$(findstring $(GCC_MINOR),56789)-,-4--)
16 CFLAGS += -D_FORTIFY_SOURCE=0
17 endif
19 LIBTCC = libtcc.a
20 LIBTCC1 = libtcc1.a
21 LINK_LIBTCC =
22 LIBS =
23 CFLAGS += -I$(TOP)
24 CFLAGS += $(CPPFLAGS)
25 VPATH = $(TOPSRC)
27 ifdef CONFIG_WIN32
28 CFG = -win
29 ifneq ($(CONFIG_static),yes)
30 LIBTCC = libtcc$(DLLSUF)
31 LIBTCCDEF = libtcc.def
32 -LTCC = $(bindir)/libtcc.dll
33 else
34 -LTCC = -ltcc -L$(libdir)
35 endif
36 ifneq ($(CONFIG_debug),yes)
37 LDFLAGS += -s
38 endif
39 NATIVE_TARGET = $(ARCH)-win$(if $(findstring arm,$(ARCH)),ce,32)
40 else
41 CFG = -unx
42 LIBS+=-lm
43 ifneq ($(CONFIG_ldl),no)
44 LIBS+=-ldl
45 endif
46 ifneq ($(CONFIG_pthread),no)
47 LIBS+=-lpthread
48 endif
49 # make libtcc as static or dynamic library?
50 ifeq ($(CONFIG_static),no)
51 LIBTCC=libtcc$(DLLSUF)
52 export LD_LIBRARY_PATH := $(CURDIR)/$(TOP)
53 ifneq ($(CONFIG_rpath),no)
54 ifndef CONFIG_OSX
55 LINK_LIBTCC += -Wl,-rpath,"$(libdir)"
56 else
57 # macOS doesn't support env-vars libdir out of the box - which we need for
58 # `make test' when libtcc.dylib is used (configure --disable-static), so
59 # we bake a relative path into the binary. $libdir is used after install.
60 LINK_LIBTCC += -Wl,-rpath,"@executable_path/$(TOP)" -Wl,-rpath,"$(libdir)"
61 # -current/compatibility_version must not contain letters.
62 MACOS_DYLIB_VERSION := $(firstword $(subst rc, ,$(VERSION)))
63 DYLIBVER += -current_version $(MACOS_DYLIB_VERSION)
64 DYLIBVER += -compatibility_version $(MACOS_DYLIB_VERSION)
65 endif
66 endif
67 endif
68 NATIVE_TARGET = $(ARCH)
69 ifdef CONFIG_OSX
70 NATIVE_TARGET = $(ARCH)-osx
71 ifneq ($(CC_NAME),tcc)
72 LDFLAGS += -flat_namespace -undefined warning
73 endif
74 export MACOSX_DEPLOYMENT_TARGET := 10.6
75 endif
76 -LTCC = -ltcc
77 endif
79 # run local version of tcc with local libraries and includes
80 TCCFLAGS-unx = -B$(TOP) -I$(TOPSRC)/include -I$(TOPSRC) -I$(TOP)
81 TCCFLAGS-win = -B$(TOPSRC)/win32 -I$(TOPSRC)/include -I$(TOPSRC) -I$(TOP) -L$(TOP)
82 TCCFLAGS = $(TCCFLAGS$(CFG))
83 TCC_LOCAL = $(TOP)/tcc$(EXESUF)
84 TCC = $(TCC_LOCAL) $(TCCFLAGS)
86 # run tests with the installed tcc instead
87 ifdef TESTINSTALL
88 TCC_LOCAL = $(bindir)/tcc
89 TCCFLAGS-unx = -I..
90 TCCFLAGS-win = -I.. -B$(bindir)
91 LIBTCC =
92 LIBS += $(-LTCC)
93 endif
95 CFLAGS_P = $(CFLAGS) -pg -static -DCONFIG_TCC_STATIC -DTCC_PROFILE
96 LIBS_P = $(LIBS)
97 LDFLAGS_P = $(LDFLAGS)
99 CONFIG_$(ARCH) = yes
100 NATIVE_DEFINES_$(CONFIG_i386) += -DTCC_TARGET_I386
101 NATIVE_DEFINES_$(CONFIG_x86_64) += -DTCC_TARGET_X86_64
102 NATIVE_DEFINES_$(CONFIG_WIN32) += -DTCC_TARGET_PE
103 NATIVE_DEFINES_$(CONFIG_OSX) += -DTCC_TARGET_MACHO
104 NATIVE_DEFINES_$(CONFIG_uClibc) += -DTCC_UCLIBC
105 NATIVE_DEFINES_$(CONFIG_musl) += -DTCC_MUSL
106 NATIVE_DEFINES_$(CONFIG_libgcc) += -DCONFIG_USE_LIBGCC
107 NATIVE_DEFINES_$(CONFIG_selinux) += -DHAVE_SELINUX
108 NATIVE_DEFINES_$(CONFIG_arm) += -DTCC_TARGET_ARM
109 NATIVE_DEFINES_$(CONFIG_arm_eabihf) += -DTCC_ARM_EABI -DTCC_ARM_HARDFLOAT
110 NATIVE_DEFINES_$(CONFIG_arm_eabi) += -DTCC_ARM_EABI
111 NATIVE_DEFINES_$(CONFIG_arm_vfp) += -DTCC_ARM_VFP
112 NATIVE_DEFINES_$(CONFIG_arm64) += -DTCC_TARGET_ARM64
113 NATIVE_DEFINES_$(CONFIG_riscv64) += -DTCC_TARGET_RISCV64
114 NATIVE_DEFINES_$(CONFIG_BSD) += -DTARGETOS_$(TARGETOS)
115 NATIVE_DEFINES_$(CONFIG_Android) += -DTARGETOS_ANDROID
116 NATIVE_DEFINES_$(CONFIG_pie) += -DCONFIG_TCC_PIE
117 NATIVE_DEFINES_$(CONFIG_pic) += -DCONFIG_TCC_PIC
118 NATIVE_DEFINES_no_$(CONFIG_new_macho) += -DCONFIG_NEW_MACHO=0
119 NATIVE_DEFINES_$(CONFIG_codesign) += -DCONFIG_CODESIGN
120 NATIVE_DEFINES_$(CONFIG_new-dtags) += -DCONFIG_NEW_DTAGS
121 NATIVE_DEFINES_no_$(CONFIG_bcheck) += -DCONFIG_TCC_BCHECK=0
122 NATIVE_DEFINES_no_$(CONFIG_backtrace) += -DCONFIG_TCC_BACKTRACE=0
123 NATIVE_DEFINES += $(NATIVE_DEFINES_yes) $(NATIVE_DEFINES_no_no)
125 DEF-i386 = -DTCC_TARGET_I386
126 DEF-i386-win32 = -DTCC_TARGET_I386 -DTCC_TARGET_PE
127 DEF-i386-OpenBSD = $(DEF-i386) -DTARGETOS_OpenBSD
128 DEF-x86_64 = -DTCC_TARGET_X86_64
129 DEF-x86_64-win32 = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE
130 DEF-x86_64-osx = -DTCC_TARGET_X86_64 -DTCC_TARGET_MACHO
131 DEF-arm-fpa = -DTCC_TARGET_ARM
132 DEF-arm-fpa-ld = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
133 DEF-arm-vfp = -DTCC_TARGET_ARM -DTCC_ARM_VFP
134 DEF-arm-eabi = -DTCC_TARGET_ARM -DTCC_ARM_VFP -DTCC_ARM_EABI
135 DEF-arm-eabihf = $(DEF-arm-eabi) -DTCC_ARM_HARDFLOAT
136 DEF-arm = $(DEF-arm-eabihf)
137 DEF-arm-NetBSD = $(DEF-arm-eabihf) -DTARGETOS_NetBSD
138 DEF-arm-wince = $(DEF-arm-eabihf) -DTCC_TARGET_PE
139 DEF-arm64 = -DTCC_TARGET_ARM64
140 DEF-arm64-osx = $(DEF-arm64) -DTCC_TARGET_MACHO
141 DEF-arm64-FreeBSD = $(DEF-arm64) -DTARGETOS_FreeBSD
142 DEF-arm64-NetBSD = $(DEF-arm64) -DTARGETOS_NetBSD
143 DEF-arm64-OpenBSD = $(DEF-arm64) -DTARGETOS_OpenBSD
144 DEF-riscv64 = -DTCC_TARGET_RISCV64
145 DEF-c67 = -DTCC_TARGET_C67 -w # disable warnigs
146 DEF-x86_64-FreeBSD = $(DEF-x86_64) -DTARGETOS_FreeBSD
147 DEF-x86_64-NetBSD = $(DEF-x86_64) -DTARGETOS_NetBSD
148 DEF-x86_64-OpenBSD = $(DEF-x86_64) -DTARGETOS_OpenBSD
150 DEF-$(NATIVE_TARGET) = $(NATIVE_DEFINES)
152 ifeq ($(INCLUDED),no)
153 # --------------------------------------------------------------------------
154 # running top Makefile
156 PROGS = tcc$(EXESUF)
157 TCCLIBS = $(LIBTCCDEF) $(LIBTCC) $(LIBTCC1)
158 TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
160 all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
162 # cross compiler targets to build
163 TCC_X = i386 x86_64 i386-win32 x86_64-win32 x86_64-osx arm arm64 arm-wince c67
164 TCC_X += riscv64 arm64-osx
165 # TCC_X += arm-fpa arm-fpa-ld arm-vfp arm-eabi
167 # cross libtcc1.a targets to build
168 LIBTCC1_X = $(filter-out c67,$(TCC_X))
170 PROGS_CROSS = $(foreach X,$(TCC_X),$X-tcc$(EXESUF))
171 LIBTCC1_CROSS = $(foreach X,$(LIBTCC1_X),$X-libtcc1.a)
173 # build cross compilers & libs
174 cross: $(LIBTCC1_CROSS) $(PROGS_CROSS)
176 # build specific cross compiler & lib
177 cross-%: %-tcc$(EXESUF) %-libtcc1.a ;
179 install: ; @$(MAKE) --no-print-directory install$(CFG)
180 install-strip: ; @$(MAKE) --no-print-directory install$(CFG) CONFIG_strip=yes
181 uninstall: ; @$(MAKE) --no-print-directory uninstall$(CFG)
183 ifdef CONFIG_cross
184 all : cross
185 endif
187 # --------------------------------------------
189 T = $(or $(CROSS_TARGET),$(NATIVE_TARGET),unknown)
190 X = $(if $(CROSS_TARGET),$(CROSS_TARGET)-)
192 DEFINES += $(DEF-$T) $(DEF-all)
193 DEFINES += $(if $(ROOT-$T),-DCONFIG_SYSROOT="\"$(ROOT-$T)\"")
194 DEFINES += $(if $(CRT-$T),-DCONFIG_TCC_CRTPREFIX="\"$(CRT-$T)\"")
195 DEFINES += $(if $(LIB-$T),-DCONFIG_TCC_LIBPATHS="\"$(LIB-$T)\"")
196 DEFINES += $(if $(INC-$T),-DCONFIG_TCC_SYSINCLUDEPATHS="\"$(INC-$T)\"")
197 DEFINES += $(if $(ELF-$T),-DCONFIG_TCC_ELFINTERP="\"$(ELF-$T)\"")
198 DEFINES += $(DEF-$(or $(findstring win,$T),unx))
200 ifneq ($(X),)
201 DEF-all += -DCONFIG_TCC_CROSSPREFIX="\"$X\""
202 ifneq ($(CONFIG_WIN32),yes)
203 DEF-win += -DCONFIG_TCCDIR="\"$(tccdir)/win32\""
204 endif
205 endif
207 # include custom configuration (see make help)
208 -include config-extra.mak
210 ifneq ($(T),$(NATIVE_TARGET))
211 # assume support files for cross-targets in "/usr/<triplet>" by default
212 TRIPLET-i386 ?= i686-linux-gnu
213 TRIPLET-x86_64 ?= x86_64-linux-gnu
214 TRIPLET-arm ?= arm-linux-gnueabi
215 TRIPLET-arm64 ?= aarch64-linux-gnu
216 TRIPLET-riscv64 ?= riscv64-linux-gnu
217 MARCH-i386 ?= i386-linux-gnu
218 MARCH-$T ?= $(TRIPLET-$T)
219 TR = $(if $(TRIPLET-$T),$T,ignored)
220 CRT-$(TR) ?= /usr/$(TRIPLET-$T)/lib
221 LIB-$(TR) ?= {B}:/usr/$(TRIPLET-$T)/lib:/usr/lib/$(MARCH-$T)
222 INC-$(TR) ?= {B}/include:/usr/$(TRIPLET-$T)/include:/usr/include
223 endif
225 CORE_FILES = tcc.c tcctools.c libtcc.c tccpp.c tccgen.c tccdbg.c tccelf.c tccasm.c tccrun.c
226 CORE_FILES += tcc.h config.h libtcc.h tcctok.h
227 i386_FILES = $(CORE_FILES) i386-gen.c i386-link.c i386-asm.c i386-asm.h i386-tok.h
228 i386-win32_FILES = $(i386_FILES) tccpe.c
229 x86_64_FILES = $(CORE_FILES) x86_64-gen.c x86_64-link.c i386-asm.c x86_64-asm.h
230 x86_64-win32_FILES = $(x86_64_FILES) tccpe.c
231 x86_64-osx_FILES = $(x86_64_FILES) tccmacho.c
232 arm_FILES = $(CORE_FILES) arm-gen.c arm-link.c arm-asm.c arm-tok.h
233 arm-wince_FILES = $(arm_FILES) tccpe.c
234 arm-eabihf_FILES = $(arm_FILES)
235 arm-fpa_FILES = $(arm_FILES)
236 arm-fpa-ld_FILES = $(arm_FILES)
237 arm-vfp_FILES = $(arm_FILES)
238 arm-eabi_FILES = $(arm_FILES)
239 arm-eabihf_FILES = $(arm_FILES)
240 arm64_FILES = $(CORE_FILES) arm64-gen.c arm64-link.c arm64-asm.c
241 arm64-osx_FILES = $(arm64_FILES) tccmacho.c
242 c67_FILES = $(CORE_FILES) c67-gen.c c67-link.c tcccoff.c
243 riscv64_FILES = $(CORE_FILES) riscv64-gen.c riscv64-link.c riscv64-asm.c
245 TCCDEFS_H$(subst yes,,$(CONFIG_predefs)) = tccdefs_.h
247 # libtcc sources
248 LIBTCC_SRC = $(filter-out tcc.c tcctools.c,$(filter %.c,$($T_FILES)))
250 ifeq ($(ONE_SOURCE),yes)
251 LIBTCC_OBJ = $(X)libtcc.o
252 LIBTCC_INC = $($T_FILES)
253 TCC_FILES = $(X)tcc.o
254 tcc.o : DEFINES += -DONE_SOURCE=0
255 $(X)tcc.o $(X)libtcc.o : $(TCCDEFS_H)
256 else
257 LIBTCC_OBJ = $(patsubst %.c,$(X)%.o,$(LIBTCC_SRC))
258 LIBTCC_INC = $(filter %.h %-gen.c %-link.c,$($T_FILES))
259 TCC_FILES = $(X)tcc.o $(LIBTCC_OBJ)
260 $(TCC_FILES) : DEFINES += -DONE_SOURCE=0
261 $(X)tccpp.o : $(TCCDEFS_H)
262 endif
264 GITHASH:=$(shell git rev-parse --abbrev-ref HEAD 2>/dev/null || echo no)
265 ifneq ($(GITHASH),no)
266 GITHASH:=$(shell git log -1 --date=short --pretty='format:%cd $(GITHASH)@%h')
267 GITMODF:=$(shell git diff --quiet || echo '*')
268 DEF_GITHASH:= -DTCC_GITHASH="\"$(GITHASH)$(GITMODF)\""
269 endif
271 ifeq ($(CONFIG_debug),yes)
272 CFLAGS += -g
273 LDFLAGS += -g
274 endif
276 # convert "include/tccdefs.h" to "tccdefs_.h"
277 %_.h : include/%.h conftest.c
278 $S$(CC) -DC2STR $(filter %.c,$^) -o c2str.exe && ./c2str.exe $< $@
280 # target specific object rule
281 $(X)%.o : %.c $(LIBTCC_INC)
282 $S$(CC) -o $@ -c $< $(DEFINES) $(CFLAGS)
284 # additional dependencies
285 $(X)tcc.o : tcctools.c
286 $(X)tcc.o : DEFINES += $(DEF_GITHASH)
288 # Host Tiny C Compiler
289 tcc$(EXESUF): tcc.o $(LIBTCC)
290 $S$(CC) -o $@ $^ $(LIBS) $(LDFLAGS) $(LINK_LIBTCC)
292 # Cross Tiny C Compilers
293 # (the TCCDEFS_H dependency is only necessary for parallel makes,
294 # ala 'make -j x86_64-tcc i386-tcc tcc', which would create multiple
295 # c2str.exe and tccdefs_.h files in parallel, leading to access errors.
296 # This forces it to be made only once. Make normally tracks multiple paths
297 # to the same goals and only remakes it once, but that doesn't work over
298 # sub-makes like in this target)
299 %-tcc$(EXESUF): $(TCCDEFS_H) FORCE
300 @$(MAKE) --no-print-directory $@ CROSS_TARGET=$* ONE_SOURCE=$(or $(ONE_SOURCE),yes)
302 $(CROSS_TARGET)-tcc$(EXESUF): $(TCC_FILES)
303 $S$(CC) -o $@ $^ $(LIBS) $(LDFLAGS)
305 # profiling version
306 tcc_p$(EXESUF): $($T_FILES)
307 $S$(CC) -o $@ $< $(DEFINES) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
309 # static libtcc library
310 libtcc.a: $(LIBTCC_OBJ)
311 $S$(AR) rcs $@ $^
313 # dynamic libtcc library
314 libtcc.so: $(LIBTCC_OBJ)
315 $S$(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LIBS) $(LDFLAGS)
317 libtcc.so: CFLAGS+=-fPIC
318 libtcc.so: LDFLAGS+=-fPIC
320 # OSX dynamic libtcc library
321 libtcc.dylib: $(LIBTCC_OBJ)
322 $S$(CC) -dynamiclib $(DYLIBVER) -install_name @rpath/$@ -o $@ $^ $(LDFLAGS)
324 # OSX libtcc.dylib (without rpath/ prefix)
325 libtcc.osx: $(LIBTCC_OBJ)
326 $S$(CC) -shared -install_name libtcc.dylib -o libtcc.dylib $^ $(LDFLAGS)
328 # windows dynamic libtcc library
329 libtcc.dll : $(LIBTCC_OBJ)
330 $S$(CC) -shared -o $@ $^ $(LDFLAGS)
331 libtcc.dll : DEFINES += -DLIBTCC_AS_DLL
333 # import file for windows libtcc.dll
334 libtcc.def : libtcc.dll tcc$(EXESUF)
335 $S$(XTCC) -impdef $< -o $@
336 XTCC ?= ./tcc$(EXESUF)
338 # TinyCC runtime libraries
339 libtcc1.a : tcc$(EXESUF) FORCE
340 @$(MAKE) -C lib
342 # Cross libtcc1.a
343 %-libtcc1.a : %-tcc$(EXESUF) FORCE
344 @$(MAKE) -C lib CROSS_TARGET=$*
346 .PRECIOUS: %-libtcc1.a
347 FORCE:
349 # WHICH = which $1 2>/dev/null
350 # some versions of gnu-make do not recognize 'command' as a shell builtin
351 WHICH = sh -c 'command -v $1'
353 run-if = $(if $(shell $(call WHICH,$1)),$S $1 $2)
354 S = $(if $(findstring yes,$(SILENT)),@$(info * $@))
356 # --------------------------------------------------------------------------
357 # documentation and man page
358 tcc-doc.html: tcc-doc.texi
359 $(call run-if,makeinfo,--no-split --html --number-sections -o $@ $<)
361 tcc-doc.info: tcc-doc.texi
362 $(call run-if,makeinfo,$< || true)
364 tcc.1 : tcc-doc.pod
365 $(call run-if,pod2man,--section=1 --center="Tiny C Compiler" \
366 --release="$(VERSION)" $< >$@)
367 %.pod : %.texi
368 $(call run-if,perl,$(TOPSRC)/texi2pod.pl $< $@)
370 doc : $(TCCDOCS)
372 # --------------------------------------------------------------------------
373 # install
375 INSTALL = install -m644
376 INSTALLBIN = install -m755 $(STRIP_$(CONFIG_strip))
377 STRIP_yes = -s
379 LIBTCC1_W = $(filter %-win32-libtcc1.a %-wince-libtcc1.a,$(LIBTCC1_CROSS))
380 LIBTCC1_U = $(filter-out $(LIBTCC1_W),$(wildcard *-libtcc1.a))
381 IB = $(if $1,$(IM) mkdir -p $2 && $(INSTALLBIN) $1 $2)
382 IBw = $(call IB,$(wildcard $1),$2)
383 IF = $(if $1,$(IM) mkdir -p $2 && $(INSTALL) $1 $2)
384 IFw = $(call IF,$(wildcard $1),$2)
385 IR = $(IM) mkdir -p $2 && cp -r $1/. $2
386 IM = @echo "-> $2 : $1" ;
387 BINCHECK = $(if $(wildcard $(PROGS) *-tcc$(EXESUF)),,@echo "Makefile: nothing found to install" && exit 1)
389 EXTRA_O = runmain.o bt-exe.o bt-dll.o bt-log.o bcheck.o
391 # install progs & libs
392 install-unx:
393 $(call BINCHECK)
394 $(call IBw,$(PROGS) *-tcc,"$(bindir)")
395 $(call IFw,$(LIBTCC1) $(EXTRA_O) $(LIBTCC1_U),"$(tccdir)")
396 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/include")
397 $(call $(if $(findstring .so,$(LIBTCC)),IBw,IFw),$(LIBTCC),"$(libdir)")
398 $(call IF,$(TOPSRC)/libtcc.h,"$(includedir)")
399 $(call IFw,tcc.1,"$(mandir)/man1")
400 $(call IFw,tcc-doc.info,"$(infodir)")
401 $(call IFw,tcc-doc.html,"$(docdir)")
402 ifneq "$(wildcard $(LIBTCC1_W))" ""
403 $(call IFw,$(TOPSRC)/win32/lib/*.def $(LIBTCC1_W),"$(tccdir)/win32/lib")
404 $(call IR,$(TOPSRC)/win32/include,"$(tccdir)/win32/include")
405 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/win32/include")
406 endif
408 # uninstall
409 uninstall-unx:
410 @rm -fv $(addprefix "$(bindir)/",$(PROGS) $(PROGS_CROSS))
411 @rm -fv $(addprefix "$(libdir)/", libtcc*.a libtcc*.so libtcc.dylib,$P)
412 @rm -fv $(addprefix "$(includedir)/", libtcc.h)
413 @rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
414 @rm -fv "$(docdir)/tcc-doc.html"
415 @rm -frv "$(tccdir)"
417 # install progs & libs on windows
418 install-win:
419 $(call BINCHECK)
420 $(call IBw,$(PROGS) *-tcc.exe libtcc.dll,"$(bindir)")
421 $(call IF,$(TOPSRC)/win32/lib/*.def,"$(tccdir)/lib")
422 $(call IFw,libtcc1.a $(EXTRA_O) $(LIBTCC1_W),"$(tccdir)/lib")
423 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/include")
424 $(call IR,$(TOPSRC)/win32/include,"$(tccdir)/include")
425 $(call IR,$(TOPSRC)/win32/examples,"$(tccdir)/examples")
426 $(call IF,$(TOPSRC)/tests/libtcc_test.c,"$(tccdir)/examples")
427 $(call IFw,$(TOPSRC)/libtcc.h libtcc.def libtcc.a,"$(libdir)")
428 $(call IFw,$(TOPSRC)/win32/tcc-win32.txt tcc-doc.html,"$(docdir)")
429 ifneq "$(wildcard $(LIBTCC1_U))" ""
430 $(call IFw,$(LIBTCC1_U),"$(tccdir)/lib")
431 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/lib/include")
432 endif
434 # uninstall on windows
435 uninstall-win:
436 @rm -fv $(foreach P,libtcc*.dll $(PROGS) *-tcc.exe,"$(bindir)"/$P)
437 @rm -fr $(foreach P,doc examples include lib libtcc,"$(tccdir)"/$P/*)
438 @rm -frv $(foreach P,doc examples include lib libtcc,"$(tccdir)"/$P)
440 # the msys-git shell works to configure && make except it does not have install
441 ifeq ($(OS),Windows_NT)
442 ifeq ($(shell $(call WHICH,install) || echo no),no)
443 INSTALL = cp
444 INSTALLBIN = cp
445 endif
446 endif
448 # --------------------------------------------------------------------------
449 # other stuff
451 TAGFILES = *.[ch] include/*.h lib/*.[chS]
452 tags : ; ctags $(TAGFILES)
453 # cannot have both tags and TAGS on windows
454 ETAGS : ; etags $(TAGFILES)
456 # create release tarball from *current* git branch (including tcc-doc.html
457 # and converting two files to CRLF)
458 TCC-VERSION = tcc-$(VERSION)
459 TCC-VERSION = tinycc-mob-$(shell git rev-parse --short=7 HEAD)
460 tar: tcc-doc.html
461 mkdir -p $(TCC-VERSION)
462 ( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
463 cp tcc-doc.html $(TCC-VERSION)
464 for f in tcc-win32.txt build-tcc.bat ; do \
465 cat win32/$$f | sed 's,\(.*\),\1\r,g' > $(TCC-VERSION)/win32/$$f ; \
466 done
467 tar cjf $(TCC-VERSION).tar.bz2 $(TCC-VERSION)
468 rm -rf $(TCC-VERSION)
469 git reset
471 config.mak:
472 $(if $(wildcard $@),,@echo "Please run ./configure." && exit 1)
474 # run all tests
475 test:
476 @$(MAKE) -C tests
477 # run test(s) from tests2 subdir (see make help)
478 tests2.%:
479 @$(MAKE) -C tests/tests2 $@
480 # run test(s) from testspp subdir (see make help)
481 testspp.%:
482 @$(MAKE) -C tests/pp $@
483 # run tests with code coverage
484 tcov-tes% : tcc_c$(EXESUF)
485 @rm -f $<.tcov
486 @$(MAKE) --no-print-directory TCC_LOCAL=$(CURDIR)/$< tes$*
487 tcc_c$(EXESUF): $($T_FILES)
488 $S$(TCC) tcc.c -o $@ -ftest-coverage $(DEFINES) $(LIBS)
489 # test the installed tcc instead
490 test-install: tccdefs_.h
491 @$(MAKE) -C tests TESTINSTALL=yes #_all
493 clean:
494 @rm -f tcc *-tcc tcc_p tcc_c
495 @rm -f tags ETAGS *.o *.a *.so* *.out *.log lib*.def *.exe *.dll
496 @rm -f a.out *.dylib *_.h *.pod *.tcov
497 @$(MAKE) -s -C lib $@
498 @$(MAKE) -s -C tests $@
500 distclean: clean
501 @rm -vf config.h config.mak config.texi
502 @rm -vf $(TCCDOCS)
504 .PHONY: all clean test tar tags ETAGS doc distclean install uninstall FORCE
506 help:
507 @echo "make"
508 @echo " build native compiler (from separate objects)"
509 @echo "make cross"
510 @echo " build cross compilers (from one source)"
511 @echo "make ONE_SOURCE=no/yes SILENT=no/yes"
512 @echo " force building from separate/one object(s), less/more silently"
513 @echo "make cross-TARGET"
514 @echo " build one specific cross compiler for 'TARGET'. Currently supported:"
515 @echo " $(wordlist 1,8,$(TCC_X))"
516 @echo " $(wordlist 9,99,$(TCC_X))"
517 @echo "make test"
518 @echo " run all tests"
519 @echo "make tests2.all / make tests2.37 / make tests2.37+"
520 @echo " run all/single test(s) from tests2, optionally update .expect"
521 @echo "make testspp.all / make testspp.17"
522 @echo " run all/single test(s) from tests/pp"
523 @echo "make tcov-test / tcov-tests2... / tcov-testspp..."
524 @echo " run tests as above with code coverage. After test(s) see tcc_c$(EXESUF).tcov"
525 @echo "make test-install"
526 @echo " run tests with the installed tcc"
527 @echo "Other supported make targets:"
528 @echo " install install-strip doc clean tags ETAGS tar distclean help"
529 @echo "Custom configuration:"
530 @echo " The makefile includes a file 'config-extra.mak' if it is present."
531 @echo " This file may contain some custom configuration. For example:"
532 @echo " NATIVE_DEFINES += -D..."
533 @echo " Or for example to configure the search paths for a cross-compiler"
534 @echo " assuming the support files in /usr/i686-linux-gnu:"
535 @echo " ROOT-i386 = /usr/i686-linux-gnu"
536 @echo " CRT-i386 = {R}/lib"
537 @echo " LIB-i386 = {B}:{R}/lib"
538 @echo " INC-i386 = {B}/include:{R}/include (*)"
539 @echo " DEF-i386 += -D__linux__"
540 @echo " Or also, for the cross platform files in /usr/<triplet>"
541 @echo " TRIPLET-i386 = i686-linux-gnu"
542 @echo " (*) tcc replaces {B} by 'tccdir' and {R} by 'CONFIG_SYSROOT'"
544 # --------------------------------------------------------------------------
545 endif # ($(INCLUDED),no)