mirror of
https://github.com/frida/tinycc
synced 2025-01-12 22:59:25 +03:00
tccgen: nocode_wanted++/--
uses 'nocode_wanted' as a level couter instead of 'saved_nocode_wanted' everywhere.
This commit is contained in:
parent
e5efd18435
commit
f7fc4f02cf
88
tccgen.c
88
tccgen.c
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user