win32 defines + new internal file layer

This commit is contained in:
bellard 2002-01-12 16:39:35 +00:00
parent bbd541d760
commit 9c06595a1e
2 changed files with 193 additions and 88 deletions

View File

@ -80,10 +80,12 @@ static void libc_free(void *ptr);
static void install_malloc_hooks(void); static void install_malloc_hooks(void);
static void restore_malloc_hooks(void); static void restore_malloc_hooks(void);
#ifndef WIN32
static void *saved_malloc_hook; static void *saved_malloc_hook;
static void *saved_free_hook; static void *saved_free_hook;
static void *saved_realloc_hook; static void *saved_realloc_hook;
static void *saved_memalign_hook; static void *saved_memalign_hook;
#endif
extern char _end; extern char _end;
@ -123,8 +125,7 @@ static BoundEntry *__bound_find_region(BoundEntry *e1, void *p)
return __bound_empty_t2; return __bound_empty_t2;
} }
/* print a bound error and recurse thru 'nb_callers' to get the error /* print a bound error message */
position */
static void bound_error(const void *caller, const char *fmt, ...) static void bound_error(const void *caller, const char *fmt, ...)
{ {
rt_error((unsigned long)caller, "%s", fmt); rt_error((unsigned long)caller, "%s", fmt);
@ -132,7 +133,7 @@ static void bound_error(const void *caller, const char *fmt, ...)
static void bound_alloc_error(void) static void bound_alloc_error(void)
{ {
bound_error(NULL, "not enough memory for bound checking code\n"); bound_error(NULL, "not enough memory for bound checking code");
} }
/* currently, tcc cannot compile that because we use GNUC extensions */ /* currently, tcc cannot compile that because we use GNUC extensions */
@ -406,7 +407,7 @@ void __bound_init(void)
size = BOUND_T23_SIZE; size = BOUND_T23_SIZE;
mark_invalid(start, size); mark_invalid(start, size);
#if !defined(__TINYC__) #if !defined(__TINYC__) && !defined(WIN32)
/* malloc zone is also marked invalid */ /* malloc zone is also marked invalid */
start = (unsigned long)&_end; start = (unsigned long)&_end;
size = 128 * 0x100000; size = 128 * 0x100000;
@ -641,6 +642,7 @@ static unsigned long get_region_size(void *p)
static void install_malloc_hooks(void) static void install_malloc_hooks(void)
{ {
#ifndef WIN32
saved_malloc_hook = __malloc_hook; saved_malloc_hook = __malloc_hook;
saved_free_hook = __free_hook; saved_free_hook = __free_hook;
saved_realloc_hook = __realloc_hook; saved_realloc_hook = __realloc_hook;
@ -649,14 +651,17 @@ static void install_malloc_hooks(void)
__free_hook = __bound_free; __free_hook = __bound_free;
__realloc_hook = __bound_realloc; __realloc_hook = __bound_realloc;
__memalign_hook = __bound_memalign; __memalign_hook = __bound_memalign;
#endif
} }
static void restore_malloc_hooks(void) static void restore_malloc_hooks(void)
{ {
#ifndef WIN32
__malloc_hook = saved_malloc_hook; __malloc_hook = saved_malloc_hook;
__free_hook = saved_free_hook; __free_hook = saved_free_hook;
__realloc_hook = saved_realloc_hook; __realloc_hook = saved_realloc_hook;
__memalign_hook = saved_memalign_hook; __memalign_hook = saved_memalign_hook;
#endif
} }
static void *libc_malloc(size_t size) static void *libc_malloc(size_t size)
@ -693,6 +698,7 @@ void *__bound_malloc(size_t size, const void *caller)
return ptr; return ptr;
} }
#ifndef WIN32
void *__bound_memalign(size_t size, size_t align, const void *caller) void *__bound_memalign(size_t size, size_t align, const void *caller)
{ {
void *ptr; void *ptr;
@ -711,6 +717,7 @@ void *__bound_memalign(size_t size, size_t align, const void *caller)
__bound_new_region(ptr, size); __bound_new_region(ptr, size);
return ptr; return ptr;
} }
#endif
void __bound_free(void *ptr, const void *caller) void __bound_free(void *ptr, const void *caller)
{ {
@ -773,7 +780,7 @@ static void bound_dump(void)
/* some useful checked functions */ /* some useful checked functions */
/* check that (p ... p + size - 1) lies inside 'p' region, if any */ /* check that (p ... p + size - 1) lies inside 'p' region, if any */
static void __bound_check(const void *p, ssize_t size) static void __bound_check(const void *p, size_t size)
{ {
if (size == 0) if (size == 0)
return; return;
@ -805,7 +812,7 @@ void *__bound_memset(void *dst, int c, size_t size)
return memset(dst, c, size); return memset(dst, c, size);
} }
/* resolve check check syms */ /* resolve bound check syms */
typedef struct BCSyms { typedef struct BCSyms {
char *str; char *str;
void *ptr; void *ptr;

234
tcc.c
View File

@ -25,11 +25,15 @@
#include <math.h> #include <math.h>
#include <unistd.h> #include <unistd.h>
#include <signal.h> #include <signal.h>
#include <malloc.h>
#include <unistd.h>
#include <fcntl.h>
#ifndef WIN32
#include <sys/ucontext.h> #include <sys/ucontext.h>
#include <sys/mman.h> #include <sys/mman.h>
#include <elf.h> #endif
#include <stab.h> #include "elf.h"
#include <malloc.h> #include "stab.h"
#ifndef CONFIG_TCC_STATIC #ifndef CONFIG_TCC_STATIC
#include <dlfcn.h> #include <dlfcn.h>
#endif #endif
@ -145,15 +149,22 @@ typedef struct AttributeDef {
#define TYPE_ABSTRACT 1 /* type without variable */ #define TYPE_ABSTRACT 1 /* type without variable */
#define TYPE_DIRECT 2 /* type with variable */ #define TYPE_DIRECT 2 /* type with variable */
typedef struct { #define IO_BUF_SIZE 8192
FILE *file;
char *filename; typedef struct BufferedFile {
int line_num; unsigned char *buf_ptr;
} IncludeFile; unsigned char *buf_end;
int fd;
int line_num; /* current line number - here to simply code */
char filename[1024]; /* current filename - here to simply code */
unsigned char buffer[IO_BUF_SIZE + 1]; /* extra size for CH_EOB char */
} BufferedFile;
#define CH_EOB 0 /* end of buffer or '\0' char in file */
#define CH_EOF (-1) /* end of file */
/* parser */ /* parser */
FILE *file; struct BufferedFile *file;
int line_num;
int ch, ch1, tok, tok1; int ch, ch1, tok, tok1;
CValue tokc, tok1c; CValue tokc, tok1c;
@ -185,14 +196,14 @@ int tok_ident;
TokenSym **table_ident; TokenSym **table_ident;
TokenSym *hash_ident[TOK_HASH_SIZE]; TokenSym *hash_ident[TOK_HASH_SIZE];
char token_buf[STRING_MAX_SIZE + 1]; char token_buf[STRING_MAX_SIZE + 1];
char *filename, *funcname; char *funcname;
/* contains global symbols which remain between each translation unit */ /* contains global symbols which remain between each translation unit */
SymStack extern_stack; SymStack extern_stack;
SymStack define_stack, global_stack, local_stack, label_stack; SymStack define_stack, global_stack, local_stack, label_stack;
SValue vstack[VSTACK_SIZE], *vtop; SValue vstack[VSTACK_SIZE], *vtop;
int *macro_ptr, *macro_ptr_allocated; int *macro_ptr, *macro_ptr_allocated;
IncludeFile include_stack[INCLUDE_STACK_SIZE], *include_stack_ptr; BufferedFile *include_stack[INCLUDE_STACK_SIZE], **include_stack_ptr;
int ifdef_stack[IFDEF_STACK_SIZE], *ifdef_stack_ptr; int ifdef_stack[IFDEF_STACK_SIZE], *ifdef_stack_ptr;
char *include_paths[INCLUDE_PATHS_MAX]; char *include_paths[INCLUDE_PATHS_MAX];
int nb_include_paths; int nb_include_paths;
@ -316,6 +327,8 @@ int tcc_ext = 1;
#define TOK_A_SHL 0x81 #define TOK_A_SHL 0x81
#define TOK_A_SAR 0x82 #define TOK_A_SAR 0x82
#define TOK_EOF (-1) /* end of file */
/* all identificators and strings have token above that */ /* all identificators and strings have token above that */
#define TOK_IDENT 256 #define TOK_IDENT 256
@ -344,8 +357,10 @@ enum {
TOK_LONG, TOK_LONG,
TOK_REGISTER, TOK_REGISTER,
TOK_SIGNED, TOK_SIGNED,
TOK___SIGNED__, /* gcc keyword */
TOK_AUTO, TOK_AUTO,
TOK_INLINE, TOK_INLINE,
TOK___INLINE__, /* gcc keyword */
TOK_RESTRICT, TOK_RESTRICT,
/* unsupported type */ /* unsupported type */
@ -392,9 +407,22 @@ enum {
TOK___UNUSED__, TOK___UNUSED__,
}; };
#ifdef WIN32
#define snprintf _snprintf
/* currently incorrect */
long double strtold(const char *nptr, char **endptr)
{
return (long double)strtod(nptr, endptr);
}
float strtof(const char *nptr, char **endptr)
{
return (float)strtod(nptr, endptr);
}
#else
/* XXX: need to define this to use them in non ISOC99 context */ /* XXX: need to define this to use them in non ISOC99 context */
extern float strtof (const char *__nptr, char **__endptr); extern float strtof (const char *__nptr, char **__endptr);
extern long double strtold (const char *__nptr, char **__endptr); extern long double strtold (const char *__nptr, char **__endptr);
#endif
void sum(int l); void sum(int l);
void next(void); void next(void);
@ -495,7 +523,7 @@ static TCCSyms tcc_syms[] = {
{ NULL, NULL }, { NULL, NULL },
}; };
void *dlsym(void *handle, char *symbol) void *dlsym(void *handle, const char *symbol)
{ {
TCCSyms *p; TCCSyms *p;
p = tcc_syms; p = tcc_syms;
@ -582,12 +610,13 @@ unsigned long long __ldtoull(long double a)
/********************************************************/ /********************************************************/
/* copy a string and truncate it */ /* copy a string and truncate it. */
char *pstrcpy(char *buf, int buf_size, const char *s) char *pstrcpy(char *buf, int buf_size, const char *s)
{ {
char *q, *q_end; char *q, *q_end;
int c; int c;
if (buf_size > 0) {
q = buf; q = buf;
q_end = buf + buf_size - 1; q_end = buf + buf_size - 1;
while (q < q_end) { while (q < q_end) {
@ -597,10 +626,11 @@ char *pstrcpy(char *buf, int buf_size, const char *s)
*q++ = c; *q++ = c;
} }
*q = '\0'; *q = '\0';
}
return buf; return buf;
} }
/* strcat and truncate */ /* strcat and truncate. */
char *pstrcat(char *buf, int buf_size, const char *s) char *pstrcat(char *buf, int buf_size, const char *s)
{ {
int len; int len;
@ -624,12 +654,19 @@ Section *new_section(const char *name, int sh_type, int sh_flags)
sec->sh_num = ++section_num; sec->sh_num = ++section_num;
sec->sh_type = sh_type; sec->sh_type = sh_type;
sec->sh_flags = sh_flags; sec->sh_flags = sh_flags;
#ifdef WIN32
/* XXX: currently, a single malloc */
data = malloc(SECTION_VSIZE);
if (data == NULL)
error("could not alloc section '%s'", name);
#else
data = mmap(NULL, SECTION_VSIZE, data = mmap(NULL, SECTION_VSIZE,
PROT_EXEC | PROT_READ | PROT_WRITE, PROT_EXEC | PROT_READ | PROT_WRITE,
MAP_PRIVATE | MAP_ANONYMOUS, MAP_PRIVATE | MAP_ANONYMOUS,
-1, 0); -1, 0);
if (data == (void *)(-1)) if (data == (void *)(-1))
error("could not mmap section '%s'", name); error("could not mmap section '%s'", name);
#endif
sec->data = data; sec->data = data;
sec->data_ptr = data; sec->data_ptr = data;
psec = &first_section; psec = &first_section;
@ -706,11 +743,11 @@ static inline int toup(int c)
void printline(void) void printline(void)
{ {
IncludeFile *f; BufferedFile **f;
for(f = include_stack; f < include_stack_ptr; f++) for(f = include_stack; f < include_stack_ptr; f++)
fprintf(stderr, "In file included from %s:%d:\n", fprintf(stderr, "In file included from %s:%d:\n",
f->filename, f->line_num); (*f)->filename, (*f)->line_num);
fprintf(stderr, "%s:%d: ", filename, line_num); fprintf(stderr, "%s:%d: ", file->filename, file->line_num);
} }
void error(const char *fmt, ...) void error(const char *fmt, ...)
@ -976,39 +1013,94 @@ void sym_undef(SymStack *st, Sym *s)
s->v = 0; s->v = 0;
} }
/* no need to put that inline */ /* I/O layer */
int handle_eof(void)
BufferedFile *tcc_open(const char *filename)
{ {
int fd;
BufferedFile *bf;
fd = open(filename, O_RDONLY);
if (fd < 0)
return NULL;
bf = malloc(sizeof(BufferedFile));
if (!bf) {
close(fd);
return NULL;
}
bf->fd = fd;
bf->buf_ptr = bf->buffer;
bf->buf_end = bf->buffer;
bf->buffer[0] = CH_EOB; /* put eob symbol */
pstrcpy(bf->filename, sizeof(bf->filename), filename);
bf->line_num = 1;
return bf;
}
void tcc_close(BufferedFile *bf)
{
close(bf->fd);
free(bf);
}
/* read one char. MUST call tcc_fillbuf if CH_EOB is read */
#define TCC_GETC(bf) (*(bf)->buf_ptr++)
/* fill input buffer and return next char */
int tcc_getc_slow(BufferedFile *bf)
{
int len;
/* only tries to read if really end of buffer */
if (bf->buf_ptr >= bf->buf_end) {
if (bf->fd != -1) {
len = read(bf->fd, bf->buffer, IO_BUF_SIZE);
if (len < 0)
len = 0;
} else {
len = 0;
}
bf->buf_ptr = bf->buffer;
bf->buf_end = bf->buffer + len;
*bf->buf_end = CH_EOB;
}
if (bf->buf_ptr < bf->buf_end) {
return *bf->buf_ptr++;
} else {
bf->buf_ptr = bf->buf_end;
return CH_EOF;
}
}
/* no need to put that inline */
void handle_eob(void)
{
for(;;) {
ch1 = tcc_getc_slow(file);
if (ch1 != CH_EOF)
return;
if (include_stack_ptr == include_stack) if (include_stack_ptr == include_stack)
return -1; return;
/* add end of include file debug info */ /* add end of include file debug info */
if (do_debug) { if (do_debug) {
put_stabd(N_EINCL, 0, 0); put_stabd(N_EINCL, 0, 0);
} }
/* pop include stack */ /* pop include stack */
fclose(file); tcc_close(file);
free(filename);
include_stack_ptr--; include_stack_ptr--;
file = include_stack_ptr->file; file = *include_stack_ptr;
filename = include_stack_ptr->filename; }
line_num = include_stack_ptr->line_num;
return 0;
} }
/* read next char from current input file */ /* read next char from current input file */
static inline void inp(void) static inline void inp(void)
{ {
redo: ch1 = TCC_GETC(file);
/* faster than fgetc */ /* end of buffer/file handling */
ch1 = getc_unlocked(file); if (ch1 == CH_EOB)
if (ch1 == -1) { handle_eob();
if (handle_eof() < 0)
return;
else
goto redo;
}
if (ch1 == '\n') if (ch1 == '\n')
line_num++; file->line_num++;
// printf("ch1=%c 0x%x\n", ch1, ch1); // printf("ch1=%c 0x%x\n", ch1, ch1);
} }
@ -1219,7 +1311,7 @@ void preprocess(void)
int size, i, c, v, t, *str, len; int size, i, c, v, t, *str, len;
char buf[1024], *q, *p; char buf[1024], *q, *p;
char buf1[1024]; char buf1[1024];
FILE *f; BufferedFile *f;
Sym **ps, *first, *s; Sym **ps, *first, *s;
cinp(); cinp();
@ -1304,15 +1396,15 @@ void preprocess(void)
if (c == '\"') { if (c == '\"') {
/* first search in current dir if "header.h" */ /* first search in current dir if "header.h" */
size = 0; size = 0;
p = strrchr(filename, '/'); p = strrchr(file->filename, '/');
if (p) if (p)
size = p + 1 - filename; size = p + 1 - file->filename;
if (size > sizeof(buf1) - 1) if (size > sizeof(buf1) - 1)
size = sizeof(buf1) - 1; size = sizeof(buf1) - 1;
memcpy(buf1, filename, size); memcpy(buf1, file->filename, size);
buf1[size] = '\0'; buf1[size] = '\0';
pstrcat(buf1, sizeof(buf1), buf); pstrcat(buf1, sizeof(buf1), buf);
f = fopen(buf1, "r"); f = tcc_open(buf1);
if (f) if (f)
goto found; goto found;
} }
@ -1321,7 +1413,7 @@ void preprocess(void)
strcpy(buf1, include_paths[i]); strcpy(buf1, include_paths[i]);
strcat(buf1, "/"); strcat(buf1, "/");
strcat(buf1, buf); strcat(buf1, buf);
f = fopen(buf1, "r"); f = tcc_open(buf1);
if (f) if (f)
goto found; goto found;
} }
@ -1330,16 +1422,11 @@ void preprocess(void)
found: found:
/* push current file in stack */ /* push current file in stack */
/* XXX: fix current line init */ /* XXX: fix current line init */
include_stack_ptr->file = file; *include_stack_ptr++ = file;
include_stack_ptr->filename = filename;
include_stack_ptr->line_num = line_num;
include_stack_ptr++;
file = f; file = f;
filename = strdup(buf1);
line_num = 1;
/* add include file debug info */ /* add include file debug info */
if (do_debug) { if (do_debug) {
put_stabs(filename, N_BINCL, 0, 0, 0); put_stabs(file->filename, N_BINCL, 0, 0, 0);
} }
} else if (tok == TOK_IFNDEF) { } else if (tok == TOK_IFNDEF) {
c = 1; c = 1;
@ -1382,14 +1469,14 @@ void preprocess(void)
next(); next();
if (tok != TOK_CINT) if (tok != TOK_CINT)
error("#line"); error("#line");
line_num = tokc.i; file->line_num = tokc.i;
skip_spaces(); skip_spaces();
if (ch != '\n') { if (ch != '\n') {
next(); next();
if (tok != TOK_STR) if (tok != TOK_STR)
error("#line"); error("#line");
/* XXX: potential memory leak */ pstrcpy(file->filename, sizeof(file->filename),
filename = strdup(get_tok_str(tok, &tokc)); get_tok_str(tok, &tokc));
} }
} else if (tok == TOK_ERROR) { } else if (tok == TOK_ERROR) {
error("#error"); error("#error");
@ -2025,10 +2112,10 @@ void macro_subst(int **tok_str, int *tok_len,
break; break;
/* special macros */ /* special macros */
if (tok == TOK___LINE__) { if (tok == TOK___LINE__) {
cval.i = line_num; cval.i = file->line_num;
tok_add2(tok_str, tok_len, TOK_CINT, &cval); tok_add2(tok_str, tok_len, TOK_CINT, &cval);
} else if (tok == TOK___FILE__) { } else if (tok == TOK___FILE__) {
cval.ts = tok_alloc(filename, 0); cval.ts = tok_alloc(file->filename, 0);
tok_add2(tok_str, tok_len, TOK_STR, &cval); tok_add2(tok_str, tok_len, TOK_STR, &cval);
} else if (tok == TOK___DATE__) { } else if (tok == TOK___DATE__) {
cval.ts = tok_alloc("Jan 1 1970", 0); cval.ts = tok_alloc("Jan 1 1970", 0);
@ -3912,8 +3999,10 @@ int parse_btype(int *type_ptr, AttributeDef *ad)
case TOK_VOLATILE: case TOK_VOLATILE:
case TOK_REGISTER: case TOK_REGISTER:
case TOK_SIGNED: case TOK_SIGNED:
case TOK___SIGNED__:
case TOK_AUTO: case TOK_AUTO:
case TOK_INLINE: case TOK_INLINE:
case TOK___INLINE__:
case TOK_RESTRICT: case TOK_RESTRICT:
next(); next();
break; break;
@ -4665,10 +4754,10 @@ void block(int *bsym, int *csym, int *case_sym, int *def_sym, int case_reg)
/* generate line number info */ /* generate line number info */
if (do_debug && if (do_debug &&
(last_line_num != line_num || last_ind != ind)) { (last_line_num != file->line_num || last_ind != ind)) {
put_stabn(N_SLINE, 0, line_num, ind - func_ind); put_stabn(N_SLINE, 0, file->line_num, ind - func_ind);
last_ind = ind; last_ind = ind;
last_line_num = line_num; last_line_num = file->line_num;
} }
if (tok == TOK_IF) { if (tok == TOK_IF) {
@ -5339,7 +5428,7 @@ void put_func_debug(int t)
/* XXX: we put here a dummy type */ /* XXX: we put here a dummy type */
snprintf(buf, sizeof(buf), "%s:%c1", snprintf(buf, sizeof(buf), "%s:%c1",
funcname, t & VT_STATIC ? 'f' : 'F'); funcname, t & VT_STATIC ? 'f' : 'F');
put_stabs(buf, N_FUN, 0, line_num, ind); put_stabs(buf, N_FUN, 0, file->line_num, ind);
func_ind = ind; func_ind = ind;
last_ind = 0; last_ind = 0;
last_line_num = 0; last_line_num = 0;
@ -5533,13 +5622,11 @@ int tcc_compile_file(const char *filename1)
Sym *define_start; Sym *define_start;
char buf[512]; char buf[512];
line_num = 1;
funcname = ""; funcname = "";
filename = (char *)filename1;
file = fopen(filename, "r"); file = tcc_open(filename1);
if (!file) if (!file)
error("file '%s' not found", filename); error("file '%s' not found", filename1);
include_stack_ptr = include_stack; include_stack_ptr = include_stack;
ifdef_stack_ptr = ifdef_stack; ifdef_stack_ptr = ifdef_stack;
@ -5551,7 +5638,8 @@ int tcc_compile_file(const char *filename1)
getcwd(buf, sizeof(buf)); getcwd(buf, sizeof(buf));
pstrcat(buf, sizeof(buf), "/"); pstrcat(buf, sizeof(buf), "/");
put_stabs(buf, N_SO, 0, 0, (unsigned long)text_section->data_ptr); put_stabs(buf, N_SO, 0, 0, (unsigned long)text_section->data_ptr);
put_stabs(filename, N_SO, 0, 0, (unsigned long)text_section->data_ptr); put_stabs(file->filename, N_SO, 0, 0,
(unsigned long)text_section->data_ptr);
} }
/* define common 'char *' type because it is often used internally /* define common 'char *' type because it is often used internally
for arrays and struct dereference */ for arrays and struct dereference */
@ -5564,7 +5652,7 @@ int tcc_compile_file(const char *filename1)
decl(VT_CONST); decl(VT_CONST);
if (tok != -1) if (tok != -1)
expect("declaration"); expect("declaration");
fclose(file); tcc_close(file);
/* end of translation unit info */ /* end of translation unit info */
if (do_debug) { if (do_debug) {
@ -5993,6 +6081,7 @@ void rt_error(unsigned long pc, const char *fmt, ...)
va_end(ap); va_end(ap);
} }
#ifndef WIN32
/* signal handler for fatal errors */ /* signal handler for fatal errors */
static void sig_error(int signum, siginfo_t *siginf, void *puc) static void sig_error(int signum, siginfo_t *siginf, void *puc)
{ {
@ -6033,19 +6122,23 @@ static void sig_error(int signum, siginfo_t *siginf, void *puc)
} }
exit(255); exit(255);
} }
#endif
/* launch the compiled program with the given arguments */ /* launch the compiled program with the given arguments */
int launch_exe(int argc, char **argv) int launch_exe(int argc, char **argv)
{ {
Sym *s; Sym *s;
int (*t)(); int (*t)();
struct sigaction sigact;
s = sym_find1(&extern_stack, TOK_MAIN); s = sym_find1(&extern_stack, TOK_MAIN);
if (!s || (s->r & VT_FORWARD)) if (!s || (s->r & VT_FORWARD))
error("main() not defined"); error("main() not defined");
if (do_debug) { if (do_debug) {
#ifdef WIN32
error("debug mode currently not available for Windows");
#else
struct sigaction sigact;
/* install TCC signal handlers to print debug info on fatal /* install TCC signal handlers to print debug info on fatal
runtime errors */ runtime errors */
sigact.sa_flags = SA_SIGINFO | SA_ONESHOT; sigact.sa_flags = SA_SIGINFO | SA_ONESHOT;
@ -6056,9 +6149,13 @@ int launch_exe(int argc, char **argv)
sigaction(SIGSEGV, &sigact, NULL); sigaction(SIGSEGV, &sigact, NULL);
sigaction(SIGBUS, &sigact, NULL); sigaction(SIGBUS, &sigact, NULL);
sigaction(SIGABRT, &sigact, NULL); sigaction(SIGABRT, &sigact, NULL);
#endif
} }
if (do_bounds_check) { if (do_bounds_check) {
#ifdef WIN32
error("bound checking currently not available for Windows");
#else
int *p, *p_end; int *p, *p_end;
__bound_init(); __bound_init();
/* add all known static regions */ /* add all known static regions */
@ -6068,6 +6165,7 @@ int launch_exe(int argc, char **argv)
__bound_new_region((void *)p[0], p[1]); __bound_new_region((void *)p[0], p[1]);
p += 2; p += 2;
} }
#endif
} }
t = (int (*)())s->c; t = (int (*)())s->c;
@ -6077,7 +6175,7 @@ int launch_exe(int argc, char **argv)
void help(void) void help(void)
{ {
printf("tcc version 0.9.3 - Tiny C Compiler - Copyright (C) 2001, 2002 Fabrice Bellard\n" printf("tcc version 0.9.4 - Tiny C Compiler - Copyright (C) 2001, 2002 Fabrice Bellard\n"
"usage: tcc [-Idir] [-Dsym[=val]] [-Usym] [-llib] [-g] [-b]\n" "usage: tcc [-Idir] [-Dsym[=val]] [-Usym] [-llib] [-g] [-b]\n"
" [-i infile] infile [infile_args...]\n" " [-i infile] infile [infile_args...]\n"
"\n" "\n"
@ -6103,7 +6201,7 @@ int main(int argc, char **argv)
/* add all tokens */ /* add all tokens */
tok_ident = TOK_IDENT; tok_ident = TOK_IDENT;
p = "int\0void\0char\0if\0else\0while\0break\0return\0for\0extern\0static\0unsigned\0goto\0do\0continue\0switch\0case\0const\0volatile\0long\0register\0signed\0auto\0inline\0restrict\0float\0double\0_Bool\0short\0struct\0union\0typedef\0default\0enum\0sizeof\0__attribute__\0define\0include\0ifdef\0ifndef\0elif\0endif\0defined\0undef\0error\0line\0__LINE__\0__FILE__\0__DATE__\0__TIME__\0__VA_ARGS__\0__func__\0main\0section\0__section__\0aligned\0__aligned__\0unused\0__unused__\0"; p = "int\0void\0char\0if\0else\0while\0break\0return\0for\0extern\0static\0unsigned\0goto\0do\0continue\0switch\0case\0const\0volatile\0long\0register\0signed\0__signed__\0auto\0inline\0__inline__\0restrict\0float\0double\0_Bool\0short\0struct\0union\0typedef\0default\0enum\0sizeof\0__attribute__\0define\0include\0ifdef\0ifndef\0elif\0endif\0defined\0undef\0error\0line\0__LINE__\0__FILE__\0__DATE__\0__TIME__\0__VA_ARGS__\0__func__\0main\0section\0__section__\0aligned\0__aligned__\0unused\0__unused__\0";
while (*p) { while (*p) {
r = p; r = p;
while (*r++); while (*r++);