suppressed section_ptr - fixed constant string allocation

This commit is contained in:
bellard 2002-08-18 14:34:57 +00:00
parent 524be938fd
commit f946dffd33
2 changed files with 45 additions and 54 deletions

64
tcc.c
View File

@ -562,9 +562,10 @@ int expr_const(void);
void expr_eq(void); void expr_eq(void);
void gexpr(void); void gexpr(void);
void decl(int l); void decl(int l);
void decl_initializer(int t, Section *sec, unsigned long c, int first, int size_only); static void decl_initializer(int t, Section *sec, unsigned long c,
void decl_initializer_alloc(int t, AttributeDef *ad, int r, int has_init, int first, int size_only);
int v, int scope); static void decl_initializer_alloc(int t, AttributeDef *ad, int r,
int has_init, int v, int scope);
int gv(int rc); int gv(int rc);
void gv2(int rc1, int rc2); void gv2(int rc1, int rc2);
void move_reg(int r, int s); void move_reg(int r, int s);
@ -607,7 +608,6 @@ static Sym *get_sym_ref(int t, Section *sec,
/* section generation */ /* section generation */
static void section_realloc(Section *sec, unsigned long new_size); static void section_realloc(Section *sec, unsigned long new_size);
static void *section_ptr(Section *sec, unsigned long size);
static void *section_ptr_add(Section *sec, unsigned long size); static void *section_ptr_add(Section *sec, unsigned long size);
static void put_extern_sym(Sym *sym, Section *section, static void put_extern_sym(Sym *sym, Section *section,
unsigned long value, unsigned long size); unsigned long value, unsigned long size);
@ -873,17 +873,7 @@ static void section_realloc(Section *sec, unsigned long new_size)
} }
/* reserve at least 'size' bytes in section 'sec' from /* reserve at least 'size' bytes in section 'sec' from
sec->data_offset. Optimized for speed */ sec->data_offset. */
static inline void *section_ptr(Section *sec, unsigned long size)
{
unsigned long offset, offset1;
offset = sec->data_offset;
offset1 = offset + size;
if (offset1 > sec->data_allocated)
section_realloc(sec, offset1);
return sec->data + offset;
}
static void *section_ptr_add(Section *sec, unsigned long size) static void *section_ptr_add(Section *sec, unsigned long size)
{ {
unsigned long offset, offset1; unsigned long offset, offset1;
@ -5010,7 +5000,7 @@ void gfunc_param_typed(GFuncContext *gf, Sym *func, Sym *arg)
void unary(void) void unary(void)
{ {
int n, t, ft, fc, align, size, r, data_offset; int n, t, ft, align, size, r;
Sym *s; Sym *s;
GFuncContext gf; GFuncContext gf;
AttributeDef ad; AttributeDef ad;
@ -5057,19 +5047,9 @@ void unary(void)
/* string parsing */ /* string parsing */
t = VT_BYTE; t = VT_BYTE;
str_init: str_init:
type_size(t, &align);
data_offset = data_section->data_offset;
data_offset = (data_offset + align - 1) & -align;
fc = data_offset;
/* we must declare it as an array first to use initializer parser */
t = VT_ARRAY | mk_pointer(t); t = VT_ARRAY | mk_pointer(t);
/* XXX: fix it */ memset(&ad, 0, sizeof(AttributeDef));
section_ptr(data_section, 1024); decl_initializer_alloc(t, &ad, VT_CONST, 2, 0, 0);
decl_initializer(t, data_section, data_offset, 1, 0);
size = type_size(t, &align);
data_offset += size;
vpush_ref(t, data_section, fc, size);
data_section->data_offset = data_offset;
} else { } else {
t = tok; t = tok;
next(); next();
@ -5794,7 +5774,7 @@ void block(int *bsym, int *csym, int *case_sym, int *def_sym, int case_reg)
address. cur_index/cur_field is the pointer to the current address. cur_index/cur_field is the pointer to the current
value. 'size_only' is true if only size info is needed (only used value. 'size_only' is true if only size info is needed (only used
in arrays) */ in arrays) */
void decl_designator(int t, Section *sec, unsigned long c, static void decl_designator(int t, Section *sec, unsigned long c,
int *cur_index, Sym **cur_field, int *cur_index, Sym **cur_field,
int size_only) int size_only)
{ {
@ -5871,7 +5851,7 @@ void decl_designator(int t, Section *sec, unsigned long c,
#define EXPR_ANY 2 #define EXPR_ANY 2
/* store a value or an expression directly in global data or in local array */ /* store a value or an expression directly in global data or in local array */
void init_putv(int t, Section *sec, unsigned long c, static void init_putv(int t, Section *sec, unsigned long c,
int v, int expr_type) int v, int expr_type)
{ {
int saved_global_expr, bt; int saved_global_expr, bt;
@ -5941,7 +5921,7 @@ void init_putv(int t, Section *sec, unsigned long c,
} }
/* put zeros for variable based init */ /* put zeros for variable based init */
void init_putz(int t, Section *sec, unsigned long c, int size) static void init_putz(int t, Section *sec, unsigned long c, int size)
{ {
GFuncContext gf; GFuncContext gf;
@ -5965,7 +5945,8 @@ void init_putz(int t, Section *sec, unsigned long c, int size)
allocation. 'first' is true if array '{' must be read (multi allocation. 'first' is true if array '{' must be read (multi
dimension implicit array init handling). 'size_only' is true if dimension implicit array init handling). 'size_only' is true if
size only evaluation is wanted (only for arrays). */ size only evaluation is wanted (only for arrays). */
void decl_initializer(int t, Section *sec, unsigned long c, int first, int size_only) static void decl_initializer(int t, Section *sec, unsigned long c,
int first, int size_only)
{ {
int index, array_length, n, no_oblock, nb, parlevel, i; int index, array_length, n, no_oblock, nb, parlevel, i;
int t1, size1, align1, expr_type; int t1, size1, align1, expr_type;
@ -6118,14 +6099,15 @@ void decl_initializer(int t, Section *sec, unsigned long c, int first, int size_
} }
} }
/* parse an initializer for type 't' if 'has_init' is true, and /* parse an initializer for type 't' if 'has_init' is non zero, and
allocate space in local or global data space ('r' is either allocate space in local or global data space ('r' is either
VT_LOCAL or VT_CONST). If 'v' is non zero, then an associated VT_LOCAL or VT_CONST). If 'v' is non zero, then an associated
variable 'v' of scope 'scope' is declared before initializers are variable 'v' of scope 'scope' is declared before initializers are
parsed. If 'v' is zero, then a reference to the new object is put parsed. If 'v' is zero, then a reference to the new object is put
in the value stack. */ in the value stack. If 'has_init' is 2, a special parsing is done
void decl_initializer_alloc(int t, AttributeDef *ad, int r, int has_init, to handle string constants. */
int v, int scope) static void decl_initializer_alloc(int t, AttributeDef *ad, int r,
int has_init, int v, int scope)
{ {
int size, align, addr, data_offset; int size, align, addr, data_offset;
int level; int level;
@ -6145,6 +6127,13 @@ void decl_initializer_alloc(int t, AttributeDef *ad, int r, int has_init,
if (!has_init) if (!has_init)
error("unknown type size"); error("unknown type size");
/* get all init string */ /* get all init string */
if (has_init == 2) {
/* only get strings */
while (tok == TOK_STR || tok == TOK_LSTR) {
tok_str_add_tok(&init_str);
next();
}
} else {
level = 0; level = 0;
while (level > 0 || (tok != ',' && tok != ';')) { while (level > 0 || (tok != ',' && tok != ';')) {
if (tok < 0) if (tok < 0)
@ -6159,6 +6148,7 @@ void decl_initializer_alloc(int t, AttributeDef *ad, int r, int has_init,
} }
next(); next();
} }
}
tok_str_add(&init_str, -1); tok_str_add(&init_str, -1);
tok_str_add(&init_str, 0); tok_str_add(&init_str, 0);
@ -7138,7 +7128,7 @@ int tcc_set_output_type(TCCState *s, int output_type)
void help(void) void help(void)
{ {
printf("tcc version 0.9.10pre1 - Tiny C Compiler - Copyright (C) 2001, 2002 Fabrice Bellard\n" printf("tcc version 0.9.10 - Tiny C Compiler - Copyright (C) 2001, 2002 Fabrice Bellard\n"
"usage: tcc [-c] [-o outfile] [-Bdir] [-bench] [-Idir] [-Dsym[=val]] [-Usym]\n" "usage: tcc [-c] [-o outfile] [-Bdir] [-bench] [-Idir] [-Dsym[=val]] [-Usym]\n"
" [-g] [-b] [-Ldir] [-llib] [-shared] [-static]\n" " [-g] [-b] [-Ldir] [-llib] [-shared] [-static]\n"
" [--] infile1 [infile2... --] [infile_args...]\n" " [--] infile1 [infile2... --] [infile_args...]\n"

View File

@ -1511,11 +1511,12 @@ static int tcc_load_object_file(TCCState *s1,
if (sh->sh_type != SHT_NOBITS) { if (sh->sh_type != SHT_NOBITS) {
unsigned char *ptr; unsigned char *ptr;
lseek(fd, file_offset + sh->sh_offset, SEEK_SET); lseek(fd, file_offset + sh->sh_offset, SEEK_SET);
ptr = section_ptr(s, size); ptr = section_ptr_add(s, size);
read(fd, ptr, size); read(fd, ptr, size);
} } else {
s->data_offset += size; s->data_offset += size;
} }
}
/* second short pass to update sh_link and sh_info fields of new /* second short pass to update sh_link and sh_info fields of new
sections */ sections */