mirror of
https://github.com/mirror/tinycc.git
synced 2025-02-04 06:30:10 +08:00
build: revert Makefiles to 0.9.26 state (mostly)
Except - that libtcc1.a is now installed in subdirs i386/ etc. - the support for arm and arm64 - some of the "Darwin" fixes - tests are mosly unchanged Also - removed the "legacy links for cross compilers" (was total mess) - removed "out-of-tree" build support (was broken anyway)
This commit is contained in:
parent
6d2be31b93
commit
0a624782df
348
Makefile
348
Makefile
@ -4,49 +4,52 @@
|
|||||||
|
|
||||||
TOP ?= .
|
TOP ?= .
|
||||||
include $(TOP)/config.mak
|
include $(TOP)/config.mak
|
||||||
VPATH = $(top_srcdir)
|
VPATH = $(TOP)
|
||||||
|
|
||||||
CPPFLAGS += -I$(TOP) # for config.h
|
ifeq (-$(findstring gcc,$(CC))-,-gcc-)
|
||||||
|
ifeq (-$(GCC_MAJOR)-$(findstring $(GCC_MINOR),56789)-,-4--)
|
||||||
ifneq (-$(findstring gcc,$(CC))-,-gcc-)
|
CFLAGS += -D_FORTIFY_SOURCE=0
|
||||||
ifeq (-$(findstring clang,$(CC))-,-clang-)
|
endif
|
||||||
# make clang accept gnuisms in libtcc1.c
|
else
|
||||||
CFLAGS+=-fheinous-gnu-extensions
|
ifeq (-$(findstring clang,$(CC))-,-clang-)
|
||||||
endif
|
# make clang accept gnuisms in libtcc1.c
|
||||||
|
CFLAGS+=-fheinous-gnu-extensions
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CPPFLAGS_P=$(CPPFLAGS) -DCONFIG_TCC_STATIC
|
CFLAGS_P = $(CFLAGS) -pg -static -DCONFIG_TCC_STATIC
|
||||||
CFLAGS_P=$(CFLAGS) -pg -static
|
|
||||||
LIBS_P=
|
LIBS_P=
|
||||||
LDFLAGS_P=$(LDFLAGS)
|
LDFLAGS_P = $(LDFLAGS)
|
||||||
|
|
||||||
ifdef CONFIG_WIN64
|
LIBTCC = libtcc.a
|
||||||
CONFIG_WIN32=yes
|
LIBTCC1 = libtcc1.a
|
||||||
endif
|
LINK_LIBTCC =
|
||||||
|
LIBS =
|
||||||
|
|
||||||
ifndef CONFIG_WIN32
|
ifdef CONFIG_WIN32
|
||||||
LIBS=-lm
|
ifeq ($(ARCH),x86-64)
|
||||||
ifndef CONFIG_NOLDL
|
CONFIG_WIN64=yes
|
||||||
LIBS+=-ldl
|
endif
|
||||||
endif
|
STRIP_BINARIES = yes
|
||||||
endif
|
LIBTCC = libtcc.dll
|
||||||
|
|
||||||
# make libtcc as static or dynamic library?
|
|
||||||
ifdef DISABLE_STATIC
|
|
||||||
ifndef CONFIG_WIN32
|
|
||||||
LIBTCC=libtcc.so.1.0
|
|
||||||
else
|
else
|
||||||
LIBTCC=libtcc.dll
|
LIBS=-lm
|
||||||
LIBTCC_DLL=yes
|
ifndef CONFIG_NOLDL
|
||||||
LIBTCC_EXTRA=libtcc.def libtcc.a
|
LIBS+=-ldl
|
||||||
|
endif
|
||||||
|
# make libtcc as static or dynamic library?
|
||||||
|
ifdef DISABLE_STATIC
|
||||||
|
LIBTCC=libtcc.so
|
||||||
|
ifndef DISABLE_RPATH
|
||||||
|
LINK_LIBTCC += -Wl,-rpath,"$(libdir)"
|
||||||
|
export LD_LIBRARY_PATH := $(CURDIR)/$(TOP)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
LINK_LIBTCC=-Wl,-rpath,"$(libdir)"
|
|
||||||
ifdef DISABLE_RPATH
|
ifeq ($(TARGETOS),Darwin)
|
||||||
LINK_LIBTCC=
|
CFLAGS += -Wl,-flat_namespace,-undefined,warning
|
||||||
endif
|
export MACOSX_DEPLOYMENT_TARGET:=10.2
|
||||||
else
|
|
||||||
LIBTCC=libtcc.a
|
|
||||||
LINK_LIBTCC=
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CONFIG_$(ARCH) = yes
|
CONFIG_$(ARCH) = yes
|
||||||
@ -64,53 +67,20 @@ NATIVE_DEFINES += $(NATIVE_DEFINES_yes)
|
|||||||
ifeq ($(TOP),.)
|
ifeq ($(TOP),.)
|
||||||
|
|
||||||
PROGS=tcc$(EXESUF)
|
PROGS=tcc$(EXESUF)
|
||||||
I386_CROSS = i386-linux-gnu-tcc$(EXESUF)
|
I386_CROSS = i386-tcc$(EXESUF)
|
||||||
WIN32_CROSS = i386-win-mingw32-tcc$(EXESUF)
|
WIN32_CROSS = i386-win32-tcc$(EXESUF)
|
||||||
WIN64_CROSS = x86_64-win-mingw32-tcc$(EXESUF)
|
WIN64_CROSS = x86_64-win32-tcc$(EXESUF)
|
||||||
WINCE_CROSS = arm-win-mingw32ce-tcc$(EXESUF)
|
WINCE_CROSS = arm-wince-tcc$(EXESUF)
|
||||||
X64_CROSS = x86_64-linux-gnu-tcc$(EXESUF)
|
X64_CROSS = x86_64-tcc$(EXESUF)
|
||||||
ARM_FPA_CROSS = arm-linux-fpa-tcc$(EXESUF)
|
ARM_FPA_CROSS = arm-fpa-tcc$(EXESUF)
|
||||||
ARM_FPA_LD_CROSS = arm-linux-fpa-ld-tcc$(EXESUF)
|
ARM_FPA_LD_CROSS = arm-fpa-ld-tcc$(EXESUF)
|
||||||
ARM_VFP_CROSS = arm-linux-gnu-tcc$(EXESUF)
|
ARM_VFP_CROSS = arm-vfp-tcc$(EXESUF)
|
||||||
ARM_EABI_CROSS = arm-linux-gnueabi-tcc$(EXESUF)
|
ARM_EABI_CROSS = arm-eabi-tcc$(EXESUF)
|
||||||
ARM_EABIHF_CROSS = arm-linux-gnueabihf-tcc$(EXESUF)
|
ARM_EABIHF_CROSS = arm-eabihf-tcc$(EXESUF)
|
||||||
ARM_CROSS = $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS)
|
ARM_CROSS = $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS)
|
||||||
ARM64_CROSS = arm64-tcc$(EXESUF)
|
ARM64_CROSS = arm64-tcc$(EXESUF)
|
||||||
C67_CROSS = c67-tcc$(EXESUF)
|
C67_CROSS = c67-tcc$(EXESUF)
|
||||||
|
|
||||||
# Legacy symlinks for cross compilers
|
|
||||||
$(I386_CROSS)_LINK = i386-tcc$(EXESUF)
|
|
||||||
$(WIN32_CROSS)_LINK = i386-win-tcc$(EXESUF)
|
|
||||||
$(WIN64_CROSS)_LINK = x86_64-win-tcc$(EXESUF)
|
|
||||||
$(WINCE_CROSS)_LINK = arm-win-tcc$(EXESUF)
|
|
||||||
$(X64_CROSS)_LINK = x86_64-tcc$(EXESUF)
|
|
||||||
$(ARM_FPA_CROSS)_LINK = arm-fpa-tcc$(EXESUF)
|
|
||||||
$(ARM_FPA_LD_CROSS)_LINK = arm-fpa-ld-tcc$(EXESUF)
|
|
||||||
$(ARM_VFP_CROSS)_LINK = arm-vfp-tcc$(EXESUF)
|
|
||||||
$(ARM_EABI_CROSS)_LINK = arm-eabi-tcc$(EXESUF)
|
|
||||||
|
|
||||||
ifeq ($(TARGETOS),Windows)
|
|
||||||
ifeq ($(ARCH),i386)
|
|
||||||
PROGS:=$($(WIN32_CROSS)_LINK)
|
|
||||||
$($(WIN32_CROSS)_LINK)_TCC = yes
|
|
||||||
endif
|
|
||||||
ifeq ($(ARCH),x86-64)
|
|
||||||
PROGS:=$($(WIN64_CROSS)_LINK)
|
|
||||||
$($(WIN64_CROSS)_LINK)_TCC = yes
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(TARGETOS),Linux)
|
|
||||||
ifeq ($(ARCH),i386)
|
|
||||||
PROGS:=$($(I386_CROSS)_LINK)
|
|
||||||
$($(I386_CROSS)_LINK)_TCC = yes
|
|
||||||
endif
|
|
||||||
ifeq ($(ARCH),x86-64)
|
|
||||||
PROGS:=$($(X64_CROSS)_LINK)
|
|
||||||
$($(X64_CROSS)_LINK)_TCC = yes
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
|
CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
|
||||||
CORE_FILES += tcc.h config.h libtcc.h tcctok.h
|
CORE_FILES += tcc.h config.h libtcc.h tcctok.h
|
||||||
I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
|
I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
|
||||||
@ -126,102 +96,84 @@ ifdef CONFIG_WIN64
|
|||||||
PROGS+=tiny_impdef$(EXESUF)
|
PROGS+=tiny_impdef$(EXESUF)
|
||||||
NATIVE_FILES=$(WIN64_FILES)
|
NATIVE_FILES=$(WIN64_FILES)
|
||||||
PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a
|
LIBTCC1_CROSS=lib/i386-win32/libtcc1.a
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
else ifdef CONFIG_WIN32
|
else ifdef CONFIG_WIN32
|
||||||
PROGS+=tiny_impdef$(EXESUF)
|
PROGS+=tiny_impdef$(EXESUF)
|
||||||
NATIVE_FILES=$(WIN32_FILES)
|
NATIVE_FILES=$(WIN32_FILES)
|
||||||
PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/x86_64-win/libtcc1.a
|
LIBTCC1_CROSS=lib/x86_64-win32/libtcc1.a
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
else ifeq ($(ARCH),i386)
|
else ifeq ($(ARCH),i386)
|
||||||
NATIVE_FILES=$(I386_FILES)
|
NATIVE_FILES=$(I386_FILES)
|
||||||
PROGS_CROSS=$($(X64_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a lib/x86_64/libtcc1.a \
|
LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a
|
||||||
lib/arm64/libtcc1.a
|
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
else ifeq ($(ARCH),x86-64)
|
else ifeq ($(ARCH),x86-64)
|
||||||
ifeq ($(TARGETOS),Darwin)
|
|
||||||
NATIVE_FILES=$(X86_64_FILES)
|
NATIVE_FILES=$(X86_64_FILES)
|
||||||
PROGS_CROSS=$($(I386_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(I386_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a lib/x86_64/libtcc1.a
|
LIBTCC1_CROSS=lib/i386-win32/libtcc1.a lib/x86_64-win32/libtcc1.a
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
else
|
|
||||||
NATIVE_FILES=$(X86_64_FILES)
|
|
||||||
PROGS_CROSS=$($(I386_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a lib/x86_64/libtcc1.a \
|
|
||||||
lib/arm64/libtcc1.a
|
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
endif
|
|
||||||
else ifeq ($(ARCH),arm)
|
else ifeq ($(ARCH),arm)
|
||||||
NATIVE_FILES=$(ARM_FILES)
|
NATIVE_FILES=$(ARM_FILES)
|
||||||
PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
|
|
||||||
else ifeq ($(ARCH),arm64)
|
else ifeq ($(ARCH),arm64)
|
||||||
NATIVE_FILES=$(ARM64_FILES)
|
NATIVE_FILES=$(ARM64_FILES)
|
||||||
PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1=libtcc1.a
|
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
|
|
||||||
endif
|
endif
|
||||||
PROGS_CROSS_LINK=$(foreach PROG_CROSS,$(PROGS_CROSS),$($(PROG_CROSS)_LINK))
|
|
||||||
|
|
||||||
PROGS+=tiny_libmaker$(EXESUF)
|
ifeq ($(TARGETOS),Darwin)
|
||||||
|
PROGS += tiny_libmaker$(EXESUF)
|
||||||
|
endif
|
||||||
|
|
||||||
TCCLIBS = $(LIBTCC1) $(LIBTCC) $(LIBTCC_EXTRA)
|
TCCLIBS = $(LIBTCC1) $(LIBTCC)
|
||||||
TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
|
TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
|
||||||
|
|
||||||
ifdef CONFIG_CROSS
|
ifdef CONFIG_CROSS
|
||||||
PROGS+=$(PROGS_CROSS)
|
PROGS += $(PROGS_CROSS)
|
||||||
TCCLIBS+=$(LIBTCC1_CROSS)
|
TCCLIBS += $(LIBTCC1_CROSS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
||||||
|
|
||||||
ifdef ONE_SOURCE
|
|
||||||
NATIVE_TCC_REQUISITES=tcc.o
|
|
||||||
else
|
|
||||||
NATIVE_TCC_REQUISITES=tcc.o $(LIBTCC)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Host Tiny C Compiler
|
# Host Tiny C Compiler
|
||||||
tcc$(EXESUF): $(NATIVE_TCC_REQUISITES)
|
tcc$(EXESUF): tcc.c $(LIBTCC)
|
||||||
$(CC) -o $@ $^ $(LIBS) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) $(LINK_LIBTCC)
|
$(CC) -o $@ $^ $(LIBS) $(CFLAGS) $(LDFLAGS) $(LINK_LIBTCC)
|
||||||
|
|
||||||
# Cross Tiny C Compilers
|
# Cross Tiny C Compilers
|
||||||
%-tcc$(EXESUF): tcc.c
|
%-tcc$(EXESUF): tcc.c
|
||||||
$(CC) -o $@ $< -DONE_SOURCE $(if $($@_TCC),$(NATIVE_DEFINES),$(DEFINES)) $(CPPFLAGS) $(CFLAGS) $(LIBS) $(LDFLAGS)
|
$(CC) -o $@ $< -DONE_SOURCE $(DEFINES) $(CFLAGS) $(LIBS) $(LDFLAGS)
|
||||||
$(if $($@_LINK),ln -sf $@ $($@_LINK))
|
|
||||||
$(if $($@_TCC),ln -sf $@ tcc$(EXESUF))
|
|
||||||
|
|
||||||
# profiling version
|
# profiling version
|
||||||
tcc_p$(EXESUF): $(NATIVE_FILES)
|
tcc_p$(EXESUF): $(NATIVE_FILES)
|
||||||
$(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
|
$(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
|
||||||
|
|
||||||
$(I386_CROSS) $($(I386_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386
|
$(I386_CROSS): DEFINES = -DTCC_TARGET_I386 \
|
||||||
$(X64_CROSS) $($(X64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64
|
-DCONFIG_TCCDIR="\"$(tccdir)/i386\""
|
||||||
$(WIN32_CROSS) $($(WIN32_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
|
$(X64_CROSS) : DEFINES = -DTCC_TARGET_X86_64
|
||||||
|
-DCONFIG_TCCDIR="\"$(tccdir)/x86_64\""
|
||||||
|
$(WIN32_CROSS) : DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
|
||||||
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
|
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
|
||||||
$(WIN64_CROSS) $($(WIN64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
|
$(WIN64_CROSS) : DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
|
||||||
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
|
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
|
||||||
$(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
|
$(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
|
||||||
$(C67_CROSS): DEFINES = -DTCC_TARGET_C67
|
$(C67_CROSS): DEFINES = -DTCC_TARGET_C67 -w # disable warnigs
|
||||||
$(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
|
$(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
|
||||||
$(ARM_FPA_LD_CROSS)$(EXESUF): DEFINES = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
|
$(ARM_FPA_LD_CROSS)$(EXESUF): DEFINES = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
|
||||||
$(ARM_VFP_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_VFP
|
$(ARM_VFP_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_VFP
|
||||||
$(ARM_EABI_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_EABI -DTCC_ARM_VFP
|
$(ARM_EABI_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_EABI -DTCC_ARM_VFP
|
||||||
$(ARM64_CROSS): DEFINES = -DTCC_TARGET_ARM64
|
$(ARM64_CROSS): DEFINES = -DTCC_TARGET_ARM64
|
||||||
|
|
||||||
$(I386_CROSS) $($(I386_CROSS)_LINK): $(I386_FILES)
|
$(I386_CROSS) : $(I386_FILES)
|
||||||
$(X64_CROSS) $($(X64_CROSS)_LINK): $(X86_64_FILES)
|
$(X64_CROSS) : $(X86_64_FILES)
|
||||||
$(WIN32_CROSS) $($(WIN32_CROSS)_LINK): $(WIN32_FILES)
|
$(WIN32_CROSS) : $(WIN32_FILES)
|
||||||
$(WIN64_CROSS) $($(WIN64_CROSS)_LINK): $(WIN64_FILES)
|
$(WIN64_CROSS) : $(WIN64_FILES)
|
||||||
$(WINCE_CROSS) $($(WINCE_CROSS)_LINK): $(WINCE_FILES)
|
$(WINCE_CROSS) : $(WINCE_FILES)
|
||||||
$(C67_CROSS) $($(C67_CROSS)_LINK): $(C67_FILES)
|
$(C67_CROSS) : $(C67_FILES)
|
||||||
$(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS): $(ARM_FILES)
|
$(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS): $(ARM_FILES)
|
||||||
$($(ARM_FPA_CROSS)_LINK) $($(ARM_FPA_LD_CROSS)_LINK) $($(ARM_VFP_CROSS)_LINK) $($(ARM_EABI_CROSS)_LINK): $(ARM_FILES)
|
|
||||||
$(ARM64_CROSS): $(ARM64_FILES)
|
$(ARM64_CROSS): $(ARM64_FILES)
|
||||||
|
|
||||||
# libtcc generation and test
|
# libtcc generation and test
|
||||||
@ -236,34 +188,33 @@ tcc.o : NATIVE_DEFINES += -DONE_SOURCE
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
$(LIBTCC_OBJ) tcc.o : %.o : %.c $(LIBTCC_INC)
|
$(LIBTCC_OBJ) tcc.o : %.o : %.c $(LIBTCC_INC)
|
||||||
$(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CPPFLAGS) $(CFLAGS)
|
$(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CFLAGS)
|
||||||
|
|
||||||
ifndef LIBTCC_DLL
|
|
||||||
libtcc.a: $(LIBTCC_OBJ)
|
libtcc.a: $(LIBTCC_OBJ)
|
||||||
$(AR) rcs $@ $^
|
$(AR) rcs $@ $^
|
||||||
endif
|
|
||||||
|
|
||||||
libtcc.so.1.0: $(LIBTCC_OBJ)
|
libtcc.so: $(LIBTCC_OBJ)
|
||||||
$(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS)
|
$(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS)
|
||||||
|
|
||||||
libtcc.so.1.0: CFLAGS+=-fPIC
|
libtcc.so: CFLAGS+=-fPIC
|
||||||
|
|
||||||
ifdef LIBTCC_DLL
|
# windows : libtcc.dll
|
||||||
libtcc.dll libtcc.def libtcc.a: $(LIBTCC_OBJ)
|
libtcc.dll : $(LIBTCC_OBJ) tiny_impdef$(EXESUF)
|
||||||
$(CC) -shared $^ -o $@ $(LDFLAGS) -Wl,--output-def,libtcc.def,--out-implib,libtcc.a
|
$(CC) -shared $(LIBTCC_OBJ) -o $@ $(LDFLAGS)
|
||||||
|
./tiny_impdef $@
|
||||||
|
|
||||||
|
libtcc.dll : NATIVE_DEFINES += -DLIBTCC_AS_DLL
|
||||||
|
|
||||||
|
# windows : utilities
|
||||||
|
tiny_%$(EXESUF): $(SRCTOP)/win32/tools/tiny_%.c
|
||||||
|
$(CC) -o $@ $< $(CFLAGS) $(LDFLAGS) $(NATIVE_DEFINES)
|
||||||
|
|
||||||
|
ifneq ($(LIBTCC1),)
|
||||||
|
# TinyCC runtime libraries
|
||||||
|
$(LIBTCC1) : FORCE $(PROGS)
|
||||||
|
$(MAKE) -C lib native
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# windows utilities
|
|
||||||
tiny_impdef$(EXESUF): win32/tools/tiny_impdef.c
|
|
||||||
$(CC) -o $@ $< $(CPPFLAGS) $(CFLAGS) $(LDFLAGS)
|
|
||||||
tiny_libmaker$(EXESUF): win32/tools/tiny_libmaker.c
|
|
||||||
$(CC) -o $@ $< $(CPPFLAGS) $(CFLAGS) $(LDFLAGS)
|
|
||||||
|
|
||||||
# TinyCC runtime libraries
|
|
||||||
libtcc1.a : FORCE $(PROGS)
|
|
||||||
$(MAKE) -C lib native
|
|
||||||
if test ! -d $(ARCH); then mkdir $(ARCH); fi
|
|
||||||
if test ! -L $(ARCH)/$@; then ln -sf ../$@ $(ARCH)/$@; fi
|
|
||||||
lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
|
lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
|
||||||
$(MAKE) -C lib cross TARGET=$*
|
$(MAKE) -C lib cross TARGET=$*
|
||||||
|
|
||||||
@ -272,27 +223,20 @@ FORCE:
|
|||||||
# install
|
# install
|
||||||
TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h
|
TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h
|
||||||
INSTALL=install
|
INSTALL=install
|
||||||
ifdef STRIP_BINARIES
|
|
||||||
INSTALLBIN=$(INSTALL) -s
|
|
||||||
else
|
|
||||||
INSTALLBIN=$(INSTALL)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifdef CONFIG_WIN32
|
ifdef STRIP_BINARIES
|
||||||
CONFIG_WIN=yes
|
INSTALLBIN=$(INSTALL) -s
|
||||||
endif
|
else
|
||||||
ifdef CONFIG_WIN64
|
INSTALLBIN=$(INSTALL)
|
||||||
CONFIG_WIN=yes
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
install-strip: install
|
install-strip: install
|
||||||
strip $(foreach PROG,$(PROGS),"$(bindir)"/$(PROG))
|
strip $(foreach PROG,$(PROGS),"$(bindir)"/$(PROG))
|
||||||
|
|
||||||
ifndef CONFIG_WIN
|
ifndef CONFIG_WIN32
|
||||||
install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
||||||
mkdir -p "$(bindir)"
|
mkdir -p "$(bindir)"
|
||||||
$(INSTALLBIN) -m755 $(PROGS) "$(bindir)"
|
$(INSTALLBIN) -m755 $(PROGS) "$(bindir)"
|
||||||
cp -P tcc$(EXESUF) "$(bindir)"
|
|
||||||
mkdir -p "$(mandir)/man1"
|
mkdir -p "$(mandir)/man1"
|
||||||
-$(INSTALL) -m644 tcc.1 "$(mandir)/man1"
|
-$(INSTALL) -m644 tcc.1 "$(mandir)/man1"
|
||||||
mkdir -p "$(infodir)"
|
mkdir -p "$(infodir)"
|
||||||
@ -300,46 +244,32 @@ install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
|||||||
mkdir -p "$(tccdir)"
|
mkdir -p "$(tccdir)"
|
||||||
mkdir -p "$(tccdir)/include"
|
mkdir -p "$(tccdir)/include"
|
||||||
ifneq ($(LIBTCC1),)
|
ifneq ($(LIBTCC1),)
|
||||||
mkdir -p "$(tccdir)/$(ARCH)"
|
$(INSTALL) -m644 $(LIBTCC1) "$(tccdir)"
|
||||||
$(INSTALL) -m644 $(LIBTCC1) "$(tccdir)/$(ARCH)"
|
|
||||||
endif
|
endif
|
||||||
$(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
|
$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) tcclib.h "$(tccdir)/include"
|
||||||
mkdir -p "$(libdir)"
|
mkdir -p "$(libdir)"
|
||||||
$(INSTALL) -m644 $(LIBTCC) "$(libdir)"
|
$(INSTALL) -m644 $(LIBTCC) "$(libdir)"
|
||||||
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"
|
|
||||||
endif
|
|
||||||
mkdir -p "$(includedir)"
|
mkdir -p "$(includedir)"
|
||||||
$(INSTALL) -m644 $(top_srcdir)/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/32"
|
mkdir -p "$(tccdir)/win32/lib/32"
|
||||||
mkdir -p "$(tccdir)/win32/lib/64"
|
mkdir -p "$(tccdir)/win32/lib/64"
|
||||||
mkdir -p "$(tccdir)/i386"
|
$(INSTALL) -m644 win32/lib/*.def "$(tccdir)/win32/lib"
|
||||||
mkdir -p "$(tccdir)/x86-64"
|
-$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/win32/lib/32"
|
||||||
ifneq ($(HOST_OS),Darwin)
|
-$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/win32/lib/64"
|
||||||
mkdir -p "$(tccdir)/arm64"
|
cp -r win32/include/. "$(tccdir)/win32/include"
|
||||||
$(INSTALL) -m644 lib/arm64/libtcc1.a "$(tccdir)/arm64"
|
|
||||||
endif
|
|
||||||
$(INSTALL) -m644 lib/i386/libtcc1.a "$(tccdir)/i386"
|
|
||||||
$(INSTALL) -m644 lib/x86_64/libtcc1.a "$(tccdir)/x86-64"
|
|
||||||
$(INSTALL) -m644 $(top_srcdir)/win32/lib/*.def "$(tccdir)/win32/lib"
|
|
||||||
$(INSTALL) -m644 lib/i386-win/libtcc1.a "$(tccdir)/win32/lib/32"
|
|
||||||
$(INSTALL) -m644 lib/x86_64-win/libtcc1.a "$(tccdir)/win32/lib/64"
|
|
||||||
cp -r $(top_srcdir)/win32/include/. "$(tccdir)/win32/include"
|
|
||||||
cp -r "$(tccdir)/include" "$(tccdir)/win32"
|
cp -r "$(tccdir)/include" "$(tccdir)/win32"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
|
rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
|
||||||
rm -fv "$(bindir)/tcc$(EXESUF)"
|
|
||||||
rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
|
rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
|
||||||
rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
|
rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
|
||||||
rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
|
rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
|
||||||
rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
|
rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
|
||||||
rm -fv "$(libdir)/libtcc.so*"
|
rm -fv $(libdir)/libtcc.so*
|
||||||
rm -rv "$(tccdir)"
|
rm -rv "$(tccdir)"
|
||||||
rm -rv "$(docdir)"
|
rm -rv "$(docdir)"
|
||||||
else
|
else
|
||||||
@ -351,24 +281,23 @@ install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
|||||||
mkdir -p "$(tccdir)/examples"
|
mkdir -p "$(tccdir)/examples"
|
||||||
mkdir -p "$(tccdir)/doc"
|
mkdir -p "$(tccdir)/doc"
|
||||||
mkdir -p "$(tccdir)/libtcc"
|
mkdir -p "$(tccdir)/libtcc"
|
||||||
$(INSTALLBIN) -m755 $(PROGS) "$(tccdir)"
|
$(INSTALLBIN) -m755 $(PROGS) $(LIBTCC) "$(tccdir)"
|
||||||
$(INSTALLBIN) -m755 tcc.exe "$(tccdir)"
|
$(INSTALL) -m644 libtcc1.a win32/lib/*.def "$(tccdir)/lib"
|
||||||
$(INSTALL) -m644 $(LIBTCC1) $(top_srcdir)/win32/lib/*.def "$(tccdir)/lib"
|
cp -r win32/include/. "$(tccdir)/include"
|
||||||
cp -r $(top_srcdir)/win32/include/. "$(tccdir)/include"
|
cp -r win32/examples/. "$(tccdir)/examples"
|
||||||
cp -r $(top_srcdir)/win32/examples/. "$(tccdir)/examples"
|
cp tests/libtcc_test.c "$(tccdir)/examples"
|
||||||
$(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
|
$(INSTALL) -m644 $(addprefix include/,$(TCC_INCLUDES)) tcclib.h "$(tccdir)/include"
|
||||||
$(INSTALL) -m644 tcc-doc.html $(top_srcdir)/win32/tcc-win32.txt "$(tccdir)/doc"
|
$(INSTALL) -m644 tcc-doc.html win32/tcc-win32.txt "$(tccdir)/doc"
|
||||||
$(INSTALL) -m644 $(top_srcdir)/libtcc.h $(LIBTCC_EXTRA) "$(tccdir)/libtcc"
|
$(INSTALL) -m644 libtcc.h libtcc.def "$(tccdir)/libtcc"
|
||||||
$(INSTALL) -m644 $(LIBTCC) "$(tccdir)"
|
|
||||||
ifdef CONFIG_CROSS
|
ifdef CONFIG_CROSS
|
||||||
mkdir -p "$(tccdir)/lib/32"
|
mkdir -p "$(tccdir)/lib/32"
|
||||||
mkdir -p "$(tccdir)/lib/64"
|
mkdir -p "$(tccdir)/lib/64"
|
||||||
-$(INSTALL) -m644 lib/i386-win/libtcc1.a "$(tccdir)/lib/32"
|
-$(INSTALL) -m644 lib/i386-win32/libtcc1.a "$(tccdir)/lib/32"
|
||||||
-$(INSTALL) -m644 lib/x86_64-win/libtcc1.a "$(tccdir)/lib/64"
|
-$(INSTALL) -m644 lib/x86_64-win32/libtcc1.a "$(tccdir)/lib/64"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
rm -rfv "$(tccdir)/*"
|
rm -rfv "$(tccdir)/"*
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# documentation and man page
|
# documentation and man page
|
||||||
@ -376,30 +305,21 @@ tcc-doc.html: tcc-doc.texi
|
|||||||
-makeinfo --no-split --html --number-sections -o $@ $<
|
-makeinfo --no-split --html --number-sections -o $@ $<
|
||||||
|
|
||||||
tcc.1: tcc-doc.texi
|
tcc.1: tcc-doc.texi
|
||||||
-$(top_srcdir)/texi2pod.pl $< tcc.pod
|
-texi2pod.pl $< tcc.pod
|
||||||
-pod2man --section=1 --center="Tiny C Compiler" --release=`cat $(top_srcdir)/VERSION` tcc.pod > $@
|
-pod2man --section=1 --center="Tiny C Compiler" --release="$(VERSION)" tcc.pod > $@
|
||||||
|
|
||||||
tcc-doc.info: tcc-doc.texi
|
tcc-doc.info: tcc-doc.texi
|
||||||
-makeinfo $<
|
-makeinfo $<
|
||||||
|
|
||||||
# in tests subdir
|
# in tests subdir
|
||||||
export LIBTCC1
|
test:
|
||||||
|
$(MAKE) -C tests
|
||||||
%est:
|
|
||||||
$(MAKE) -C tests $@ 'PROGS_CROSS=$(PROGS_CROSS)'
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
|
rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
|
||||||
*.exe a.out tags TAGS libtcc_test$(EXESUF) tcc$(EXESUF)
|
lib*.def *.exe *.dll a.out tags TAGS libtcc_test$(EXESUF) tcc$(EXESUF)
|
||||||
-rm -r $(ARCH) arm64
|
|
||||||
ifeq ($(HOST_OS),Linux)
|
|
||||||
-rm -r ./C:
|
|
||||||
endif
|
|
||||||
-rm *-tcc$(EXESUF)
|
|
||||||
$(MAKE) -C tests $@
|
$(MAKE) -C tests $@
|
||||||
ifneq ($(LIBTCC1),)
|
|
||||||
$(MAKE) -C lib $@
|
$(MAKE) -C lib $@
|
||||||
endif
|
|
||||||
|
|
||||||
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
|
||||||
@ -408,15 +328,13 @@ config.mak:
|
|||||||
@echo "Please run ./configure."
|
@echo "Please run ./configure."
|
||||||
@exit 1
|
@exit 1
|
||||||
|
|
||||||
tags:
|
TAGFILES = *.[ch] include/*.h lib/*.[chS]
|
||||||
ctags $(top_srcdir)/*.[ch] $(top_srcdir)/include/*.h $(top_srcdir)/lib/*.[chS]
|
tags : ; ctags $(TAGFILES)
|
||||||
|
TAGS : ; etags $(TAGFILES)
|
||||||
TAGS:
|
|
||||||
etags $(top_srcdir)/*.[ch] $(top_srcdir)/include/*.h $(top_srcdir)/lib/*.[chS]
|
|
||||||
|
|
||||||
# create release tarball from *current* git branch (including tcc-doc.html
|
# create release tarball from *current* git branch (including tcc-doc.html
|
||||||
# and converting two files to CRLF)
|
# and converting two files to CRLF)
|
||||||
TCC-VERSION := tcc-$(shell cat $(top_srcdir)/VERSION)
|
TCC-VERSION = $(VERSION)
|
||||||
tar: tcc-doc.html
|
tar: tcc-doc.html
|
||||||
mkdir $(TCC-VERSION)
|
mkdir $(TCC-VERSION)
|
||||||
( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
|
( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
|
||||||
@ -428,6 +346,6 @@ tar: tcc-doc.html
|
|||||||
rm -rf $(TCC-VERSION)
|
rm -rf $(TCC-VERSION)
|
||||||
git reset
|
git reset
|
||||||
|
|
||||||
.PHONY: all clean tar tags TAGS distclean install uninstall FORCE
|
.PHONY: all clean test tar tags TAGS distclean install uninstall FORCE
|
||||||
|
|
||||||
endif # ifeq ($(TOP),.)
|
endif # ifeq ($(TOP),.)
|
||||||
|
321
configure
vendored
321
configure
vendored
@ -19,7 +19,6 @@ TMPH=$TMPN.h
|
|||||||
# default parameters
|
# default parameters
|
||||||
build_cross="no"
|
build_cross="no"
|
||||||
use_libgcc="no"
|
use_libgcc="no"
|
||||||
enable_assert="no"
|
|
||||||
prefix=""
|
prefix=""
|
||||||
execprefix=""
|
execprefix=""
|
||||||
bindir=""
|
bindir=""
|
||||||
@ -31,7 +30,6 @@ infodir=""
|
|||||||
sysroot=""
|
sysroot=""
|
||||||
cross_prefix=""
|
cross_prefix=""
|
||||||
cc="gcc"
|
cc="gcc"
|
||||||
host_cc="gcc"
|
|
||||||
ar="ar"
|
ar="ar"
|
||||||
strip="strip"
|
strip="strip"
|
||||||
cygwin="no"
|
cygwin="no"
|
||||||
@ -48,16 +46,10 @@ tcc_lddir=
|
|||||||
confvars=
|
confvars=
|
||||||
cpu=
|
cpu=
|
||||||
|
|
||||||
host_os=`uname`
|
|
||||||
case $host_os in
|
|
||||||
MINGW32*) host_os=Windows; ;;
|
|
||||||
*) ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# OS specific
|
# OS specific
|
||||||
targetos=`uname`
|
targetos=`uname`
|
||||||
case $targetos in
|
case $targetos in
|
||||||
MINGW32*) mingw32=yes; host_os=Windows; ;;
|
MINGW32*) mingw32=yes;;
|
||||||
DragonFly) noldl=yes;;
|
DragonFly) noldl=yes;;
|
||||||
OpenBSD) noldl=yes;;
|
OpenBSD) noldl=yes;;
|
||||||
FreeBSD) noldl=yes;;
|
FreeBSD) noldl=yes;;
|
||||||
@ -76,55 +68,57 @@ if test -z "$source_path" -o "$source_path" = "." ; then
|
|||||||
source_path_used="no"
|
source_path_used="no"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
classify_cpu ()
|
cpu=`uname -m`
|
||||||
{
|
if test $mingw32=yes; then
|
||||||
cpu="$1"
|
if test "$PROCESSOR_ARCHITEW6432" = "AMD64" \
|
||||||
|
-o "$PROCESSOR_ARCHITECTURE" = "AMD64"; then
|
||||||
|
cpu="x86_64"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
case "$cpu" in
|
case "$cpu" in
|
||||||
x86|i386|i486|i586|i686|i86pc|BePC|i686-AT386)
|
x86|i386|i486|i586|i686|i86pc|BePC|i686-AT386)
|
||||||
cpu="x86"
|
cpu="x86"
|
||||||
;;
|
;;
|
||||||
x86_64|amd64)
|
x86_64|amd64)
|
||||||
cpu="x86-64"
|
cpu="x86-64"
|
||||||
;;
|
;;
|
||||||
arm*)
|
arm*)
|
||||||
case "$cpu" in
|
case "$cpu" in
|
||||||
arm|armv4l)
|
arm|armv4l)
|
||||||
cpuver=4
|
cpuver=4
|
||||||
;;
|
;;
|
||||||
armv5tel|armv5tejl)
|
armv5tel|armv5tejl)
|
||||||
cpuver=5
|
cpuver=5
|
||||||
;;
|
;;
|
||||||
armv6j|armv6l)
|
armv6j|armv6l)
|
||||||
cpuver=6
|
cpuver=6
|
||||||
;;
|
;;
|
||||||
armv7a|armv7l)
|
armv7a|armv7l)
|
||||||
cpuver=7
|
cpuver=7
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
cpu="armv4l"
|
cpu="armv4l"
|
||||||
;;
|
;;
|
||||||
aarch64)
|
aarch64)
|
||||||
cpu="aarch64"
|
cpu="aarch64"
|
||||||
;;
|
;;
|
||||||
alpha)
|
alpha)
|
||||||
cpu="alpha"
|
cpu="alpha"
|
||||||
;;
|
;;
|
||||||
"Power Macintosh"|ppc|ppc64)
|
"Power Macintosh"|ppc|ppc64)
|
||||||
cpu="powerpc"
|
cpu="powerpc"
|
||||||
;;
|
;;
|
||||||
mips)
|
mips)
|
||||||
cpu="mips"
|
cpu="mips"
|
||||||
;;
|
;;
|
||||||
s390)
|
s390)
|
||||||
cpu="s390"
|
cpu="s390"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Unsupported CPU: $cpu"
|
cpu="unknown"
|
||||||
exit 1
|
;;
|
||||||
;;
|
esac
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
for opt do
|
for opt do
|
||||||
eval opt=\"$opt\"
|
eval opt=\"$opt\"
|
||||||
@ -155,6 +149,16 @@ for opt do
|
|||||||
;;
|
;;
|
||||||
--cross-prefix=*) cross_prefix=`echo $opt | cut -d '=' -f 2`
|
--cross-prefix=*) cross_prefix=`echo $opt | cut -d '=' -f 2`
|
||||||
;;
|
;;
|
||||||
|
--cc=*) cc=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
|
--ar=*) ar=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
|
--extra-cflags=*) CFLAGS="${opt#--extra-cflags=}"
|
||||||
|
;;
|
||||||
|
--extra-ldflags=*) LDFLAGS="${opt#--extra-ldflags=}"
|
||||||
|
;;
|
||||||
|
--extra-libs=*) extralibs="${opt#--extra-libs=}"
|
||||||
|
;;
|
||||||
--sysincludepaths=*) tcc_sysincludepaths=`echo $opt | cut -d '=' -f 2`
|
--sysincludepaths=*) tcc_sysincludepaths=`echo $opt | cut -d '=' -f 2`
|
||||||
;;
|
;;
|
||||||
--libpaths=*) tcc_libpaths=`echo $opt | cut -d '=' -f 2`
|
--libpaths=*) tcc_libpaths=`echo $opt | cut -d '=' -f 2`
|
||||||
@ -163,32 +167,16 @@ for opt do
|
|||||||
;;
|
;;
|
||||||
--elfinterp=*) tcc_elfinterp=`echo $opt | cut -d '=' -f 2`
|
--elfinterp=*) tcc_elfinterp=`echo $opt | cut -d '=' -f 2`
|
||||||
;;
|
;;
|
||||||
--ar=*) ar=`echo $opt | cut -d '=' -f 2`
|
|
||||||
;;
|
|
||||||
--cc=*) cc=`echo $opt | cut -d '=' -f 2`
|
|
||||||
;;
|
|
||||||
--extra-cflags=*) CFLAGS="${opt#--extra-cflags=}"
|
|
||||||
;;
|
|
||||||
--extra-ldflags=*) LDFLAGS="${opt#--extra-ldflags=}"
|
|
||||||
;;
|
|
||||||
--extra-libs=*) extralibs=${opt#--extra-libs=}
|
|
||||||
;;
|
|
||||||
--cpu=*) cpu=`echo $opt | cut -d '=' -f 2`
|
--cpu=*) cpu=`echo $opt | cut -d '=' -f 2`
|
||||||
;;
|
;;
|
||||||
--enable-gprof) gprof="yes"
|
--enable-gprof) gprof="yes"
|
||||||
;;
|
;;
|
||||||
--enable-mingw32) mingw32="yes" ; cross_prefix="i686-pc-mingw32-" ; cpu=x86; targetos=Windows;
|
--enable-mingw32) mingw32="yes" ; cross_prefix="i686-pc-mingw32-" ; cpu=x86
|
||||||
;;
|
;;
|
||||||
--enable-cygwin) mingw32="yes" ; cygwin="yes" ; cross_prefix="mingw32-" ; cpu=x86; targetos=Windows;
|
--enable-cygwin) mingw32="yes" ; cygwin="yes" ; cross_prefix="mingw32-" ; cpu=x86
|
||||||
;;
|
|
||||||
--enable-tcc32-mingw) mingw32="yes" ; cross_prefix="i386-win-" ; cpu=x86; cc=tcc; targetos=Windows;
|
|
||||||
;;
|
|
||||||
--enable-tcc64-mingw) mingw32="yes" ; cross_prefix="x86_64-win-" ; cpu=x86_64; cc=tcc; targetos=Windows;
|
|
||||||
;;
|
;;
|
||||||
--enable-cross) build_cross="yes"
|
--enable-cross) build_cross="yes"
|
||||||
;;
|
;;
|
||||||
--enable-assert) enable_assert="yes"
|
|
||||||
;;
|
|
||||||
--disable-static) disable_static="yes"
|
--disable-static) disable_static="yes"
|
||||||
;;
|
;;
|
||||||
--disable-rpath) disable_rpath="yes"
|
--disable-rpath) disable_rpath="yes"
|
||||||
@ -206,29 +194,23 @@ for opt do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
if test -z "$cpu" ; then
|
|
||||||
if test -n "$ARCH" ; then
|
|
||||||
cpu="$ARCH"
|
|
||||||
else
|
|
||||||
cpu=`uname -m`
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
classify_cpu "$cpu"
|
|
||||||
|
|
||||||
# Checking for CFLAGS
|
# Checking for CFLAGS
|
||||||
if test -z "$CFLAGS"; then
|
if test -z "$CFLAGS"; then
|
||||||
CFLAGS="-Wall -g -O0"
|
CFLAGS="-Wall -g -O2"
|
||||||
|
if test "$mingw32" = "yes" -a "$cpu" = "x86-64"; then
|
||||||
|
CFLAGS="-m64 $CFLAGS"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$mingw32" = "yes" ; then
|
if test "$mingw32" = "yes" ; then
|
||||||
if test x"$tccdir" = x""; then
|
if test x"$tccdir" = x""; then
|
||||||
tccdir="tcc"
|
tccdir="tcc"
|
||||||
fi
|
fi
|
||||||
if test -z "$prefix" ; then
|
if test -z "$prefix" ; then
|
||||||
prefix="C:/Program Files/${tccdir}"
|
prefix="C:/Program Files/${tccdir}"
|
||||||
fi
|
fi
|
||||||
if test -z "$sharedir" ; then
|
if test -z "$sharedir" ; then
|
||||||
sharedir="${prefix}"
|
sharedir="${prefix}"
|
||||||
fi
|
fi
|
||||||
execprefix="$prefix"
|
execprefix="$prefix"
|
||||||
bindir="${prefix}"
|
bindir="${prefix}"
|
||||||
@ -241,46 +223,37 @@ if test "$mingw32" = "yes" ; then
|
|||||||
EXESUF=".exe"
|
EXESUF=".exe"
|
||||||
else
|
else
|
||||||
if test -z "$prefix" ; then
|
if test -z "$prefix" ; then
|
||||||
prefix="/usr/local"
|
prefix="/usr/local"
|
||||||
fi
|
fi
|
||||||
if test -z "$sharedir" ; then
|
if test -z "$sharedir" ; then
|
||||||
sharedir="${prefix}/share"
|
sharedir="${prefix}/share"
|
||||||
fi
|
fi
|
||||||
if test x"$execprefix" = x""; then
|
if test x"$execprefix" = x""; then
|
||||||
execprefix="${prefix}"
|
execprefix="${prefix}"
|
||||||
fi
|
|
||||||
if test x"$tccdir" = x""; then
|
|
||||||
tccdir="tcc"
|
|
||||||
fi
|
fi
|
||||||
if test x"$libdir" = x""; then
|
if test x"$libdir" = x""; then
|
||||||
libdir="${execprefix}/lib"
|
libdir="${execprefix}/lib"
|
||||||
if test -n "${tccdir}"; then
|
|
||||||
tccdir="${libdir}/${tccdir}"
|
|
||||||
else
|
|
||||||
tccdir="${libdir}"
|
|
||||||
fi
|
|
||||||
if test "$cpu" = "x86-64"; then
|
|
||||||
libdir="${execprefix}/lib64"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
tccdir="${libdir}/${tccdir}"
|
|
||||||
fi
|
fi
|
||||||
if test x"$bindir" = x""; then
|
if test x"$bindir" = x""; then
|
||||||
bindir="${execprefix}/bin"
|
bindir="${execprefix}/bin"
|
||||||
|
fi
|
||||||
|
if test x"$tccdir" = x""; then
|
||||||
|
tccdir="tcc"
|
||||||
fi
|
fi
|
||||||
if test x"$docdir" = x""; then
|
if test x"$docdir" = x""; then
|
||||||
docdir="${sharedir}/doc"
|
docdir="${sharedir}/doc/${tccdir}"
|
||||||
fi
|
fi
|
||||||
if test x"$mandir" = x""; then
|
if test x"$mandir" = x""; then
|
||||||
mandir="${sharedir}/man"
|
mandir="${sharedir}/man"
|
||||||
fi
|
fi
|
||||||
if test x"$infodir" = x""; then
|
if test x"$infodir" = x""; then
|
||||||
infodir="${sharedir}/info"
|
infodir="${sharedir}/info"
|
||||||
fi
|
fi
|
||||||
|
tccdir="${libdir}/${tccdir}"
|
||||||
fi # mingw32
|
fi # mingw32
|
||||||
|
|
||||||
if test x"$includedir" = x""; then
|
if test x"$includedir" = x""; then
|
||||||
includedir="${prefix}/include"
|
includedir="${prefix}/include"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test x"$show_help" = "xyes" ; then
|
if test x"$show_help" = "xyes" ; then
|
||||||
@ -292,7 +265,7 @@ Standard options:
|
|||||||
--help print this message
|
--help print this message
|
||||||
--prefix=PREFIX install in PREFIX [$prefix]
|
--prefix=PREFIX install in PREFIX [$prefix]
|
||||||
--exec-prefix=EPREFIX install architecture-dependent files in EPREFIX
|
--exec-prefix=EPREFIX install architecture-dependent files in EPREFIX
|
||||||
[same as prefix]
|
[same as prefix]
|
||||||
--bindir=DIR user executables in DIR [EPREFIX/bin]
|
--bindir=DIR user executables in DIR [EPREFIX/bin]
|
||||||
--libdir=DIR object code libraries in DIR [EPREFIX/lib]
|
--libdir=DIR object code libraries in DIR [EPREFIX/lib]
|
||||||
--tccdir=DIR installation directory [EPREFIX/lib/tcc]
|
--tccdir=DIR installation directory [EPREFIX/lib/tcc]
|
||||||
@ -310,17 +283,13 @@ Advanced options (experts only):
|
|||||||
--ar=AR create archives using AR [$ar]
|
--ar=AR create archives using AR [$ar]
|
||||||
--extra-cflags= specify compiler flags [$CFLAGS]
|
--extra-cflags= specify compiler flags [$CFLAGS]
|
||||||
--extra-ldflags= specify linker options []
|
--extra-ldflags= specify linker options []
|
||||||
--cpu=CPU CPU [$cpu]
|
|
||||||
--strip-binaries strip symbol tables from resulting binaries
|
--strip-binaries strip symbol tables from resulting binaries
|
||||||
--disable-static make libtcc.so instead of libtcc.a
|
--disable-static make libtcc.so instead of libtcc.a
|
||||||
--disable-rpath disable use of -rpath with the above
|
--disable-rpath disable use of -rpath with the above
|
||||||
--with-libgcc use libgcc_s.so.1 instead of libtcc1.a in dynamic link
|
--with-libgcc use libgcc_s.so.1 instead of libtcc1.a in dynamic link
|
||||||
--enable-tcc64-mingw build windows version on linux with x86_64-win-tcc
|
|
||||||
--enable-tcc32-mingw build windows version on linux with i386-win-tcc
|
|
||||||
--enable-mingw32 build windows version on linux with mingw32
|
--enable-mingw32 build windows version on linux with mingw32
|
||||||
--enable-cygwin build windows version on windows with cygwin
|
--enable-cygwin build windows version on windows with cygwin
|
||||||
--enable-cross build cross compilers
|
--enable-cross build cross compilers
|
||||||
--enable-assert enable debug assertions
|
|
||||||
--with-selinux use mmap for exec mem [needs writable /tmp]
|
--with-selinux use mmap for exec mem [needs writable /tmp]
|
||||||
--sysincludepaths=... specify system include paths, colon separated
|
--sysincludepaths=... specify system include paths, colon separated
|
||||||
--libpaths=... specify system library paths, colon separated
|
--libpaths=... specify system library paths, colon separated
|
||||||
@ -331,10 +300,8 @@ EOF
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$cc" != "tcc"; then
|
|
||||||
ar="${cross_prefix}${ar}"
|
|
||||||
fi
|
|
||||||
cc="${cross_prefix}${cc}"
|
cc="${cross_prefix}${cc}"
|
||||||
|
ar="${cross_prefix}${ar}"
|
||||||
strip="${cross_prefix}${strip}"
|
strip="${cross_prefix}${strip}"
|
||||||
|
|
||||||
CONFTEST=./conftest$EXESUF
|
CONFTEST=./conftest$EXESUF
|
||||||
@ -349,21 +316,21 @@ if test -z "$cross_prefix" ; then
|
|||||||
if test "$mingw32" = "no" ; then
|
if test "$mingw32" = "no" ; then
|
||||||
triplet="$($CONFTEST triplet)"
|
triplet="$($CONFTEST triplet)"
|
||||||
if test -f "/usr/lib/$triplet/crti.o" ; then
|
if test -f "/usr/lib/$triplet/crti.o" ; then
|
||||||
tcc_lddir="lib"
|
tcc_lddir="lib/$triplet"
|
||||||
multiarch_triplet="$triplet"
|
multiarch_triplet="$triplet"
|
||||||
elif test "$cpu" != "x86" -a -f "/usr/lib64/crti.o" ; then
|
elif test -f "/usr/lib64/crti.o" ; then
|
||||||
tcc_lddir="lib64"
|
tcc_lddir="lib64"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$cpu" = "armv4l" ; then
|
if test "$cpu" = "armv4l" ; then
|
||||||
if test "${triplet%eabihf}" != "$triplet" ; then
|
if test "${triplet%eabihf}" != "$triplet" ; then
|
||||||
confvars="$confvars arm_eabihf"
|
confvars="$confvars arm_eabihf"
|
||||||
elif test "${triplet%eabi}" != "$triplet" ; then
|
elif test "${triplet%eabi}" != "$triplet" ; then
|
||||||
confvars="$confvars arm_eabi"
|
confvars="$confvars arm_eabi"
|
||||||
fi
|
fi
|
||||||
if grep -s -q "^Features.* \(vfp\|iwmmxt\) " /proc/cpuinfo ; then
|
if grep -s -q "^Features.* \(vfp\|iwmmxt\) " /proc/cpuinfo ; then
|
||||||
confvars="$confvars arm_vfp"
|
confvars="$confvars arm_vfp"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# multiarch_triplet=${libc_dir#*/}
|
# multiarch_triplet=${libc_dir#*/}
|
||||||
@ -374,11 +341,12 @@ if test -z "$cross_prefix" ; then
|
|||||||
# fi
|
# fi
|
||||||
|
|
||||||
if test -f "/lib/ld-uClibc.so.0" ; then
|
if test -f "/lib/ld-uClibc.so.0" ; then
|
||||||
confvars="$confvars uClibc"
|
confvars="$confvars uClibc"
|
||||||
fi
|
fi
|
||||||
# gr: maybe for after the release:
|
|
||||||
# tcc_elfinterp="$(ldd $CONFTEST | grep 'ld.*.so' | sed 's,\s*\(\S\+\).*,\1,')"
|
# if test -z "$tcc_elfinterp" ; then
|
||||||
# echo "elfinterp $tcc_elfinterp"
|
# tcc_elfinterp="$(ldd $CONFTEST | grep '/ld-.*.so' | sed 's,\s*\(\S\+\).*,\1,')"
|
||||||
|
# fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -390,22 +358,23 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# a final configuration tuning
|
# a final configuration tuning
|
||||||
|
$cc -v --help > cc_help.txt 2>&1
|
||||||
W_OPTIONS="declaration-after-statement"
|
W_OPTIONS="declaration-after-statement"
|
||||||
for i in $W_OPTIONS; do
|
for i in $W_OPTIONS; do
|
||||||
O_PRESENT="$($cc -v --help 2>&1 | grep -- -W$i)"
|
O_PRESENT="$(grep -- -W$i cc_help.txt)"
|
||||||
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -W$i"; fi
|
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -W$i"; fi
|
||||||
done
|
done
|
||||||
W_OPTIONS="deprecated-declarations strict-aliasing pointer-sign sign-compare unused-result uninitialized"
|
W_OPTIONS="deprecated-declarations strict-aliasing pointer-sign sign-compare unused-result uninitialized"
|
||||||
for i in $W_OPTIONS; do
|
for i in $W_OPTIONS; do
|
||||||
O_PRESENT="$($cc -v --help 2>&1 | grep -- -W$i)"
|
O_PRESENT="$(grep -- -W$i cc_help.txt)"
|
||||||
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -Wno-$i"; fi
|
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -Wno-$i"; fi
|
||||||
done
|
done
|
||||||
F_OPTIONS="strict-aliasing"
|
F_OPTIONS="strict-aliasing"
|
||||||
for i in $F_OPTIONS; do
|
for i in $F_OPTIONS; do
|
||||||
O_PRESENT="$($cc -v --help 2>&1 | grep -- -f$i)"
|
O_PRESENT="$(grep -- -f$i cc_help.txt)"
|
||||||
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -fno-$i"; fi
|
if test -n "$O_PRESENT"; then CFLAGS="$CFLAGS -fno-$i"; fi
|
||||||
done
|
done
|
||||||
if test -z "$tcc_lddir" -a "$cpu" = "x86-64"; then tcc_lddir="lib64"; fi
|
rm -f cc_help.txt
|
||||||
|
|
||||||
echo "Binary directory $bindir"
|
echo "Binary directory $bindir"
|
||||||
echo "TinyCC directory $tccdir"
|
echo "TinyCC directory $tccdir"
|
||||||
@ -415,18 +384,14 @@ echo "Manual directory $mandir"
|
|||||||
echo "Info directory $infodir"
|
echo "Info directory $infodir"
|
||||||
echo "Doc directory $docdir"
|
echo "Doc directory $docdir"
|
||||||
echo "Target root prefix $sysroot"
|
echo "Target root prefix $sysroot"
|
||||||
echo "Source path $source_path"
|
echo "Source path $source_path"
|
||||||
echo "C compiler $cc"
|
echo "C compiler $cc"
|
||||||
echo "ar $ar"
|
echo "Target OS $targetos"
|
||||||
echo "cross compilers $build_cross"
|
echo "CPU $cpu"
|
||||||
if test "$build_cross" = "no"; then
|
echo "Big Endian $bigendian"
|
||||||
echo "Target CPU $cpu"
|
echo "gprof enabled $gprof"
|
||||||
fi
|
echo "cross compilers $build_cross"
|
||||||
echo "Host OS $host_os"
|
echo "use libgcc $use_libgcc"
|
||||||
echo "Target OS $targetos"
|
|
||||||
echo "Big Endian $bigendian"
|
|
||||||
echo "gprof enabled $gprof"
|
|
||||||
echo "use libgcc $use_libgcc"
|
|
||||||
|
|
||||||
echo "Creating config.mak and config.h"
|
echo "Creating config.mak and config.h"
|
||||||
|
|
||||||
@ -444,21 +409,13 @@ docdir=\$(DESTDIR)$docdir
|
|||||||
CC=$cc
|
CC=$cc
|
||||||
GCC_MAJOR=$gcc_major
|
GCC_MAJOR=$gcc_major
|
||||||
GCC_MINOR=$gcc_minor
|
GCC_MINOR=$gcc_minor
|
||||||
HOST_CC=$host_cc
|
|
||||||
AR=$ar
|
AR=$ar
|
||||||
STRIP=$strip -s -R .comment -R .note
|
STRIP=$strip -s -R .comment -R .note
|
||||||
CFLAGS=$CFLAGS
|
CFLAGS=$CFLAGS
|
||||||
LDFLAGS=$LDFLAGS
|
LDFLAGS=$LDFLAGS
|
||||||
LIBSUF=$LIBSUF
|
LIBSUF=$LIBSUF
|
||||||
EXESUF=$EXESUF
|
EXESUF=$EXESUF
|
||||||
HOST_OS=$host_os
|
|
||||||
EOF
|
EOF
|
||||||
if test "$mingw32" = "yes" -a "$host_os" != "Windows" ; then
|
|
||||||
cat >>config.mak <<EOF
|
|
||||||
XCC=$cc
|
|
||||||
XAR=$ar
|
|
||||||
EOF
|
|
||||||
fi
|
|
||||||
|
|
||||||
print_inc() {
|
print_inc() {
|
||||||
if test -n "$2"; then
|
if test -n "$2"; then
|
||||||
@ -477,13 +434,11 @@ echo "/* Automatically generated by configure - do not modify */" > $TMPH
|
|||||||
|
|
||||||
print_inc CONFIG_SYSROOT "$sysroot"
|
print_inc CONFIG_SYSROOT "$sysroot"
|
||||||
print_inc CONFIG_TCCDIR "$tccdir"
|
print_inc CONFIG_TCCDIR "$tccdir"
|
||||||
if test "$build_cross" = "no"; then
|
|
||||||
print_inc CONFIG_LDDIR "$tcc_lddir"
|
|
||||||
fi
|
|
||||||
print_mak CONFIG_TCC_SYSINCLUDEPATHS "$tcc_sysincludepaths"
|
print_mak CONFIG_TCC_SYSINCLUDEPATHS "$tcc_sysincludepaths"
|
||||||
print_mak CONFIG_TCC_LIBPATHS "$tcc_libpaths"
|
print_mak CONFIG_TCC_LIBPATHS "$tcc_libpaths"
|
||||||
print_mak CONFIG_TCC_CRTPREFIX "$tcc_crtprefix"
|
print_mak CONFIG_TCC_CRTPREFIX "$tcc_crtprefix"
|
||||||
print_mak CONFIG_TCC_ELFINTERP "$tcc_elfinterp"
|
print_mak CONFIG_TCC_ELFINTERP "$tcc_elfinterp"
|
||||||
|
print_mak CONFIG_LDDIR "$tcc_lddir"
|
||||||
print_mak CONFIG_MULTIARCHDIR "$multiarch_triplet"
|
print_mak CONFIG_MULTIARCHDIR "$multiarch_triplet"
|
||||||
|
|
||||||
echo "#define GCC_MAJOR $gcc_major" >> $TMPH
|
echo "#define GCC_MAJOR $gcc_major" >> $TMPH
|
||||||
@ -520,13 +475,7 @@ if test "$noldl" = "yes" ; then
|
|||||||
echo "CONFIG_NOLDL=yes" >> config.mak
|
echo "CONFIG_NOLDL=yes" >> config.mak
|
||||||
fi
|
fi
|
||||||
if test "$mingw32" = "yes" ; then
|
if test "$mingw32" = "yes" ; then
|
||||||
if test "$cpu" = "x86-64"; then
|
echo "CONFIG_WIN32=yes" >> config.mak
|
||||||
echo "CONFIG_WIN64=yes" >> config.mak
|
|
||||||
echo "#define CONFIG_WIN64 1" >> $TMPH
|
|
||||||
else
|
|
||||||
echo "CONFIG_WIN32=yes" >> config.mak
|
|
||||||
echo "#define CONFIG_WIN32 1" >> $TMPH
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
if test "$cygwin" = "yes" ; then
|
if test "$cygwin" = "yes" ; then
|
||||||
echo "#ifndef _WIN32" >> $TMPH
|
echo "#ifndef _WIN32" >> $TMPH
|
||||||
@ -562,25 +511,20 @@ if test "$have_selinux" = "yes" ; then
|
|||||||
echo "#define HAVE_SELINUX" >> $TMPH
|
echo "#define HAVE_SELINUX" >> $TMPH
|
||||||
echo "HAVE_SELINUX=yes" >> config.mak
|
echo "HAVE_SELINUX=yes" >> config.mak
|
||||||
fi
|
fi
|
||||||
if test "$enable_assert" = "yes" ; then
|
|
||||||
echo "#define CONFIG_TCC_ASSERT" >> $TMPH
|
|
||||||
fi
|
|
||||||
|
|
||||||
version=`head $source_path/VERSION`
|
version=`head $source_path/VERSION`
|
||||||
echo "VERSION=$version" >>config.mak
|
echo "VERSION = $version" >> config.mak
|
||||||
echo "#define TCC_VERSION \"$version\"" >> $TMPH
|
echo "#define TCC_VERSION \"$version\"" >> $TMPH
|
||||||
echo "@set VERSION $version" > config.texi
|
echo "@set VERSION $version" > config.texi
|
||||||
echo "SRC_PATH=$source_path" >>config.mak
|
|
||||||
|
|
||||||
if test "$source_path_used" = "yes" ; then
|
if test "$source_path_used" = "yes" ; then
|
||||||
case $source_path in
|
case $source_path in
|
||||||
/*) echo "top_srcdir=$source_path";;
|
/*) echo "SRCTOP=$source_path";;
|
||||||
*) echo "top_srcdir=\$(TOP)/$source_path";;
|
*) echo "SRCTOP=\$(TOP)/$source_path";;
|
||||||
esac >>config.mak
|
esac >>config.mak
|
||||||
else
|
else
|
||||||
echo 'top_srcdir=$(TOP)' >>config.mak
|
echo 'SRCTOP=$(TOP)' >>config.mak
|
||||||
fi
|
fi
|
||||||
echo 'top_builddir=$(TOP)' >>config.mak
|
|
||||||
|
|
||||||
diff $TMPH config.h >/dev/null 2>&1
|
diff $TMPH config.h >/dev/null 2>&1
|
||||||
if test $? -ne 0 ; then
|
if test $? -ne 0 ; then
|
||||||
@ -596,17 +540,24 @@ rm -f $TMPN* $CONFTEST
|
|||||||
|
|
||||||
fn_makelink()
|
fn_makelink()
|
||||||
{
|
{
|
||||||
SRCDIR=$(realpath $1)
|
tgt=$1/$2
|
||||||
DIR=$(dirname $2)
|
case $2 in
|
||||||
FILE=$(basename $2)
|
*/*) dn=${2%/*}
|
||||||
if test ! -d "$DIR"; then
|
test -d $dn || mkdir -p $dn
|
||||||
mkdir -p "$DIR"
|
case $1 in
|
||||||
fi
|
/*) ;;
|
||||||
ln -s $SRCDIR/$DIR/$FILE $DIR/
|
*) while test $dn ; do
|
||||||
|
tgt=../$tgt; dn=${dn#${dn%%/*}}; dn=${dn#/}
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
ln -sfn $tgt $2
|
||||||
}
|
}
|
||||||
|
|
||||||
if test "$source_path_used" = "yes" ; then
|
if test "$source_path_used" = "yes" ; then
|
||||||
FILES="Makefile lib/Makefile tests/Makefile tests/tests2/* tests/pp/* tests/exsymtab/*"
|
FILES="Makefile lib/Makefile tests/Makefile tests/tests2/Makefile tests/pp/Makefile"
|
||||||
for f in $FILES ; do
|
for f in $FILES ; do
|
||||||
fn_makelink $source_path $f
|
fn_makelink $source_path $f
|
||||||
done
|
done
|
||||||
|
100
lib/Makefile
100
lib/Makefile
@ -4,37 +4,31 @@
|
|||||||
|
|
||||||
TOP = ..
|
TOP = ..
|
||||||
include $(TOP)/Makefile
|
include $(TOP)/Makefile
|
||||||
VPATH = $(top_srcdir)/lib $(top_srcdir)/win32/lib
|
VPATH = $(TOP)/lib $(TOP)/win32/lib
|
||||||
|
|
||||||
ifndef TARGET # native library
|
ifndef TARGET
|
||||||
|
# we're building the native libtcc1.a
|
||||||
ifdef CONFIG_WIN64
|
ifdef CONFIG_WIN64
|
||||||
TARGET = x86_64-win
|
TARGET = x86_64-win32
|
||||||
else
|
# using tcc
|
||||||
ifdef CONFIG_WIN32
|
else ifdef CONFIG_WIN32
|
||||||
TARGET = i386-win
|
TARGET = i386-win32
|
||||||
else
|
# using tcc
|
||||||
ifeq ($(ARCH),i386)
|
else ifeq ($(ARCH),i386)
|
||||||
TARGET = i386
|
TARGET = i386
|
||||||
else
|
XCC = $(CC) # using gcc
|
||||||
ifeq ($(ARCH),x86-64)
|
else ifeq ($(ARCH),x86-64)
|
||||||
TARGET = x86_64
|
TARGET = x86_64
|
||||||
else
|
XCC = $(CC) # using gcc
|
||||||
ifeq ($(ARCH),arm)
|
else ifeq ($(ARCH),arm)
|
||||||
TARGET = arm
|
TARGET = arm
|
||||||
XCC = $(CC)
|
XCC = $(CC) # using gcc
|
||||||
else
|
else ifeq ($(ARCH),arm64)
|
||||||
ifeq ($(ARCH),arm64)
|
|
||||||
TARGET = arm64
|
TARGET = arm64
|
||||||
else
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
|
BCHECK_O = bcheck.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
BCHECK_O = bcheck.o
|
|
||||||
DIR = $(TARGET)
|
DIR = $(TARGET)
|
||||||
|
|
||||||
native : ../libtcc1.a
|
native : ../libtcc1.a
|
||||||
@ -54,53 +48,39 @@ ARM64_O = lib-arm64.o
|
|||||||
# into shared libraries
|
# into shared libraries
|
||||||
PICFLAGS = -fPIC
|
PICFLAGS = -fPIC
|
||||||
|
|
||||||
# don't compile with -fstack-protector-strong, TCC doesn't handle it
|
ifeq "$(TARGET)" "i386-win32"
|
||||||
# correctly
|
|
||||||
CFLAGS := $(filter-out -fstack-protector-strong,$(CFLAGS))
|
|
||||||
|
|
||||||
ifeq "$(TARGET)" "i386-win"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(WIN32_O))
|
OBJ = $(addprefix $(DIR)/,$(WIN32_O))
|
||||||
TGT = -DTCC_TARGET_I386 -DTCC_TARGET_PE
|
TGT = -DTCC_TARGET_I386 -DTCC_TARGET_PE
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)/win32 -I$(top_srcdir)/include
|
XCC = $(TCC) -B$(TOP)/win32 -I$(TOP)/include
|
||||||
XAR ?= $(DIR)/tiny_libmaker$(EXESUF)
|
XAR = $(DIR)/tiny_libmaker$(EXESUF)
|
||||||
PICFLAGS =
|
XFLAGS = $(TGT)
|
||||||
else
|
else ifeq "$(TARGET)" "x86_64-win32"
|
||||||
ifeq "$(TARGET)" "x86_64-win"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(WIN64_O))
|
OBJ = $(addprefix $(DIR)/,$(WIN64_O))
|
||||||
TGT = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE
|
TGT = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)/win32 -I$(top_srcdir)/include
|
XCC = $(TCC) -B$(TOP)/win32 -I$(TOP)/include
|
||||||
XAR ?= $(DIR)/tiny_libmaker$(EXESUF)
|
XAR = $(DIR)/tiny_libmaker$(EXESUF)
|
||||||
PICFLAGS =
|
XFLAGS = $(TGT)
|
||||||
else
|
else ifeq "$(TARGET)" "i386"
|
||||||
ifeq "$(TARGET)" "i386"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(I386_O))
|
OBJ = $(addprefix $(DIR)/,$(I386_O))
|
||||||
TGT = -DTCC_TARGET_I386
|
TGT = -DTCC_TARGET_I386
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)
|
XCC ?= $(TCC) -B$(TOP)
|
||||||
else
|
else ifeq "$(TARGET)" "x86_64"
|
||||||
ifeq "$(TARGET)" "x86_64"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(X86_64_O))
|
OBJ = $(addprefix $(DIR)/,$(X86_64_O))
|
||||||
TGT = -DTCC_TARGET_X86_64
|
TGT = -DTCC_TARGET_X86_64
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)
|
XCC ?= $(TCC) -B$(TOP)
|
||||||
else
|
else ifeq "$(TARGET)" "arm"
|
||||||
ifeq "$(TARGET)" "arm"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(ARM_O))
|
OBJ = $(addprefix $(DIR)/,$(ARM_O))
|
||||||
TGT = -DTCC_TARGET_ARM
|
TGT = -DTCC_TARGET_ARM
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)
|
XCC ?= $(TCC) -B$(TOP)
|
||||||
else
|
else ifeq "$(TARGET)" "arm64"
|
||||||
ifeq "$(TARGET)" "arm64"
|
|
||||||
OBJ = $(addprefix $(DIR)/,$(ARM64_O))
|
OBJ = $(addprefix $(DIR)/,$(ARM64_O))
|
||||||
TGT = -DTCC_TARGET_ARM64
|
TGT = -DTCC_TARGET_ARM64
|
||||||
XCC ?= $(TCC) -B$(top_srcdir)
|
XCC ?= $(TCC) -B$(top_srcdir)
|
||||||
else
|
else
|
||||||
$(error libtcc1.a not supported on target '$(TARGET)')
|
$(error libtcc1.a not supported on target '$(TARGET)')
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
XFLAGS = $(filter-out -b,$(CPPFLAGS) $(CFLAGS) $(PICFLAGS) $(TGT))
|
XFLAGS ?= $(CFLAGS) $(PICFLAGS) $(TGT)
|
||||||
|
|
||||||
ifeq ($(TARGETOS),Darwin)
|
ifeq ($(TARGETOS),Darwin)
|
||||||
XAR = $(DIR)/tiny_libmaker$(EXESUF)
|
XAR = $(DIR)/tiny_libmaker$(EXESUF)
|
||||||
@ -108,21 +88,25 @@ ifeq ($(TARGETOS),Darwin)
|
|||||||
BCHECK_O =
|
BCHECK_O =
|
||||||
endif
|
endif
|
||||||
|
|
||||||
XAR ?= $(AR)
|
ifdef XAR
|
||||||
|
AR = $(XAR)
|
||||||
|
endif
|
||||||
|
|
||||||
$(DIR)/libtcc1.a ../libtcc1.a : $(OBJ) $(XAR)
|
$(DIR)/libtcc1.a ../libtcc1.a : $(OBJ) $(XAR)
|
||||||
$(XAR) rcs $@ $(OBJ)
|
$(AR) rcs $@ $(OBJ)
|
||||||
$(DIR)/%.o : %.c
|
$(DIR)/%.o : %.c
|
||||||
$(XCC) -c $< -o $@ $(XFLAGS)
|
$(XCC) -c $< -o $@ $(XFLAGS)
|
||||||
$(DIR)/%.o : %.S
|
$(DIR)/%.o : %.S
|
||||||
$(XCC) -c $< -o $@ $(XFLAGS)
|
$(XCC) -c $< -o $@ $(XFLAGS)
|
||||||
$(DIR)/%$(EXESUF) : $(TOP)/win32/tools/%.c
|
# windows : utilities
|
||||||
$(CC) -o $@ $< $(XFLAGS) $(LDFLAGS)
|
$(DIR)/tiny_%$(EXESUF) : $(TOP)/win32/tools/tiny_%.c
|
||||||
|
$(CC) -o $@ $< $(CFLAGS) $(LDFLAGS) $(TGT)
|
||||||
|
|
||||||
$(OBJ) $(XAR) : $(DIR)/exists
|
$(OBJ) $(XAR) : $(DIR)/exists
|
||||||
$(DIR)/exists :
|
|
||||||
|
%/exists :
|
||||||
mkdir -p $(DIR)
|
mkdir -p $(DIR)
|
||||||
@echo $@ > $@
|
@echo $@ > $@
|
||||||
|
|
||||||
clean :
|
clean :
|
||||||
rm -rfv i386-win x86_64-win i386 x86_64 arm64
|
rm -rfv i386-win32 x86_64-win32 i386 x86_64 arm arm64
|
||||||
|
6
libtcc.c
6
libtcc.c
@ -135,7 +135,7 @@ BOOL WINAPI DllMain (HINSTANCE hDll, DWORD dwReason, LPVOID lpReserved)
|
|||||||
|
|
||||||
/********************************************************/
|
/********************************************************/
|
||||||
/* copy a string and truncate it. */
|
/* copy a string and truncate it. */
|
||||||
ST_FUNC char *pstrcpy(char *buf, int buf_size, const char *s)
|
PUB_FUNC char *pstrcpy(char *buf, int buf_size, const char *s)
|
||||||
{
|
{
|
||||||
char *q, *q_end;
|
char *q, *q_end;
|
||||||
int c;
|
int c;
|
||||||
@ -155,7 +155,7 @@ ST_FUNC char *pstrcpy(char *buf, int buf_size, const char *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* strcat and truncate. */
|
/* strcat and truncate. */
|
||||||
ST_FUNC char *pstrcat(char *buf, int buf_size, const char *s)
|
PUB_FUNC char *pstrcat(char *buf, int buf_size, const char *s)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
len = strlen(buf);
|
len = strlen(buf);
|
||||||
@ -164,7 +164,7 @@ ST_FUNC char *pstrcat(char *buf, int buf_size, const char *s)
|
|||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
ST_FUNC char *pstrncpy(char *out, const char *in, size_t num)
|
PUB_FUNC char *pstrncpy(char *out, const char *in, size_t num)
|
||||||
{
|
{
|
||||||
memcpy(out, in, num);
|
memcpy(out, in, num);
|
||||||
out[num] = '\0';
|
out[num] = '\0';
|
||||||
|
11
tcc.h
11
tcc.h
@ -281,6 +281,11 @@
|
|||||||
# define DEFAULT_ELFINTERP(s) default_elfinterp(s)
|
# define DEFAULT_ELFINTERP(s) default_elfinterp(s)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* target specific subdir for libtcc1.a */
|
||||||
|
#ifndef TCC_ARCH_DIR
|
||||||
|
# define TCC_ARCH_DIR ""
|
||||||
|
#endif
|
||||||
|
|
||||||
/* library to use with CONFIG_USE_LIBGCC instead of libtcc1.a */
|
/* library to use with CONFIG_USE_LIBGCC instead of libtcc1.a */
|
||||||
#define TCC_LIBGCC USE_MUADIR(CONFIG_SYSROOT "/" CONFIG_LDDIR) "/libgcc_s.so.1"
|
#define TCC_LIBGCC USE_MUADIR(CONFIG_SYSROOT "/" CONFIG_LDDIR) "/libgcc_s.so.1"
|
||||||
|
|
||||||
@ -1068,9 +1073,9 @@ ST_DATA int tcc_ext;
|
|||||||
ST_DATA struct TCCState *tcc_state;
|
ST_DATA struct TCCState *tcc_state;
|
||||||
|
|
||||||
/* public functions currently used by the tcc main function */
|
/* public functions currently used by the tcc main function */
|
||||||
ST_FUNC char *pstrcpy(char *buf, int buf_size, const char *s);
|
PUB_FUNC char *pstrcpy(char *buf, int buf_size, const char *s);
|
||||||
ST_FUNC char *pstrcat(char *buf, int buf_size, const char *s);
|
PUB_FUNC char *pstrcat(char *buf, int buf_size, const char *s);
|
||||||
ST_FUNC char *pstrncpy(char *out, const char *in, size_t num);
|
PUB_FUNC char *pstrncpy(char *out, const char *in, size_t num);
|
||||||
PUB_FUNC char *tcc_basename(const char *name);
|
PUB_FUNC char *tcc_basename(const char *name);
|
||||||
PUB_FUNC char *tcc_fileextension (const char *name);
|
PUB_FUNC char *tcc_fileextension (const char *name);
|
||||||
|
|
||||||
|
19
tccelf.c
19
tccelf.c
@ -1555,24 +1555,7 @@ static void add_init_array_defines(TCCState *s1, const char *section_name)
|
|||||||
static int tcc_add_support(TCCState *s1, const char *filename)
|
static int tcc_add_support(TCCState *s1, const char *filename)
|
||||||
{
|
{
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
snprintf(buf, sizeof(buf), "%s/%s/%s", s1->tcc_lib_path,
|
snprintf(buf, sizeof(buf), "%s/"TCC_ARCH_DIR"%s", s1->tcc_lib_path, filename);
|
||||||
/* an cpu specific path inside tcc_lib_path, mainly for keeping libtcc1.a */
|
|
||||||
#ifdef TCC_TARGET_I386
|
|
||||||
"i386"
|
|
||||||
#endif
|
|
||||||
#ifdef TCC_TARGET_X86_64
|
|
||||||
"x86-64"
|
|
||||||
#endif
|
|
||||||
#ifdef TCC_TARGET_ARM
|
|
||||||
"arm"
|
|
||||||
#endif
|
|
||||||
#ifdef TCC_TARGET_ARM64
|
|
||||||
"arm64"
|
|
||||||
#endif
|
|
||||||
#ifdef TCC_TARGET_C67
|
|
||||||
"C67"
|
|
||||||
#endif
|
|
||||||
,filename);
|
|
||||||
return tcc_add_file(s1, buf);
|
return tcc_add_file(s1, buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
109
tests/Makefile
109
tests/Makefile
@ -4,12 +4,8 @@
|
|||||||
|
|
||||||
TOP = ..
|
TOP = ..
|
||||||
include $(TOP)/Makefile
|
include $(TOP)/Makefile
|
||||||
SRCDIR = $(top_srcdir)/tests
|
VPATH = $(TOP)/tests $(TOP)
|
||||||
VPATH = $(SRCDIR) $(top_srcdir)
|
CFLAGS = -I$(TOP)
|
||||||
|
|
||||||
# clear CFLAGS and LDFLAGS
|
|
||||||
CFLAGS :=
|
|
||||||
LDFLAGS :=
|
|
||||||
|
|
||||||
# what tests to run
|
# what tests to run
|
||||||
TESTS = \
|
TESTS = \
|
||||||
@ -19,14 +15,11 @@ TESTS = \
|
|||||||
test3 \
|
test3 \
|
||||||
abitest \
|
abitest \
|
||||||
vla_test-run \
|
vla_test-run \
|
||||||
tests2-dir pp-dir
|
tests2-dir \
|
||||||
|
pp-dir
|
||||||
|
|
||||||
BTESTS = test1b test3b btest
|
BTESTS = test1b test3b btest
|
||||||
|
|
||||||
ifdef CONFIG_CROSS
|
|
||||||
TESTS += hello-cross
|
|
||||||
endif
|
|
||||||
|
|
||||||
# test4 -- problem with -static
|
# test4 -- problem with -static
|
||||||
# asmtest -- minor differences with gcc
|
# asmtest -- minor differences with gcc
|
||||||
# btest -- works on i386 (including win32)
|
# btest -- works on i386 (including win32)
|
||||||
@ -48,62 +41,40 @@ ifeq ($(CONFIG_arm_eabi),yes)
|
|||||||
TESTS := $(filter-out test3,$(TESTS))
|
TESTS := $(filter-out test3,$(TESTS))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifdef DISABLE_STATIC
|
|
||||||
export LD_LIBRARY_PATH:=$(CURDIR)/..
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(TARGETOS),Darwin)
|
|
||||||
CFLAGS+=-Wl,-flat_namespace,-undefined,warning
|
|
||||||
export MACOSX_DEPLOYMENT_TARGET:=10.2
|
|
||||||
NATIVE_DEFINES+=-D_ANSI_SOURCE
|
|
||||||
endif
|
|
||||||
|
|
||||||
# run local version of tcc with local libraries and includes
|
# run local version of tcc with local libraries and includes
|
||||||
TCCFLAGS = -B$(TOP) -I$(TOP) -I$(top_srcdir) -I$(top_srcdir)/include -L$(TOP)
|
TCCFLAGS = -B$(TOP) -I$(TOP)
|
||||||
ifdef CONFIG_WIN32
|
ifdef CONFIG_WIN32
|
||||||
TCCFLAGS = -B$(top_srcdir)/win32 -I$(top_srcdir) -I$(top_srcdir)/include -L$(TOP)
|
TCCFLAGS = -B$(TOP)/win32 -I$(TOP)/include -I$(TOP) -L$(TOP)
|
||||||
|
PATH := $(CURDIR)/$(TOP):$(PATH) # for libtcc_test to find libtcc.dll
|
||||||
endif
|
endif
|
||||||
XTCCFLAGS = -B$(TOP) -B$(top_srcdir)/win32 -I$(TOP) -I$(top_srcdir) -I$(top_srcdir)/include
|
|
||||||
|
|
||||||
TCC = $(TOP)/tcc $(TCCFLAGS)
|
TCC = $(TOP)/tcc $(TCCFLAGS)
|
||||||
RUN_TCC = $(NATIVE_DEFINES) -DONE_SOURCE -run $(top_srcdir)/tcc.c $(TCCFLAGS)
|
RUN_TCC = $(NATIVE_DEFINES) -DONE_SOURCE -run $(TOP)/tcc.c $(TCCFLAGS)
|
||||||
|
|
||||||
|
ifeq ($(TARGETOS),Darwin)
|
||||||
|
CFLAGS += -Wl,-flat_namespace,-undefined,warning
|
||||||
|
TCCFLAGS += -D_ANSI_SOURCE
|
||||||
|
export MACOSX_DEPLOYMENT_TARGET:=10.2
|
||||||
|
endif
|
||||||
|
|
||||||
DISAS = objdump -d
|
DISAS = objdump -d
|
||||||
|
|
||||||
# libtcc test
|
all test : clean-s $(TESTS)
|
||||||
ifdef LIBTCC1
|
|
||||||
ifdef CONFIG_WIN32
|
|
||||||
LIBTCC1:=$(TOP)/win32/libtcc/libtcc.a
|
|
||||||
else
|
|
||||||
LIBTCC1:=$(TOP)/$(LIBTCC1)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
all test : $(TESTS)
|
|
||||||
|
|
||||||
hello-exe: ../examples/ex1.c
|
hello-exe: ../examples/ex1.c
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
$(TCC) $< -o hello$(EXESUF) || ($(TOP)/tcc -vv; exit 1) && ./hello$(EXESUF)
|
$(TCC) $< -o hello$(EXESUF) || ($(TOP)/tcc -vv; exit 1) && ./hello$(EXESUF)
|
||||||
|
|
||||||
hello-cross: ../examples/ex1.c
|
|
||||||
@echo ------------ $@ ------------
|
|
||||||
for XTCC in $(PROGS_CROSS) ; \
|
|
||||||
do echo -n "Test of $$XTCC... "; \
|
|
||||||
out=$$($(TOP)/$$XTCC $(XTCCFLAGS) -c $< 2>&1); \
|
|
||||||
test $$? -ne 0 && { echo "Failed\n$$out\n" ; $(TOP)/$$XTCC -vv; exit 1; } ; \
|
|
||||||
echo "Success"; \
|
|
||||||
done
|
|
||||||
|
|
||||||
hello-run: ../examples/ex1.c
|
hello-run: ../examples/ex1.c
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
$(TCC) -run $<
|
$(TCC) -run $<
|
||||||
|
|
||||||
libtest: libtcc_test$(EXESUF) $(LIBTCC1)
|
libtest: libtcc_test$(EXESUF)
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
./libtcc_test$(EXESUF) $(TCCFLAGS)
|
./libtcc_test$(EXESUF) $(TCCFLAGS)
|
||||||
|
|
||||||
libtcc_test$(EXESUF): libtcc_test.c $(top_builddir)/$(LIBTCC)
|
libtcc_test$(EXESUF): libtcc_test.c $(LIBTCC)
|
||||||
$(CC) -o $@ $^ $(CPPFLAGS) $(CFLAGS) $(NATIVE_DEFINES) $(LIBS) $(LINK_LIBTCC) $(LDFLAGS) -I$(top_srcdir)
|
$(CC) -o $@ $^ $(CFLAGS) $(LIBS)
|
||||||
|
|
||||||
%-dir:
|
%-dir:
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
@ -111,8 +82,8 @@ libtcc_test$(EXESUF): libtcc_test.c $(top_builddir)/$(LIBTCC)
|
|||||||
|
|
||||||
# test.ref - generate using cc
|
# test.ref - generate using cc
|
||||||
test.ref: tcctest.c
|
test.ref: tcctest.c
|
||||||
$(CC) -o tcctest.cc $< -I$(top_srcdir) $(CPPFLAGS) -w $(CFLAGS) $(NATIVE_DEFINES) -std=gnu99 -O0 -fno-omit-frame-pointer $(LDFLAGS)
|
$(CC) -o tcctest.gcc $< $(NATIVE_DEFINES) $(CFLAGS) -w -O0 -std=gnu99 -fno-omit-frame-pointer
|
||||||
./tcctest.cc > $@
|
./tcctest.gcc > $@
|
||||||
|
|
||||||
# auto test
|
# auto test
|
||||||
test1 test1b: tcctest.c test.ref
|
test1 test1b: tcctest.c test.ref
|
||||||
@ -183,19 +154,19 @@ btest: boundtest.c
|
|||||||
speedtest: ex2 ex3
|
speedtest: ex2 ex3
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
time ./ex2 1238 2 3 4 10 13 4
|
time ./ex2 1238 2 3 4 10 13 4
|
||||||
time $(TCC) -run $(top_srcdir)/examples/ex2.c 1238 2 3 4 10 13 4
|
time $(TCC) -run $(TOP)/examples/ex2.c 1238 2 3 4 10 13 4
|
||||||
time ./ex3 35
|
time ./ex3 35
|
||||||
time $(TCC) -run $(top_srcdir)/examples/ex3.c 35
|
time $(TCC) -run $(TOP)/examples/ex3.c 35
|
||||||
|
|
||||||
weaktest: tcctest.c test.ref
|
weaktest: tcctest.c test.ref
|
||||||
$(TCC) -c $< -o weaktest.tcc.o $(CPPFLAGS) $(CFLAGS)
|
$(TCC) -c $< -o weaktest.tcc.o
|
||||||
$(CC) -c $< -o weaktest.cc.o -I. $(CPPFLAGS) -w $(CFLAGS)
|
$(CC) -c $< -o weaktest.gcc.o -I. $(CFLAGS)
|
||||||
objdump -t weaktest.tcc.o | grep ' w ' | sed -e 's/.* \([a-zA-Z0-9_]*\)$$/\1/' | LC_ALL=C sort > weaktest.tcc.o.txt
|
objdump -t weaktest.tcc.o | grep ' w ' | sed -e 's/.* \([a-zA-Z0-9_]*\)$$/\1/' | LC_ALL=C sort > weaktest.tcc.o.txt
|
||||||
objdump -t weaktest.cc.o | grep ' w ' | sed -e 's/.* \([a-zA-Z0-9_]*\)$$/\1/' | LC_ALL=C sort > weaktest.cc.o.txt
|
objdump -t weaktest.gcc.o | grep ' w ' | sed -e 's/.* \([a-zA-Z0-9_]*\)$$/\1/' | LC_ALL=C sort > weaktest.gcc.o.txt
|
||||||
diff weaktest.cc.o.txt weaktest.tcc.o.txt && echo "Weak Auto Test OK"
|
diff weaktest.gcc.o.txt weaktest.tcc.o.txt && echo "Weak Auto Test OK"
|
||||||
|
|
||||||
ex%: $(top_srcdir)/examples/ex%.c
|
ex%: $(TOP)/examples/ex%.c
|
||||||
$(CC) -o $@ $< $(CPPFLAGS) $(CFLAGS) $(LDFLAGS)
|
$(CC) -o $@ $< $(CFLAGS)
|
||||||
|
|
||||||
# tiny assembler testing
|
# tiny assembler testing
|
||||||
asmtest.ref: asmtest.S
|
asmtest.ref: asmtest.S
|
||||||
@ -210,24 +181,27 @@ asmtest: asmtest.ref
|
|||||||
|
|
||||||
# Check that code generated by libtcc is binary compatible with
|
# Check that code generated by libtcc is binary compatible with
|
||||||
# that generated by CC
|
# that generated by CC
|
||||||
abitest-cc$(EXESUF): abitest.c $(top_builddir)/$(LIBTCC)
|
abitest-cc$(EXESUF): abitest.c $(LIBTCC)
|
||||||
$(CC) -o $@ $^ $(CPPFLAGS) $(CFLAGS) $(NATIVE_DEFINES) $(LIBS) $(LINK_LIBTCC) $(LDFLAGS) -I$(top_srcdir)
|
$(CC) -o $@ $^ $(CFLAGS) $(LIBS) -w
|
||||||
|
|
||||||
abitest-tcc$(EXESUF): abitest.c libtcc.c
|
abitest-tcc$(EXESUF): abitest.c libtcc.c
|
||||||
$(TCC) -o $@ $^ $(CPPFLAGS) $(CFLAGS) $(NATIVE_DEFINES) -DONE_SOURCE $(LIBS) $(LDFLAGS) -I$(top_srcdir)
|
$(TCC) -o $@ $^ $(NATIVE_DEFINES) -DONE_SOURCE $(LIBS)
|
||||||
|
|
||||||
ABITESTS := abitest-cc$(EXESUF)
|
ABITESTS := abitest-cc$(EXESUF)
|
||||||
ifneq ($(CONFIG_arm_eabi),yes) # not ARM soft-float
|
ifneq ($(CONFIG_arm_eabi),yes) # not ARM soft-float
|
||||||
ABITESTS += abitest-tcc$(EXESUF)
|
ABITESTS += abitest-tcc$(EXESUF)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
abitest: $(ABITESTS)
|
abitest: $(ABITESTS)
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
./abitest-cc$(EXESUF) $(TCCFLAGS)
|
./abitest-cc$(EXESUF) $(TCCFLAGS)
|
||||||
if [ "$(CONFIG_arm_eabi)" != "yes" ]; then ./abitest-tcc$(EXESUF) $(TCCFLAGS); fi
|
ifneq ($(CONFIG_arm_eabi),yes) # not ARM soft-float
|
||||||
|
./abitest-tcc$(EXESUF) $(TCCFLAGS)
|
||||||
|
endif
|
||||||
|
|
||||||
vla_test$(EXESUF): vla_test.c
|
vla_test$(EXESUF): vla_test.c
|
||||||
$(TCC) -o $@ $^ $(CPPFLAGS) $(CFLAGS)
|
$(TCC) -o $@ $^
|
||||||
|
|
||||||
vla_test-run: vla_test$(EXESUF)
|
vla_test-run: vla_test$(EXESUF)
|
||||||
@echo ------------ $@ ------------
|
@echo ------------ $@ ------------
|
||||||
./vla_test$(EXESUF)
|
./vla_test$(EXESUF)
|
||||||
@ -249,8 +223,11 @@ cache: tcc_g
|
|||||||
|
|
||||||
# clean
|
# clean
|
||||||
clean:
|
clean:
|
||||||
|
rm -f *~ *.o *.a *.bin *.i *.ref *.out *.out? *.out?b *.cc *.gcc \
|
||||||
|
*-cc *-gcc *-tcc *.exe hello libtcc_test vla_test tcctest[1234] ex? tcc_g
|
||||||
$(MAKE) -C tests2 $@
|
$(MAKE) -C tests2 $@
|
||||||
$(MAKE) -C pp $@
|
$(MAKE) -C pp $@
|
||||||
rm -vf *~ *.o *.a *.bin *.i *.ref *.out *.out? *.out?b *.cc \
|
|
||||||
*-cc *-tcc *.exe \
|
# silent clean, used before running tests
|
||||||
hello libtcc_test vla_test tcctest[1234] ex? tcc_g
|
clean-s:
|
||||||
|
@$(MAKE) -s --no-print-directory clean
|
||||||
|
@ -3,9 +3,8 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
TCC = ../../tcc
|
TCC = ../../tcc
|
||||||
|
files = $(patsubst %.$1,%.test,$(wildcard *.$1))
|
||||||
TESTS = $(patsubst %.c,%.test,$(wildcard *.c))
|
TESTS = $(call files,c) $(call files,S)
|
||||||
TESTS += $(patsubst %.S,%.test,$(wildcard *.S))
|
|
||||||
|
|
||||||
all test : $(sort $(TESTS))
|
all test : $(sort $(TESTS))
|
||||||
|
|
||||||
@ -25,10 +24,10 @@ DIFF_OPTS = -Nu -b -B -I "^\#"
|
|||||||
|
|
||||||
# automatically generate .expect files with gcc:
|
# automatically generate .expect files with gcc:
|
||||||
%.expect: %.c
|
%.expect: %.c
|
||||||
gcc -E -P $*.c >$*.expect 2>&1
|
gcc -E -P $< >$*.expect 2>&1
|
||||||
|
|
||||||
%.expect: %.S
|
%.expect: %.S
|
||||||
gcc -E -P $*.S >$*.expect 2>&1
|
gcc -E -P $< >$*.expect 2>&1
|
||||||
|
|
||||||
# tell make not to delete
|
# tell make not to delete
|
||||||
.PRECIOUS: %.expect
|
.PRECIOUS: %.expect
|
||||||
|
@ -1,22 +1,11 @@
|
|||||||
TOP = ../..
|
TOP = ../..
|
||||||
include $(TOP)/Makefile
|
include $(TOP)/Makefile
|
||||||
|
|
||||||
# clear CFLAGS and LDFLAGS
|
# run local version of tcc with local libraries and includes
|
||||||
CFLAGS :=
|
TCCFLAGS = -B$(TOP) -I$(TOP)
|
||||||
LDFLAGS :=
|
|
||||||
|
|
||||||
ifdef CONFIG_WIN32
|
ifdef CONFIG_WIN32
|
||||||
TCCFLAGS = -B$(top_srcdir)/win32 -I$(top_srcdir)/include -L$(TOP)
|
TCCFLAGS = -B$(TOP)/win32 -I$(TOP)/include -I$(TOP) -L$(TOP)
|
||||||
else
|
|
||||||
TCCFLAGS = -B$(TOP) -I$(top_srcdir)/include -lm
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(TARGETOS),Darwin)
|
|
||||||
CFLAGS += -Wl,-flat_namespace,-undefined,warning
|
|
||||||
TCCFLAGS += -D_ANSI_SOURCE
|
|
||||||
export MACOSX_DEPLOYMENT_TARGET:=10.2
|
|
||||||
endif
|
|
||||||
|
|
||||||
TCC = $(TOP)/tcc $(TCCFLAGS)
|
TCC = $(TOP)/tcc $(TCCFLAGS)
|
||||||
|
|
||||||
TESTS = $(patsubst %.c,%.test,$(sort $(wildcard *.c)))
|
TESTS = $(patsubst %.c,%.test,$(sort $(wildcard *.c)))
|
||||||
@ -48,8 +37,7 @@ ARGS =
|
|||||||
46_grep.test : ARGS = '[^* ]*[:a:d: ]+\:\*-/: $$' 46_grep.c
|
46_grep.test : ARGS = '[^* ]*[:a:d: ]+\:\*-/: $$' 46_grep.c
|
||||||
|
|
||||||
# Some tests might need different flags
|
# Some tests might need different flags
|
||||||
FLAGS =
|
76_dollars_in_identifiers.test : TCCFLAGS += -fdollars-in-identifiers
|
||||||
76_dollars_in_identifiers.test : FLAGS = -fdollars-in-identifiers
|
|
||||||
|
|
||||||
# Filter some always-warning
|
# Filter some always-warning
|
||||||
FILTER =
|
FILTER =
|
||||||
@ -62,7 +50,7 @@ all test: $(filter-out $(SKIP),$(TESTS))
|
|||||||
%.test: %.c %.expect
|
%.test: %.c %.expect
|
||||||
@echo Test: $*...
|
@echo Test: $*...
|
||||||
# test -run
|
# test -run
|
||||||
@$(TCC) $(FLAGS) -run $< $(ARGS) $(FILTER) >$*.output 2>&1 || true
|
@$(TCC) -run $< $(ARGS) $(FILTER) >$*.output 2>&1 || true
|
||||||
@diff -Nbu $*.expect $*.output && rm -f $*.output
|
@diff -Nbu $*.expect $*.output && rm -f $*.output
|
||||||
# test exe (disabled for speed)
|
# test exe (disabled for speed)
|
||||||
# @($(TCC) $(FLAGS) $< -o $*.exe && ./$*.exe $(ARGS)) $(FiLTER) >$*.output2 2>&1 ; \
|
# @($(TCC) $(FLAGS) $< -o $*.exe && ./$*.exe $(ARGS)) $(FiLTER) >$*.output2 2>&1 ; \
|
||||||
@ -76,4 +64,4 @@ all test: $(filter-out $(SKIP),$(TESTS))
|
|||||||
.PRECIOUS: %.expect
|
.PRECIOUS: %.expect
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -vf fred.txt *.output a.exe
|
rm -f fred.txt *.output a.exe
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
@echo off
|
|
||||||
@rem ----------------------------------------------------
|
@rem ----------------------------------------------------
|
||||||
@rem batch file to build tcc using mingw gcc
|
@rem batch file to build tcc using mingw gcc
|
||||||
@rem ----------------------------------------------------
|
@rem ----------------------------------------------------
|
||||||
@ -10,26 +9,25 @@ echo>..\config.h #define TCC_VERSION "%VERSION%"
|
|||||||
@if _%1_==_x64_ shift /1 && goto x86_64
|
@if _%1_==_x64_ shift /1 && goto x86_64
|
||||||
|
|
||||||
@set target=-DTCC_TARGET_PE -DTCC_TARGET_I386
|
@set target=-DTCC_TARGET_PE -DTCC_TARGET_I386
|
||||||
@set CC=gcc -Os -s -fno-strict-aliasing -Wno-incompatible-pointer-types
|
@set CC=gcc -Os -s -fno-strict-aliasing
|
||||||
@if _%1_==_debug_ set CC=gcc -g -ggdb
|
@if _%1_==_debug_ set CC=gcc -g -ggdb
|
||||||
@set P=32
|
@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-w64-mingw32-gcc -Os -s -fno-strict-aliasing -Wno-incompatible-pointer-types
|
@set CC=x86_64-w64-mingw32-gcc -Os -s -fno-strict-aliasing
|
||||||
@if _%1_==_debug_ set CC=x86_64-w64-mingw32-gcc -g -ggdb
|
@if _%1_==_debug_ set CC=x86_64-w64-mingw32-gcc -g -ggdb
|
||||||
@set P=64
|
@set P=64
|
||||||
@goto tools
|
@goto tools
|
||||||
|
|
||||||
:tools
|
:tools
|
||||||
echo will use %CC% %target%
|
|
||||||
%CC% %target% tools/tiny_impdef.c -o tiny_impdef.exe
|
%CC% %target% tools/tiny_impdef.c -o tiny_impdef.exe
|
||||||
%CC% %target% tools/tiny_libmaker.c -o tiny_libmaker.exe
|
%CC% %target% tools/tiny_libmaker.c -o tiny_libmaker.exe
|
||||||
|
|
||||||
:libtcc
|
:libtcc
|
||||||
if not exist libtcc mkdir libtcc
|
if not exist libtcc mkdir libtcc
|
||||||
copy ..\libtcc.h libtcc\libtcc.h > nul
|
copy ..\libtcc.h libtcc\libtcc.h
|
||||||
%CC% %target% -shared -DLIBTCC_AS_DLL -DONE_SOURCE ../libtcc.c -o libtcc.dll -Wl,-out-implib,libtcc/libtcc.a
|
%CC% %target% -shared -DLIBTCC_AS_DLL -DONE_SOURCE ../libtcc.c -o libtcc.dll -Wl,-out-implib,libtcc/libtcc.a
|
||||||
tiny_impdef libtcc.dll -o libtcc/libtcc.def
|
tiny_impdef libtcc.dll -o libtcc/libtcc.def
|
||||||
|
|
||||||
@ -37,7 +35,7 @@ tiny_impdef libtcc.dll -o libtcc/libtcc.def
|
|||||||
%CC% %target% ../tcc.c -o tcc.exe -ltcc -Llibtcc
|
%CC% %target% ../tcc.c -o tcc.exe -ltcc -Llibtcc
|
||||||
|
|
||||||
:copy_std_includes
|
:copy_std_includes
|
||||||
copy ..\include\*.h include > nul
|
copy ..\include\*.h include
|
||||||
|
|
||||||
:libtcc1.a
|
:libtcc1.a
|
||||||
.\tcc %target% -c ../lib/libtcc1.c
|
.\tcc %target% -c ../lib/libtcc1.c
|
||||||
@ -61,13 +59,10 @@ tiny_libmaker lib/libtcc1.a libtcc1.o alloca86_64.o crt1.o wincrt1.o dllcrt1.o d
|
|||||||
|
|
||||||
:the_end
|
:the_end
|
||||||
del *.o
|
del *.o
|
||||||
|
copy ..\tests\libtcc_test.c examples
|
||||||
|
|
||||||
:makedoc
|
:makedoc
|
||||||
for /f "delims=" %%i in ('where makeinfo') do set minfo=perl "%%~i"
|
|
||||||
if "%minfo%"=="" goto :skip_makedoc
|
|
||||||
echo>..\config.texi @set VERSION %VERSION%
|
|
||||||
if not exist doc md doc
|
if not exist doc md doc
|
||||||
%minfo% --html --no-split -o doc\tcc-doc.html ../tcc-doc.texi
|
|
||||||
copy tcc-win32.txt doc
|
copy tcc-win32.txt doc
|
||||||
copy ..\tests\libtcc_test.c examples
|
echo>..\config.texi @set VERSION %VERSION%
|
||||||
:skip_makedoc
|
makeinfo --html --no-split -o doc\tcc-doc.html ../tcc-doc.texi
|
||||||
|
Loading…
Reference in New Issue
Block a user