tccrun: another incompatible change to the tcc_relocate API

We are now compatible with the 0.9,25 version though.  A special
value for the second (ptr) argument is used to get the simple
behavior as with the 0.9.24 version.
This commit is contained in:
grischka 2012-09-01 11:33:34 +02:00
parent 56e23984b9
commit ca38792df1
3 changed files with 15 additions and 6 deletions

View File

@ -91,9 +91,14 @@ LIBTCCAPI int tcc_output_file(TCCState *s, const char *filename);
tcc_relocate() before. */ tcc_relocate() before. */
LIBTCCAPI int tcc_run(TCCState *s, int argc, char **argv); LIBTCCAPI int tcc_run(TCCState *s, int argc, char **argv);
/* Do all relocations (needed before using tcc_get_symbol()) /* do all relocations (needed before using tcc_get_symbol())
Returns -1 on error. */ possible values for 'ptr':
LIBTCCAPI int tcc_relocate(TCCState *s1); - TCC_RELOCATE_AUTO : Allocate and manage memory internally
- NULL : return required memory size for the step below
- memory address : copy code to memory passed by the caller
returns -1 on error. */
LIBTCCAPI int tcc_relocate(TCCState *s1, void *ptr);
#define TCC_RELOCATE_AUTO (void*)1
/* return symbol value or NULL if not found */ /* return symbol value or NULL if not found */
LIBTCCAPI void *tcc_get_symbol(TCCState *s, const char *name); LIBTCCAPI void *tcc_get_symbol(TCCState *s, const char *name);

View File

@ -47,9 +47,13 @@ static void win64_add_function_table(TCCState *s1);
/* Do all relocations (needed before using tcc_get_symbol()) /* Do all relocations (needed before using tcc_get_symbol())
Returns -1 on error. */ Returns -1 on error. */
LIBTCCAPI int tcc_relocate(TCCState *s1) LIBTCCAPI int tcc_relocate(TCCState *s1, void *ptr)
{ {
int ret; int ret;
if (TCC_RELOCATE_AUTO != ptr)
return tcc_relocate_ex(s1, ptr);
#ifdef HAVE_SELINUX #ifdef HAVE_SELINUX
/* Use mmap instead of malloc for Selinux /* Use mmap instead of malloc for Selinux
Ref http://www.gnu.org/s/libc/manual/html_node/File-Size.html */ Ref http://www.gnu.org/s/libc/manual/html_node/File-Size.html */
@ -87,7 +91,7 @@ LIBTCCAPI int tcc_run(TCCState *s1, int argc, char **argv)
int (*prog_main)(int, char **); int (*prog_main)(int, char **);
int ret; int ret;
if (tcc_relocate(s1) < 0) if (tcc_relocate(s1, TCC_RELOCATE_AUTO) < 0)
return -1; return -1;
prog_main = tcc_get_symbol_err(s1, "main"); prog_main = tcc_get_symbol_err(s1, "main");

View File

@ -58,7 +58,7 @@ int main(int argc, char **argv)
tcc_add_symbol(s, "add", add); tcc_add_symbol(s, "add", add);
/* relocate the code */ /* relocate the code */
if (tcc_relocate(s) < 0) if (tcc_relocate(s, TCC_RELOCATE_AUTO) < 0)
return 1; return 1;
/* get entry symbol */ /* get entry symbol */