diff --git a/tcc.c b/tcc.c index 56b80695..64a8d51a 100644 --- a/tcc.c +++ b/tcc.c @@ -476,6 +476,9 @@ struct TCCState { /* if true, static linking is performed */ int static_link; + /* soname as specified on the command line (-soname) */ + const char *soname; + /* if true, all symbols are exported */ int rdynamic; @@ -10560,8 +10563,8 @@ void help(void) { printf("tcc version " TCC_VERSION " - Tiny C Compiler - Copyright (C) 2001-2006 Fabrice Bellard\n" "usage: tcc [-v] [-c] [-o outfile] [-Bdir] [-bench] [-Idir] [-Dsym[=val]] [-Usym]\n" - " [-Wwarn] [-g] [-b] [-bt N] [-Ldir] [-llib] [-shared] [-static]\n" - " [infile1 infile2...] [-run infile args...]\n" + " [-Wwarn] [-g] [-b] [-bt N] [-Ldir] [-llib] [-shared] [-soname name]\n" + " [-static] [infile1 infile2...] [-run infile args...]\n" "\n" "General options:\n" " -v display current version\n" @@ -10582,6 +10585,7 @@ void help(void) " -Ldir add library path 'dir'\n" " -llib link with dynamic or static library 'lib'\n" " -shared generate a shared library\n" + " -soname set name for shared library to be used at runtime\n" " -static static linking\n" " -rdynamic export all global symbols to dynamic linker\n" " -r generate (relocatable) object file\n" @@ -10618,6 +10622,7 @@ enum { TCC_OPTION_c, TCC_OPTION_static, TCC_OPTION_shared, + TCC_OPTION_soname, TCC_OPTION_o, TCC_OPTION_r, TCC_OPTION_Wl, @@ -10654,6 +10659,7 @@ static const TCCOption tcc_options[] = { { "c", TCC_OPTION_c, 0 }, { "static", TCC_OPTION_static, 0 }, { "shared", TCC_OPTION_shared, 0 }, + { "soname", TCC_OPTION_soname, TCC_OPTION_HAS_ARG }, { "o", TCC_OPTION_o, TCC_OPTION_HAS_ARG }, { "run", TCC_OPTION_run, TCC_OPTION_HAS_ARG | TCC_OPTION_NOSEP }, { "rdynamic", TCC_OPTION_rdynamic, 0 }, @@ -10825,6 +10831,9 @@ int parse_args(TCCState *s, int argc, char **argv) case TCC_OPTION_shared: output_type = TCC_OUTPUT_DLL; break; + case TCC_OPTION_soname: + s->soname = optarg; + break; case TCC_OPTION_o: multiple_files = 1; outfile = optarg; diff --git a/tccelf.c b/tccelf.c index 4913a045..25631978 100644 --- a/tccelf.c +++ b/tccelf.c @@ -1314,8 +1314,11 @@ int tcc_output_file(TCCState *s1, const char *filename) } /* XXX: currently, since we do not handle PIC code, we must relocate the readonly segments */ - if (file_type == TCC_OUTPUT_DLL) + if (file_type == TCC_OUTPUT_DLL) { + if (s1->soname) + put_dt(dynamic, DT_SONAME, put_elf_str(dynstr, s1->soname)); put_dt(dynamic, DT_TEXTREL, 0); + } /* add necessary space for other entries */ saved_dynamic_data_offset = dynamic->data_offset; @@ -2286,8 +2289,60 @@ static int ld_next(TCCState *s1, char *name, int name_size) goto parse_name; } break; - case 'a' ... 'z': - case 'A' ... 'Z': + /* case 'a' ... 'z': */ + case 'a': + case 'b': + case 'c': + case 'd': + case 'e': + case 'f': + case 'g': + case 'h': + case 'i': + case 'j': + case 'k': + case 'l': + case 'm': + case 'n': + case 'o': + case 'p': + case 'q': + case 'r': + case 's': + case 't': + case 'u': + case 'v': + case 'w': + case 'x': + case 'y': + case 'z': + /* case 'A' ... 'z': */ + case 'A': + case 'B': + case 'C': + case 'D': + case 'E': + case 'F': + case 'G': + case 'H': + case 'I': + case 'J': + case 'K': + case 'L': + case 'M': + case 'N': + case 'O': + case 'P': + case 'Q': + case 'R': + case 'S': + case 'T': + case 'U': + case 'V': + case 'W': + case 'X': + case 'Y': + case 'Z': case '_': case '\\': case '.':