tccgen: nocode_wanted++/--

uses 'nocode_wanted' as a level couter instead of
'saved_nocode_wanted' everywhere.
This commit is contained in:
grischka 2016-12-18 18:58:33 +01:00
parent e5efd18435
commit f7fc4f02cf

View File

@ -146,6 +146,7 @@ ST_FUNC void tccgen_start(TCCState *s1)
funcname = ""; funcname = "";
anon_sym = SYM_FIRST_ANOM; anon_sym = SYM_FIRST_ANOM;
section_sym = 0; section_sym = 0;
const_wanted = 0;
nocode_wanted = 1; nocode_wanted = 1;
/* define some often used types */ /* define some often used types */
@ -4457,16 +4458,14 @@ ST_FUNC void unary(void)
case TOK_builtin_expect: case TOK_builtin_expect:
{ {
/* __builtin_expect is a no-op for now */ /* __builtin_expect is a no-op for now */
int saved_nocode_wanted;
next(); next();
skip('('); skip('(');
expr_eq(); expr_eq();
skip(','); skip(',');
saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
expr_lor_const(); expr_lor_const();
vpop(); vpop();
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
skip(')'); skip(')');
} }
break; break;
@ -4486,45 +4485,41 @@ ST_FUNC void unary(void)
break; break;
case TOK_builtin_choose_expr: case TOK_builtin_choose_expr:
{ {
int saved_nocode_wanted;
int64_t c; int64_t c;
next(); next();
skip('('); skip('(');
c = expr_const64(); c = expr_const64();
skip(','); skip(',');
if (!c) { if (!c) {
saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
} }
expr_eq(); expr_eq();
if (!c) { if (!c) {
vpop(); vpop();
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
} }
skip(','); skip(',');
if (c) { if (c) {
saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
} }
expr_eq(); expr_eq();
if (c) { if (c) {
vpop(); vpop();
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
} }
skip(')'); skip(')');
} }
break; break;
case TOK_builtin_constant_p: case TOK_builtin_constant_p:
{ {
int saved_nocode_wanted, res; int res;
next(); next();
skip('('); skip('(');
saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
gexpr(); gexpr();
res = (vtop->r & (VT_VALMASK | VT_LVAL | VT_SYM)) == VT_CONST; res = (vtop->r & (VT_VALMASK | VT_LVAL | VT_SYM)) == VT_CONST;
vpop(); vpop();
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
skip(')'); skip(')');
vpushi(res); vpushi(res);
} }
@ -5054,14 +5049,13 @@ static void expr_land(void)
if (vtop->c.i) { if (vtop->c.i) {
vpop(); vpop();
} else { } else {
int saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
while (tok == TOK_LAND) { while (tok == TOK_LAND) {
next(); next();
expr_or(); expr_or();
vpop(); vpop();
} }
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
if (t) if (t)
gsym(t); gsym(t);
gen_cast(&int_type); gen_cast(&int_type);
@ -5098,14 +5092,13 @@ static void expr_lor(void)
if (!vtop->c.i) { if (!vtop->c.i) {
vpop(); vpop();
} else { } else {
int saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
while (tok == TOK_LOR) { while (tok == TOK_LOR) {
next(); next();
expr_land(); expr_land();
vpop(); vpop();
} }
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
if (t) if (t)
gsym(t); gsym(t);
gen_cast(&int_type); gen_cast(&int_type);
@ -5153,7 +5146,6 @@ static void expr_cond(void)
int tt, u, r1, r2, rc, t1, t2, bt1, bt2, islv, c, g; int tt, u, r1, r2, rc, t1, t2, bt1, bt2, islv, c, g;
SValue sv; SValue sv;
CType type, type1, type2; CType type, type1, type2;
int saved_nocode_wanted = nocode_wanted;
expr_lor(); expr_lor();
if (tok == '?') { if (tok == '?') {
@ -5186,7 +5178,7 @@ static void expr_cond(void)
if (1) { if (1) {
if (c == 0) if (c == 0)
nocode_wanted = 1; nocode_wanted++;
if (!g) if (!g)
gexpr(); gexpr();
@ -5199,11 +5191,14 @@ static void expr_cond(void)
if (c < 0) if (c < 0)
u = gjmp(0); u = gjmp(0);
gsym(tt); gsym(tt);
nocode_wanted = saved_nocode_wanted;
if (c == 0)
nocode_wanted--;
if (c == 1) if (c == 1)
nocode_wanted = 1; nocode_wanted++;
expr_cond(); expr_cond();
nocode_wanted = saved_nocode_wanted; if (c == 1)
nocode_wanted--;
type2 = vtop->type; type2 = vtop->type;
t1 = type1.t; t1 = type1.t;
@ -5355,38 +5350,31 @@ ST_FUNC void gexpr(void)
/* parse an expression and return its type without any side effect. */ /* parse an expression and return its type without any side effect. */
static void expr_type(CType *type) static void expr_type(CType *type)
{ {
int saved_nocode_wanted;
saved_nocode_wanted = nocode_wanted; nocode_wanted++;
nocode_wanted = 1;
gexpr(); gexpr();
*type = vtop->type; *type = vtop->type;
vpop(); vpop();
nocode_wanted = saved_nocode_wanted; nocode_wanted--;
} }
/* parse a unary expression and return its type without any side /* parse a unary expression and return its type without any side
effect. */ effect. */
static void unary_type(CType *type) static void unary_type(CType *type)
{ {
int a; nocode_wanted++;
a = nocode_wanted;
nocode_wanted = 1;
unary(); unary();
*type = vtop->type; *type = vtop->type;
vpop(); vpop();
nocode_wanted = a; nocode_wanted--;
} }
/* parse a constant expression and return value in vtop. */ /* parse a constant expression and return value in vtop. */
static void expr_const1(void) static void expr_const1(void)
{ {
int a; const_wanted++;
a = const_wanted;
const_wanted = 1;
expr_cond(); expr_cond();
const_wanted = a; const_wanted--;
} }
/* parse an integer constant and return its value. */ /* parse an integer constant and return its value. */
@ -5552,7 +5540,7 @@ static void block(int *bsym, int *csym, int is_expr)
else else
a = gvtst(1, 0); a = gvtst(1, 0);
if (cond == 0) if (cond == 0)
nocode_wanted |= 2; nocode_wanted |= 0x20000000;
block(bsym, csym, 0); block(bsym, csym, 0);
if (cond != 1) if (cond != 1)
nocode_wanted = saved_nocode_wanted; nocode_wanted = saved_nocode_wanted;
@ -5562,7 +5550,7 @@ static void block(int *bsym, int *csym, int is_expr)
d = gjmp(0); d = gjmp(0);
gsym(a); gsym(a);
if (cond == 1) if (cond == 1)
nocode_wanted |= 2; nocode_wanted |= 0x20000000;
block(bsym, csym, 0); block(bsym, csym, 0);
gsym(d); /* patch else jmp */ gsym(d); /* patch else jmp */
if (cond != 0) if (cond != 0)
@ -5571,7 +5559,7 @@ static void block(int *bsym, int *csym, int is_expr)
gsym(a); gsym(a);
} else if (tok == TOK_WHILE) { } else if (tok == TOK_WHILE) {
int saved_nocode_wanted; int saved_nocode_wanted;
nocode_wanted &= ~2; nocode_wanted &= ~0x20000000;
next(); next();
d = ind; d = ind;
vla_sp_restore(); vla_sp_restore();
@ -5718,7 +5706,7 @@ static void block(int *bsym, int *csym, int is_expr)
/* jump unless last stmt in top-level block */ /* jump unless last stmt in top-level block */
if (tok != '}' || local_scope != 1) if (tok != '}' || local_scope != 1)
rsym = gjmp(rsym); rsym = gjmp(rsym);
nocode_wanted |= 2; nocode_wanted |= 0x20000000;
} else if (tok == TOK_BREAK) { } else if (tok == TOK_BREAK) {
/* compute jump */ /* compute jump */
if (!bsym) if (!bsym)
@ -5726,7 +5714,7 @@ static void block(int *bsym, int *csym, int is_expr)
*bsym = gjmp(*bsym); *bsym = gjmp(*bsym);
next(); next();
skip(';'); skip(';');
nocode_wanted |= 2; nocode_wanted |= 0x20000000;
} else if (tok == TOK_CONTINUE) { } else if (tok == TOK_CONTINUE) {
/* compute jump */ /* compute jump */
if (!csym) if (!csym)
@ -5738,7 +5726,7 @@ static void block(int *bsym, int *csym, int is_expr)
} else if (tok == TOK_FOR) { } else if (tok == TOK_FOR) {
int e; int e;
int saved_nocode_wanted; int saved_nocode_wanted;
nocode_wanted &= ~2; nocode_wanted &= ~0x20000000;
next(); next();
skip('('); skip('(');
s = local_stack; s = local_stack;
@ -5784,7 +5772,7 @@ static void block(int *bsym, int *csym, int is_expr)
} else } else
if (tok == TOK_DO) { if (tok == TOK_DO) {
int saved_nocode_wanted; int saved_nocode_wanted;
nocode_wanted &= ~2; nocode_wanted &= ~0x20000000;
next(); next();
a = 0; a = 0;
b = 0; b = 0;
@ -5844,7 +5832,7 @@ static void block(int *bsym, int *csym, int is_expr)
struct case_t *cr = tcc_malloc(sizeof(struct case_t)); struct case_t *cr = tcc_malloc(sizeof(struct case_t));
if (!cur_switch) if (!cur_switch)
expect("switch"); expect("switch");
nocode_wanted &= ~2; nocode_wanted &= ~0x20000000;
next(); next();
cr->v1 = cr->v2 = expr_const64(); cr->v1 = cr->v2 = expr_const64();
if (gnu_ext && tok == TOK_DOTS) { if (gnu_ext && tok == TOK_DOTS) {
@ -5917,7 +5905,7 @@ static void block(int *bsym, int *csym, int is_expr)
vla_sp_restore(); vla_sp_restore();
/* we accept this, but it is a mistake */ /* we accept this, but it is a mistake */
block_after_label: block_after_label:
nocode_wanted &= ~2; nocode_wanted &= ~0x20000000;
if (tok == '}') { if (tok == '}') {
tcc_warning("deprecated use of label at end of compound statement"); tcc_warning("deprecated use of label at end of compound statement");
} else { } else {
@ -6833,8 +6821,6 @@ static void func_decl_list(Sym *func_sym)
'cur_text_section' */ 'cur_text_section' */
static void gen_function(Sym *sym) static void gen_function(Sym *sym)
{ {
int saved_nocode_wanted = nocode_wanted;
nocode_wanted = 0; nocode_wanted = 0;
ind = cur_text_section->data_offset; ind = cur_text_section->data_offset;
/* NOTE: we patch the symbol size later */ /* NOTE: we patch the symbol size later */
@ -6881,7 +6867,7 @@ static void gen_function(Sym *sym)
func_vt.t = VT_VOID; /* for safety */ func_vt.t = VT_VOID; /* for safety */
func_var = 0; /* for safety */ func_var = 0; /* for safety */
ind = 0; /* for safety */ ind = 0; /* for safety */
nocode_wanted = saved_nocode_wanted; nocode_wanted = 1;
check_vstack(); check_vstack();
} }