Revert "--whole-archive support"

- would parse linker args in two different places
- would mess up "tcc -v ..." output:
  	tcc -v test.c
  	-> test.c
  	+> test.c
- would use function "tcc_load_alacarte()" to do the contrary of
  what its name suggests.

This reverts commit 19a169ceb8.
This commit is contained in:
grischka 2016-10-01 19:56:25 +02:00
parent e238e6521b
commit cf32bb8812
6 changed files with 3 additions and 43 deletions

View File

@ -1419,11 +1419,9 @@ ST_FUNC int tcc_add_file_internal(TCCState *s1, const char *filename, int flags,
ret = tcc_load_ldscript(s1); ret = tcc_load_ldscript(s1);
#endif #endif
if (ret < 0) if (ret < 0)
tcc_error_noabort("%s: unrecognized file type (error=%d)", filename, ret); tcc_error_noabort("unrecognized file type");
the_end: the_end:
if (s1->verbose)
printf("+> %s\n", filename);
tcc_close(); tcc_close();
return ret; return ret;
} }
@ -2321,16 +2319,6 @@ ST_FUNC int tcc_parse_args1(TCCState *s, int argc, char **argv)
s->rdynamic = 1; s->rdynamic = 1;
break; break;
case TCC_OPTION_Wl: case TCC_OPTION_Wl:
if (optarg && *optarg == '-') {
int offs = 0;
if (!strncmp("-no", optarg+1, 3))
offs += 3;
if (!strcmp("-whole-archive", optarg+1 + offs)) {
args_parser_add_file(s, "", (offs == 0) ? TCC_FILETYPE_AR_WHOLE_ON :
TCC_FILETYPE_AR_WHOLE_OFF);
break;
}
}
if (pas->linker_arg.size) if (pas->linker_arg.size)
--pas->linker_arg.size, cstr_ccat(&pas->linker_arg, ','); --pas->linker_arg.size, cstr_ccat(&pas->linker_arg, ',');
cstr_cat(&pas->linker_arg, optarg, 0); cstr_cat(&pas->linker_arg, optarg, 0);

View File

@ -53,8 +53,6 @@ LIBTCCAPI int tcc_add_file(TCCState *s, const char *filename, int filetype);
#define TCC_FILETYPE_C 2 #define TCC_FILETYPE_C 2
#define TCC_FILETYPE_ASM 3 #define TCC_FILETYPE_ASM 3
#define TCC_FILETYPE_ASM_PP 4 #define TCC_FILETYPE_ASM_PP 4
#define TCC_FILETYPE_AR_WHOLE_OFF 5
#define TCC_FILETYPE_AR_WHOLE_ON 6
/* compile a string containing a C source. Return -1 if error. */ /* compile a string containing a C source. Return -1 if error. */
LIBTCCAPI int tcc_compile_string(TCCState *s, const char *buf); LIBTCCAPI int tcc_compile_string(TCCState *s, const char *buf);

View File

@ -317,14 +317,6 @@ Generate an object file combining all input files.
@item -Wl,-rpath=path @item -Wl,-rpath=path
Put custom search path for dynamic libraries into executable. Put custom search path for dynamic libraries into executable.
@item -Wl,--whole-archive
Add a whole archive, not just the symbols of the archive that would
satisfy undefined symbols in the program.
@item -Wl,--no-whole-archive
Turn off the effect of the --whole-archive option for subsequent archive
files.
@item -Wl,--oformat=fmt @item -Wl,--oformat=fmt
Use @var{fmt} as output format. The supported output formats are: Use @var{fmt} as output format. The supported output formats are:
@table @code @table @code

18
tcc.c
View File

@ -247,13 +247,6 @@ static int64_t getclock_us(void)
#endif #endif
} }
static void set_whole_archive(TCCState* s, int on)
{
s->whole_archive = on;
if (1 == s->verbose)
printf("%cwhole-archive>\n", s->whole_archive? '+' : '-');
}
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
TCCState *s; TCCState *s;
@ -308,14 +301,6 @@ int main(int argc, char **argv)
for(i = ret = 0; i < s->nb_files && ret == 0; i++) { for(i = ret = 0; i < s->nb_files && ret == 0; i++) {
int filetype = *(unsigned char *)s->files[i]; int filetype = *(unsigned char *)s->files[i];
const char *filename = s->files[i] + 1; const char *filename = s->files[i] + 1;
if (filetype == TCC_FILETYPE_AR_WHOLE_ON ||
filetype == TCC_FILETYPE_AR_WHOLE_OFF)
{
set_whole_archive(s, filetype == TCC_FILETYPE_AR_WHOLE_ON);
continue;
}
if (1 == s->verbose)
printf("-> %s\n", filename);
if (filename[0] == '-' && filename[1] == 'l') { if (filename[0] == '-' && filename[1] == 'l') {
if (tcc_add_library(s, filename + 2) < 0) { if (tcc_add_library(s, filename + 2) < 0) {
/* don't fail on -lm as it's harmless to skip math lib */ /* don't fail on -lm as it's harmless to skip math lib */
@ -325,6 +310,8 @@ int main(int argc, char **argv)
} }
} }
} else { } else {
if (1 == s->verbose)
printf("-> %s\n", filename);
if (!s->outfile) if (!s->outfile)
s->outfile = default_outputfile(s, filename); s->outfile = default_outputfile(s, filename);
if (tcc_add_file(s, filename, filetype) < 0) if (tcc_add_file(s, filename, filetype) < 0)
@ -348,7 +335,6 @@ int main(int argc, char **argv)
} }
} }
} }
set_whole_archive(s, 0);
if (0 == ret) { if (0 == ret) {
if (s->output_type == TCC_OUTPUT_MEMORY) { if (s->output_type == TCC_OUTPUT_MEMORY) {

1
tcc.h
View File

@ -692,7 +692,6 @@ struct TCCState {
int rdynamic; /* if true, all symbols are exported */ int rdynamic; /* if true, all symbols are exported */
int symbolic; /* if true, resolve symbols in the current module first */ int symbolic; /* if true, resolve symbols in the current module first */
int alacarte_link; /* if true, only link in referenced objects from archive */ int alacarte_link; /* if true, only link in referenced objects from archive */
int whole_archive; /* if true, link in a whole *.a even when alacarte_link */
char *tcc_lib_path; /* CONFIG_TCCDIR or -B option */ char *tcc_lib_path; /* CONFIG_TCCDIR or -B option */
char *soname; /* as specified on the command line (-soname) */ char *soname; /* as specified on the command line (-soname) */

View File

@ -3076,7 +3076,6 @@ static int tcc_load_alacarte(TCCState *s1, int fd, int size)
if(sym_index) { if(sym_index) {
sym = &((ElfW(Sym) *)symtab_section->data)[sym_index]; sym = &((ElfW(Sym) *)symtab_section->data)[sym_index];
if(sym->st_shndx == SHN_UNDEF) { if(sym->st_shndx == SHN_UNDEF) {
load_obj:
off = get_be32(ar_index + i * 4) + sizeof(ArchiveHeader); off = get_be32(ar_index + i * 4) + sizeof(ArchiveHeader);
++bound; ++bound;
lseek(fd, off, SEEK_SET); lseek(fd, off, SEEK_SET);
@ -3086,8 +3085,6 @@ static int tcc_load_alacarte(TCCState *s1, int fd, int size)
goto the_end; goto the_end;
} }
} }
} else if (s1->whole_archive) {
goto load_obj;
} }
} }
} while(bound); } while(bound);