mirror of
https://github.com/mirror/tinycc.git
synced 2025-02-04 06:30:10 +08:00
changed tcc_get_symbol() prototype
This commit is contained in:
parent
c5959b77b4
commit
f8d0241764
4
libtcc.h
4
libtcc.h
@ -83,8 +83,8 @@ int tcc_run(TCCState *s, int argc, char **argv);
|
|||||||
non zero if link error. */
|
non zero if link error. */
|
||||||
int tcc_relocate(TCCState *s);
|
int tcc_relocate(TCCState *s);
|
||||||
|
|
||||||
/* return symbol value or error */
|
/* return symbol value. return 0 if OK, -1 if symbol not found */
|
||||||
void *tcc_get_symbol(TCCState *s, const char *name);
|
int tcc_get_symbol(TCCState *s, unsigned long *pval, const char *name);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@ int main(int argc, char **argv)
|
|||||||
{
|
{
|
||||||
TCCState *s;
|
TCCState *s;
|
||||||
int (*func)(int);
|
int (*func)(int);
|
||||||
|
unsigned long val;
|
||||||
|
|
||||||
s = tcc_new();
|
s = tcc_new();
|
||||||
if (!s) {
|
if (!s) {
|
||||||
@ -54,7 +55,8 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
tcc_relocate(s);
|
tcc_relocate(s);
|
||||||
|
|
||||||
func = tcc_get_symbol(s, "foo");
|
tcc_get_symbol(s, &val, "foo");
|
||||||
|
func = (void *)val;
|
||||||
|
|
||||||
func(32);
|
func(32);
|
||||||
|
|
||||||
|
7
tcc.c
7
tcc.c
@ -9115,7 +9115,7 @@ int tcc_run(TCCState *s1, int argc, char **argv)
|
|||||||
if (tcc_relocate(s1) < 0)
|
if (tcc_relocate(s1) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
prog_main = tcc_get_symbol(s1, "main");
|
prog_main = tcc_get_symbol_err(s1, "main");
|
||||||
|
|
||||||
if (do_debug) {
|
if (do_debug) {
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@ -9140,10 +9140,11 @@ int tcc_run(TCCState *s1, int argc, char **argv)
|
|||||||
void (*bound_init)(void);
|
void (*bound_init)(void);
|
||||||
|
|
||||||
/* set error function */
|
/* set error function */
|
||||||
rt_bound_error_msg = (void *)tcc_get_symbol(s1, "__bound_error_msg");
|
rt_bound_error_msg = (void *)tcc_get_symbol_err(s1,
|
||||||
|
"__bound_error_msg");
|
||||||
|
|
||||||
/* XXX: use .init section so that it also work in binary ? */
|
/* XXX: use .init section so that it also work in binary ? */
|
||||||
bound_init = (void *)tcc_get_symbol(s1, "__bound_init");
|
bound_init = (void *)tcc_get_symbol_err(s1, "__bound_init");
|
||||||
bound_init();
|
bound_init();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
17
tccelf.c
17
tccelf.c
@ -154,16 +154,25 @@ static int find_elf_sym(Section *s, const char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* return elf symbol value or error */
|
/* return elf symbol value or error */
|
||||||
void *tcc_get_symbol(TCCState *s, const char *name)
|
int tcc_get_symbol(TCCState *s, unsigned long *pval, const char *name)
|
||||||
{
|
{
|
||||||
int sym_index;
|
int sym_index;
|
||||||
Elf32_Sym *sym;
|
Elf32_Sym *sym;
|
||||||
|
|
||||||
sym_index = find_elf_sym(symtab_section, name);
|
sym_index = find_elf_sym(symtab_section, name);
|
||||||
if (!sym_index)
|
if (!sym_index)
|
||||||
error("%s not defined", name);
|
return -1;
|
||||||
sym = &((Elf32_Sym *)symtab_section->data)[sym_index];
|
sym = &((Elf32_Sym *)symtab_section->data)[sym_index];
|
||||||
return (void *)sym->st_value;
|
*pval = sym->st_value;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *tcc_get_symbol_err(TCCState *s, const char *name)
|
||||||
|
{
|
||||||
|
unsigned long val;
|
||||||
|
if (tcc_get_symbol(s, &val, name) < 0)
|
||||||
|
error("%s not defined", name);
|
||||||
|
return (void *)val;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* add an elf symbol : check if it is already defined and patch
|
/* add an elf symbol : check if it is already defined and patch
|
||||||
@ -1383,7 +1392,7 @@ int tcc_output_file(TCCState *s1, const char *filename)
|
|||||||
|
|
||||||
/* get entry point address */
|
/* get entry point address */
|
||||||
if (file_type == TCC_OUTPUT_EXE)
|
if (file_type == TCC_OUTPUT_EXE)
|
||||||
ehdr.e_entry = (unsigned long)tcc_get_symbol(s1, "_start");
|
ehdr.e_entry = (unsigned long)tcc_get_symbol_err(s1, "_start");
|
||||||
else
|
else
|
||||||
ehdr.e_entry = text_section->sh_addr; /* XXX: is it correct ? */
|
ehdr.e_entry = text_section->sh_addr; /* XXX: is it correct ? */
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user