]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gcov-io.c (gcov_position): Use gcov_nonruntime_assert.
authorTeresa Johnson <tejohnson@google.com>
Thu, 22 May 2014 14:06:08 +0000 (14:06 +0000)
committerTeresa Johnson <tejohnson@gcc.gnu.org>
Thu, 22 May 2014 14:06:08 +0000 (14:06 +0000)
2014-05-22  Teresa Johnson  <tejohnson@google.com>

* gcov-io.c (gcov_position): Use gcov_nonruntime_assert.
(gcov_is_error): Remove gcc_assert from IN_LIBGCOV code.
(gcov_rewrite): Use gcov_nonruntime_assert.
(gcov_open): Ditto.
(gcov_write_words): Ditto.
(gcov_write_length): Ditto.
(gcov_read_words): Use gcov_nonruntime_assert, and remove
gcc_assert from IN_LIBGCOV code.
(gcov_read_summary): Use gcov_error to flag profile corruption.
(gcov_sync): Use gcov_nonruntime_assert.
(gcov_seek): Remove gcc_assert from IN_LIBGCOV code.
(gcov_histo_index): Use gcov_nonruntime_assert.
(static void gcov_histogram_merge): Ditto.
(compute_working_sets): Ditto.
* gcov-io.h (gcov_nonruntime_assert): Define.
(gcov_error): Define for !IN_LIBGCOV

* libgcov-driver.c (gcov_error): Move declaration before gcov-io.c
include.

From-SVN: r210805

gcc/ChangeLog
gcc/gcov-io.c
gcc/gcov-io.h
libgcc/ChangeLog
libgcc/libgcov-driver.c

index ad78d7819eea62584e49928ed7d75b6dd8dfa448..d2dbcbd838ff9610d702a585494ce5bafa31ac33 100644 (file)
@@ -1,3 +1,22 @@
+2014-05-22  Teresa Johnson  <tejohnson@google.com>
+
+       * gcov-io.c (gcov_position): Use gcov_nonruntime_assert.
+       (gcov_is_error): Remove gcc_assert from IN_LIBGCOV code.
+       (gcov_rewrite): Use gcov_nonruntime_assert.
+       (gcov_open): Ditto.
+       (gcov_write_words): Ditto.
+       (gcov_write_length): Ditto.
+       (gcov_read_words): Use gcov_nonruntime_assert, and remove
+       gcc_assert from IN_LIBGCOV code.
+       (gcov_read_summary): Use gcov_error to flag profile corruption.
+       (gcov_sync): Use gcov_nonruntime_assert.
+       (gcov_seek): Remove gcc_assert from IN_LIBGCOV code.
+       (gcov_histo_index): Use gcov_nonruntime_assert.
+       (static void gcov_histogram_merge): Ditto.
+       (compute_working_sets): Ditto.
+       * gcov-io.h (gcov_nonruntime_assert): Define.
+       (gcov_error): Define for !IN_LIBGCOV
+
 2014-05-22  Richard Biener  <rguenther@suse.de>
 
        * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Handle
index 5ef82f6837200ad8b1227487b0583908ae6dbffb..cb88cdca4727bfe567036a7819544f770f989454 100644 (file)
@@ -67,7 +67,7 @@ GCOV_LINKAGE struct gcov_var
 static inline gcov_position_t
 gcov_position (void)
 {
-  gcc_assert (gcov_var.mode > 0); 
+  gcov_nonruntime_assert (gcov_var.mode > 0); 
   return gcov_var.start + gcov_var.offset;
 }
 
@@ -83,7 +83,6 @@ gcov_is_error (void)
 GCOV_LINKAGE inline void
 gcov_rewrite (void)
 {
-  gcc_assert (gcov_var.mode > 0); 
   gcov_var.mode = -1; 
   gcov_var.start = 0;
   gcov_var.offset = 0;
@@ -133,7 +132,7 @@ gcov_open (const char *name, int mode)
   s_flock.l_pid = getpid ();
 #endif
 
-  gcc_assert (!gcov_var.file);
+  gcov_nonruntime_assert (!gcov_var.file);
   gcov_var.start = 0;
   gcov_var.offset = gcov_var.length = 0;
   gcov_var.overread = -1u;
@@ -297,14 +296,13 @@ gcov_write_words (unsigned words)
 {
   gcov_unsigned_t *result;
 
-  gcc_assert (gcov_var.mode < 0);
+  gcov_nonruntime_assert (gcov_var.mode < 0);
 #if IN_LIBGCOV
   if (gcov_var.offset >= GCOV_BLOCK_SIZE)
     {
       gcov_write_block (GCOV_BLOCK_SIZE);
       if (gcov_var.offset)
        {
-         gcc_assert (gcov_var.offset == 1);
          memcpy (gcov_var.buffer, gcov_var.buffer + GCOV_BLOCK_SIZE, 4);
        }
     }
@@ -399,9 +397,9 @@ gcov_write_length (gcov_position_t position)
   gcov_unsigned_t length;
   gcov_unsigned_t *buffer;
 
-  gcc_assert (gcov_var.mode < 0);
-  gcc_assert (position + 2 <= gcov_var.start + gcov_var.offset);
-  gcc_assert (position >= gcov_var.start);
+  gcov_nonruntime_assert (gcov_var.mode < 0);
+  gcov_nonruntime_assert (position + 2 <= gcov_var.start + gcov_var.offset);
+  gcov_nonruntime_assert (position >= gcov_var.start);
   offset = position - gcov_var.start;
   length = gcov_var.offset - offset - 2;
   buffer = (gcov_unsigned_t *) &gcov_var.buffer[offset];
@@ -487,14 +485,13 @@ gcov_read_words (unsigned words)
   const gcov_unsigned_t *result;
   unsigned excess = gcov_var.length - gcov_var.offset;
 
-  gcc_assert (gcov_var.mode > 0);
+  gcov_nonruntime_assert (gcov_var.mode > 0);
   if (excess < words)
     {
       gcov_var.start += gcov_var.offset;
 #if IN_LIBGCOV
       if (excess)
        {
-         gcc_assert (excess == 1);
          memcpy (gcov_var.buffer, gcov_var.buffer + gcov_var.offset, 4);
        }
 #else
@@ -503,7 +500,6 @@ gcov_read_words (unsigned words)
       gcov_var.offset = 0;
       gcov_var.length = excess;
 #if IN_LIBGCOV
-      gcc_assert (!gcov_var.length || gcov_var.length == 1);
       excess = GCOV_BLOCK_SIZE;
 #else
       if (gcov_var.length + words > gcov_var.alloc)
@@ -620,7 +616,9 @@ gcov_read_summary (struct gcov_summary *summary)
           while (!cur_bitvector)
             {
               h_ix = bv_ix * 32;
-              gcc_assert (bv_ix < GCOV_HISTOGRAM_BITVECTOR_SIZE);
+              if (bv_ix >= GCOV_HISTOGRAM_BITVECTOR_SIZE)
+                gcov_error ("corrupted profile info: summary histogram "
+                            "bitvector is corrupt");
               cur_bitvector = histo_bitvector[bv_ix++];
             }
           while (!(cur_bitvector & 0x1))
@@ -628,7 +626,9 @@ gcov_read_summary (struct gcov_summary *summary)
               h_ix++;
               cur_bitvector >>= 1;
             }
-          gcc_assert (h_ix < GCOV_HISTOGRAM_SIZE);
+          if (h_ix >= GCOV_HISTOGRAM_SIZE)
+            gcov_error ("corrupted profile info: summary histogram "
+                        "index is corrupt");
 
           csum->histogram[h_ix].num_counters = gcov_read_unsigned ();
           csum->histogram[h_ix].min_value = gcov_read_counter ();
@@ -648,7 +648,7 @@ gcov_read_summary (struct gcov_summary *summary)
 GCOV_LINKAGE void
 gcov_sync (gcov_position_t base, gcov_unsigned_t length)
 {
-  gcc_assert (gcov_var.mode > 0);
+  gcov_nonruntime_assert (gcov_var.mode > 0);
   base += length;
   if (base - gcov_var.start <= gcov_var.length)
     gcov_var.offset = base - gcov_var.start;
@@ -667,7 +667,6 @@ gcov_sync (gcov_position_t base, gcov_unsigned_t length)
 GCOV_LINKAGE void
 gcov_seek (gcov_position_t base)
 {
-  gcc_assert (gcov_var.mode < 0);
   if (gcov_var.offset)
     gcov_write_block (gcov_var.offset);
   fseek (gcov_var.file, base << 2, SEEK_SET);
@@ -742,7 +741,7 @@ gcov_histo_index (gcov_type value)
   if (r < 2)
     return (unsigned)value;
 
-  gcc_assert (r < 64);
+  gcov_nonruntime_assert (r < 64);
 
   /* Find the two next most significant bits to determine which
      of the four linear sub-buckets to select.  */
@@ -859,7 +858,7 @@ static void gcov_histogram_merge (gcov_bucket_type *tgt_histo,
           /* The merged counters get placed in the new merged histogram
              at the entry for the merged min_value.  */
           tmp_i = gcov_histo_index (merge_min);
-          gcc_assert (tmp_i < GCOV_HISTOGRAM_SIZE);
+          gcov_nonruntime_assert (tmp_i < GCOV_HISTOGRAM_SIZE);
           tmp_histo[tmp_i].num_counters += merge_num;
           tmp_histo[tmp_i].cum_value += merge_cum;
           if (!tmp_histo[tmp_i].min_value ||
@@ -873,7 +872,7 @@ static void gcov_histogram_merge (gcov_bucket_type *tgt_histo,
         }
     }
 
-  gcc_assert (tgt_i < 0);
+  gcov_nonruntime_assert (tgt_i < 0);
 
   /* In the case where there were more counters in the source histogram,
      accumulate the remaining unmerged cumulative counter values. Add
@@ -890,8 +889,8 @@ static void gcov_histogram_merge (gcov_bucket_type *tgt_histo,
     }
   /* At this point, tmp_i should be the smallest non-zero entry in the
      tmp_histo.  */
-  gcc_assert (tmp_i >= 0 && tmp_i < GCOV_HISTOGRAM_SIZE
-             && tmp_histo[tmp_i].num_counters > 0);
+  gcov_nonruntime_assert (tmp_i >= 0 && tmp_i < GCOV_HISTOGRAM_SIZE
+                          && tmp_histo[tmp_i].num_counters > 0);
   tmp_histo[tmp_i].cum_value += src_cum;
 
   /* Finally, copy the merged histogram into tgt_histo.  */
@@ -1003,6 +1002,6 @@ compute_working_sets (const struct gcov_ctr_summary *summary,
          using a temporary above.  */
       cum += histo_bucket->cum_value;
     }
-  gcc_assert (ws_ix == NUM_GCOV_WORKING_SETS);
+  gcov_nonruntime_assert (ws_ix == NUM_GCOV_WORKING_SETS);
 }
 #endif /* IN_GCOV <= 0 && !IN_LIBGCOV */
index cbf95cfc5523cb04f9714d860aff14931a8ae340..1a9f07694e8f006caf45cffb322200a5ab1a0a1f 100644 (file)
@@ -195,6 +195,13 @@ typedef unsigned HOST_WIDEST_INT gcov_type_unsigned;
 #define GCOV_LINKAGE extern
 #endif
 
+#if IN_LIBGCOV
+#define gcov_nonruntime_assert(EXPR) ((void)(0 && (EXPR)))
+#else
+#define gcov_nonruntime_assert(EXPR) gcc_assert (EXPR)
+#define gcov_error(...) fatal_error (__VA_ARGS__)
+#endif
+
 /* File suffixes.  */
 #define GCOV_DATA_SUFFIX ".gcda"
 #define GCOV_NOTE_SUFFIX ".gcno"
index d7b93e8215b279f44ff641a44a95a7dc2cc089f8..345472c4a29d91f4e30229feb9fcdee3d6bac9e7 100644 (file)
@@ -1,3 +1,8 @@
+2014-05-22  Teresa Johnson  <tejohnson@google.com>
+
+       * libgcov-driver.c (gcov_error): Move declaration before gcov-io.c
+       include.
+
 2014-05-20  John Marino  <gnugcc@marino.st>
 
        * config.host (*-*-dragonfly*): New target.
index f8abdb1e8ac5fff52326c75c7f5da1f968117db9..ef0505e617e03876f7234c44209ebee4ab6c957d 100644 (file)
@@ -42,6 +42,10 @@ void __gcov_init (struct gcov_info *p __attribute__ ((unused))) {}
 #endif
 
 #ifdef L_gcov
+
+/* A utility function for outputing errors.  */
+static int gcov_error (const char *, ...);
+
 #include "gcov-io.c"
 
 /* The following functions can be called from outside of this file.  */
@@ -108,9 +112,6 @@ reset_gcov_dump_complete (void)
   gcov_dump_complete = 0;
 }
 
-/* A utility function for outputing errors.  */
-static int gcov_error (const char *, ...);
-
 static struct gcov_fn_buffer *
 free_fn_data (const struct gcov_info *gi_ptr, struct gcov_fn_buffer *buffer,
               unsigned limit)