diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-05-11 00:32:01 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-05-11 00:32:01 +0000 |
commit | 6b6672beb27be6029d40983fee5425c8f545b88c (patch) | |
tree | 2cb1f64448644304b80597457c575f4d16bb0144 /gcc/final.c | |
parent | 843dd7a3db214e25bf208900bff2936f525a4cda (diff) | |
download | gcc-6b6672beb27be6029d40983fee5425c8f545b88c.tar.gz |
* final.c (end_final): Tidy whitespace. Don't honor flag_pack_struct.
Convert integers constants as needed. Replace "nwords" field with
"sizeof_bb".
(final): Save profile data if cfun->arc_profile, not profile_arc_flag.
* function.h: Fix typo in comment.
* libgcc2.c (struct bb): Replace "nwords" with "sizeof_bb".
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@53374 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/final.c')
-rw-r--r-- | gcc/final.c | 228 |
1 files changed, 109 insertions, 119 deletions
diff --git a/gcc/final.c b/gcc/final.c index 57e94e78e4f..13e2aca11a1 100644 --- a/gcc/final.c +++ b/gcc/final.c @@ -258,14 +258,13 @@ end_final (filename) tree string_type, string_cst; tree structure_decl, structure_value, structure_pointer_type; tree field_decl, decl_chain, value_chain; - tree nwords_field_value, domain_type; + tree sizeof_field_value, domain_type; /* Build types. */ string_type = build_pointer_type (char_type_node); /* Libgcc2 bb structure. */ structure_decl = make_node (RECORD_TYPE); - TYPE_PACKED (structure_decl) = flag_pack_struct; structure_pointer_type = build_pointer_type (structure_decl); /* Output the main header, of 7 words: @@ -284,96 +283,103 @@ end_final (filename) decl_chain = build_decl (FIELD_DECL, get_identifier ("zero_word"), long_integer_type_node); - value_chain = build_tree_list (decl_chain, integer_zero_node); + value_chain = build_tree_list (decl_chain, + convert (long_integer_type_node, + integer_zero_node)); /* Address of filename. */ { - char *cwd = getpwd (); - int da_filename_len = strlen (filename) + strlen (cwd) + 4 + 1; - char *da_filename = (char *) alloca (da_filename_len); + char *cwd, *da_filename; + int da_filename_len; + field_decl = + build_decl (FIELD_DECL, get_identifier ("filename"), string_type); + TREE_CHAIN (field_decl) = decl_chain; + decl_chain = field_decl; + + cwd = getpwd (); + da_filename_len = strlen (filename) + strlen (cwd) + 4 + 1; + da_filename = (char *) alloca (da_filename_len); strcpy (da_filename, cwd); strcat (da_filename, "/"); strcat (da_filename, filename); strip_off_ending (da_filename, da_filename_len - 3); strcat (da_filename, ".da"); - field_decl = - build_decl (FIELD_DECL, get_identifier ("filename"), string_type); - string_cst = build_string (strlen (da_filename) + 1, da_filename); - domain_type = build_index_type (build_int_2 (strlen (da_filename) + 1, - 0)); - TREE_TYPE (string_cst) = - build_array_type (char_type_node, domain_type); + da_filename_len = strlen (da_filename); + string_cst = build_string (da_filename_len + 1, da_filename); + domain_type = build_index_type (build_int_2 (da_filename_len, 0)); + TREE_TYPE (string_cst) + = build_array_type (char_type_node, domain_type); value_chain = tree_cons (field_decl, build1 (ADDR_EXPR, string_type, string_cst), value_chain); - TREE_CHAIN (field_decl) = decl_chain; - decl_chain = field_decl; } /* Table of counts. */ { tree gcov_type_type = make_unsigned_type (GCOV_TYPE_SIZE); tree gcov_type_pointer_type = build_pointer_type (gcov_type_type); - tree gcov_type_array_type, gcov_type_array_pointer_type; - tree domain_tree = build_index_type (build_int_2 - (profile_info. - count_instrumented_edges - 1, - 0)); + tree domain_tree + = build_index_type (build_int_2 (profile_info. + count_instrumented_edges - 1, 0)); + tree gcov_type_array_type + = build_array_type (gcov_type_type, domain_tree); + tree gcov_type_array_pointer_type + = build_pointer_type (gcov_type_array_type); tree counts_table; - gcov_type_array_type = build_array_type (gcov_type_type, domain_tree); - gcov_type_array_pointer_type = - build_pointer_type (gcov_type_array_type); + field_decl = + build_decl (FIELD_DECL, get_identifier ("counts"), + gcov_type_pointer_type); + TREE_CHAIN (field_decl) = decl_chain; + decl_chain = field_decl; /* No values. */ - counts_table = - build (VAR_DECL, gcov_type_array_type, NULL_TREE, NULL_TREE); + counts_table + = build (VAR_DECL, gcov_type_array_type, NULL_TREE, NULL_TREE); TREE_STATIC (counts_table) = 1; ASM_GENERATE_INTERNAL_LABEL (name, "LPBX", 2); DECL_NAME (counts_table) = get_identifier (name); assemble_variable (counts_table, 0, 0, 0); - field_decl = - build_decl (FIELD_DECL, get_identifier ("counts"), - gcov_type_pointer_type); value_chain = tree_cons (field_decl, build1 (ADDR_EXPR, gcov_type_array_pointer_type, counts_table), value_chain); - TREE_CHAIN (field_decl) = decl_chain; - decl_chain = field_decl; } /* Count of the # of instrumented arcs. */ - field_decl = - build_decl (FIELD_DECL, get_identifier ("ncounts"), - long_integer_type_node); + field_decl + = build_decl (FIELD_DECL, get_identifier ("ncounts"), + long_integer_type_node); + TREE_CHAIN (field_decl) = decl_chain; + decl_chain = field_decl; + value_chain = tree_cons (field_decl, convert (long_integer_type_node, build_int_2 (profile_info. count_instrumented_edges, 0)), value_chain); + /* Pointer to the next bb. */ + field_decl + = build_decl (FIELD_DECL, get_identifier ("next"), + structure_pointer_type); TREE_CHAIN (field_decl) = decl_chain; decl_chain = field_decl; - /* Pointer to the next bb. */ - field_decl = - build_decl (FIELD_DECL, get_identifier ("next"), - structure_pointer_type); value_chain = tree_cons (field_decl, null_pointer_node, value_chain); - TREE_CHAIN (field_decl) = decl_chain; - decl_chain = field_decl; - /* Number of words. We'll set this after entire structure is laid out. */ - field_decl = - build_decl (FIELD_DECL, get_identifier ("nwords"), - long_integer_type_node); - value_chain = nwords_field_value = - tree_cons (field_decl, NULL, value_chain); + /* sizeof(struct bb). We'll set this after entire structure + is laid out. */ + field_decl + = build_decl (FIELD_DECL, get_identifier ("sizeof_bb"), + long_integer_type_node); TREE_CHAIN (field_decl) = decl_chain; decl_chain = field_decl; + sizeof_field_value = tree_cons (field_decl, NULL, value_chain); + value_chain = sizeof_field_value; + /* struct bb_function []. */ { struct function_list *item; @@ -388,16 +394,17 @@ end_final (filename) tree field_value, field_value_chain; bb_fn_struct_type = make_node (RECORD_TYPE); - TYPE_PACKED (bb_fn_struct_type) = flag_pack_struct; checksum_field = build_decl (FIELD_DECL, get_identifier ("checksum"), long_integer_type_node); - arc_count_field = - build_decl (FIELD_DECL, get_identifier ("arc_count"), - integer_type_node); + + arc_count_field + = build_decl (FIELD_DECL, get_identifier ("arc_count"), + integer_type_node); TREE_CHAIN (checksum_field) = arc_count_field; - name_field = - build_decl (FIELD_DECL, get_identifier ("name"), string_type); + + name_field + = build_decl (FIELD_DECL, get_identifier ("name"), string_type); TREE_CHAIN (arc_count_field) = name_field; TYPE_FIELDS (bb_fn_struct_type) = checksum_field; @@ -411,10 +418,10 @@ end_final (filename) domain = build_index_type (build_int_2 (num_nodes, 0)); bb_fn_struct_pointer_type = build_pointer_type (bb_fn_struct_type); - bb_fn_struct_array_type = build_array_type (bb_fn_struct_type, - domain); - bb_fn_struct_array_pointer_type = - build_pointer_type (bb_fn_struct_array_type); + bb_fn_struct_array_type + = build_array_type (bb_fn_struct_type, domain); + bb_fn_struct_array_pointer_type + = build_pointer_type (bb_fn_struct_array_type); layout_type (bb_fn_struct_type); layout_type (bb_fn_struct_pointer_type); @@ -423,38 +430,35 @@ end_final (filename) for (item = functions_head; item != 0; item = item->next) { + size_t name_len; + /* create constructor for structure. */ - field_value_chain = build_tree_list (checksum_field, - convert - (long_integer_type_node, - build_int_2 (item-> - cfg_checksum, - 0))); - field_value_chain = - tree_cons (arc_count_field, - convert (integer_type_node, - build_int_2 (item->count_edges, 0)), - field_value_chain); - - string_cst = build_string (strlen (item->name) + 1, item->name); - domain_type = build_index_type (build_int_2 (strlen (item->name) + - 1, 0)); - TREE_TYPE (string_cst) = build_array_type (char_type_node, - domain_type); + field_value_chain + = build_tree_list (checksum_field, + convert (long_integer_type_node, + build_int_2 (item->cfg_checksum, 0))); + field_value_chain + = tree_cons (arc_count_field, + convert (integer_type_node, + build_int_2 (item->count_edges, 0)), + field_value_chain); + + name_len = strlen (item->name); + string_cst = build_string (name_len + 1, item->name); + domain_type = build_index_type (build_int_2 (name_len, 0)); + TREE_TYPE (string_cst) + = build_array_type (char_type_node, domain_type); field_value_chain = tree_cons (name_field, build1 (ADDR_EXPR, string_type, string_cst), field_value_chain); /* Add to chain. */ - - array_value_chain = tree_cons (NULL_TREE, - build (CONSTRUCTOR, - bb_fn_struct_type, - NULL_TREE, - nreverse - (field_value_chain)), - array_value_chain); + array_value_chain + = tree_cons (NULL_TREE, build (CONSTRUCTOR, + bb_fn_struct_type, NULL_TREE, + nreverse (field_value_chain)), + array_value_chain); } /* Add terminator. */ @@ -469,10 +473,9 @@ end_final (filename) /* Create constructor for array. */ - - field_decl = - build_decl (FIELD_DECL, get_identifier ("function_infos"), - bb_fn_struct_pointer_type); + field_decl + = build_decl (FIELD_DECL, get_identifier ("function_infos"), + bb_fn_struct_pointer_type); value_chain = tree_cons (field_decl, build1 (ADDR_EXPR, bb_fn_struct_array_pointer_type, @@ -486,37 +489,26 @@ end_final (filename) decl_chain = field_decl; } - /* Finish structure. */ TYPE_FIELDS (structure_decl) = nreverse (decl_chain); layout_type (structure_decl); - structure_value = - build (VAR_DECL, structure_decl, NULL_TREE, NULL_TREE); - DECL_INITIAL (structure_value) = - build (CONSTRUCTOR, structure_decl, NULL_TREE, - nreverse (value_chain)); + structure_value + = build (VAR_DECL, structure_decl, NULL_TREE, NULL_TREE); + DECL_INITIAL (structure_value) + = build (CONSTRUCTOR, structure_decl, NULL_TREE, + nreverse (value_chain)); TREE_STATIC (structure_value) = 1; ASM_GENERATE_INTERNAL_LABEL (name, "LPBX", 0); DECL_NAME (structure_value) = get_identifier (name); - /* Set number of words in this structure. */ - TREE_VALUE (nwords_field_value) = - build_int_2 (TREE_INT_CST_LOW (TYPE_SIZE_UNIT (structure_decl)) / - (INT_TYPE_SIZE / BITS_PER_UNIT), 0); + /* Size of this structure. */ + TREE_VALUE (sizeof_field_value) + = convert (long_integer_type_node, + build_int_2 (int_size_in_bytes (structure_decl), 0)); /* Build structure. */ assemble_variable (structure_value, 0, 0, 0); - - /* Offset to table of arc counters for thread-safe profiling. */ - { - tree table_offset_var = make_node (VAR_DECL); - TREE_TYPE (table_offset_var) = build_pointer_type (integer_type_node); - DECL_INITIAL (table_offset_var) = integer_zero_node; - DECL_NAME (table_offset_var) = get_identifier (".LPBF0"); - TREE_STATIC (table_offset_var) = 1; - assemble_variable (table_offset_var, 0, 0, 0); - } } } @@ -1931,22 +1923,20 @@ final (first, file, optimize, prescan) } /* Store function names for edge-profiling. */ + /* ??? Probably should re-use the existing struct function. */ - if (profile_arc_flag) - { - struct function_list *new_item = xmalloc (sizeof (struct function_list)); - - /* Add function to linked list. */ - new_item->next = 0; - *functions_tail = new_item; - functions_tail = &new_item->next; - - /* Set values. */ - new_item->cfg_checksum = profile_info.current_function_cfg_checksum; - new_item->count_edges = profile_info.count_edges_instrumented_now; - new_item->name = xstrdup (current_function_name); - - } + if (cfun->arc_profile) + { + struct function_list *new_item = xmalloc (sizeof (struct function_list)); + + *functions_tail = new_item; + functions_tail = &new_item->next; + + new_item->next = 0; + new_item->name = xstrdup (current_function_name); + new_item->cfg_checksum = profile_info.current_function_cfg_checksum; + new_item->count_edges = profile_info.count_edges_instrumented_now; + } free (line_note_exists); line_note_exists = NULL; |