diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-06-22 17:23:14 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-06-22 17:23:14 +0000 |
commit | 17a8121649b62d1893a5c942bdf0719e766894ed (patch) | |
tree | dd8484defdb75a57e43380239e2d1f1b2bcafed1 /gcc/gcov-io.h | |
parent | 63f236087f033781e482c61b8d159595cb371d4f (diff) | |
download | gcc-17a8121649b62d1893a5c942bdf0719e766894ed.tar.gz |
* predict.c (estimate_bb_frequencies): Do not handle conditional
jumps jumping to fallthru basic block as conditional jumps.
* tm.texi (GCOV_TYPE_SIZE): Document.
* basic-block.h (gcov_type): Define.
(struct edge_def): Use gcov_type for count field.
(struct basic_block_def): Likewise.
* defaults.h (GCOV_TYPE_SIZE): Define.
* final.c (end_final): Use GCOV_TYPE_SIZE.
* flow.c (dump_edge_info, dump_flow_info, dump_bb): Print count fields
using HOST_WIDEST_INT_PRINT_DEC.
* gcov-io.h (__fetch_gcov_type, __store_gcov_type, __read_gcov_type,
__write_gcov_type): New.
(store_long): Remove.
* gcov.c (gcov_type): Set default.
(struct adj_list): Use gcov_type for arc_count.
(bb_info): Use gcov_type for succ_count, pred_count and exec_count.
(create_program_flow_graph): Read arc_count properly.
(solve_program_flow_graph): 'total' is gcov_type.
(output_data): Line_counts is gcov_type, print it properly.
* libgcc2.c (struct bb): Counts is gcov_type.
(__bb_exit_func): Use __read_gcov_type and __write_gcov_type.
* profile.c (LONG_TYPE_SIZE, LONG_LONG_TYPE_SIZE): Set default.
(GCOV_TYPE_SIZE): Define.
(struct bb_info): succ_count and pred_count is gcov_type.
(compute_branch_probabilities): Use __read_gcov_type,
print read edges to the dump file.
(total): Is gcov_type.
(gen_edge_profiler): Use GCOV_TYPE_SIZE.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@43506 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gcov-io.h')
-rw-r--r-- | gcc/gcov-io.h | 64 |
1 files changed, 59 insertions, 5 deletions
diff --git a/gcc/gcov-io.h b/gcc/gcov-io.h index 48f83aa00d1..8e360225718 100644 --- a/gcc/gcov-io.h +++ b/gcc/gcov-io.h @@ -25,9 +25,12 @@ Boston, MA 02111-1307, USA. */ #include <sys/types.h> static int __fetch_long PARAMS ((long *, char *, size_t)) ATTRIBUTE_UNUSED; -static int __store_long PARAMS ((long, char *, size_t)) ATTRIBUTE_UNUSED; static int __read_long PARAMS ((long *, FILE *, size_t)) ATTRIBUTE_UNUSED; static int __write_long PARAMS ((long, FILE *, size_t)) ATTRIBUTE_UNUSED; +static int __fetch_gcov_type PARAMS ((gcov_type *, char *, size_t)) ATTRIBUTE_UNUSED; +static int __store_gcov_type PARAMS ((gcov_type, char *, size_t)) ATTRIBUTE_UNUSED; +static int __read_gcov_type PARAMS ((gcov_type *, FILE *, size_t)) ATTRIBUTE_UNUSED; +static int __write_gcov_type PARAMS ((gcov_type, FILE *, size_t)) ATTRIBUTE_UNUSED; /* These routines only work for signed values. */ @@ -36,8 +39,8 @@ static int __write_long PARAMS ((long, FILE *, size_t)) ATTRIBUTE_UNUSED; to store. */ static int -__store_long (value, dest, bytes) - long value; +__store_gcov_type (value, dest, bytes) + gcov_type value; char *dest; size_t bytes; { @@ -46,7 +49,7 @@ __store_long (value, dest, bytes) if (value < 0) { - long oldvalue = value; + gcov_type oldvalue = value; value = -value; if (oldvalue != -value) return 1; @@ -71,6 +74,29 @@ __store_long (value, dest, bytes) will not fit in DEST. */ static int +__fetch_gcov_type (dest, source, bytes) + gcov_type *dest; + char *source; + size_t bytes; +{ + gcov_type value = 0; + int i; + + for (i = bytes - 1; (size_t) i > (sizeof (*dest) - 1); i--) + if (source[i] & ((size_t) i == (bytes - 1) ? 127 : 255 )) + return 1; + + for (; i >= 0; i--) + value = value * 256 + (source[i] & ((size_t)i == (bytes - 1) ? 127 : 255)); + + if ((source[bytes - 1] & 128) && (value > 0)) + value = - value; + + *dest = value; + return 0; +} + +static int __fetch_long (dest, source, bytes) long *dest; char *source; @@ -103,6 +129,20 @@ __fetch_long (dest, source, bytes) BYTES may be a maximum of 10. */ static int +__write_gcov_type (value, file, bytes) + gcov_type value; + FILE *file; + size_t bytes; +{ + char c[10]; + + if (bytes > 10 || __store_gcov_type (value, c, bytes)) + return 1; + else + return fwrite(c, 1, bytes, file) != bytes; +} + +static int __write_long (value, file, bytes) long value; FILE *file; @@ -110,7 +150,7 @@ __write_long (value, file, bytes) { char c[10]; - if (bytes > 10 || __store_long (value, c, bytes)) + if (bytes > 10 || __store_gcov_type ((gcov_type)value, c, bytes)) return 1; else return fwrite(c, 1, bytes, file) != bytes; @@ -126,6 +166,20 @@ __write_long (value, file, bytes) BYTES may be a maximum of 10. */ static int +__read_gcov_type (dest, file, bytes) + gcov_type *dest; + FILE *file; + size_t bytes; +{ + char c[10]; + + if (bytes > 10 || fread(c, 1, bytes, file) != bytes) + return 1; + else + return __fetch_gcov_type (dest, c, bytes); +} + +static int __read_long (dest, file, bytes) long *dest; FILE *file; |