aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Henderson <rth@cygnus.com>1999-09-27 23:05:53 -0700
committerRichard Henderson <rth@gcc.gnu.org>1999-09-27 23:05:53 -0700
commita70261eec1b9b6f3a985e84763d465ceaf387175 (patch)
tree5580dcc183ad9c8931308296e2c2f1646ee368b2 /gcc
parent82bd61bdd4c210078a8e25ae894b0f44a297bb72 (diff)
downloadgcc-a70261eec1b9b6f3a985e84763d465ceaf387175.zip
gcc-a70261eec1b9b6f3a985e84763d465ceaf387175.tar.gz
gcc-a70261eec1b9b6f3a985e84763d465ceaf387175.tar.bz2
ggc-page.c (GGC_MIN_LAST_ALLOCATED): New.
* ggc-page.c (GGC_MIN_LAST_ALLOCATED): New. (init_ggc): Use it instead of a constant. (ggc_collect): Bound allocated_last_gc by it. From-SVN: r29685
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/ggc-page.c10
2 files changed, 13 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7c1d114..23c794a 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+Mon Sep 27 23:03:16 1999 Richard Henderson <rth@cygnus.com>
+
+ * ggc-page.c (GGC_MIN_LAST_ALLOCATED): New.
+ (init_ggc): Use it instead of a constant.
+ (ggc_collect): Bound allocated_last_gc by it.
+
Mon Sep 27 19:06:04 1999 Jeffrey A Law (law@cygnus.com)
* fixinc/fixinc.irix (stdio.h): Hack stdio.h to avoid problems
diff --git a/gcc/ggc-page.c b/gcc/ggc-page.c
index b5a2899..54528a5 100644
--- a/gcc/ggc-page.c
+++ b/gcc/ggc-page.c
@@ -255,6 +255,10 @@ static struct globals
one) before collection is performed. */
#define GGC_MIN_EXPAND_FOR_GC (1.3)
+/* Bound `allocated_last_gc' to 4MB, to prevent the memory expansion
+ test from triggering too often when the heap is small. */
+#define GGC_MIN_LAST_ALLOCATED (4 * 1024 * 1024)
+
static page_entry *lookup_page_table_entry PROTO ((void *));
static void set_page_table_entry PROTO ((void *, page_entry *));
@@ -724,9 +728,7 @@ init_ggc ()
G.debug_file = stdout;
#endif
- /* Set the initial allocation to 4MB, so no collection will be
- performed until the heap is somewhat larger than 4 MB. */
- G.allocated_last_gc = 4 * 1024 * 1024;
+ G.allocated_last_gc = GGC_MIN_LAST_ALLOCATED;
empty_string = ggc_alloc_string ("", 0);
ggc_add_string_root (&empty_string, 1);
@@ -1034,6 +1036,8 @@ ggc_collect ()
#endif
G.allocated_last_gc = G.allocated;
+ if (G.allocated_last_gc < GGC_MIN_LAST_ALLOCATED)
+ G.allocated_last_gc = GGC_MIN_LAST_ALLOCATED;
time = get_run_time () - time;
gc_time += time;