Commit f9b36bb3 by Kazu Hirata Committed by Nathan Froyd

coverage.c (build_fn_info_value): Call build_constructor instead of build_constructor_from_list.

	* coverage.c (build_fn_info_value): Call build_constructor instead of
	build_constructor_from_list.
	(build_ctr_info_value): Likewise.
	(build_gcov_info): Likewise.

Co-Authored-By: Nathan Froyd <froydnj@codesourcery.com>

From-SVN: r159326
parent f88203b0
2010-05-12 Kazu Hirata <kazu@codesourcery.com>
Nathan Froyd <froydnj@codesourcery.com>
* coverage.c (build_fn_info_value): Call build_constructor instead of
build_constructor_from_list.
(build_ctr_info_value): Likewise.
(build_gcov_info): Likewise.
2010-05-12 Nathan Froyd <froydnj@codesourcery.com> 2010-05-12 Nathan Froyd <froydnj@codesourcery.com>
* tree.c (build_constructor): Compute TREE_CONSTANT for the * tree.c (build_constructor): Compute TREE_CONSTANT for the
......
...@@ -672,40 +672,34 @@ build_fn_info_type (unsigned int counters) ...@@ -672,40 +672,34 @@ build_fn_info_type (unsigned int counters)
static tree static tree
build_fn_info_value (const struct function_list *function, tree type) build_fn_info_value (const struct function_list *function, tree type)
{ {
tree value = NULL_TREE;
tree fields = TYPE_FIELDS (type); tree fields = TYPE_FIELDS (type);
unsigned ix; unsigned ix;
tree array_value = NULL_TREE; VEC(constructor_elt,gc) *v1 = NULL;
VEC(constructor_elt,gc) *v2 = NULL;
/* ident */ /* ident */
value = tree_cons (fields, build_int_cstu (get_gcov_unsigned_t (), CONSTRUCTOR_APPEND_ELT (v1, fields,
function->ident), value); build_int_cstu (get_gcov_unsigned_t (),
function->ident));
fields = TREE_CHAIN (fields); fields = TREE_CHAIN (fields);
/* checksum */ /* checksum */
value = tree_cons (fields, build_int_cstu (get_gcov_unsigned_t (), CONSTRUCTOR_APPEND_ELT (v1, fields,
function->checksum), value); build_int_cstu (get_gcov_unsigned_t (),
function->checksum));
fields = TREE_CHAIN (fields); fields = TREE_CHAIN (fields);
/* counters */ /* counters */
for (ix = 0; ix != GCOV_COUNTERS; ix++) for (ix = 0; ix != GCOV_COUNTERS; ix++)
if (prg_ctr_mask & (1 << ix)) if (prg_ctr_mask & (1 << ix))
{ CONSTRUCTOR_APPEND_ELT (v2, NULL,
tree counters = build_int_cstu (get_gcov_unsigned_t (), build_int_cstu (get_gcov_unsigned_t (),
function->n_ctrs[ix]); function->n_ctrs[ix]));
array_value = tree_cons (NULL_TREE, counters, array_value); CONSTRUCTOR_APPEND_ELT (v1, fields,
} build_constructor (TREE_TYPE (fields), v2));
/* FIXME: use build_constructor directly. */ return build_constructor (type, v1);
array_value = build_constructor_from_list (TREE_TYPE (fields),
nreverse (array_value));
value = tree_cons (fields, array_value, value);
/* FIXME: use build_constructor directly. */
value = build_constructor_from_list (type, nreverse (value));
return value;
} }
/* Creates the gcov_ctr_info RECORD_TYPE. */ /* Creates the gcov_ctr_info RECORD_TYPE. */
...@@ -753,15 +747,14 @@ build_ctr_info_type (void) ...@@ -753,15 +747,14 @@ build_ctr_info_type (void)
static tree static tree
build_ctr_info_value (unsigned int counter, tree type) build_ctr_info_value (unsigned int counter, tree type)
{ {
tree value = NULL_TREE;
tree fields = TYPE_FIELDS (type); tree fields = TYPE_FIELDS (type);
tree fn; tree fn;
VEC(constructor_elt,gc) *v = NULL;
/* counters */ /* counters */
value = tree_cons (fields, CONSTRUCTOR_APPEND_ELT (v, fields,
build_int_cstu (get_gcov_unsigned_t (), build_int_cstu (get_gcov_unsigned_t (),
prg_n_ctrs[counter]), prg_n_ctrs[counter]));
value);
fields = TREE_CHAIN (fields); fields = TREE_CHAIN (fields);
if (prg_n_ctrs[counter]) if (prg_n_ctrs[counter])
...@@ -779,13 +772,12 @@ build_ctr_info_value (unsigned int counter, tree type) ...@@ -779,13 +772,12 @@ build_ctr_info_value (unsigned int counter, tree type)
DECL_SIZE_UNIT (tree_ctr_tables[counter]) = TYPE_SIZE_UNIT (array_type); DECL_SIZE_UNIT (tree_ctr_tables[counter]) = TYPE_SIZE_UNIT (array_type);
varpool_finalize_decl (tree_ctr_tables[counter]); varpool_finalize_decl (tree_ctr_tables[counter]);
value = tree_cons (fields, CONSTRUCTOR_APPEND_ELT (v, fields,
build1 (ADDR_EXPR, TREE_TYPE (fields), build1 (ADDR_EXPR, TREE_TYPE (fields),
tree_ctr_tables[counter]), tree_ctr_tables[counter]));
value);
} }
else else
value = tree_cons (fields, null_pointer_node, value); CONSTRUCTOR_APPEND_ELT (v, fields, null_pointer_node);
fields = TREE_CHAIN (fields); fields = TREE_CHAIN (fields);
fn = build_decl (BUILTINS_LOCATION, fn = build_decl (BUILTINS_LOCATION,
...@@ -797,14 +789,9 @@ build_ctr_info_value (unsigned int counter, tree type) ...@@ -797,14 +789,9 @@ build_ctr_info_value (unsigned int counter, tree type)
DECL_ARTIFICIAL (fn) = 1; DECL_ARTIFICIAL (fn) = 1;
TREE_NOTHROW (fn) = 1; TREE_NOTHROW (fn) = 1;
DECL_ASSEMBLER_NAME (fn); /* Initialize assembler name so we can stream out. */ DECL_ASSEMBLER_NAME (fn); /* Initialize assembler name so we can stream out. */
value = tree_cons (fields, CONSTRUCTOR_APPEND_ELT (v, fields, build1 (ADDR_EXPR, TREE_TYPE (fields), fn));
build1 (ADDR_EXPR, TREE_TYPE (fields), fn),
value);
/* FIXME: use build_constructor directly. */
value = build_constructor_from_list (type, nreverse (value));
return value; return build_constructor (type, v);
} }
/* Creates the gcov_info RECORD_TYPE and initializer for it. Returns a /* Creates the gcov_info RECORD_TYPE and initializer for it. Returns a
...@@ -819,12 +806,13 @@ build_gcov_info (void) ...@@ -819,12 +806,13 @@ build_gcov_info (void)
tree fn_info_ptr_type; tree fn_info_ptr_type;
tree ctr_info_type, ctr_info_ary_type, ctr_info_value = NULL_TREE; tree ctr_info_type, ctr_info_ary_type, ctr_info_value = NULL_TREE;
tree field, fields = NULL_TREE; tree field, fields = NULL_TREE;
tree value = NULL_TREE;
tree filename_string; tree filename_string;
int da_file_name_len; int da_file_name_len;
unsigned n_fns; unsigned n_fns;
const struct function_list *fn; const struct function_list *fn;
tree string_type; tree string_type;
VEC(constructor_elt,gc) *v1 = NULL;
VEC(constructor_elt,gc) *v2 = NULL;
/* Count the number of active counters. */ /* Count the number of active counters. */
for (n_ctr_types = 0, ix = 0; ix != GCOV_COUNTERS; ix++) for (n_ctr_types = 0, ix = 0; ix != GCOV_COUNTERS; ix++)
...@@ -839,23 +827,23 @@ build_gcov_info (void) ...@@ -839,23 +827,23 @@ build_gcov_info (void)
FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ()); FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ());
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, build_int_cstu (TREE_TYPE (field), GCOV_VERSION), CONSTRUCTOR_APPEND_ELT (v1, field,
value); build_int_cstu (TREE_TYPE (field), GCOV_VERSION));
/* next -- NULL */ /* next -- NULL */
field = build_decl (BUILTINS_LOCATION, field = build_decl (BUILTINS_LOCATION,
FIELD_DECL, NULL_TREE, build_pointer_type (const_type)); FIELD_DECL, NULL_TREE, build_pointer_type (const_type));
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, null_pointer_node, value); CONSTRUCTOR_APPEND_ELT (v1, field, null_pointer_node);
/* stamp */ /* stamp */
field = build_decl (BUILTINS_LOCATION, field = build_decl (BUILTINS_LOCATION,
FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ()); FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ());
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, build_int_cstu (TREE_TYPE (field), local_tick), CONSTRUCTOR_APPEND_ELT (v1, field,
value); build_int_cstu (TREE_TYPE (field), local_tick));
/* Filename */ /* Filename */
string_type = build_pointer_type (build_qualified_type (char_type_node, string_type = build_pointer_type (build_qualified_type (char_type_node,
...@@ -869,17 +857,17 @@ build_gcov_info (void) ...@@ -869,17 +857,17 @@ build_gcov_info (void)
TREE_TYPE (filename_string) = build_array_type TREE_TYPE (filename_string) = build_array_type
(char_type_node, build_index_type (char_type_node, build_index_type
(build_int_cst (NULL_TREE, da_file_name_len))); (build_int_cst (NULL_TREE, da_file_name_len)));
value = tree_cons (field, build1 (ADDR_EXPR, string_type, filename_string), CONSTRUCTOR_APPEND_ELT (v1, field,
value); build1 (ADDR_EXPR, string_type, filename_string));
/* Build the fn_info type and initializer. */ /* Build the fn_info type and initializer. */
fn_info_type = build_fn_info_type (n_ctr_types); fn_info_type = build_fn_info_type (n_ctr_types);
fn_info_ptr_type = build_pointer_type (build_qualified_type fn_info_ptr_type = build_pointer_type (build_qualified_type
(fn_info_type, TYPE_QUAL_CONST)); (fn_info_type, TYPE_QUAL_CONST));
for (fn = functions_head, n_fns = 0; fn; fn = fn->next, n_fns++) for (fn = functions_head, n_fns = 0; fn; fn = fn->next, n_fns++)
fn_info_value = tree_cons (NULL_TREE, CONSTRUCTOR_APPEND_ELT (v2, NULL_TREE,
build_fn_info_value (fn, fn_info_type), build_fn_info_value (fn, fn_info_type));
fn_info_value);
if (n_fns) if (n_fns)
{ {
tree array_type; tree array_type;
...@@ -887,9 +875,7 @@ build_gcov_info (void) ...@@ -887,9 +875,7 @@ build_gcov_info (void)
array_type = build_index_type (build_int_cst (NULL_TREE, n_fns - 1)); array_type = build_index_type (build_int_cst (NULL_TREE, n_fns - 1));
array_type = build_array_type (fn_info_type, array_type); array_type = build_array_type (fn_info_type, array_type);
/* FIXME: use build_constructor directly. */ fn_info_value = build_constructor (array_type, v2);
fn_info_value = build_constructor_from_list (array_type,
nreverse (fn_info_value));
fn_info_value = build1 (ADDR_EXPR, fn_info_ptr_type, fn_info_value); fn_info_value = build1 (ADDR_EXPR, fn_info_ptr_type, fn_info_value);
} }
else else
...@@ -900,52 +886,46 @@ build_gcov_info (void) ...@@ -900,52 +886,46 @@ build_gcov_info (void)
FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ()); FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ());
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, CONSTRUCTOR_APPEND_ELT (v1, field,
build_int_cstu (get_gcov_unsigned_t (), n_fns), build_int_cstu (get_gcov_unsigned_t (), n_fns));
value);
/* fn_info table */ /* fn_info table */
field = build_decl (BUILTINS_LOCATION, field = build_decl (BUILTINS_LOCATION,
FIELD_DECL, NULL_TREE, fn_info_ptr_type); FIELD_DECL, NULL_TREE, fn_info_ptr_type);
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, fn_info_value, value); CONSTRUCTOR_APPEND_ELT (v1, field, fn_info_value);
/* counter_mask */ /* counter_mask */
field = build_decl (BUILTINS_LOCATION, field = build_decl (BUILTINS_LOCATION,
FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ()); FIELD_DECL, NULL_TREE, get_gcov_unsigned_t ());
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, CONSTRUCTOR_APPEND_ELT (v1, field,
build_int_cstu (get_gcov_unsigned_t (), prg_ctr_mask), build_int_cstu (get_gcov_unsigned_t (),
value); prg_ctr_mask));
/* counters */ /* counters */
ctr_info_type = build_ctr_info_type (); ctr_info_type = build_ctr_info_type ();
ctr_info_ary_type = build_index_type (build_int_cst (NULL_TREE, ctr_info_ary_type = build_index_type (build_int_cst (NULL_TREE,
n_ctr_types)); n_ctr_types));
ctr_info_ary_type = build_array_type (ctr_info_type, ctr_info_ary_type); ctr_info_ary_type = build_array_type (ctr_info_type, ctr_info_ary_type);
v2 = NULL;
for (ix = 0; ix != GCOV_COUNTERS; ix++) for (ix = 0; ix != GCOV_COUNTERS; ix++)
if (prg_ctr_mask & (1 << ix)) if (prg_ctr_mask & (1 << ix))
ctr_info_value = tree_cons (NULL_TREE, CONSTRUCTOR_APPEND_ELT (v2, NULL_TREE,
build_ctr_info_value (ix, ctr_info_type), build_ctr_info_value (ix, ctr_info_type));
ctr_info_value); ctr_info_value = build_constructor (ctr_info_ary_type, v2);
/* FIXME: use build_constructor directly. */
ctr_info_value = build_constructor_from_list (ctr_info_ary_type,
nreverse (ctr_info_value));
field = build_decl (BUILTINS_LOCATION, field = build_decl (BUILTINS_LOCATION,
FIELD_DECL, NULL_TREE, ctr_info_ary_type); FIELD_DECL, NULL_TREE, ctr_info_ary_type);
TREE_CHAIN (field) = fields; TREE_CHAIN (field) = fields;
fields = field; fields = field;
value = tree_cons (field, ctr_info_value, value); CONSTRUCTOR_APPEND_ELT (v1, field, ctr_info_value);
finish_builtin_struct (type, "__gcov_info", fields, NULL_TREE); finish_builtin_struct (type, "__gcov_info", fields, NULL_TREE);
/* FIXME: use build_constructor directly. */ return build_constructor (type, v1);
value = build_constructor_from_list (type, nreverse (value));
return value;
} }
/* Write out the structure which libgcov uses to locate all the /* Write out the structure which libgcov uses to locate all the
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment