tccgen.c: cleanup debug support
[tinycc.git] / Makefile
blob83e99880bb3c8ad34e939e2af1d7ff57e97acf15
1 # --------------------------------------------------------------------------
3 # Tiny C Compiler Makefile
6 ifndef TOP
7 TOP = .
8 INCLUDED = no
9 endif
11 include $(TOP)/config.mak
13 ifeq (-$(CC)-$(GCC_MAJOR)-$(findstring $(GCC_MINOR),56789)-,-gcc-4--)
14 CFLAGS += -D_FORTIFY_SOURCE=0
15 endif
17 LIBTCC = libtcc.a
18 LIBTCC1 = libtcc1.a
19 LINK_LIBTCC =
20 LIBS =
21 CFLAGS += -I$(TOP)
22 CFLAGS += $(CPPFLAGS)
23 VPATH = $(TOPSRC)
25 ifdef CONFIG_WIN32
26 ifneq ($(CONFIG_static),yes)
27 LIBTCC = libtcc$(DLLSUF)
28 LIBTCCDEF = libtcc.def
29 endif
30 CFGWIN = -win
31 NATIVE_TARGET = $(ARCH)-win$(if $(findstring arm,$(ARCH)),ce,32)
32 else
33 LIBS=-lm -lpthread
34 ifneq ($(CONFIG_ldl),no)
35 LIBS+=-ldl
36 endif
37 # make libtcc as static or dynamic library?
38 ifeq ($(CONFIG_static),no)
39 LIBTCC=libtcc$(DLLSUF)
40 export LD_LIBRARY_PATH := $(CURDIR)/$(TOP)
41 ifneq ($(CONFIG_rpath),no)
42 LINK_LIBTCC += -Wl,-rpath,"$(libdir)"
43 endif
44 endif
45 CFGWIN =-unx
46 NATIVE_TARGET = $(ARCH)
47 ifdef CONFIG_OSX
48 NATIVE_TARGET = $(ARCH)-osx
49 LDFLAGS += -flat_namespace -undefined warning
50 export MACOSX_DEPLOYMENT_TARGET := 10.4
51 endif
52 endif
54 # run local version of tcc with local libraries and includes
55 TCCFLAGS-unx = -B$(TOP) -I$(TOPSRC)/include -I$(TOPSRC) -I$(TOP)
56 TCCFLAGS-win = -B$(TOPSRC)/win32 -I$(TOPSRC)/include -I$(TOPSRC) -I$(TOP) -L$(TOP)
57 TCCFLAGS = $(TCCFLAGS$(CFGWIN))
58 TCC = $(TOP)/tcc$(EXESUF) $(TCCFLAGS)
59 ifdef CONFIG_OSX
60 TCCFLAGS += -D_ANSI_SOURCE
61 endif
63 CFLAGS_P = $(CFLAGS) -pg -static -DCONFIG_TCC_STATIC -DTCC_PROFILE
64 LIBS_P = $(LIBS)
65 LDFLAGS_P = $(LDFLAGS)
67 CONFIG_$(ARCH) = yes
68 NATIVE_DEFINES_$(CONFIG_i386) += -DTCC_TARGET_I386
69 NATIVE_DEFINES_$(CONFIG_x86_64) += -DTCC_TARGET_X86_64
70 NATIVE_DEFINES_$(CONFIG_WIN32) += -DTCC_TARGET_PE
71 NATIVE_DEFINES_$(CONFIG_OSX) += -DTCC_TARGET_MACHO
72 NATIVE_DEFINES_$(CONFIG_uClibc) += -DTCC_UCLIBC
73 NATIVE_DEFINES_$(CONFIG_musl) += -DTCC_MUSL
74 NATIVE_DEFINES_$(CONFIG_libgcc) += -DCONFIG_USE_LIBGCC
75 NATIVE_DEFINES_$(CONFIG_selinux) += -DHAVE_SELINUX
76 NATIVE_DEFINES_$(CONFIG_arm) += -DTCC_TARGET_ARM
77 NATIVE_DEFINES_$(CONFIG_arm_eabihf) += -DTCC_ARM_EABI -DTCC_ARM_HARDFLOAT
78 NATIVE_DEFINES_$(CONFIG_arm_eabi) += -DTCC_ARM_EABI
79 NATIVE_DEFINES_$(CONFIG_arm_vfp) += -DTCC_ARM_VFP
80 NATIVE_DEFINES_$(CONFIG_arm64) += -DTCC_TARGET_ARM64
81 NATIVE_DEFINES_$(CONFIG_riscv64) += -DTCC_TARGET_RISCV64
82 NATIVE_DEFINES += $(NATIVE_DEFINES_yes)
84 ifeq ($(INCLUDED),no)
85 # --------------------------------------------------------------------------
86 # running top Makefile
88 PROGS = tcc$(EXESUF)
89 TCCLIBS = $(LIBTCC1) $(LIBTCC) $(LIBTCCDEF)
90 TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
92 all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
94 # cross compiler targets to build
95 TCC_X = i386 x86_64 i386-win32 x86_64-win32 x86_64-osx arm arm64 arm-wince c67
96 TCC_X += riscv64
97 # TCC_X += arm-fpa arm-fpa-ld arm-vfp arm-eabi
99 # cross libtcc1.a targets to build
100 LIBTCC1_X = i386 x86_64 i386-win32 x86_64-win32 x86_64-osx arm arm64 arm-wince
101 LIBTCC1_X += riscv64
103 PROGS_CROSS = $(foreach X,$(TCC_X),$X-tcc$(EXESUF))
104 LIBTCC1_CROSS = $(foreach X,$(LIBTCC1_X),$X-libtcc1.a)
106 # build cross compilers & libs
107 cross: $(LIBTCC1_CROSS) $(PROGS_CROSS)
109 # build specific cross compiler & lib
110 cross-%: %-tcc$(EXESUF) %-libtcc1.a ;
112 install: ; @$(MAKE) --no-print-directory install$(CFGWIN)
113 install-strip: ; @$(MAKE) --no-print-directory install$(CFGWIN) CONFIG_strip=yes
114 uninstall: ; @$(MAKE) --no-print-directory uninstall$(CFGWIN)
116 ifdef CONFIG_cross
117 all : cross
118 endif
120 # --------------------------------------------
122 T = $(or $(CROSS_TARGET),$(NATIVE_TARGET),unknown)
123 X = $(if $(CROSS_TARGET),$(CROSS_TARGET)-)
125 DEF-i386 = -DTCC_TARGET_I386
126 DEF-x86_64 = -DTCC_TARGET_X86_64
127 DEF-i386-win32 = -DTCC_TARGET_PE -DTCC_TARGET_I386
128 DEF-x86_64-win32= -DTCC_TARGET_PE -DTCC_TARGET_X86_64
129 DEF-x86_64-osx = -DTCC_TARGET_MACHO -DTCC_TARGET_X86_64
130 DEF-arm-wince = -DTCC_TARGET_PE -DTCC_TARGET_ARM -DTCC_ARM_EABI -DTCC_ARM_VFP -DTCC_ARM_HARDFLOAT
131 DEF-arm64 = -DTCC_TARGET_ARM64 -Wno-format
132 DEF-c67 = -DTCC_TARGET_C67 -w # disable warnigs
133 DEF-arm-fpa = -DTCC_TARGET_ARM
134 DEF-arm-fpa-ld = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
135 DEF-arm-vfp = -DTCC_TARGET_ARM -DTCC_ARM_VFP
136 DEF-arm-eabi = -DTCC_TARGET_ARM -DTCC_ARM_VFP -DTCC_ARM_EABI
137 DEF-arm-eabihf = -DTCC_TARGET_ARM -DTCC_ARM_VFP -DTCC_ARM_EABI -DTCC_ARM_HARDFLOAT
138 DEF-arm = $(DEF-arm-eabihf)
139 DEF-riscv64 = -DTCC_TARGET_RISCV64
140 DEF-$(NATIVE_TARGET) = $(NATIVE_DEFINES)
142 DEFINES += $(DEF-$T) $(DEF-all)
143 DEFINES += $(if $(ROOT-$T),-DCONFIG_SYSROOT="\"$(ROOT-$T)\"")
144 DEFINES += $(if $(CRT-$T),-DCONFIG_TCC_CRTPREFIX="\"$(CRT-$T)\"")
145 DEFINES += $(if $(LIB-$T),-DCONFIG_TCC_LIBPATHS="\"$(LIB-$T)\"")
146 DEFINES += $(if $(INC-$T),-DCONFIG_TCC_SYSINCLUDEPATHS="\"$(INC-$T)\"")
147 DEFINES += $(DEF-$(or $(findstring win,$T),unx))
149 ifneq ($(X),)
150 ifeq ($(CONFIG_WIN32),yes)
151 DEF-win += -DTCC_LIBTCC1="\"$(X)libtcc1.a\""
152 DEF-unx += -DTCC_LIBTCC1="\"lib/$(X)libtcc1.a\""
153 else
154 DEF-all += -DTCC_LIBTCC1="\"$(X)libtcc1.a\""
155 DEF-win += -DCONFIG_TCCDIR="\"$(tccdir)/win32\""
156 endif
157 endif
159 # include custom configuration (see make help)
160 -include config-extra.mak
162 CORE_FILES = tcc.c tcctools.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
163 CORE_FILES += tcc.h config.h libtcc.h tcctok.h
164 i386_FILES = $(CORE_FILES) i386-gen.c i386-link.c i386-asm.c i386-asm.h i386-tok.h
165 i386-win32_FILES = $(i386_FILES) tccpe.c
166 x86_64_FILES = $(CORE_FILES) x86_64-gen.c x86_64-link.c i386-asm.c x86_64-asm.h
167 x86_64-win32_FILES = $(x86_64_FILES) tccpe.c
168 x86_64-osx_FILES = $(x86_64_FILES)
169 arm_FILES = $(CORE_FILES) arm-gen.c arm-link.c arm-asm.c
170 arm-wince_FILES = $(arm_FILES) tccpe.c
171 arm-eabihf_FILES = $(arm_FILES)
172 arm-fpa_FILES = $(arm_FILES)
173 arm-fpa-ld_FILES = $(arm_FILES)
174 arm-vfp_FILES = $(arm_FILES)
175 arm-eabi_FILES = $(arm_FILES)
176 arm-eabihf_FILES = $(arm_FILES)
177 arm64_FILES = $(CORE_FILES) arm64-gen.c arm64-link.c
178 c67_FILES = $(CORE_FILES) c67-gen.c c67-link.c tcccoff.c
179 riscv64_FILES = $(CORE_FILES) riscv64-gen.c riscv64-link.c
181 # libtcc sources
182 LIBTCC_SRC = $(filter-out tcc.c tcctools.c,$(filter %.c,$($T_FILES)))
184 ifeq ($(ONE_SOURCE),yes)
185 LIBTCC_OBJ = $(X)libtcc.o
186 LIBTCC_INC = $($T_FILES)
187 TCC_FILES = $(X)tcc.o
188 tcc.o : DEFINES += -DONE_SOURCE=0
189 else
190 LIBTCC_OBJ = $(patsubst %.c,$(X)%.o,$(LIBTCC_SRC))
191 LIBTCC_INC = $(filter %.h %-gen.c %-link.c,$($T_FILES))
192 TCC_FILES = $(X)tcc.o $(LIBTCC_OBJ)
193 $(TCC_FILES) : DEFINES += -DONE_SOURCE=0
194 endif
196 # target specific object rule
197 $(X)%.o : %.c $(LIBTCC_INC)
198 $(CC) -o $@ -c $< $(DEFINES) $(CFLAGS)
200 # additional dependencies
201 $(X)tcc.o : tcctools.c
203 # Host Tiny C Compiler
204 tcc$(EXESUF): tcc.o $(LIBTCC)
205 $(CC) -o $@ $^ $(LIBS) $(LDFLAGS) $(LINK_LIBTCC)
207 # Cross Tiny C Compilers
208 %-tcc$(EXESUF): FORCE
209 @$(MAKE) --no-print-directory $@ CROSS_TARGET=$* ONE_SOURCE=$(or $(ONE_SOURCE),yes)
211 $(CROSS_TARGET)-tcc$(EXESUF): $(TCC_FILES)
212 $(CC) -o $@ $^ $(LIBS) $(LDFLAGS)
214 # profiling version
215 tcc_p$(EXESUF): $($T_FILES)
216 $(CC) -o $@ $< $(DEFINES) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
218 # static libtcc library
219 libtcc.a: $(LIBTCC_OBJ)
220 $(AR) rcs $@ $^
222 # dynamic libtcc library
223 libtcc.so: $(LIBTCC_OBJ)
224 $(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS)
226 libtcc.so: CFLAGS+=-fPIC
227 libtcc.so: LDFLAGS+=-fPIC
229 libtcc.dylib: $(LIBTCC_OBJ)
230 $(CC) -shared -o libtcc.dylib libtcc.o tccpp.o tccgen.o tccelf.o tccasm.o tccrun.o x86_64-gen.o x86_64-link.o i386-asm.o -flat_namespace
232 # windows dynamic libtcc library
233 libtcc.dll : $(LIBTCC_OBJ)
234 $(CC) -shared -o $@ $^ $(LDFLAGS)
235 libtcc.dll : DEFINES += -DLIBTCC_AS_DLL
237 # import file for windows libtcc.dll
238 libtcc.def : libtcc.dll tcc$(EXESUF)
239 $(XTCC) -impdef $< -o $@
240 XTCC ?= ./tcc$(EXESUF)
242 # TinyCC runtime libraries
243 libtcc1.a : tcc$(EXESUF) FORCE
244 @$(MAKE) -C lib
246 # Cross libtcc1.a
247 %-libtcc1.a : %-tcc$(EXESUF) FORCE
248 @$(MAKE) -C lib CROSS_TARGET=$*
250 .PRECIOUS: %-libtcc1.a
251 FORCE:
253 # --------------------------------------------------------------------------
254 # documentation and man page
255 tcc-doc.html: tcc-doc.texi
256 makeinfo --no-split --html --number-sections -o $@ $< || true
258 tcc.1: tcc-doc.texi
259 $(TOPSRC)/texi2pod.pl $< tcc.pod \
260 && pod2man --section=1 --center="Tiny C Compiler" --release="$(VERSION)" tcc.pod >tmp.1 \
261 && mv tmp.1 $@ || rm -f tmp.1
263 tcc-doc.info: tcc-doc.texi
264 makeinfo $< || true
266 # --------------------------------------------------------------------------
267 # install
269 INSTALL = install -m644
270 INSTALLBIN = install -m755 $(STRIP_$(CONFIG_strip))
271 STRIP_yes = -s
273 LIBTCC1_W = $(filter %-win32-libtcc1.a %-wince-libtcc1.a,$(LIBTCC1_CROSS))
274 LIBTCC1_U = $(filter-out $(LIBTCC1_W),$(LIBTCC1_CROSS))
275 IB = $(if $1,mkdir -p $2 && $(INSTALLBIN) $1 $2)
276 IBw = $(call IB,$(wildcard $1),$2)
277 IF = $(if $1,mkdir -p $2 && $(INSTALL) $1 $2)
278 IFw = $(call IF,$(wildcard $1),$2)
279 IR = mkdir -p $2 && cp -r $1/. $2
280 B_O = bcheck.o bt-exe.o bt-log.o bt-dll.o
282 # install progs & libs
283 install-unx:
284 $(call IBw,$(PROGS) $(PROGS_CROSS),"$(bindir)")
285 $(call IFw,$(LIBTCC1) $(B_O) $(LIBTCC1_U),"$(tccdir)")
286 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/include")
287 $(call $(if $(findstring .so,$(LIBTCC)),IBw,IFw),$(LIBTCC),"$(libdir)")
288 $(call IF,$(TOPSRC)/libtcc.h,"$(includedir)")
289 $(call IFw,tcc.1,"$(mandir)/man1")
290 $(call IFw,tcc-doc.info,"$(infodir)")
291 $(call IFw,tcc-doc.html,"$(docdir)")
292 ifneq "$(wildcard $(LIBTCC1_W))" ""
293 $(call IFw,$(TOPSRC)/win32/lib/*.def $(LIBTCC1_W),"$(tccdir)/win32/lib")
294 $(call IR,$(TOPSRC)/win32/include,"$(tccdir)/win32/include")
295 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/win32/include")
296 endif
298 # uninstall
299 uninstall-unx:
300 @rm -fv $(foreach P,$(PROGS) $(PROGS_CROSS),"$(bindir)/$P")
301 @rm -fv "$(libdir)/libtcc.a" "$(libdir)/libtcc.so" "$(includedir)/libtcc.h"
302 @rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
303 @rm -fv "$(docdir)/tcc-doc.html"
304 rm -r "$(tccdir)"
306 # install progs & libs on windows
307 install-win:
308 $(call IBw,$(PROGS) $(PROGS_CROSS) $(subst libtcc.a,,$(LIBTCC)),"$(bindir)")
309 $(call IF,$(TOPSRC)/win32/lib/*.def,"$(tccdir)/lib")
310 $(call IFw,libtcc1.a $(B_O) $(LIBTCC1_W),"$(tccdir)/lib")
311 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/include")
312 $(call IR,$(TOPSRC)/win32/include,"$(tccdir)/include")
313 $(call IR,$(TOPSRC)/win32/examples,"$(tccdir)/examples")
314 $(call IF,$(TOPSRC)/tests/libtcc_test.c,"$(tccdir)/examples")
315 $(call IFw,$(TOPSRC)/libtcc.h $(subst .dll,.def,$(LIBTCC)),"$(libdir)")
316 $(call IFw,$(TOPSRC)/win32/tcc-win32.txt tcc-doc.html,"$(docdir)")
317 ifneq "$(wildcard $(LIBTCC1_U))" ""
318 $(call IFw,$(LIBTCC1_U),"$(tccdir)/lib")
319 $(call IF,$(TOPSRC)/include/*.h $(TOPSRC)/tcclib.h,"$(tccdir)/lib/include")
320 endif
322 # the msys-git shell works to configure && make except it does not have install
323 ifeq "$(and $(CONFIG_WIN32),$(shell which install >/dev/null 2>&1 || echo no))" "no"
324 install-win : INSTALL = cp
325 install-win : INSTALLBIN = cp
326 endif
328 # uninstall on windows
329 uninstall-win:
330 @rm -fv $(foreach P,$(PROGS) $(PROGS_CROSS) libtcc.dll,"$(bindir)/$P")
331 @rm -fv $(foreach F,tcc-doc.html tcc-win32.txt,"$(docdir)/$F")
332 @rm -fv $(foreach F,libtcc.h libtcc.def libtcc.a,"$(libdir)/$F")
333 rm -r "$(tccdir)"
335 # --------------------------------------------------------------------------
336 # other stuff
338 TAGFILES = *.[ch] include/*.h lib/*.[chS]
339 tags : ; ctags $(TAGFILES)
340 # cannot have both tags and TAGS on windows
341 ETAGS : ; etags $(TAGFILES)
343 # create release tarball from *current* git branch (including tcc-doc.html
344 # and converting two files to CRLF)
345 TCC-VERSION = tcc-$(VERSION)
346 tar: tcc-doc.html
347 mkdir $(TCC-VERSION)
348 ( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
349 cp tcc-doc.html $(TCC-VERSION)
350 for f in tcc-win32.txt build-tcc.bat ; do \
351 cat win32/$$f | sed 's,\(.*\),\1\r,g' > $(TCC-VERSION)/win32/$$f ; \
352 done
353 tar cjf $(TCC-VERSION).tar.bz2 $(TCC-VERSION)
354 rm -rf $(TCC-VERSION)
355 git reset
357 config.mak:
358 $(if $(wildcard $@),,@echo "Please run ./configure." && exit 1)
360 # run all tests
361 test:
362 $(MAKE) -C tests
363 # run test(s) from tests2 subdir (see make help)
364 tests2.%:
365 $(MAKE) -C tests/tests2 $@
367 testspp.%:
368 $(MAKE) -C tests/pp $@
370 clean:
371 rm -f tcc$(EXESUF) tcc_p$(EXESUF) *-tcc$(EXESUF) tcc.pod
372 rm -f *~ *.o *.a *.so* *.out *.log lib*.def *.exe *.dll a.out tags TAGS *.dylib
373 @$(MAKE) -C lib $@
374 @$(MAKE) -C tests $@
376 distclean: clean
377 rm -f config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html
379 .PHONY: all clean test tar tags ETAGS distclean install uninstall FORCE
381 help:
382 @echo "make"
383 @echo " build native compiler (from separate objects)"
384 @echo ""
385 @echo "make cross"
386 @echo " build cross compilers (from one source)"
387 @echo ""
388 @echo "make ONE_SOURCE=yes / no"
389 @echo " force building from one source / separate objects"
390 @echo ""
391 @echo "make cross-TARGET"
392 @echo " build one specific cross compiler for 'TARGET', as in"
393 @echo " $(TCC_X)"
394 @echo ""
395 @echo "Custom configuration:"
396 @echo " The makefile includes a file 'config-extra.mak' if it is present."
397 @echo " This file may contain some custom configuration. For example:"
398 @echo ""
399 @echo " NATIVE_DEFINES += -D..."
400 @echo ""
401 @echo " Or for example to configure the search paths for a cross-compiler"
402 @echo " that expects the linux files in <tccdir>/i386-linux:"
403 @echo ""
404 @echo " ROOT-i386 = {B}/i386-linux"
405 @echo " CRT-i386 = {B}/i386-linux/usr/lib"
406 @echo " LIB-i386 = {B}/i386-linux/lib:{B}/i386-linux/usr/lib"
407 @echo " INC-i386 = {B}/lib/include:{B}/i386-linux/usr/include"
408 @echo " DEF-i386 += -D__linux__"
409 @echo ""
410 @echo "make test"
411 @echo " run all tests"
412 @echo ""
413 @echo "make tests2.all / make tests2.37 / make tests2.37+"
414 @echo " run all/single test(s) from tests2, optionally update .expect"
415 @echo "make testspp.all / make testspp.17"
416 @echo " run all/single test(s) from tests/pp"
417 @echo ""
418 @echo "Other supported make targets:"
419 @echo " install install-strip tags ETAGS tar clean distclean help"
420 @echo ""
422 # --------------------------------------------------------------------------
423 endif # ($(INCLUDED),no)