make: new lib/Makefile for libtcc1.a on more platforms
win32/64 cross-compilers now build libtcc1.a and install it together with the windows headers in a 'win32' sub-directory of TCCDIR.
This commit is contained in:
		
							parent
							
								
									2ce9a0e2fe
								
							
						
					
					
						commit
						86ffc48129
					
				
					 6 changed files with 266 additions and 254 deletions
				
			
		
							
								
								
									
										331
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										331
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -4,68 +4,70 @@ | ||||||
| 
 | 
 | ||||||
| TOP ?= . | TOP ?= . | ||||||
| include $(TOP)/config.mak | include $(TOP)/config.mak | ||||||
| TCC=./tcc | 
 | ||||||
| LIBTCC1_DIR= $(TOP) |  | ||||||
| CFLAGS+=-g -Wall | CFLAGS+=-g -Wall | ||||||
| CFLAGS_P=$(CFLAGS) -pg -static -DCONFIG_TCC_STATIC | CFLAGS_P=$(CFLAGS) -pg -static -DCONFIG_TCC_STATIC | ||||||
| LIBS_P= | LIBS_P= | ||||||
| 
 | 
 | ||||||
| LIBTCC1=libtcc1.a |  | ||||||
| ifdef CONFIG_USE_LIBGCC |  | ||||||
|     LIBTCC1= |  | ||||||
| endif |  | ||||||
| 
 |  | ||||||
| ifneq ($(GCC_MAJOR),2) | ifneq ($(GCC_MAJOR),2) | ||||||
|     CFLAGS+=-fno-strict-aliasing | CFLAGS+=-fno-strict-aliasing | ||||||
|     ifneq ($(GCC_MAJOR),3) | ifneq ($(GCC_MAJOR),3) | ||||||
|         CFLAGS+=-Wno-pointer-sign -Wno-sign-compare -D_FORTIFY_SOURCE=0 | CFLAGS+=-Wno-pointer-sign -Wno-sign-compare -D_FORTIFY_SOURCE=0 | ||||||
|     endif | endif | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(ARCH),i386) | ifeq ($(ARCH),i386) | ||||||
|     CFLAGS+=-mpreferred-stack-boundary=2 | CFLAGS+=-mpreferred-stack-boundary=2 | ||||||
|     ifeq ($(GCC_MAJOR),2) | ifeq ($(GCC_MAJOR),2) | ||||||
|         CFLAGS+=-m386 -malign-functions=0 | CFLAGS+=-m386 -malign-functions=0 | ||||||
|     else | else | ||||||
|         CFLAGS+=-march=i386 -falign-functions=0 | CFLAGS+=-march=i386 -falign-functions=0 | ||||||
|     endif | endif | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | ifdef CONFIG_WIN64 | ||||||
|  | CONFIG_WIN32=yes | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifndef CONFIG_WIN32 | ifndef CONFIG_WIN32 | ||||||
|     LIBS=-lm | LIBS=-lm | ||||||
|     ifndef CONFIG_NOLDL | ifndef CONFIG_NOLDL | ||||||
|         LIBS+=-ldl | LIBS+=-ldl | ||||||
|     endif | endif | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(ARCH),i386) | ifeq ($(ARCH),i386) | ||||||
|     NATIVE_DEFINES=-DTCC_TARGET_I386 | NATIVE_DEFINES=-DTCC_TARGET_I386 | ||||||
|     LIBTCC1_DIR=lib | else | ||||||
|     BCHECK_O=bcheck.o | ifeq ($(ARCH),x86-64) | ||||||
|     ALLOCA_O=alloca86.o alloca86-bt.o | NATIVE_DEFINES=-DTCC_TARGET_X86_64 | ||||||
| else ifeq ($(ARCH),x86-64) | NATIVE_DEFINES+=$(if $(wildcard /lib64/ld-linux-x86-64.so.2),-DTCC_TARGET_X86_64_CENTOS) | ||||||
|     NATIVE_DEFINES=-DTCC_TARGET_X86_64 | endif | ||||||
|     NATIVE_DEFINES+=$(if $(wildcard /lib64/ld-linux-x86-64.so.2),-DTCC_TARGET_X86_64_CENTOS) |  | ||||||
|     LIBTCC1_DIR=lib64 |  | ||||||
|     BCHECK_O= |  | ||||||
|     ALLOCA_O=alloca86_64.o |  | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(ARCH),arm) | ifeq ($(ARCH),arm) | ||||||
|     NATIVE_DEFINES=-DTCC_TARGET_ARM | NATIVE_DEFINES=-DTCC_TARGET_ARM | ||||||
|     NATIVE_TARGET=-DWITHOUT_LIBTCC | NATIVE_DEFINES+=-DWITHOUT_LIBTCC | ||||||
|     NATIVE_DEFINES+=$(if $(wildcard /lib/ld-linux.so.3),-DTCC_ARM_EABI) | NATIVE_DEFINES+=$(if $(wildcard /lib/ld-linux.so.3),-DTCC_ARM_EABI) | ||||||
|     NATIVE_DEFINES+=$(if $(shell grep -l "^Features.* \(vfp\|iwmmxt\) " /proc/cpuinfo),-DTCC_ARM_VFP) | NATIVE_DEFINES+=$(if $(shell grep -l "^Features.* \(vfp\|iwmmxt\) " /proc/cpuinfo),-DTCC_ARM_VFP) | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifdef CONFIG_WIN32 | ifdef CONFIG_WIN32 | ||||||
|     NATIVE_DEFINES+=-DTCC_TARGET_PE | NATIVE_DEFINES+=-DTCC_TARGET_PE | ||||||
|     BCHECK_O= |  | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifneq ($(wildcard /lib/ld-uClibc.so.0),) | ifneq ($(wildcard /lib/ld-uClibc.so.0),) | ||||||
|     NATIVE_DEFINES+=-DTCC_UCLIBC | NATIVE_DEFINES+=-DTCC_UCLIBC | ||||||
|     BCHECK_O= | CONFIG_UCLIBC = 1 | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | # make libtcc as static or dynamic library?
 | ||||||
|  | ifdef DISABLE_STATIC | ||||||
|  | LIBTCC=libtcc.so.1.0 | ||||||
|  | LINK_LIBTCC=-Wl,-rpath,"$(libdir)" | ||||||
|  | else | ||||||
|  | LIBTCC=libtcc.a | ||||||
|  | LINK_LIBTCC= | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(TOP),.) | ifeq ($(TOP),.) | ||||||
|  | @ -93,47 +95,63 @@ X86_64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h | ||||||
| ARM_FILES = $(CORE_FILES) arm-gen.c | ARM_FILES = $(CORE_FILES) arm-gen.c | ||||||
| C67_FILES = $(CORE_FILES) c67-gen.c tcccoff.c | C67_FILES = $(CORE_FILES) c67-gen.c tcccoff.c | ||||||
| 
 | 
 | ||||||
|  | ifdef CONFIG_WIN64 | ||||||
|  | PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF) | ||||||
|  | NATIVE_FILES=$(WIN64_FILES) | ||||||
|  | PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(C67_CROSS) | ||||||
|  | LIBTCC1_CROSS=lib/i386-win32/libtcc1.a | ||||||
|  | LIBTCC1=libtcc1.a | ||||||
|  | else | ||||||
| ifdef CONFIG_WIN32 | ifdef CONFIG_WIN32 | ||||||
|     PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF) | PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF) | ||||||
|     NATIVE_FILES=$(WIN32_FILES) | NATIVE_FILES=$(WIN32_FILES) | ||||||
|     PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(C67_CROSS) | PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(C67_CROSS) | ||||||
| else ifeq ($(ARCH),i386) | LIBTCC1_CROSS=lib/x86_64-win32/libtcc1.a | ||||||
|     NATIVE_FILES=$(I386_FILES) | LIBTCC1=libtcc1.a | ||||||
|     PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) | else | ||||||
| else ifeq ($(ARCH),x86-64) | ifeq ($(ARCH),i386) | ||||||
|     NATIVE_FILES=$(X86_64_FILES) | NATIVE_FILES=$(I386_FILES) | ||||||
|     PROGS_CROSS= $(WIN32_CROSS) $(I386_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) | PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) | ||||||
| else ifeq ($(ARCH),arm) | LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a | ||||||
|     NATIVE_FILES=$(ARM_FILES) | LIBTCC1=libtcc1.a | ||||||
|     PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(C67_CROSS) | BCHECK_O=bcheck.o | ||||||
|  | else | ||||||
|  | ifeq ($(ARCH),x86-64) | ||||||
|  | NATIVE_FILES=$(X86_64_FILES) | ||||||
|  | PROGS_CROSS=$(I386_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) | ||||||
|  | LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a | ||||||
|  | LIBTCC1=libtcc1.a | ||||||
|  | else | ||||||
|  | ifeq ($(ARCH),arm) | ||||||
|  | NATIVE_FILES=$(ARM_FILES) | ||||||
|  | PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(C67_CROSS) | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | endif | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| # LIBTCCB decides whether libtcc is built static or dynamic
 | ifdef CONFIG_UCLIBC | ||||||
| LIBTCCB=libtcc.a | BCHECK_O= | ||||||
| ifdef DISABLE_STATIC |  | ||||||
|     CFLAGS+=-fPIC |  | ||||||
|     LIBTCCL=-L. -ltcc |  | ||||||
|     LIBTCCB=libtcc.so.1.0 |  | ||||||
| endif | endif | ||||||
| LIBTCCLIBS=$(LIBTCCB) |  | ||||||
| 
 | 
 | ||||||
| # conditionally make win32/lib/xx/libtcc1.a cross compiler lib archives
 | ifdef CONFIG_USE_LIBGCC | ||||||
|  | LIBTCC1= | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | TCCLIBS = $(LIBTCC1) $(LIBTCC) $(BCHECK_O) | ||||||
|  | TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info | ||||||
|  | 
 | ||||||
| ifdef CONFIG_CROSS | ifdef CONFIG_CROSS | ||||||
|     PROGS+=$(PROGS_CROSS) | PROGS+=$(PROGS_CROSS) | ||||||
|     ifdef CONFIG_WIN32 | TCCLIBS+=$(LIBTCC1_CROSS) | ||||||
|         LIBTCCLIBS+=win32 |  | ||||||
|     else ifdef CONFIG_WIN64 |  | ||||||
|         LIBTCCLIBS+=win64 |  | ||||||
|     else |  | ||||||
|         LIBTCCLIBS+=$(ARCH) |  | ||||||
|     endif |  | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| all: $(PROGS) $(LIBTCC1_DIR)/$(LIBTCC1) $(BCHECK_O) $(LIBTCCLIBS) tcc-doc.html tcc.1 tcc-doc.info libtcc_test$(EXESUF) | all: $(PROGS) $(TCCLIBS) $(TCCDOCS) | ||||||
| 
 | 
 | ||||||
| # Host Tiny C Compiler
 | # Host Tiny C Compiler
 | ||||||
| tcc$(EXESUF): tcc.o $(LIBTCCB) | tcc$(EXESUF): tcc.o $(LIBTCC) | ||||||
| 	$(CC) -o $@ $^ $(LIBS) $(LIBTCCL) | 	$(CC) -o $@ $^ $(LIBS) $(LINK_LIBTCC) | ||||||
| 
 | 
 | ||||||
| # Cross Tiny C Compilers
 | # Cross Tiny C Compilers
 | ||||||
| %-tcc$(EXESUF): | %-tcc$(EXESUF): | ||||||
|  | @ -141,8 +159,8 @@ tcc$(EXESUF): tcc.o $(LIBTCCB) | ||||||
| 
 | 
 | ||||||
| $(I386_CROSS): DEFINES = -DTCC_TARGET_I386 | $(I386_CROSS): DEFINES = -DTCC_TARGET_I386 | ||||||
| $(X64_CROSS): DEFINES = -DTCC_TARGET_X86_64 | $(X64_CROSS): DEFINES = -DTCC_TARGET_X86_64 | ||||||
| $(WIN32_CROSS): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE | $(WIN32_CROSS): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" -DCONFIG_TCC_CROSSLIB="\"lib/32\"" | ||||||
| $(WIN64_CROSS): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE | $(WIN64_CROSS): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" -DCONFIG_TCC_CROSSLIB="\"lib/64\"" | ||||||
| $(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE | $(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE | ||||||
| $(C67_CROSS): DEFINES = -DTCC_TARGET_C67 | $(C67_CROSS): DEFINES = -DTCC_TARGET_C67 | ||||||
| $(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM | $(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM | ||||||
|  | @ -177,14 +195,8 @@ libtcc.a: $(LIBTCC_OBJ) | ||||||
| 
 | 
 | ||||||
| libtcc.so.1.0: $(LIBTCC_OBJ) | libtcc.so.1.0: $(LIBTCC_OBJ) | ||||||
| 	$(CC) -shared -Wl,-soname,$@ -o $@ $^ | 	$(CC) -shared -Wl,-soname,$@ -o $@ $^ | ||||||
| 	ln -sf libtcc.so.1.0 libtcc.so.1 |  | ||||||
| 	ln -sf libtcc.so.1.0 libtcc.so |  | ||||||
| 
 | 
 | ||||||
| libtcc_test$(EXESUF): tests/libtcc_test.c $(LIBTCCB) | libtcc.so.1.0: CFLAGS+=-fPIC | ||||||
| 	$(CC) -o $@ $^ -I. $(CFLAGS) $(LIBS) $(LIBTCCL) |  | ||||||
| 		 |  | ||||||
| libtest: libtcc_test$(EXESUF) $(LIBTCC1) |  | ||||||
| 	./libtcc_test$(EXESUF) lib_path=. |  | ||||||
| 
 | 
 | ||||||
| # profiling version
 | # profiling version
 | ||||||
| tcc_p$(EXESUF): $(NATIVE_FILES) | tcc_p$(EXESUF): $(NATIVE_FILES) | ||||||
|  | @ -197,96 +209,37 @@ tiny_libmaker$(EXESUF): win32/tools/tiny_libmaker.c | ||||||
| 	$(CC) -o $@ $< $(CFLAGS) | 	$(CC) -o $@ $< $(CFLAGS) | ||||||
| 
 | 
 | ||||||
| # TinyCC runtime libraries
 | # TinyCC runtime libraries
 | ||||||
| LIBTCC1_OBJS=$(LIBTCC1_DIR)/libtcc1.o $(ALLOCA_O) | libtcc1.a : FORCE | ||||||
| LIBTCC1_CC=$(CC) | 	@$(MAKE) -C lib native | ||||||
| VPATH+=lib | lib/%/libtcc1.a : FORCE | ||||||
| 
 | 	@$(MAKE) -C lib cross TARGET=$* | ||||||
| WINDLLS=$(LIBTCC1_DIR)/crt1.o $(LIBTCC1_DIR)/wincrt1.o $(LIBTCC1_DIR)/dllcrt1.o $(LIBTCC1_DIR)/dllmain.o | bcheck.o : lib/bcheck.c | ||||||
| ifdef CONFIG_WIN32 | 	gcc -c $< -o $@ -O2 -Wall | ||||||
|     # for windows, we must use TCC because we generate ELF objects | FORCE: | ||||||
|     LIBTCC1_OBJS+=$(WINDLLS) $(LIBTCC1_DIR)/chkstk.o $(LIBTCC1_DIR)/bcheck.o |  | ||||||
|     LIBTCC1_CC=./$(TCC)$(EXESUF) -B. -Iinclude $(NATIVE_DEFINES) |  | ||||||
|     VPATH+=win32/lib |  | ||||||
| endif |  | ||||||
| 
 |  | ||||||
| ifdef CONFIG_WIN64 |  | ||||||
|     # windows 64: fixme: chkstk.o bcheck.o fails, not included |  | ||||||
|     # windows 64: fixme: alloca86_64 is broken |  | ||||||
|     LIBTCC1_OBJS+=$(WINDLLS) |  | ||||||
|     LIBTCC1_CC=./$(TCC)$(EXESUF) -B. -Iinclude $(NATIVE_DEFINES) |  | ||||||
|     VPATH+=win32/lib |  | ||||||
| endif |  | ||||||
| #~ win32/lib/64/libtcc1.o:
 |  | ||||||
| 	#~ $(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CFLAGS) |  | ||||||
| $(LIBTCC1_DIR)/%.o: %.c |  | ||||||
| 	$(LIBTCC1_CC) -o $@ -c $< -O2 -Wall |  | ||||||
| $(LIBTCC1_DIR)/%.o: %.S |  | ||||||
| 	$(LIBTCC1_CC) -o $@ -c $< |  | ||||||
| 
 |  | ||||||
| $(LIBTCC1_DIR)/libtcc1.a: $(LIBTCC1_OBJS) |  | ||||||
| 	$(AR) rcs $@ $^ |  | ||||||
| 	$(RM) $^ |  | ||||||
| 
 |  | ||||||
| #recursively build cross-compiler lib archives for each arch
 |  | ||||||
| win32: $(TCC)$(EXESUF) $(WIN64_CROSS) |  | ||||||
| #testing: bleeding: cross-cross (./configure --enable-mingw32 --enable-cross)
 |  | ||||||
| #fixme: The windows exe cross-compilers still use Linux libc
 |  | ||||||
| #fixme: thus cygwin or some such needed to even run them on Windows
 |  | ||||||
| 	$(MAKE) CC=./$(I386_CROSS) ARCH=i386 LIBTCC1_DIR=lib lib/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(X64_CROSS) LIBTCC1_DIR=lib64 \
 |  | ||||||
|     ARCH=x86-64 LIBTCC1_OBJS="lib/libtcc1.o alloca86_64.o" lib64/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(WIN64_CROSS) CONFIG_CROSS= TCC=./x86_64-win32-tcc \
 |  | ||||||
|     ARCH=x86-64 LIBTCC1_DIR=win32/lib/64 CONFIG_WIN64=1 win32/lib/64/libtcc1.a |  | ||||||
|     #todo: add arm, etc cross lib archives |  | ||||||
| 
 |  | ||||||
| win64: $(PROGS_CROSS) |  | ||||||
| #testing: bleeding: mingw64 cross-cross lib stuff would go here
 |  | ||||||
| 	$(MAKE) TCC=./$(WIN32_CROSS) CC=./$(WIN32_CROSS) LIBTCC1_DIR=win32/lib/32 \
 |  | ||||||
|     ARCH=i386 CONFIG_WIN32=1 win32/lib/32/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(I386_CROSS) LIBTCC1_DIR=lib ARCH=i386 lib/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(X64_CROSS) LIBTCC1_DIR=lib64 ARCH=x86-64 lib64/libtcc1.a |  | ||||||
| 
 |  | ||||||
| i386: $(PROGS_CROSS) |  | ||||||
| #testing: unstable: build cross-compiler libs on i386 platform
 |  | ||||||
| 	$(MAKE) TCC=./$(WIN32_CROSS) CC=./$(WIN32_CROSS) LIBTCC1_DIR=win32/lib/32 \
 |  | ||||||
|     ARCH=i386 CONFIG_WIN32=1 win32/lib/32/libtcc1.a |  | ||||||
| 	$(MAKE) TCC=./$(WIN64_CROSS) CC=./$(WIN64_CROSS) LIBTCC1_DIR=win32/lib/64 \
 |  | ||||||
|     ARCH=x86-64 CONFIG_WIN64=1 win32/lib/64/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(X64_CROSS) LIBTCC1_DIR=lib64 ARCH=x86-64 lib64/libtcc1.a |  | ||||||
| 
 |  | ||||||
| x86-64: $(PROGS_CROSS) |  | ||||||
| #stable: build cross-compiler lib archives on x86_64 platform
 |  | ||||||
| 	$(MAKE) TCC=./$(WIN32_CROSS) CC=./$(WIN32_CROSS) LIBTCC1_DIR=win32/lib/32 \
 |  | ||||||
|     ARCH=i386 CONFIG_WIN32=1 win32/lib/32/libtcc1.a |  | ||||||
| 	$(MAKE) TCC=./$(WIN64_CROSS) CC=./$(WIN64_CROSS) LIBTCC1_DIR=win32/lib/64 \
 |  | ||||||
|     ARCH=x86-64 CONFIG_WIN64=1 win32/lib/64/libtcc1.a |  | ||||||
| 	$(MAKE) CC=./$(I386_CROSS) LIBTCC1_DIR=lib ARCH=i386 lib/libtcc1.a |  | ||||||
| 
 | 
 | ||||||
| # install
 | # install
 | ||||||
| TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h tcclib.h | TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h tcclib.h | ||||||
| INSTALL=install | INSTALL=install | ||||||
| 
 | 
 | ||||||
| ifndef CONFIG_WIN32 | ifndef CONFIG_WIN32 | ||||||
| install: $(PROGS) $(LIBTCC1) $(BCHECK_O) $(LIBTCCLIBS) tcc.1 tcc-doc.info tcc-doc.html | install: $(PROGS) $(TCCLIBS) $(TCCDOCS) | ||||||
| 	mkdir -p "$(bindir)" | 	mkdir -p "$(bindir)" | ||||||
| 	-$(STRIP) $(PROGS) | 	$(INSTALL) -s -m755 $(PROGS) "$(bindir)" | ||||||
| 	$(INSTALL) -m755 $(PROGS) "$(bindir)" |  | ||||||
| 	mkdir -p "$(mandir)/man1" | 	mkdir -p "$(mandir)/man1" | ||||||
| 	$(INSTALL) tcc.1 "$(mandir)/man1" | 	-$(INSTALL) tcc.1 "$(mandir)/man1" | ||||||
| 	mkdir -p $(infodir) | 	mkdir -p "$(infodir)" | ||||||
| 	$(INSTALL)  tcc-doc.info "$(infodir)" | 	-$(INSTALL) tcc-doc.info "$(infodir)" | ||||||
| 	mkdir -p "$(tccdir)" | 	mkdir -p "$(tccdir)" | ||||||
| 	mkdir -p "$(tccdir)/include" | 	mkdir -p "$(tccdir)/include" | ||||||
| 	mkdir -p "$(tccdir)/lib" | ifneq ($(LIBTCC1),) | ||||||
| 	-$(INSTALL) lib/libtcc1.a "$(tccdir)/lib" | 	$(INSTALL) -m644 $(LIBTCC1) "$(tccdir)" | ||||||
| 	mkdir -p "$(tccdir)/lib64" | endif | ||||||
| 	-$(INSTALL) lib64/libtcc1.a "$(tccdir)/lib64" |  | ||||||
| ifneq ($(BCHECK_O),) | ifneq ($(BCHECK_O),) | ||||||
| 	$(INSTALL) -m644 $(BCHECK_O) "$(tccdir)" | 	$(INSTALL) -m644 $(BCHECK_O) "$(tccdir)" | ||||||
| endif | endif | ||||||
| 	$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include" | 	$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include" | ||||||
| 	mkdir -p "$(libdir)" | 	mkdir -p "$(libdir)" | ||||||
| 	-$(INSTALL) -m755 $(LIBTCCB) "$(libdir)" | 	$(INSTALL) -m755 $(LIBTCC) "$(libdir)" | ||||||
| ifdef DISABLE_STATIC | ifdef DISABLE_STATIC | ||||||
| 	ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so.1" | 	ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so.1" | ||||||
| 	ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so" | 	ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so" | ||||||
|  | @ -294,43 +247,28 @@ endif | ||||||
| 	mkdir -p "$(includedir)" | 	mkdir -p "$(includedir)" | ||||||
| 	$(INSTALL) -m644 libtcc.h "$(includedir)" | 	$(INSTALL) -m644 libtcc.h "$(includedir)" | ||||||
| 	mkdir -p "$(docdir)" | 	mkdir -p "$(docdir)" | ||||||
| 	$(INSTALL) -m644 tcc-doc.html "$(docdir)" | 	-$(INSTALL) -m644 tcc-doc.html "$(docdir)" | ||||||
| ifdef CONFIG_CROSS | ifdef CONFIG_CROSS | ||||||
| 	mkdir -p "$(tccdir)/win32/lib" |  | ||||||
| 	$(INSTALL) -m644 win32/lib/*.def "$(tccdir)/win32/lib" |  | ||||||
| 	mkdir -p "$(tccdir)/win32/lib/32" | 	mkdir -p "$(tccdir)/win32/lib/32" | ||||||
| 	$(INSTALL) win32/lib/32/libtcc1.a "$(tccdir)/win32/lib/32" |  | ||||||
| 	mkdir -p "$(tccdir)/win32/lib/64" | 	mkdir -p "$(tccdir)/win32/lib/64" | ||||||
| 	$(INSTALL) win32/lib/64/libtcc1.a "$(tccdir)/win32/lib/64" | 	$(INSTALL) -m644 win32/lib/*.def "$(tccdir)/win32/lib" | ||||||
| 	cp -r win32/include/. "$(tccdir)/include" | 	$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/win32/lib/32" | ||||||
| 	cp -r win32/examples/. "$(tccdir)/examples" | 	$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/win32/lib/64" | ||||||
|  | 	cp -r win32/include/. "$(tccdir)/win32/include" | ||||||
|  | 	cp -r include/. "$(tccdir)/win32/include" | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| uninstall: | uninstall: | ||||||
| 	rm -fv $(foreach P,$(PROGS),"$(bindir)/$P") | 	rm -fv $(foreach P,$(PROGS),"$(bindir)/$P") | ||||||
| 	rm -fv $(foreach P,$(BCHECK_O),"$(tccdir)/$P") | 	rm -fv $(foreach P,$(LIBTCC1) $(BCHECK_O),"$(tccdir)/$P") | ||||||
| 	rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P") | 	rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P") | ||||||
| 	rm -fv "$(docdir)/tcc-doc.html" "$(mandir)/man1/tcc.1" | 	rm -fv "$(docdir)/tcc-doc.html" "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info" | ||||||
| 	rm -fv "$(libdir)/$(LIBTCCB)" "$(includedir)/libtcc.h" | 	rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h" | ||||||
| 	rm -fv "$(tccdir)/lib/libtcc1.a" | 	rm -fv "$(libdir)/libtcc.so*" | ||||||
| 	rm -fv "$(tccdir)/lib64/libtcc1.a" | 	rm -rf "$(tccdir)/win32" | ||||||
| ifdef DISABLE_STATIC |  | ||||||
| 	rm -fv "$(libdir)/libtcc.so" |  | ||||||
| 	rm -fv "$(libdir)/libtcc.so.1" |  | ||||||
| 	rm -fv "$(libdir)/libtcc.so.1.0" |  | ||||||
| else | else | ||||||
| 	rm -fv "$(libdir)/libtcc.a" | # on windows
 | ||||||
| endif | install: $(PROGS) $(TCCLIBS) $(TCCDOCS) | ||||||
| 	-rmdir "$(tccdir)/lib" |  | ||||||
| 	-rmdir "$(tccdir)/lib64" |  | ||||||
| 	-rmdir "$(tccdir)" |  | ||||||
| ifdef CONFIG_CROSS |  | ||||||
| 	rm -rfv "$(tccdir)/include" |  | ||||||
| 	rm -rfv "$(tccdir)/examples" |  | ||||||
| 	rm -rfv "$(tccdir)/win32" |  | ||||||
| endif |  | ||||||
| else |  | ||||||
| install: $(PROGS) $(LIBTCC1) libtcc.a tcc-doc.html |  | ||||||
| 	mkdir -p "$(tccdir)" | 	mkdir -p "$(tccdir)" | ||||||
| 	mkdir -p "$(tccdir)/lib" | 	mkdir -p "$(tccdir)/lib" | ||||||
| 	mkdir -p "$(tccdir)/include" | 	mkdir -p "$(tccdir)/include" | ||||||
|  | @ -338,22 +276,21 @@ install: $(PROGS) $(LIBTCC1) libtcc.a tcc-doc.html | ||||||
| 	mkdir -p "$(tccdir)/doc" | 	mkdir -p "$(tccdir)/doc" | ||||||
| 	mkdir -p "$(tccdir)/libtcc" | 	mkdir -p "$(tccdir)/libtcc" | ||||||
| 	$(INSTALL) -s -m755 $(PROGS) "$(tccdir)" | 	$(INSTALL) -s -m755 $(PROGS) "$(tccdir)" | ||||||
| 	$(INSTALL) -m644 win32/lib/*.def "$(tccdir)/lib" | 	$(INSTALL) -m644 $(LIBTCC1) win32/lib/*.def "$(tccdir)/lib" | ||||||
| 	cp -r win32/include/. "$(tccdir)/include" | 	cp -r win32/include/. "$(tccdir)/include" | ||||||
| 	cp -r win32/examples/. "$(tccdir)/examples" | 	cp -r win32/examples/. "$(tccdir)/examples" | ||||||
| 	$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include" | 	$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) "$(tccdir)/include" | ||||||
| 	$(INSTALL) -m644 tcc-doc.html win32/tcc-win32.txt "$(tccdir)/doc" | 	$(INSTALL) -m644 tcc-doc.html win32/tcc-win32.txt "$(tccdir)/doc" | ||||||
| 	$(INSTALL) -m644 $(LIBTCCB) libtcc.h "$(tccdir)/libtcc" | 	$(INSTALL) -m644 $(LIBTCC) libtcc.h "$(tccdir)/libtcc" | ||||||
| 	mkdir -p "$(tccdir)/win32/lib/32" |  | ||||||
| 	-$(INSTALL) win32/lib/32/libtcc1.a "$(tccdir)/win32/lib/32" |  | ||||||
| 	mkdir -p "$(tccdir)/win32/lib/64" |  | ||||||
| 	-$(INSTALL) win32/lib/64/libtcc1.a "$(tccdir)/win32/lib/64" |  | ||||||
| ifdef CONFIG_CROSS | ifdef CONFIG_CROSS | ||||||
| 	$(INSTALL) lib/libtcc1.a "$(tccdir)/lib" | 	mkdir -p "$(tccdir)/lib/32" | ||||||
| 	mkdir -p "$(tccdir)/lib64" | 	mkdir -p "$(tccdir)/lib/64" | ||||||
| 	$(INSTALL) lib64/libtcc1.a "$(tccdir)/lib64
 | 	-$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/lib/32" | ||||||
|  | 	-$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/lib/64" | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
|  | uninstall: | ||||||
|  | 	rm -rfv "$(tccdir)/*" | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| # documentation and man page
 | # documentation and man page
 | ||||||
|  | @ -365,9 +302,9 @@ tcc.1: tcc-doc.texi | ||||||
| 	-pod2man --section=1 --center=" " --release=" " tcc.pod > $@ | 	-pod2man --section=1 --center=" " --release=" " tcc.pod > $@ | ||||||
| 
 | 
 | ||||||
| tcc-doc.info: tcc-doc.texi | tcc-doc.info: tcc-doc.texi | ||||||
| 	makeinfo tcc-doc.texi | 	-makeinfo tcc-doc.texi | ||||||
| 
 | 
 | ||||||
| .PHONY: all libtest clean tar distclean install uninstall win32 win64 x86 x86-64 | .PHONY: all clean tar distclean install uninstall FORCE | ||||||
| 
 | 
 | ||||||
| # tar release (use 'make -k tar' on a checkouted tree)
 | # tar release (use 'make -k tar' on a checkouted tree)
 | ||||||
| TCC-VERSION=tcc-$(shell cat VERSION) | TCC-VERSION=tcc-$(shell cat VERSION) | ||||||
|  | @ -382,15 +319,15 @@ tar: | ||||||
| 	$(MAKE) -C tests $@ | 	$(MAKE) -C tests $@ | ||||||
| 
 | 
 | ||||||
| clean: | clean: | ||||||
| 	rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.out *.so* *.exe libtcc_test$(EXESUF) | 	rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.exe libtcc_test$(EXESUF) | ||||||
| 	rm -vf win32/lib/32/libtcc1.a win32/lib/64/libtcc1.a lib64/libtcc1.a lib/libtcc1.a $(WIN32_CROSS) |  | ||||||
| 	$(MAKE) -C tests $@ | 	$(MAKE) -C tests $@ | ||||||
|  | 	$(MAKE) -C lib $@ | ||||||
| 
 | 
 | ||||||
| distclean: clean | distclean: clean | ||||||
| 	rm -vf config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html | 	rm -vf config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html | ||||||
| 
 | 
 | ||||||
| config.mak: | config.mak: | ||||||
| 	@echo Running configure ... | 	@echo "Please run ./configure." | ||||||
| 	@./configure | 	@exit 1 | ||||||
| 
 | 
 | ||||||
| endif # ifeq ($(TOP),.)
 | endif # ifeq ($(TOP),.)
 | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								configure
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								configure
									
										
									
									
										vendored
									
									
								
							|  | @ -329,7 +329,9 @@ echo "infodir=\$(DESTDIR)$infodir" >> config.mak | ||||||
| echo "docdir=\$(DESTDIR)$docdir" >> config.mak | echo "docdir=\$(DESTDIR)$docdir" >> config.mak | ||||||
| 
 | 
 | ||||||
| echo "#define CONFIG_SYSROOT \"$sysroot\"" >> $TMPH | echo "#define CONFIG_SYSROOT \"$sysroot\"" >> $TMPH | ||||||
|  | echo "#ifndef CONFIG_TCCDIR" >> $TMPH | ||||||
| echo "#define CONFIG_TCCDIR \"$tccdir\"" >> $TMPH | echo "#define CONFIG_TCCDIR \"$tccdir\"" >> $TMPH | ||||||
|  | echo "#endif" >> $TMPH | ||||||
| echo "CC=$cc" >> config.mak | echo "CC=$cc" >> config.mak | ||||||
| echo "GCC_MAJOR=$gcc_major" >> config.mak | echo "GCC_MAJOR=$gcc_major" >> config.mak | ||||||
| echo "#define GCC_MAJOR $gcc_major" >> $TMPH | echo "#define GCC_MAJOR $gcc_major" >> $TMPH | ||||||
|  |  | ||||||
							
								
								
									
										90
									
								
								lib/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								lib/Makefile
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,90 @@ | ||||||
|  | #
 | ||||||
|  | # Tiny C Compiler Makefile for libtcc1.a
 | ||||||
|  | #
 | ||||||
|  | 
 | ||||||
|  | TOP = .. | ||||||
|  | include $(TOP)/config.mak | ||||||
|  | 
 | ||||||
|  | ifndef TARGET | ||||||
|  |  ifdef CONFIG_WIN64 | ||||||
|  |   TARGET = x86_64-win32 | ||||||
|  |  else | ||||||
|  |  ifdef CONFIG_WIN32 | ||||||
|  |   TARGET = i386-win32 | ||||||
|  |  else | ||||||
|  |  ifeq ($(ARCH),i386) | ||||||
|  |   TARGET = i386 | ||||||
|  |   XCC = gcc -O2 | ||||||
|  |  else | ||||||
|  |  ifeq ($(ARCH),x86-64) | ||||||
|  |   TARGET = x86_64 | ||||||
|  |   XCC = gcc -O2 | ||||||
|  |  endif | ||||||
|  |  endif | ||||||
|  |  endif | ||||||
|  |  endif | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | DIR = $(TARGET) | ||||||
|  | 
 | ||||||
|  | native : ../libtcc1.a | ||||||
|  | cross : $(DIR)/libtcc1.a | ||||||
|  | 
 | ||||||
|  | native : TCC = $(TOP)/tcc$(EXESUF) | ||||||
|  | cross : TCC = $(TOP)/$(TARGET)-tcc$(EXESUF) | ||||||
|  | 
 | ||||||
|  | I386_O = libtcc1.o alloca86.o alloca86-bt.o | ||||||
|  | X86_64_O = libtcc1.o alloca86_64.o | ||||||
|  | WIN32_O = $(I386_O) crt1.o wincrt1.o dllcrt1.o dllmain.o chkstk.o bcheck.o | ||||||
|  | WIN64_O = $(X86_64_O) crt1.o wincrt1.o dllcrt1.o dllmain.o chkstk.o | ||||||
|  | 
 | ||||||
|  | VPATH = $(TOP)/lib $(TOP)/win32/lib | ||||||
|  | 
 | ||||||
|  | ifeq "$(TARGET)" "i386-win32" | ||||||
|  |  OBJ = $(addprefix $(DIR)/,$(WIN32_O)) | ||||||
|  |  TGT = -DTCC_TARGET_I386 -DTCC_TARGET_PE | ||||||
|  |  XCC = $(TCC) -B$(TOP)/win32 -I$(TOP)/include | ||||||
|  |  XAR = $(DIR)/tiny_libmaker$(EXESUF) | ||||||
|  | else | ||||||
|  | ifeq "$(TARGET)" "x86_64-win32" | ||||||
|  |  OBJ = $(addprefix $(DIR)/,$(WIN64_O)) | ||||||
|  |  TGT = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE | ||||||
|  |  XCC = $(TCC) -B$(TOP)/win32 -I$(TOP)/include | ||||||
|  |  XAR = $(DIR)/tiny_libmaker$(EXESUF) | ||||||
|  | else | ||||||
|  | ifeq "$(TARGET)" "i386" | ||||||
|  |  OBJ = $(addprefix $(DIR)/,$(I386_O)) | ||||||
|  |  TGT = -DTCC_TARGET_I386 | ||||||
|  |  XCC ?= $(TCC) -B$(TOP) | ||||||
|  | else | ||||||
|  | ifeq "$(TARGET)" "x86_64" | ||||||
|  |  OBJ = $(addprefix $(DIR)/,$(X86_64_O)) | ||||||
|  |  TGT = -DTCC_TARGET_X86_64 | ||||||
|  |  XCC ?= $(TCC) -B$(TOP) | ||||||
|  | else | ||||||
|  |  $(error libtcc1.a not supported on target '$(TARGET)') | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | ifdef XAR | ||||||
|  | AR = $(XAR) | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | $(DIR)/libtcc1.a ../libtcc1.a : $(OBJ) $(XAR) | ||||||
|  | 	$(AR) rcs $@ $(OBJ) | ||||||
|  | $(DIR)/%.o : %.c | ||||||
|  | 	$(XCC) -c $< -o $@ $(TGT) | ||||||
|  | $(DIR)/%.o : %.S | ||||||
|  | 	$(XCC) -c $< -o $@ $(TGT) | ||||||
|  | $(DIR)/%$(EXESUF) : $(TOP)/win32/tools/%.c | ||||||
|  | 	$(CC) -Os -s -w -o $@ $< $(TGT) | ||||||
|  | 
 | ||||||
|  | $(OBJ) $(XAR) : $(DIR)/exists | ||||||
|  | $(DIR)/exists : | ||||||
|  | 	mkdir -p $(DIR) | ||||||
|  | 	@echo $@ > $@ | ||||||
|  | 
 | ||||||
|  | clean : | ||||||
|  | 	rm -rfv i386-win32 x86_64-win32 i386 x86_64 | ||||||
							
								
								
									
										28
									
								
								libtcc.c
									
										
									
									
									
								
							
							
						
						
									
										28
									
								
								libtcc.c
									
										
									
									
									
								
							|  | @ -1273,16 +1273,11 @@ LIBTCCAPI int tcc_set_output_type(TCCState *s, int output_type) | ||||||
|         tcc_add_sysinclude_path(s, CONFIG_SYSROOT "/usr/local/include"); |         tcc_add_sysinclude_path(s, CONFIG_SYSROOT "/usr/local/include"); | ||||||
|         tcc_add_sysinclude_path(s, CONFIG_SYSROOT "/usr/include"); |         tcc_add_sysinclude_path(s, CONFIG_SYSROOT "/usr/include"); | ||||||
| #endif | #endif | ||||||
|         tcc_add_sysinclude_path(s, CONFIG_SYSROOT CONFIG_TCCDIR "/include"); |  | ||||||
|         snprintf(buf, sizeof(buf), "%s/include", s->tcc_lib_path); |         snprintf(buf, sizeof(buf), "%s/include", s->tcc_lib_path); | ||||||
|         tcc_add_sysinclude_path(s, buf); |         tcc_add_sysinclude_path(s, buf); | ||||||
| #ifdef TCC_TARGET_PE | #ifdef TCC_TARGET_PE | ||||||
|         snprintf(buf, sizeof(buf), "%s/win32/include", s->tcc_lib_path); |  | ||||||
|         tcc_add_sysinclude_path(s, buf); |  | ||||||
|         snprintf(buf, sizeof(buf), "%s/include/winapi", s->tcc_lib_path); |         snprintf(buf, sizeof(buf), "%s/include/winapi", s->tcc_lib_path); | ||||||
|         tcc_add_sysinclude_path(s, buf); |         tcc_add_sysinclude_path(s, buf); | ||||||
|         snprintf(buf, sizeof(buf), "%s/win32/include/winapi", s->tcc_lib_path); |  | ||||||
|         tcc_add_sysinclude_path(s, buf); |  | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -1323,30 +1318,13 @@ LIBTCCAPI int tcc_set_output_type(TCCState *s, int output_type) | ||||||
|             tcc_add_file(s, CONFIG_TCC_CRT_PREFIX "/crt1.o"); |             tcc_add_file(s, CONFIG_TCC_CRT_PREFIX "/crt1.o"); | ||||||
|         tcc_add_file(s, CONFIG_TCC_CRT_PREFIX "/crti.o"); |         tcc_add_file(s, CONFIG_TCC_CRT_PREFIX "/crti.o"); | ||||||
|     } |     } | ||||||
| #if defined(TCC_TARGET_X86_64) |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/lib64", s->tcc_lib_path); |  | ||||||
|     tcc_set_lib_path(s, buf); |  | ||||||
| #elif defined(TCC_TARGET_I386) |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/lib", s->tcc_lib_path); |  | ||||||
|     tcc_set_lib_path(s, buf); |  | ||||||
| #endif |  | ||||||
| #endif | #endif | ||||||
|  | 
 | ||||||
| #ifdef TCC_TARGET_PE | #ifdef TCC_TARGET_PE | ||||||
|     snprintf(buf, sizeof(buf), "%s/win32/lib", s->tcc_lib_path); | #ifdef CONFIG_TCC_CROSSLIB | ||||||
|  |     snprintf(buf, sizeof(buf), "%s/" CONFIG_TCC_CROSSLIB, s->tcc_lib_path); | ||||||
|     tcc_add_library_path(s, buf); |     tcc_add_library_path(s, buf); | ||||||
| #if defined(TCC_TARGET_X86_64) |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/win32/lib/64", s->tcc_lib_path); |  | ||||||
|     tcc_add_library_path(s, buf); |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/lib/64", s->tcc_lib_path); |  | ||||||
| #elif defined(TCC_TARGET_I386) |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/win32/lib/32", s->tcc_lib_path); |  | ||||||
|     tcc_add_library_path(s, buf); |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/lib/32", s->tcc_lib_path); |  | ||||||
| #else |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/win32/lib/other", s->tcc_lib_path); |  | ||||||
| #endif | #endif | ||||||
|     tcc_add_library_path(s, buf); |  | ||||||
|     /* support deprecated -Bwin32 */ |  | ||||||
|     snprintf(buf, sizeof(buf), "%s/lib", s->tcc_lib_path); |     snprintf(buf, sizeof(buf), "%s/lib", s->tcc_lib_path); | ||||||
|     tcc_add_library_path(s, buf); |     tcc_add_library_path(s, buf); | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
|  |  | ||||||
|  | @ -14,6 +14,10 @@ TESTS = libtest test3 | ||||||
| TOP = .. | TOP = .. | ||||||
| include $(TOP)/Makefile | include $(TOP)/Makefile | ||||||
| 
 | 
 | ||||||
|  | ifdef DISABLE_STATIC | ||||||
|  | export LD_LIBRARY_PATH:=$(CURDIR)/.. | ||||||
|  | endif | ||||||
|  | 
 | ||||||
| # run local version of tcc with local libraries and includes
 | # run local version of tcc with local libraries and includes
 | ||||||
| TCC = ../tcc -B.. | TCC = ../tcc -B.. | ||||||
| RUN_TCC = $(NATIVE_DEFINES) -run ../tcc.c -B.. | RUN_TCC = $(NATIVE_DEFINES) -run ../tcc.c -B.. | ||||||
|  | @ -22,23 +26,21 @@ DISAS=objdump -d | ||||||
| all test : $(TESTS) | all test : $(TESTS) | ||||||
| 
 | 
 | ||||||
| # make sure that tcc exists
 | # make sure that tcc exists
 | ||||||
| $(TESTS) : ../tcc | test1 test2 test3 test4 btest speedtest asmtest : ../tcc | ||||||
| 
 | ../%: | ||||||
| ../tcc ../libtcc.a : | 	$(MAKE) -C .. $* | ||||||
| 	$(MAKE) -C .. |  | ||||||
| 
 | 
 | ||||||
| # libtcc test
 | # libtcc test
 | ||||||
| libtest: libtcc_test$(EXESUF) | libtest: libtcc_test$(EXESUF) ../libtcc1.a | ||||||
| 	@echo ------------ $@ ------------ | 	@echo ------------ $@ ------------ | ||||||
| 	./libtcc_test lib_path=.. | 	./libtcc_test$(EXESUF) lib_path=.. | ||||||
| 
 | 
 | ||||||
| libtcc_test$(EXESUF): libtcc_test.c ../libtcc.a | libtcc_test$(EXESUF): libtcc_test.c ../$(LIBTCC) | ||||||
| 	$(CC) -o $@ $^ -I.. $(CFLAGS) $(LIBS) | 	$(CC) -o $@ $^ -I.. $(CFLAGS) $(LIBS) $(LINK_LIBTCC) | ||||||
| 
 | 
 | ||||||
| # test.ref - generate using gcc
 | # test.ref - generate using gcc
 | ||||||
| test.ref: tcctest.c | test.ref: tcctest.c | ||||||
| 	cp -u ../include/tcclib.h . | 	$(CC) -o tcctest.gcc $< -w $(CFLAGS) -I../include  | ||||||
| 	$(CC) -o tcctest.gcc $< -I. -w $(CFLAGS) |  | ||||||
| 	./tcctest.gcc > $@ | 	./tcctest.gcc > $@ | ||||||
| 
 | 
 | ||||||
| # auto test
 | # auto test
 | ||||||
|  | @ -84,7 +86,7 @@ test4: test.ref | ||||||
| BOUNDS_OK  = 1 4 8 10 14 | BOUNDS_OK  = 1 4 8 10 14 | ||||||
| BOUNDS_FAIL= 2 5 7 9 11 12 13 15 | BOUNDS_FAIL= 2 5 7 9 11 12 13 15 | ||||||
| 
 | 
 | ||||||
| btest: boundtest.c | btest: boundtest.c ../bcheck.o | ||||||
| 	@echo ------------ $@ ------------ | 	@echo ------------ $@ ------------ | ||||||
| 	@for i in $(BOUNDS_OK); do \
 | 	@for i in $(BOUNDS_OK); do \
 | ||||||
| 	   echo ; echo --- boundtest $$i ---; \
 | 	   echo ; echo --- boundtest $$i ---; \
 | ||||||
|  |  | ||||||
|  | @ -1,59 +1,62 @@ | ||||||
| @rem ---------------------------------------------------- | @rem ---------------------------------------------------- | ||||||
| @rem batch file to build tcc using gcc and ar from mingw | @rem batch file to build tcc using gcc and ar from mingw | ||||||
| @rem ---------------------------------------------------- | @rem ---------------------------------------------------- | ||||||
| @set PROMPT=$G$S |  | ||||||
| 
 | 
 | ||||||
| echo>..\config.h #define TCC_VERSION "0.9.25" | echo>..\config.h #define TCC_VERSION "0.9.25" | ||||||
| echo>>..\config.h #define CONFIG_TCCDIR "." | echo>>..\config.h #define CONFIG_TCCDIR "." | ||||||
| echo>>..\config.h #define CONFIG_SYSROOT "" | echo>>..\config.h #define CONFIG_SYSROOT "" | ||||||
| @set target=-DTCC_TARGET_PE -DTCC_TARGET_I386 |  | ||||||
| @set CC=gcc |  | ||||||
| @set AR=ar |  | ||||||
| 
 | 
 | ||||||
| @if _%PROCESSOR_ARCHITEW6432%_==_AMD64_ goto x86_64 | @if _%PROCESSOR_ARCHITEW6432%_==_AMD64_ goto x86_64 | ||||||
| @if _%PROCESSOR_ARCHITECTURE%_==_AMD64_ goto x86_64 | @if _%PROCESSOR_ARCHITECTURE%_==_AMD64_ goto x86_64 | ||||||
|  | 
 | ||||||
|  | @set target=-DTCC_TARGET_PE -DTCC_TARGET_I386 | ||||||
|  | @set CC=gcc -Os -s | ||||||
|  | @set AR=ar | ||||||
|  | @set P=32 | ||||||
| @goto tools | @goto tools | ||||||
| 
 | 
 | ||||||
| :x86_64 | :x86_64 | ||||||
| @set target=-DTCC_TARGET_PE -DTCC_TARGET_X86_64 | @set target=-DTCC_TARGET_PE -DTCC_TARGET_X86_64 | ||||||
| @set CC=x86_64-pc-mingw32-gCC | @rem mingw 64 has an ICE with -Os | ||||||
|  | @set CC=x86_64-pc-mingw32-gcc -O0 -s | ||||||
| @set AR=x86_64-pc-mingw32-ar | @set AR=x86_64-pc-mingw32-ar | ||||||
| @set S=_64 | @set P=64 | ||||||
| @goto tools |  | ||||||
| 
 | 
 | ||||||
| :tools | :tools | ||||||
| %CC% %target% -Os tools/tiny_impdef.c -o tiny_impdef.exe -s | %CC% %target% tools/tiny_impdef.c -o tiny_impdef.exe | ||||||
| %CC% %target% -Os tools/tiny_libmaker.c -o tiny_libmaker.exe -s | %CC% %target% tools/tiny_libmaker.c -o tiny_libmaker.exe | ||||||
| 
 | 
 | ||||||
| :libtcc | :libtcc | ||||||
| if not exist libtcc\nul mkdir libtcc | if not exist libtcc\nul mkdir libtcc | ||||||
| copy ..\libtcc.h libtcc\libtcc.h | copy ..\libtcc.h libtcc\libtcc.h | ||||||
| %CC% %target% -Os -fno-strict-aliasing ../libtcc.c -c -o libtcc.o | %CC% %target% -fno-strict-aliasing ../libtcc.c -c -o libtcc.o | ||||||
| %AR% rcs libtcc/libtcc.a libtcc.o | %AR% rcs libtcc/libtcc.a libtcc.o | ||||||
| 
 | 
 | ||||||
| :tcc | :tcc | ||||||
| %CC% %target% -Os -fno-strict-aliasing ../tcc.c -o tcc.exe -s -DTCC_USE_LIBTCC -ltcc -Llibtcc | %CC% %target% -fno-strict-aliasing ../tcc.c -o tcc.exe -DTCC_USE_LIBTCC -ltcc -Llibtcc | ||||||
| 
 | 
 | ||||||
| :copy_std_includes | :copy_std_includes | ||||||
| copy ..\include\*.h include | copy ..\include\*.h include | ||||||
| 
 | 
 | ||||||
| :libtcc1.a | :libtcc1.a | ||||||
|  | .\tcc %target% -c ../lib/libtcc1.c | ||||||
| .\tcc %target% -c lib/crt1.c | .\tcc %target% -c lib/crt1.c | ||||||
| .\tcc %target% -c lib/wincrt1.c | .\tcc %target% -c lib/wincrt1.c | ||||||
| .\tcc %target% -c lib/dllcrt1.c | .\tcc %target% -c lib/dllcrt1.c | ||||||
| .\tcc %target% -c lib/dllmain.c | .\tcc %target% -c lib/dllmain.c | ||||||
| .\tcc %target% -c ../lib/libtcc1.c |  | ||||||
| .\tcc %target% -c lib/chkstk.S | .\tcc %target% -c lib/chkstk.S | ||||||
| .\tcc %target% -c ../lib/alloca86%S%.S | @if _%P%_==_64_ goto lib64 | ||||||
| 
 | 
 | ||||||
| @set LIBFILES=crt1.o wincrt1.o dllcrt1.o dllmain.o chkstk.o libtcc1.o alloca86%S%.o | :lib32 | ||||||
| 
 | .\tcc %target% -c ../lib/alloca86.S | ||||||
| @if not _%P%==_ goto makelib | .\tcc %target% -c ../lib/alloca86-bt.S | ||||||
| .\tcc %target% -c ../lib/alloca86-bt%S%.S |  | ||||||
| .\tcc %target% -c ../lib/bcheck.c | .\tcc %target% -c ../lib/bcheck.c | ||||||
|  | tiny_libmaker lib/libtcc1.a libtcc1.o alloca86.o alloca86-bt.o crt1.o wincrt1.o dllcrt1.o dllmain.o chkstk.o bcheck.o | ||||||
|  | @goto the_end | ||||||
| 
 | 
 | ||||||
| @set LIBFILES=%LIBFILES% alloca86-bt%S%.o bcheck.o | :lib64 | ||||||
|  | .\tcc %target% -c ../lib/alloca86_64.S | ||||||
|  | tiny_libmaker lib/libtcc1.a libtcc1.o alloca86_64.o crt1.o wincrt1.o dllcrt1.o dllmain.o chkstk.o | ||||||
| 
 | 
 | ||||||
| :makelib | :the_end | ||||||
| tiny_libmaker lib/libtcc1.a %LIBFILES% |  | ||||||
| del *.o | del *.o | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue