aboutsummaryrefslogtreecommitdiff
path: root/gcc/gengtype.c
diff options
context:
space:
mode:
authorSteven Bosscher <steven@gcc.gnu.org>2012-07-31 09:20:56 +0000
committerSteven Bosscher <steven@gcc.gnu.org>2012-07-31 09:20:56 +0000
commitce24add34b019318263e5d57b4e2aca8f3727964 (patch)
tree7b64afcca3aba595d2bf430c39ed491bbd9f189b /gcc/gengtype.c
parent6e12cdead084e0ac9ca312c57149576daec5a716 (diff)
PR pch/53880
* gengtype.c (struct walk_type_data): Add have_this_obj field. (walk_type): For functions that take a this_obj argument and that process fields with a GTY((length)) argument, write the test that write_types_local_process_field will write also at the head of the loop, effectively unswitching the loop. (write_func_for_structure, write_local_func_for_structure): Clear have_this_obj before calling walk_type. (write_local_func_for_structure): Set have_this_obj before walk_type. (write_array): Set have_this_obj for output of local pointer walking functions but not for marker functions. (write_types_local_process_field): Assert have_this_obj is set. * rtl.h (simplify_using_condition): Adjust prototype using bitmap from coretypes.h. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@189999 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gengtype.c')
-rw-r--r--gcc/gengtype.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/gcc/gengtype.c b/gcc/gengtype.c
index ecb8378207e..a4aa72554be 100644
--- a/gcc/gengtype.c
+++ b/gcc/gengtype.c
@@ -2303,6 +2303,7 @@ struct walk_type_data
bool fn_wants_lvalue;
bool in_record_p;
int loopcounter;
+ bool have_this_obj;
};
/* Print a mangled name representing T to OF. */
@@ -2618,6 +2619,9 @@ walk_type (type_p t, struct walk_type_data *d)
output_escaped_param (d, length, "length");
else
oprintf (d->of, "l%d", loopcounter);
+ if (d->have_this_obj)
+ /* Try to unswitch loops (see PR53880). */
+ oprintf (d->of, ") && ((void *)%s == this_obj", oldval);
oprintf (d->of, "); i%d++) {\n", loopcounter);
d->indent += 2;
d->val = newval = xasprintf ("%s[i%d]", oldval, loopcounter);
@@ -3105,6 +3109,7 @@ write_func_for_structure (type_p orig_s, type_p s, type_p *param,
d.prev_val[1] = "not valid postage"; /* Guarantee an error. */
d.prev_val[3] = "x";
d.val = "(*x)";
+ d.have_this_obj = false;
oprintf (d.of, "\n");
oprintf (d.of, "void\n");
@@ -3400,6 +3405,7 @@ static const struct write_types_data pch_wtd = {
static void
write_types_local_process_field (type_p f, const struct walk_type_data *d)
{
+ gcc_assert (d->have_this_obj);
switch (f->kind)
{
case TYPE_POINTER:
@@ -3458,6 +3464,7 @@ write_local_func_for_structure (const_type_p orig_s, type_p s, type_p *param)
s->kind == TYPE_UNION ? "union" : "struct", s->u.s.tag,
s->kind == TYPE_UNION ? "union" : "struct", s->u.s.tag);
d.indent = 2;
+ d.have_this_obj = true;
walk_type (s, &d);
oprintf (d.of, "}\n");
}
@@ -3967,6 +3974,7 @@ write_array (outf_p f, pair_p v, const struct write_types_data *wtd)
oprintf (d.of, "{\n");
d.prev_val[0] = d.prev_val[1] = d.prev_val[2] = d.val = v->name;
d.process_field = write_types_local_process_field;
+ d.have_this_obj = true;
walk_type (v->type, &d);
oprintf (f, "}\n\n");
}
@@ -3978,6 +3986,7 @@ write_array (outf_p f, pair_p v, const struct write_types_data *wtd)
oprintf (f, "{\n");
d.prev_val[0] = d.prev_val[1] = d.prev_val[2] = d.val = v->name;
d.process_field = write_types_process_field;
+ d.have_this_obj = false;
walk_type (v->type, &d);
free (prevval3);
oprintf (f, "}\n\n");