mirror of
https://github.com/mirror/tinycc.git
synced 2025-01-15 05:20:06 +08:00
configure: add switches to set search paths
--sysincludepaths=.. specify system include paths, colon separated" Sets CONFIG_TCC_SYSINCLUDEPATHS --libpaths=... specify system library paths, colon separated" Sets CONFIG_TCC_LIBPATHS --crtprefix=... specify location of crt?.o" Sets CONFIG_TCC_CRTPREFIX --elfinterp=... specify elf interpreter" Sets CONFIG_TCC_ELFINTERP Also the CONFIG_TCC_XXX were renamed to make them look more consistent. Also move the elf_interp definitions to tcc.h.
This commit is contained in:
parent
9ffd77f18d
commit
81cd0cf6fd
4
Makefile
4
Makefile
@ -164,10 +164,10 @@ $(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_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATH="\"\b/lib/32;\b/lib\""
|
-DCONFIG_TCC_LIBPATHS="\"\b/lib/32;\b/lib\""
|
||||||
$(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_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATH="\"\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
|
||||||
$(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
|
$(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
|
||||||
|
41
configure
vendored
41
configure
vendored
@ -38,6 +38,12 @@ ar="ar"
|
|||||||
strip="strip"
|
strip="strip"
|
||||||
cygwin="no"
|
cygwin="no"
|
||||||
cpu=`uname -m`
|
cpu=`uname -m`
|
||||||
|
|
||||||
|
tcc_sysincludepaths=""
|
||||||
|
tcc_libpaths=""
|
||||||
|
tcc_crtprefix=""
|
||||||
|
tcc_elfinterp=""
|
||||||
|
|
||||||
case "$cpu" in
|
case "$cpu" in
|
||||||
i386|i486|i586|i686|i86pc|BePC|i686-AT386)
|
i386|i486|i586|i686|i86pc|BePC|i686-AT386)
|
||||||
cpu="x86"
|
cpu="x86"
|
||||||
@ -132,6 +138,14 @@ for opt do
|
|||||||
;;
|
;;
|
||||||
--extra-libs=*) extralibs=${opt#--extra-libs=}
|
--extra-libs=*) extralibs=${opt#--extra-libs=}
|
||||||
;;
|
;;
|
||||||
|
--sysincludepaths=*) tcc_sysincludepaths=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
|
--libpaths=*) tcc_libpaths=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
|
--crtprefix=*) tcc_crtprefix=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
|
--elfinterp=*) tcc_elfinterp=`echo $opt | cut -d '=' -f 2`
|
||||||
|
;;
|
||||||
--cpu=*) cpu=`echo $opt | cut -d '=' -f 2`
|
--cpu=*) cpu=`echo $opt | cut -d '=' -f 2`
|
||||||
;;
|
;;
|
||||||
--enable-gprof) gprof="yes"
|
--enable-gprof) gprof="yes"
|
||||||
@ -265,6 +279,10 @@ echo " --extra-cflags= extra compiler flags"
|
|||||||
echo " --extra-ldflags= extra linker options"
|
echo " --extra-ldflags= extra linker options"
|
||||||
echo " --with-selinux use mmap instead of exec mem"
|
echo " --with-selinux use mmap instead of exec mem"
|
||||||
echo " [requires write access to /tmp]"
|
echo " [requires write access to /tmp]"
|
||||||
|
echo " --sysincludepaths=... specify system include paths, colon separated"
|
||||||
|
echo " --libpaths=... specify system library paths, colon separated"
|
||||||
|
echo " --crtprefix=... specify location of crt?.o"
|
||||||
|
echo " --elfinterp=... specify elf interpreter"
|
||||||
echo ""
|
echo ""
|
||||||
#echo "NOTE: The object files are build at the place where configure is launched"
|
#echo "NOTE: The object files are build at the place where configure is launched"
|
||||||
exit 1
|
exit 1
|
||||||
@ -352,13 +370,23 @@ echo "includedir=\$(DESTDIR)$includedir" >> config.mak
|
|||||||
echo "mandir=\$(DESTDIR)$mandir" >> config.mak
|
echo "mandir=\$(DESTDIR)$mandir" >> config.mak
|
||||||
echo "infodir=\$(DESTDIR)$infodir" >> config.mak
|
echo "infodir=\$(DESTDIR)$infodir" >> config.mak
|
||||||
echo "docdir=\$(DESTDIR)$docdir" >> config.mak
|
echo "docdir=\$(DESTDIR)$docdir" >> config.mak
|
||||||
|
print_var1()
|
||||||
|
{
|
||||||
|
echo "#ifndef $1" >> $TMPH
|
||||||
|
echo "# define $1 \"$2\"" >> $TMPH
|
||||||
|
echo "#endif" >> $TMPH
|
||||||
|
}
|
||||||
|
print_var2()
|
||||||
|
{
|
||||||
|
if test -n "$2"; then print_var1 $1 "$2"; fi
|
||||||
|
}
|
||||||
|
print_var1 CONFIG_SYSROOT "$sysroot"
|
||||||
|
print_var1 CONFIG_TCCDIR "$tccdir"
|
||||||
|
print_var2 CONFIG_TCC_SYSINCLUDEPATHS "$tcc_sysincludepaths"
|
||||||
|
print_var2 CONFIG_TCC_LIBPATHS "$tcc_libpaths"
|
||||||
|
print_var2 CONFIG_TCC_CRTPREFIX "$tcc_crtprefix"
|
||||||
|
print_var2 CONFIG_TCC_ELFINTERP "$tcc_elfinterp"
|
||||||
|
|
||||||
echo "#ifndef CONFIG_SYSROOT" >> $TMPH
|
|
||||||
echo "#define CONFIG_SYSROOT \"$sysroot\"" >> $TMPH
|
|
||||||
echo "#endif" >> $TMPH
|
|
||||||
echo "#ifndef CONFIG_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
|
||||||
@ -369,6 +397,7 @@ echo "CFLAGS=$CFLAGS" >> config.mak
|
|||||||
echo "LDFLAGS=$LDFLAGS" >> config.mak
|
echo "LDFLAGS=$LDFLAGS" >> config.mak
|
||||||
echo "LIBSUF=$LIBSUF" >> config.mak
|
echo "LIBSUF=$LIBSUF" >> config.mak
|
||||||
echo "EXESUF=$EXESUF" >> config.mak
|
echo "EXESUF=$EXESUF" >> config.mak
|
||||||
|
|
||||||
if test "$cpu" = "x86" ; then
|
if test "$cpu" = "x86" ; then
|
||||||
echo "ARCH=i386" >> config.mak
|
echo "ARCH=i386" >> config.mak
|
||||||
echo "#define HOST_I386 1" >> $TMPH
|
echo "#define HOST_I386 1" >> $TMPH
|
||||||
|
42
libtcc.c
42
libtcc.c
@ -306,38 +306,25 @@ PUB_FUNC void dynarray_reset(void *pp, int *n)
|
|||||||
*(void**)pp = NULL;
|
*(void**)pp = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* out must not point to a valid dynarray since a new one is created */
|
|
||||||
static void tcc_split_path(TCCState *s, void ***p_ary, int *p_nb_ary, const char *in)
|
static void tcc_split_path(TCCState *s, void ***p_ary, int *p_nb_ary, const char *in)
|
||||||
{
|
{
|
||||||
const char *p;
|
const char *p;
|
||||||
do {
|
do {
|
||||||
const char *r = NULL;
|
|
||||||
int c;
|
int c;
|
||||||
CString str;
|
CString str;
|
||||||
|
|
||||||
cstr_new(&str);
|
cstr_new(&str);
|
||||||
for (p = in;;) {
|
for (p = in; c = *p, c != '\0' && c != PATHSEP; ++p) {
|
||||||
if (r) {
|
if (c == '\b') {
|
||||||
if ((c = *r++) == 0) {
|
cstr_cat(&str, s->tcc_lib_path);
|
||||||
r = NULL;
|
} else {
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else if ((c = *p++) == 0) {
|
|
||||||
;
|
|
||||||
} else if (c == PATHSEP) {
|
|
||||||
c = 0;
|
|
||||||
} else if (c == '\b') {
|
|
||||||
r = s->tcc_lib_path;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
cstr_ccat(&str, c);
|
cstr_ccat(&str, c);
|
||||||
if (0 == c)
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
//printf("path: %s\n", (char*)str.data);
|
}
|
||||||
|
cstr_ccat(&str, '\0');
|
||||||
dynarray_add(p_ary, p_nb_ary, str.data);
|
dynarray_add(p_ary, p_nb_ary, str.data);
|
||||||
in = p;
|
in = p+1;
|
||||||
} while (p[-1]);
|
} while (*p);
|
||||||
}
|
}
|
||||||
|
|
||||||
/********************************************************/
|
/********************************************************/
|
||||||
@ -1006,7 +993,7 @@ LIBTCCAPI TCCState *tcc_new(void)
|
|||||||
|
|
||||||
#ifndef TCC_TARGET_PE
|
#ifndef TCC_TARGET_PE
|
||||||
/* default library paths */
|
/* default library paths */
|
||||||
tcc_add_library_path(s, CONFIG_TCC_LIBPATH);
|
tcc_add_library_path(s, CONFIG_TCC_LIBPATHS);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* no section zero */
|
/* no section zero */
|
||||||
@ -1229,7 +1216,6 @@ the_end:
|
|||||||
LIBTCCAPI int tcc_add_file(TCCState *s, const char *filename)
|
LIBTCCAPI int tcc_add_file(TCCState *s, const char *filename)
|
||||||
{
|
{
|
||||||
dynarray_add((void ***)&s->input_files, &s->nb_input_files, tcc_strdup(filename));
|
dynarray_add((void ***)&s->input_files, &s->nb_input_files, tcc_strdup(filename));
|
||||||
|
|
||||||
if (s->output_type == TCC_OUTPUT_PREPROCESS)
|
if (s->output_type == TCC_OUTPUT_PREPROCESS)
|
||||||
return tcc_add_file_internal(s, filename, AFF_PRINT_ERROR | AFF_PREPROCESS);
|
return tcc_add_file_internal(s, filename, AFF_PRINT_ERROR | AFF_PREPROCESS);
|
||||||
else
|
else
|
||||||
@ -1306,7 +1292,7 @@ LIBTCCAPI int tcc_set_output_type(TCCState *s, int output_type)
|
|||||||
if (!s->nostdinc) {
|
if (!s->nostdinc) {
|
||||||
/* default include paths */
|
/* default include paths */
|
||||||
/* -isystem paths have already been handled */
|
/* -isystem paths have already been handled */
|
||||||
tcc_add_sysinclude_path(s, CONFIG_TCC_SYSINCLUDE_PATHS);
|
tcc_add_sysinclude_path(s, CONFIG_TCC_SYSINCLUDEPATHS);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if bound checking, then add corresponding sections */
|
/* if bound checking, then add corresponding sections */
|
||||||
@ -1338,18 +1324,18 @@ LIBTCCAPI int tcc_set_output_type(TCCState *s, int output_type)
|
|||||||
put_stabs("", 0, 0, 0, 0);
|
put_stabs("", 0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* add libc crt1/crti objects */
|
|
||||||
#ifdef TCC_TARGET_PE
|
#ifdef TCC_TARGET_PE
|
||||||
tcc_add_library_path(s, CONFIG_TCC_LIBPATH);
|
tcc_add_library_path(s, CONFIG_TCC_LIBPATHS);
|
||||||
# ifdef _WIN32
|
# ifdef _WIN32
|
||||||
tcc_add_systemdir(s);
|
tcc_add_systemdir(s);
|
||||||
# endif
|
# endif
|
||||||
#else
|
#else
|
||||||
|
/* add libc crt1/crti objects */
|
||||||
if ((output_type == TCC_OUTPUT_EXE || output_type == TCC_OUTPUT_DLL) &&
|
if ((output_type == TCC_OUTPUT_EXE || output_type == TCC_OUTPUT_DLL) &&
|
||||||
!s->nostdlib) {
|
!s->nostdlib) {
|
||||||
if (output_type != TCC_OUTPUT_DLL)
|
if (output_type != TCC_OUTPUT_DLL)
|
||||||
tcc_add_file(s, CONFIG_SYSROOT CONFIG_TCC_CRT_PREFIX "/crt1.o");
|
tcc_add_file(s, TCC_CRTO("crt1.o"));
|
||||||
tcc_add_file(s, CONFIG_SYSROOT CONFIG_TCC_CRT_PREFIX "/crti.o");
|
tcc_add_file(s, TCC_CRTO("crti.o"));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
|
59
tcc.h
59
tcc.h
@ -133,11 +133,7 @@
|
|||||||
#define CONFIG_TCC_BACKTRACE
|
#define CONFIG_TCC_BACKTRACE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define FALSE 0
|
/* ------------ path configuration ------------ */
|
||||||
#define false 0
|
|
||||||
#define TRUE 1
|
|
||||||
#define true 1
|
|
||||||
typedef int BOOL;
|
|
||||||
|
|
||||||
#ifndef CONFIG_TCC_LDDIR
|
#ifndef CONFIG_TCC_LDDIR
|
||||||
# if defined(TCC_TARGET_X86_64_CENTOS)
|
# if defined(TCC_TARGET_X86_64_CENTOS)
|
||||||
@ -148,29 +144,64 @@ typedef int BOOL;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* path to find crt1.o, crti.o and crtn.o */
|
/* path to find crt1.o, crti.o and crtn.o */
|
||||||
#ifndef CONFIG_TCC_CRT_PREFIX
|
#ifndef CONFIG_TCC_CRTPREFIX
|
||||||
# define CONFIG_TCC_CRT_PREFIX "/usr" CONFIG_TCC_LDDIR
|
# define CONFIG_TCC_CRTPREFIX "/usr" CONFIG_TCC_LDDIR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef CONFIG_TCC_SYSINCLUDE_PATHS
|
/* system include paths */
|
||||||
|
#ifndef CONFIG_TCC_SYSINCLUDEPATHS
|
||||||
# ifdef TCC_TARGET_PE
|
# ifdef TCC_TARGET_PE
|
||||||
# define CONFIG_TCC_SYSINCLUDE_PATHS "\b/include;\b/include/winapi"
|
# define CONFIG_TCC_SYSINCLUDEPATHS "\b/include;\b/include/winapi"
|
||||||
# else
|
# else
|
||||||
# define CONFIG_TCC_SYSINCLUDE_PATHS "/usr/local/include:/usr/include:\b/include"
|
# define CONFIG_TCC_SYSINCLUDEPATHS \
|
||||||
|
CONFIG_SYSROOT "/usr/local/include" \
|
||||||
|
":" CONFIG_SYSROOT "/usr/include" \
|
||||||
|
":" "\b/include"
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef CONFIG_TCC_LIBPATH
|
/* library search paths */
|
||||||
|
#ifndef CONFIG_TCC_LIBPATHS
|
||||||
# ifdef TCC_TARGET_PE
|
# ifdef TCC_TARGET_PE
|
||||||
# define CONFIG_TCC_LIBPATH "\b/lib"
|
# define CONFIG_TCC_LIBPATHS "\b/lib"
|
||||||
# else
|
# else
|
||||||
# define CONFIG_TCC_LIBPATH \
|
# define CONFIG_TCC_LIBPATHS \
|
||||||
CONFIG_SYSROOT CONFIG_TCC_CRT_PREFIX \
|
CONFIG_SYSROOT CONFIG_TCC_CRTPREFIX \
|
||||||
":" CONFIG_SYSROOT CONFIG_TCC_LDDIR \
|
":" CONFIG_SYSROOT CONFIG_TCC_LDDIR \
|
||||||
":" CONFIG_SYSROOT "/usr/local" CONFIG_TCC_LDDIR
|
":" CONFIG_SYSROOT "/usr/local" CONFIG_TCC_LDDIR
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* name of ELF interpreter */
|
||||||
|
#ifndef CONFIG_TCC_ELFINTERP
|
||||||
|
# if defined __FreeBSD__
|
||||||
|
# define CONFIG_TCC_ELFINTERP "/libexec/ld-elf.so.1"
|
||||||
|
# elif defined __FreeBSD_kernel__
|
||||||
|
# define CONFIG_TCC_ELFINTERP CONFIG_TCC_LDDIR"/ld.so.1"
|
||||||
|
# elif defined TCC_ARM_EABI
|
||||||
|
# define CONFIG_TCC_ELFINTERP CONFIG_TCC_LDDIR"/ld-linux.so.3"
|
||||||
|
# elif defined(TCC_TARGET_X86_64)
|
||||||
|
# define CONFIG_TCC_ELFINTERP CONFIG_TCC_LDDIR"/ld-linux-x86-64.so.2"
|
||||||
|
# elif defined(TCC_UCLIBC)
|
||||||
|
# define CONFIG_TCC_ELFINTERP CONFIG_TCC_LDDIR"/ld-uClibc.so.0"
|
||||||
|
# else
|
||||||
|
# define CONFIG_TCC_ELFINTERP CONFIG_TCC_LDDIR"/ld-linux.so.2"
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* library to use with CONFIG_USE_LIBGCC instead of libtcc1.a */
|
||||||
|
#define TCC_LIBGCC CONFIG_SYSROOT CONFIG_TCC_LDDIR "/libgcc_s.so.1"
|
||||||
|
/* crt?.o files */
|
||||||
|
#define TCC_CRTO(crto) CONFIG_SYSROOT CONFIG_TCC_CRTPREFIX "/" crto
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
|
||||||
|
#define FALSE 0
|
||||||
|
#define false 0
|
||||||
|
#define TRUE 1
|
||||||
|
#define true 1
|
||||||
|
typedef int BOOL;
|
||||||
|
|
||||||
#define INCLUDE_STACK_SIZE 32
|
#define INCLUDE_STACK_SIZE 32
|
||||||
#define IFDEF_STACK_SIZE 64
|
#define IFDEF_STACK_SIZE 64
|
||||||
#define VSTACK_SIZE 256
|
#define VSTACK_SIZE 256
|
||||||
|
50
tccelf.c
50
tccelf.c
@ -1189,6 +1189,13 @@ static void add_init_array_defines(TCCState *s1, const char *section_name)
|
|||||||
s->sh_num, sym_end);
|
s->sh_num, sym_end);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int tcc_add_support(TCCState *s1, const char *filename)
|
||||||
|
{
|
||||||
|
char buf[1024];
|
||||||
|
snprintf(buf, sizeof(buf), "%s/%s", s1->tcc_lib_path, filename);
|
||||||
|
return tcc_add_file(s1, buf);
|
||||||
|
}
|
||||||
|
|
||||||
ST_FUNC void tcc_add_bcheck(TCCState *s1)
|
ST_FUNC void tcc_add_bcheck(TCCState *s1)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_TCC_BCHECK
|
#ifdef CONFIG_TCC_BCHECK
|
||||||
@ -1208,11 +1215,7 @@ ST_FUNC void tcc_add_bcheck(TCCState *s1)
|
|||||||
bounds_section->sh_num, "__bounds_start");
|
bounds_section->sh_num, "__bounds_start");
|
||||||
/* add bound check code */
|
/* add bound check code */
|
||||||
#ifndef TCC_TARGET_PE
|
#ifndef TCC_TARGET_PE
|
||||||
{
|
tcc_add_support(s1, "bcheck.o");
|
||||||
char buf[1024];
|
|
||||||
snprintf(buf, sizeof(buf), "%s/%s", s1->tcc_lib_path, "bcheck.o");
|
|
||||||
tcc_add_file(s1, buf);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef TCC_TARGET_I386
|
#ifdef TCC_TARGET_I386
|
||||||
if (s1->output_type != TCC_OUTPUT_MEMORY) {
|
if (s1->output_type != TCC_OUTPUT_MEMORY) {
|
||||||
@ -1236,23 +1239,15 @@ ST_FUNC void tcc_add_runtime(TCCState *s1)
|
|||||||
|
|
||||||
/* add libc */
|
/* add libc */
|
||||||
if (!s1->nostdlib) {
|
if (!s1->nostdlib) {
|
||||||
|
tcc_add_library(s1, "c");
|
||||||
#ifdef CONFIG_USE_LIBGCC
|
#ifdef CONFIG_USE_LIBGCC
|
||||||
tcc_add_library(s1, "c");
|
tcc_add_file(s1, TCC_LIBGCC);
|
||||||
tcc_add_file(s1, CONFIG_SYSROOT CONFIG_TCC_LDDIR"/libgcc_s.so.1");
|
#elif !defined WITHOUT_LIBTCC
|
||||||
#else
|
tcc_add_support(s1, "libtcc1.a");
|
||||||
tcc_add_library(s1, "c");
|
|
||||||
#ifndef WITHOUT_LIBTCC
|
|
||||||
{
|
|
||||||
char buf[1024];
|
|
||||||
snprintf(buf, sizeof(buf), "%s/%s", s1->tcc_lib_path, "libtcc1.a");
|
|
||||||
tcc_add_file(s1, buf);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
}
|
|
||||||
/* add crt end if not memory output */
|
/* add crt end if not memory output */
|
||||||
if (s1->output_type != TCC_OUTPUT_MEMORY && !s1->nostdlib) {
|
if (s1->output_type != TCC_OUTPUT_MEMORY)
|
||||||
tcc_add_file(s1, CONFIG_SYSROOT CONFIG_TCC_CRT_PREFIX "/crtn.o");
|
tcc_add_file(s1, TCC_CRTO("crtn.o"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1316,21 +1311,6 @@ ST_FUNC void tcc_add_linker_symbols(TCCState *s1)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* name of ELF interpreter */
|
|
||||||
#if defined __FreeBSD__
|
|
||||||
static const char elf_interp[] = "/libexec/ld-elf.so.1";
|
|
||||||
#elif defined __FreeBSD_kernel__
|
|
||||||
static char elf_interp[] = CONFIG_TCC_LDDIR"/ld.so.1";
|
|
||||||
#elif defined TCC_ARM_EABI
|
|
||||||
static const char elf_interp[] = CONFIG_TCC_LDDIR"/ld-linux.so.3";
|
|
||||||
#elif defined(TCC_TARGET_X86_64)
|
|
||||||
static const char elf_interp[] = CONFIG_TCC_LDDIR"/ld-linux-x86-64.so.2";
|
|
||||||
#elif defined(TCC_UCLIBC)
|
|
||||||
static const char elf_interp[] = CONFIG_TCC_LDDIR"/ld-uClibc.so.0";
|
|
||||||
#else
|
|
||||||
static const char elf_interp[] = CONFIG_TCC_LDDIR"/ld-linux.so.2";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void tcc_output_binary(TCCState *s1, FILE *f,
|
static void tcc_output_binary(TCCState *s1, FILE *f,
|
||||||
const int *section_order)
|
const int *section_order)
|
||||||
{
|
{
|
||||||
@ -1473,7 +1453,7 @@ static int elf_output_file(TCCState *s1, const char *filename)
|
|||||||
/* allow override the dynamic loader */
|
/* allow override the dynamic loader */
|
||||||
const char *elfint = getenv("LD_SO");
|
const char *elfint = getenv("LD_SO");
|
||||||
if (elfint == NULL)
|
if (elfint == NULL)
|
||||||
elfint = elf_interp;
|
elfint = CONFIG_TCC_ELFINTERP;
|
||||||
/* add interpreter section only if executable */
|
/* add interpreter section only if executable */
|
||||||
interp = new_section(s1, ".interp", SHT_PROGBITS, SHF_ALLOC);
|
interp = new_section(s1, ".interp", SHT_PROGBITS, SHF_ALLOC);
|
||||||
interp->sh_addralign = 1;
|
interp->sh_addralign = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user