tccpp: allow "0x1e+1" in asm
[tinycc.git] / Makefile
blob57d9bc4a8f5edf859cac9368a88e1aa99e0b698f
2 # Tiny C Compiler Makefile
5 TOP ?= .
6 include $(TOP)/config.mak
7 VPATH = $(TOPSRC)
8 CFLAGS += -I$(TOP)
10 ifeq (-$(findstring gcc,$(CC))-,-gcc-)
11 ifeq (-$(GCC_MAJOR)-$(findstring $(GCC_MINOR),56789)-,-4--)
12 CFLAGS += -D_FORTIFY_SOURCE=0
13 endif
14 else
15 ifeq (-$(findstring clang,$(CC))-,-clang-)
16 # make clang accept gnuisms in libtcc1.c
17 CFLAGS+=-fheinous-gnu-extensions
18 endif
19 endif
21 CFLAGS_P = $(CFLAGS) -pg -static -DCONFIG_TCC_STATIC
22 LIBS_P=
23 LDFLAGS_P = $(LDFLAGS)
25 LIBTCC = libtcc.a
26 LIBTCC1 = libtcc1.a
27 LINK_LIBTCC =
28 LIBS =
30 ifdef CONFIG_WIN32
31 ifeq ($(ARCH),x86-64)
32 CONFIG_WIN64=yes
33 endif
34 STRIP_BINARIES = yes
35 LIBTCC = libtcc.dll
36 else
37 LIBS=-lm
38 ifndef CONFIG_NOLDL
39 LIBS+=-ldl
40 endif
41 # make libtcc as static or dynamic library?
42 ifdef DISABLE_STATIC
43 LIBTCC=libtcc.so
44 ifndef DISABLE_RPATH
45 LINK_LIBTCC += -Wl,-rpath,"$(libdir)"
46 export LD_LIBRARY_PATH := $(CURDIR)/$(TOP)
47 endif
48 endif
49 endif
51 ifeq ($(TARGETOS),Darwin)
52 CFLAGS += -Wl,-flat_namespace,-undefined,warning
53 export MACOSX_DEPLOYMENT_TARGET:=10.2
54 endif
56 CONFIG_$(ARCH) = yes
57 NATIVE_DEFINES_$(CONFIG_i386) += -DTCC_TARGET_I386
58 NATIVE_DEFINES_$(CONFIG_x86-64) += -DTCC_TARGET_X86_64
59 NATIVE_DEFINES_$(CONFIG_WIN32) += -DTCC_TARGET_PE
60 NATIVE_DEFINES_$(CONFIG_uClibc) += -DTCC_UCLIBC
61 NATIVE_DEFINES_$(CONFIG_arm) += -DTCC_TARGET_ARM
62 NATIVE_DEFINES_$(CONFIG_arm_eabihf) += -DTCC_ARM_EABI -DTCC_ARM_HARDFLOAT
63 NATIVE_DEFINES_$(CONFIG_arm_eabi) += -DTCC_ARM_EABI
64 NATIVE_DEFINES_$(CONFIG_arm_vfp) += -DTCC_ARM_VFP
65 NATIVE_DEFINES_$(CONFIG_arm64) += -DTCC_TARGET_ARM64
66 NATIVE_DEFINES += $(NATIVE_DEFINES_yes)
68 ifeq ($(TOP),.)
70 PROGS=tcc$(EXESUF)
71 I386_CROSS = i386-tcc$(EXESUF)
72 WIN32_CROSS = i386-win32-tcc$(EXESUF)
73 WIN64_CROSS = x86_64-win32-tcc$(EXESUF)
74 WINCE_CROSS = arm-wince-tcc$(EXESUF)
75 X64_CROSS = x86_64-tcc$(EXESUF)
76 ARM_FPA_CROSS = arm-fpa-tcc$(EXESUF)
77 ARM_FPA_LD_CROSS = arm-fpa-ld-tcc$(EXESUF)
78 ARM_VFP_CROSS = arm-vfp-tcc$(EXESUF)
79 ARM_EABI_CROSS = arm-eabi-tcc$(EXESUF)
80 ARM_EABIHF_CROSS = arm-eabihf-tcc$(EXESUF)
81 ARM_CROSS = $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS)
82 ARM64_CROSS = arm64-tcc$(EXESUF)
83 C67_CROSS = c67-tcc$(EXESUF)
85 CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
86 CORE_FILES += tcc.h config.h libtcc.h tcctok.h
87 I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
88 WIN32_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h tccpe.c
89 WIN64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h tccpe.c
90 WINCE_FILES = $(CORE_FILES) arm-gen.c tccpe.c
91 X86_64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h
92 ARM_FILES = $(CORE_FILES) arm-gen.c
93 ARM64_FILES = $(CORE_FILES) arm64-gen.c
94 C67_FILES = $(CORE_FILES) c67-gen.c tcccoff.c
96 ifdef CONFIG_WIN64
97 PROGS+=tiny_impdef$(EXESUF)
98 NATIVE_FILES=$(WIN64_FILES)
99 PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
100 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a
102 else ifdef CONFIG_WIN32
103 PROGS+=tiny_impdef$(EXESUF)
104 NATIVE_FILES=$(WIN32_FILES)
105 PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
106 LIBTCC1_CROSS=lib/x86_64-win32/libtcc1.a
108 else ifeq ($(ARCH),i386)
109 NATIVE_FILES=$(I386_FILES)
110 PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
111 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a
113 else ifeq ($(ARCH),x86-64)
114 NATIVE_FILES=$(X86_64_FILES)
115 PROGS_CROSS=$(I386_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
116 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a
118 else ifeq ($(ARCH),arm)
119 NATIVE_FILES=$(ARM_FILES)
120 PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
122 else ifeq ($(ARCH),arm64)
123 NATIVE_FILES=$(ARM64_FILES)
124 PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) $(WINCE_CROSS)
125 endif
127 ifeq ($(TARGETOS),Darwin)
128 PROGS += tiny_libmaker$(EXESUF)
129 endif
131 TCCLIBS = $(LIBTCC1) $(LIBTCC)
132 TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
134 ifdef CONFIG_CROSS
135 PROGS += $(PROGS_CROSS)
136 TCCLIBS += $(LIBTCC1_CROSS)
137 endif
139 all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
141 # Host Tiny C Compiler
142 tcc$(EXESUF): tcc.c $(LIBTCC)
143 $(CC) -o $@ $^ $(LIBS) $(NATIVE_DEFINES) $(CFLAGS) $(LDFLAGS) $(LINK_LIBTCC)
145 # Cross Tiny C Compilers
146 %-tcc$(EXESUF): tcc.c
147 $(CC) -o $@ $< -DONE_SOURCE $(DEFINES) $(CFLAGS) $(LIBS) $(LDFLAGS)
149 # profiling version
150 tcc_p$(EXESUF): $(NATIVE_FILES)
151 $(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
153 $(I386_CROSS): DEFINES = -DTCC_TARGET_I386 \
154 -DCONFIG_TCCDIR="\"$(tccdir)/i386\""
155 $(X64_CROSS) : DEFINES = -DTCC_TARGET_X86_64
156 -DCONFIG_TCCDIR="\"$(tccdir)/x86_64\""
157 $(WIN32_CROSS) : DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
158 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
159 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
160 $(WIN64_CROSS) : DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
161 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
162 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
163 $(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
164 $(C67_CROSS): DEFINES = -DTCC_TARGET_C67 -w # disable warnigs
165 $(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
166 $(ARM_FPA_LD_CROSS)$(EXESUF): DEFINES = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
167 $(ARM_VFP_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_VFP
168 $(ARM_EABI_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_EABI -DTCC_ARM_VFP
169 $(ARM64_CROSS): DEFINES = -DTCC_TARGET_ARM64
171 $(I386_CROSS) : $(I386_FILES)
172 $(X64_CROSS) : $(X86_64_FILES)
173 $(WIN32_CROSS) : $(WIN32_FILES)
174 $(WIN64_CROSS) : $(WIN64_FILES)
175 $(WINCE_CROSS) : $(WINCE_FILES)
176 $(C67_CROSS) : $(C67_FILES)
177 $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS): $(ARM_FILES)
178 $(ARM64_CROSS): $(ARM64_FILES)
180 # libtcc generation and test
181 ifndef ONE_SOURCE
182 LIBTCC_OBJ = $(filter-out tcc.o,$(patsubst %.c,%.o,$(filter %.c,$(NATIVE_FILES))))
183 LIBTCC_INC = $(filter %.h,$(CORE_FILES)) $(filter-out $(CORE_FILES),$(NATIVE_FILES))
184 else
185 LIBTCC_OBJ = libtcc.o
186 LIBTCC_INC = $(NATIVE_FILES)
187 libtcc.o : NATIVE_DEFINES += -DONE_SOURCE
188 tcc.o : NATIVE_DEFINES += -DONE_SOURCE
189 endif
191 $(LIBTCC_OBJ) tcc.o : %.o : %.c $(LIBTCC_INC)
192 $(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CFLAGS)
194 libtcc.a: $(LIBTCC_OBJ)
195 $(AR) rcs $@ $^
197 libtcc.so: $(LIBTCC_OBJ)
198 $(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS)
200 libtcc.so: CFLAGS+=-fPIC
202 # windows : libtcc.dll
203 libtcc.dll : $(LIBTCC_OBJ) tiny_impdef$(EXESUF)
204 $(CC) -shared $(LIBTCC_OBJ) -o $@ $(LDFLAGS)
205 ./tiny_impdef $@
207 libtcc.dll : NATIVE_DEFINES += -DLIBTCC_AS_DLL
209 # windows : utilities
210 tiny_%$(EXESUF): $(TOPSRC)/win32/tools/tiny_%.c
211 $(CC) -o $@ $< $(CFLAGS) $(LDFLAGS) $(NATIVE_DEFINES)
213 ifneq ($(LIBTCC1),)
214 # TinyCC runtime libraries
215 $(LIBTCC1) : FORCE $(PROGS)
216 $(MAKE) -C lib native
217 endif
219 lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
220 $(MAKE) -C lib cross TARGET=$*
222 FORCE:
224 # install
225 TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h
226 INSTALL=install
228 ifdef STRIP_BINARIES
229 INSTALLBIN=$(INSTALL) -s
230 else
231 INSTALLBIN=$(INSTALL)
232 endif
234 install-strip: install
235 strip $(foreach PROG,$(PROGS),"$(bindir)"/$(PROG))
237 ifndef CONFIG_WIN32
238 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
239 mkdir -p "$(bindir)"
240 $(INSTALLBIN) -m755 $(PROGS) "$(bindir)"
241 mkdir -p "$(mandir)/man1"
242 -$(INSTALL) -m644 tcc.1 "$(mandir)/man1"
243 mkdir -p "$(infodir)"
244 -$(INSTALL) -m644 tcc-doc.info "$(infodir)"
245 mkdir -p "$(tccdir)"
246 mkdir -p "$(tccdir)/include"
247 ifneq ($(LIBTCC1),)
248 $(INSTALL) -m644 $(LIBTCC1) "$(tccdir)"
249 endif
250 $(INSTALL) -m644 $(addprefix $(TOPSRC)/include/,$(TCC_INCLUDES)) $(TOPSRC)/tcclib.h "$(tccdir)/include"
251 mkdir -p "$(libdir)"
252 $(INSTALL) -m644 $(LIBTCC) "$(libdir)"
253 mkdir -p "$(includedir)"
254 $(INSTALL) -m644 $(TOPSRC)/libtcc.h "$(includedir)"
255 mkdir -p "$(docdir)"
256 -$(INSTALL) -m644 tcc-doc.html "$(docdir)"
257 ifdef CONFIG_CROSS
258 mkdir -p "$(tccdir)/win32/lib/32"
259 mkdir -p "$(tccdir)/win32/lib/64"
260 $(INSTALL) -m644 $(TOPSRC)/win32/lib/*.def "$(tccdir)/win32/lib"
261 -$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/win32/lib/32"
262 -$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/win32/lib/64"
263 cp -r $(TOPSRC)/include/. "$(tccdir)/win32/include"
264 cp -r $(TOPSRC)/win32/include/. "$(tccdir)/win32/include"
265 endif
267 uninstall:
268 rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
269 rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
270 rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
271 rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
272 rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
273 rm -fv $(libdir)/libtcc.so*
274 rm -rv "$(tccdir)"
275 rm -rv "$(docdir)"
276 else
277 # on windows
278 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
279 mkdir -p "$(tccdir)"
280 mkdir -p "$(tccdir)/lib"
281 mkdir -p "$(tccdir)/include"
282 mkdir -p "$(tccdir)/examples"
283 mkdir -p "$(tccdir)/doc"
284 mkdir -p "$(tccdir)/libtcc"
285 $(INSTALLBIN) -m755 $(PROGS) $(LIBTCC) "$(tccdir)"
286 $(INSTALL) -m644 libtcc1.a $(TOPSRC)/win32/lib/*.def "$(tccdir)/lib"
287 cp -r $(TOPSRC)/win32/include/. "$(tccdir)/include"
288 cp -r $(TOPSRC)/win32/examples/. "$(tccdir)/examples"
289 cp $(TOPSRC)/tests/libtcc_test.c "$(tccdir)/examples"
290 $(INSTALL) -m644 $(addprefix $(TOPSRC)/include/,$(TCC_INCLUDES)) $(TOPSRC)/tcclib.h "$(tccdir)/include"
291 $(INSTALL) -m644 tcc-doc.html $(TOPSRC)/win32/tcc-win32.txt "$(tccdir)/doc"
292 $(INSTALL) -m644 $(TOPSRC)/libtcc.h libtcc.def "$(tccdir)/libtcc"
293 ifdef CONFIG_CROSS
294 mkdir -p "$(tccdir)/lib/32"
295 mkdir -p "$(tccdir)/lib/64"
296 -$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/lib/32"
297 -$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/lib/64"
298 endif
300 uninstall:
301 rm -rfv "$(tccdir)/"*
302 endif
304 # documentation and man page
305 tcc-doc.html: tcc-doc.texi
306 -makeinfo --no-split --html --number-sections -o $@ $<
308 tcc.1: tcc-doc.texi
309 -texi2pod.pl $< tcc.pod
310 -pod2man --section=1 --center="Tiny C Compiler" --release="$(VERSION)" tcc.pod > $@
312 tcc-doc.info: tcc-doc.texi
313 -makeinfo $<
315 # in tests subdir
316 test:
317 $(MAKE) -C tests
319 clean:
320 rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
321 lib*.def *.exe *.dll a.out tags TAGS libtcc_test$(EXESUF) tcc$(EXESUF)
322 $(MAKE) -C tests $@
323 $(MAKE) -C lib $@
325 distclean: clean
326 rm -vf config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html
328 config.mak:
329 @echo "Please run ./configure."
330 @exit 1
332 TAGFILES = *.[ch] include/*.h lib/*.[chS]
333 tags : ; ctags $(TAGFILES)
334 TAGS : ; etags $(TAGFILES)
336 # create release tarball from *current* git branch (including tcc-doc.html
337 # and converting two files to CRLF)
338 TCC-VERSION = $(VERSION)
339 tar: tcc-doc.html
340 mkdir $(TCC-VERSION)
341 ( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
342 cp tcc-doc.html $(TCC-VERSION)
343 for f in tcc-win32.txt build-tcc.bat ; do \
344 cat win32/$$f | sed 's,\(.*\),\1\r,g' > $(TCC-VERSION)/win32/$$f ; \
345 done
346 tar cjf $(TCC-VERSION).tar.bz2 $(TCC-VERSION)
347 rm -rf $(TCC-VERSION)
348 git reset
350 .PHONY: all clean test tar tags TAGS distclean install uninstall FORCE
352 endif # ifeq ($(TOP),.)