x86-64: Fix call saved register restore
[tinycc.git] / Makefile
blob10e1cd4ca3cf0ac98de8273593cb7311bffc9bb4
2 # Tiny C Compiler Makefile
5 TOP ?= .
6 include $(TOP)/config.mak
8 CFLAGS_P=$(CFLAGS) -pg -static -DCONFIG_TCC_STATIC
9 LIBS_P=
11 ifneq ($(GCC_MAJOR),2)
12 CFLAGS+=-fno-strict-aliasing
13 ifneq ($(GCC_MAJOR),3)
14 CFLAGS+=-Wno-pointer-sign -Wno-sign-compare -D_FORTIFY_SOURCE=0
15 endif
16 endif
18 ifeq ($(ARCH),i386)
19 CFLAGS+=-mpreferred-stack-boundary=2
20 ifeq ($(GCC_MAJOR),2)
21 CFLAGS+=-m386 -malign-functions=0
22 else
23 CFLAGS+=-march=i386 -falign-functions=0
24 endif
25 endif
27 ifdef CONFIG_WIN64
28 CONFIG_WIN32=yes
29 endif
31 ifndef CONFIG_WIN32
32 LIBS=-lm
33 ifndef CONFIG_NOLDL
34 LIBS+=-ldl
35 endif
36 endif
38 ifeq ($(ARCH),i386)
39 NATIVE_DEFINES=-DTCC_TARGET_I386
40 NATIVE_DEFINES+=$(if $(wildcard /lib/i386-linux-gnu),-DCONFIG_MULTIARCHDIR=\"i386-linux-gnu\")
41 CFLAGS+=-m32
42 else
43 ifeq ($(ARCH),x86-64)
44 NATIVE_DEFINES=-DTCC_TARGET_X86_64
45 CFLAGS+=-m64
46 NATIVE_DEFINES+=$(if $(wildcard /usr/lib64),-DCONFIG_LDDIR=\"lib64\")
47 NATIVE_DEFINES+=$(if $(wildcard /lib/x86_64-linux-gnu),-DCONFIG_MULTIARCHDIR=\"x86_64-linux-gnu\")
48 endif
49 endif
51 ifeq ($(ARCH),arm)
52 NATIVE_DEFINES=-DTCC_TARGET_ARM
53 NATIVE_DEFINES+=-DWITHOUT_LIBTCC
54 NATIVE_DEFINES+=$(if $(wildcard /lib/ld-linux.so.3),-DTCC_ARM_EABI)
55 NATIVE_DEFINES+=$(if $(wildcard /lib/arm-linux-gnueabi),-DCONFIG_MULTIARCHDIR=\"arm-linux-gnueabi\")
56 NATIVE_DEFINES+=$(if $(shell grep -l "^Features.* \(vfp\|iwmmxt\) " /proc/cpuinfo),-DTCC_ARM_VFP)
57 # To use ARM hardfloat calling convension
58 #NATIVE_DEFINES+=-DTCC_ARM_HARDFLOAT
59 endif
61 ifdef CONFIG_WIN32
62 NATIVE_DEFINES+=-DTCC_TARGET_PE
63 endif
65 ifneq ($(wildcard /lib/ld-uClibc.so.0),)
66 NATIVE_DEFINES+=-DTCC_UCLIBC
67 CONFIG_UCLIBC = 1
68 endif
70 # make libtcc as static or dynamic library?
71 ifdef DISABLE_STATIC
72 LIBTCC=libtcc.so.1.0
73 LINK_LIBTCC=-Wl,-rpath,"$(libdir)"
74 ifdef DISABLE_RPATH
75 LINK_LIBTCC=
76 endif
77 else
78 LIBTCC=libtcc.a
79 LINK_LIBTCC=
80 endif
82 ifeq ($(TOP),.)
84 PROGS=tcc$(EXESUF)
85 I386_CROSS = i386-tcc$(EXESUF)
86 WIN32_CROSS = i386-win32-tcc$(EXESUF)
87 WIN64_CROSS = x86_64-win32-tcc$(EXESUF)
88 WINCE_CROSS = arm-win32-tcc$(EXESUF)
89 X64_CROSS = x86_64-tcc$(EXESUF)
90 ARM_FPA_CROSS = arm-fpa-tcc$(EXESUF)
91 ARM_FPA_LD_CROSS = arm-fpa-ld-tcc$(EXESUF)
92 ARM_VFP_CROSS = arm-vfp-tcc$(EXESUF)
93 ARM_EABI_CROSS = arm-eabi-tcc$(EXESUF)
94 ARM_CROSS = $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS)
95 C67_CROSS = c67-tcc$(EXESUF)
97 CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
98 CORE_FILES += tcc.h config.h libtcc.h tcctok.h
99 I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
100 WIN32_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h tccpe.c
101 WIN64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h tccpe.c
102 WINCE_FILES = $(CORE_FILES) arm-gen.c tccpe.c
103 X86_64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h
104 ARM_FILES = $(CORE_FILES) arm-gen.c
105 C67_FILES = $(CORE_FILES) c67-gen.c tcccoff.c
107 ifdef CONFIG_WIN64
108 PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF)
109 NATIVE_FILES=$(WIN64_FILES)
110 PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(C67_CROSS)
111 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a
112 LIBTCC1=libtcc1.a
113 else
114 ifdef CONFIG_WIN32
115 PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF)
116 NATIVE_FILES=$(WIN32_FILES)
117 PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(C67_CROSS)
118 LIBTCC1_CROSS=lib/x86_64-win32/libtcc1.a
119 LIBTCC1=libtcc1.a
120 else
121 ifeq ($(ARCH),i386)
122 NATIVE_FILES=$(I386_FILES)
123 PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS)
124 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a
125 LIBTCC1=libtcc1.a
126 BCHECK_O=bcheck.o
127 else
128 ifeq ($(ARCH),x86-64)
129 NATIVE_FILES=$(X86_64_FILES)
130 PROGS_CROSS=$(I386_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS)
131 LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a lib/i386/libtcc1.a
132 LIBTCC1=libtcc1.a
133 else
134 ifeq ($(ARCH),arm)
135 NATIVE_FILES=$(ARM_FILES)
136 PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(C67_CROSS)
137 endif
138 endif
139 endif
140 endif
141 endif
143 ifdef CONFIG_UCLIBC
144 BCHECK_O=
145 endif
146 ifeq ($(TARGETOS),Darwin)
147 BCHECK_O=
148 PROGS+=tiny_libmaker$(EXESUF)
149 endif
151 ifdef CONFIG_USE_LIBGCC
152 LIBTCC1=
153 endif
155 TCCLIBS = $(LIBTCC1) $(LIBTCC) $(BCHECK_O)
156 TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
158 ifdef CONFIG_CROSS
159 PROGS+=$(PROGS_CROSS)
160 TCCLIBS+=$(LIBTCC1_CROSS)
161 endif
163 all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
165 # Host Tiny C Compiler
166 tcc$(EXESUF): tcc.o $(LIBTCC)
167 $(CC) -o $@ $^ $(LIBS) $(CFLAGS) $(LDFLAGS) $(LINK_LIBTCC)
169 # Cross Tiny C Compilers
170 %-tcc$(EXESUF):
171 $(CC) -o $@ tcc.c -DONE_SOURCE $(DEFINES) $(CFLAGS) $(LIBS) $(LDFLAGS)
173 $(I386_CROSS): DEFINES = -DTCC_TARGET_I386 \
174 -DCONFIG_TCCDIR="\"$(tccdir)/i386\""
175 $(X64_CROSS): DEFINES = -DTCC_TARGET_X86_64
176 $(WIN32_CROSS): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
177 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
178 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
179 $(WIN64_CROSS): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
180 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
181 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
182 $(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
183 $(C67_CROSS): DEFINES = -DTCC_TARGET_C67
184 $(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
185 $(ARM_FPA_LD_CROSS)$(EXESUF): DEFINES = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
186 $(ARM_VFP_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_VFP
187 $(ARM_EABI_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_EABI
189 $(I386_CROSS): $(I386_FILES)
190 $(X64_CROSS): $(X86_64_FILES)
191 $(WIN32_CROSS): $(WIN32_FILES)
192 $(WIN64_CROSS): $(WIN64_FILES)
193 $(WINCE_CROSS): $(WINCE_FILES)
194 $(C67_CROSS): $(C67_FILES)
195 $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS): $(ARM_FILES)
197 # libtcc generation and test
198 ifndef ONE_SOURCE
199 LIBTCC_OBJ = $(filter-out tcc.o,$(patsubst %.c,%.o,$(filter %.c,$(NATIVE_FILES))))
200 LIBTCC_INC = $(filter %.h,$(CORE_FILES)) $(filter-out $(CORE_FILES),$(NATIVE_FILES))
201 else
202 LIBTCC_OBJ = libtcc.o
203 LIBTCC_INC = $(NATIVE_FILES)
204 libtcc.o : NATIVE_DEFINES += -DONE_SOURCE
205 endif
207 $(LIBTCC_OBJ) tcc.o : %.o : %.c $(LIBTCC_INC)
208 $(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CFLAGS)
210 libtcc.a: $(LIBTCC_OBJ)
211 $(AR) rcs $@ $^
213 libtcc.so.1.0: $(LIBTCC_OBJ)
214 $(CC) -shared -Wl,-soname,$@ -o $@ $^
216 libtcc.so.1.0: CFLAGS+=-fPIC
218 # profiling version
219 tcc_p$(EXESUF): $(NATIVE_FILES)
220 $(CC) -o $@ $< $(NATIVE_DEFINES) $(CFLAGS_P) $(LIBS_P)
222 # windows utilities
223 tiny_impdef$(EXESUF): win32/tools/tiny_impdef.c
224 $(CC) -o $@ $< $(CFLAGS)
225 tiny_libmaker$(EXESUF): win32/tools/tiny_libmaker.c
226 $(CC) -o $@ $< $(CFLAGS)
228 # TinyCC runtime libraries
229 libtcc1.a : FORCE
230 @$(MAKE) -C lib native
231 lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
232 @$(MAKE) -C lib cross TARGET=$*
233 bcheck.o : lib/bcheck.c
234 gcc -c $< -o $@ $(CFLAGS)
235 FORCE:
237 # install
238 TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h tcclib.h
239 INSTALL=install
240 ifdef STRIP_BINARIES
241 INSTALLBIN=$(INSTALL) -s
242 else
243 INSTALLBIN=$(INSTALL)
244 endif
246 ifndef CONFIG_WIN32
247 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
248 mkdir -p "$(bindir)"
249 ifeq ($(CC),tcc)
250 $(INSTALL) -m755 $(PROGS) "$(bindir)"
251 else
252 $(INSTALLBIN) -m755 $(PROGS) "$(bindir)"
253 endif
254 mkdir -p "$(mandir)/man1"
255 -$(INSTALL) tcc.1 "$(mandir)/man1"
256 mkdir -p "$(infodir)"
257 -$(INSTALL) tcc-doc.info "$(infodir)"
258 mkdir -p "$(tccdir)"
259 mkdir -p "$(tccdir)/include"
260 ifneq ($(LIBTCC1),)
261 $(INSTALL) -m644 $(LIBTCC1) "$(tccdir)"
262 endif
263 ifneq ($(BCHECK_O),)
264 $(INSTALL) -m644 $(BCHECK_O) "$(tccdir)"
265 endif
266 $(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include"
267 mkdir -p "$(libdir)"
268 $(INSTALL) -m755 $(LIBTCC) "$(libdir)"
269 ifdef DISABLE_STATIC
270 ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so.1"
271 ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so"
272 endif
273 mkdir -p "$(includedir)"
274 $(INSTALL) -m644 libtcc.h "$(includedir)"
275 mkdir -p "$(docdir)"
276 -$(INSTALL) -m644 tcc-doc.html "$(docdir)"
277 ifdef CONFIG_CROSS
278 mkdir -p "$(tccdir)/win32/lib/32"
279 mkdir -p "$(tccdir)/win32/lib/64"
280 ifeq ($(ARCH),x86-64)
281 mkdir -p "$(tccdir)/i386"
282 $(INSTALL) -m644 lib/i386/libtcc1.a "$(tccdir)/i386"
283 cp -r "$(tccdir)/include" "$(tccdir)/i386"
284 endif
285 $(INSTALL) -m644 win32/lib/*.def "$(tccdir)/win32/lib"
286 $(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/win32/lib/32"
287 $(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/win32/lib/64"
288 cp -r win32/include/. "$(tccdir)/win32/include"
289 cp -r include/. "$(tccdir)/win32/include"
290 endif
292 uninstall:
293 rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
294 rm -fv $(foreach P,$(LIBTCC1) $(BCHECK_O),"$(tccdir)/$P")
295 rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
296 rm -fv "$(docdir)/tcc-doc.html" "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
297 rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
298 rm -fv "$(libdir)/libtcc.so*"
299 rm -rf "$(tccdir)/win32"
300 -rmdir $(tccdir)/include
301 ifeq ($(ARCH),x86-64)
302 rm -rf "$(tccdir)/i386"
303 endif
304 else
305 # on windows
306 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
307 mkdir -p "$(tccdir)"
308 mkdir -p "$(tccdir)/lib"
309 mkdir -p "$(tccdir)/include"
310 mkdir -p "$(tccdir)/examples"
311 mkdir -p "$(tccdir)/doc"
312 mkdir -p "$(tccdir)/libtcc"
313 $(INSTALLBIN) -m755 $(PROGS) "$(tccdir)"
314 $(INSTALL) -m644 $(LIBTCC1) win32/lib/*.def "$(tccdir)/lib"
315 cp -r win32/include/. "$(tccdir)/include"
316 cp -r win32/examples/. "$(tccdir)/examples"
317 $(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include"
318 $(INSTALL) -m644 tcc-doc.html win32/tcc-win32.txt "$(tccdir)/doc"
319 $(INSTALL) -m644 $(LIBTCC) libtcc.h "$(tccdir)/libtcc"
320 ifdef CONFIG_CROSS
321 mkdir -p "$(tccdir)/lib/32"
322 mkdir -p "$(tccdir)/lib/64"
323 -$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/lib/32"
324 -$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/lib/64"
325 endif
327 uninstall:
328 rm -rfv "$(tccdir)/*"
329 endif
331 # documentation and man page
332 tcc-doc.html: tcc-doc.texi
333 -texi2html -monolithic -number $<
335 tcc.1: tcc-doc.texi
336 -./texi2pod.pl $< tcc.pod
337 -pod2man --section=1 --center=" " --release=" " tcc.pod > $@
339 tcc-doc.info: tcc-doc.texi
340 -makeinfo tcc-doc.texi
342 .PHONY: all clean tar distclean install uninstall FORCE
344 # tar release (use 'make -k tar' on a checkouted tree)
345 TCC-VERSION=tcc-$(shell cat VERSION)
346 tar:
347 rm -rf /tmp/$(TCC-VERSION)
348 cp -r . /tmp/$(TCC-VERSION)
349 ( cd /tmp ; tar zcvf ~/$(TCC-VERSION).tar.gz $(TCC-VERSION) --exclude CVS )
350 rm -rf /tmp/$(TCC-VERSION)
352 # in tests subdir
353 export LIBTCC1
355 %est:
356 $(MAKE) -C tests $@
358 clean:
359 rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.exe libtcc_test$(EXESUF)
360 $(MAKE) -C tests $@
361 ifneq ($(LIBTCC1),)
362 $(MAKE) -C lib $@
363 endif
365 distclean: clean
366 rm -vf config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html
368 config.mak:
369 @echo "Please run ./configure."
370 @exit 1
372 endif # ifeq ($(TOP),.)