1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Inroduced garbage collector. Disabled by default

This commit is contained in:
2006-01-30 22:09:13 +01:00
parent 41e8570e64
commit 4aaafc4716
6 changed files with 90 additions and 6 deletions

View File

@ -114,6 +114,7 @@ CONFIG_FINGER = @CONFIG_FINGER@
CONFIG_FORMHIST = @CONFIG_FORMHIST@ CONFIG_FORMHIST = @CONFIG_FORMHIST@
CONFIG_FSP = @CONFIG_FSP@ CONFIG_FSP = @CONFIG_FSP@
CONFIG_FTP = @CONFIG_FTP@ CONFIG_FTP = @CONFIG_FTP@
CONFIG_GC = @CONFIG_GC@
CONFIG_GLOBHIST = @CONFIG_GLOBHIST@ CONFIG_GLOBHIST = @CONFIG_GLOBHIST@
CONFIG_GNUTLS = @CONFIG_GNUTLS@ CONFIG_GNUTLS = @CONFIG_GNUTLS@
CONFIG_GNUTLS_OPENSSL_COMPAT = @CONFIG_GNUTLS_OPENSSL_COMPAT@ CONFIG_GNUTLS_OPENSSL_COMPAT = @CONFIG_GNUTLS_OPENSSL_COMPAT@

View File

@ -1253,6 +1253,26 @@ EL_ARG_ENABLE(CONFIG_OWN_LIBC, own-libc, [Own libc stubs],
EL_ARG_ENABLE(CONFIG_SMALL, small, [Small binary], EL_ARG_ENABLE(CONFIG_SMALL, small, [Small binary],
[ --enable-small reduce binary size as far as possible (but see the bottom of doc/small.txt!)]) [ --enable-small reduce binary size as far as possible (but see the bottom of doc/small.txt!)])
EL_ARG_ENABLE(CONFIG_GC, gc, [Garbage collector],
[ --enable-gc enable Boehm's garbage collector])
EL_SAVE_FLAGS
if test "x${enable_gc}" = xyes; then
CFLAGS="$CFLAGS -I/usr/include/gc"
# -lgc might already be added by SEE
AC_TRY_LINK([#include <gc.h>
], [void *p = GC_MALLOC(1);], CONFIG_GC=yes, CONFIG_GC=no)
if test "$CONFIG_GC" != yes; then
LIBS="$LIBS -lgc"
AC_TRY_LINK([#include <gc.h>
], [void *p = GC_MALLOC(1);], CONFIG_GC=yes, CONFIG_GC=no)
fi
if test "$CONFIG_GC" != yes; then
EL_RESTORE_FLAGS
fi
fi
AC_SUBST(CONFIG_GC)
AC_ARG_ENABLE(weehoofooboomookerchoo, AC_ARG_ENABLE(weehoofooboomookerchoo,
[ [
Also check out the features.conf file for more information about features! Also check out the features.conf file for more information about features!

View File

@ -336,9 +336,21 @@ check_if_root(void)
#define check_if_root() #define check_if_root()
#endif #endif
#ifdef CONFIG_GC
static void
gc_warning(char *msg, GC_word arg)
{
}
#endif
int int
main(int argc, char *argv[]) main(int argc, char *argv[])
{ {
#ifdef CONFIG_GC
GC_INIT();
GC_set_warn_proc(gc_warning);
#endif
check_if_root(); check_if_root();
program.terminate = 0; program.terminate = 0;

View File

@ -319,7 +319,11 @@ debug_mem_alloc(unsigned char *file, int line, size_t size)
true_size = SIZE_BASE2AH(size); true_size = SIZE_BASE2AH(size);
do { do {
#ifdef CONFIG_GC
ah = GC_MALLOC(true_size);
#else
ah = malloc(true_size); ah = malloc(true_size);
#endif
if (ah) break; if (ah) break;
} while (patience(file, line, "malloc")); } while (patience(file, line, "malloc"));
if (!ah) return NULL; if (!ah) return NULL;
@ -368,7 +372,11 @@ debug_mem_calloc(unsigned char *file, int line, size_t eltcount, size_t eltsize)
true_size = SIZE_BASE2AH(size); true_size = SIZE_BASE2AH(size);
do { do {
ah = calloc(1, SIZE_BASE2AH(size)); #ifdef CONFIG_GC
ah = GC_MALLOC(true_size);
#else
ah = calloc(1, true_size);
#endif
if (ah) break; if (ah) break;
} while (patience(file, line, "calloc")); } while (patience(file, line, "calloc"));
if (!ah) return NULL; if (!ah) return NULL;
@ -450,7 +458,11 @@ debug_mem_free(unsigned char *file, int line, void *ptr)
if (ah->comment) { if (ah->comment) {
mem_stats.true_amount -= strlen(ah->comment) + 1; mem_stats.true_amount -= strlen(ah->comment) + 1;
#ifdef CONFIG_GC
ah->comment = NULL;
#else
free(ah->comment); free(ah->comment);
#endif
} }
del_from_list(ah); del_from_list(ah);
@ -465,7 +477,11 @@ debug_mem_free(unsigned char *file, int line, void *ptr)
ah->magic = AH_FREE_MAGIC; ah->magic = AH_FREE_MAGIC;
#endif #endif
#ifdef CONFIG_GC
ah = NULL;
#else
free(ah); free(ah);
#endif
} }
void * void *
@ -502,7 +518,11 @@ debug_mem_realloc(unsigned char *file, int line, void *ptr, size_t size)
true_size = SIZE_BASE2AH(size); true_size = SIZE_BASE2AH(size);
do { do {
#ifdef CONFIG_GC
ah2 = GC_REALLOC(ah, true_size);
#else
ah2 = realloc(ah, true_size); ah2 = realloc(ah, true_size);
#endif
if (ah2) { if (ah2) {
ah = ah2; ah = ah2;
break; break;
@ -546,10 +566,17 @@ set_mem_comment(void *ptr, unsigned char *str, int len)
if (ah->comment) { if (ah->comment) {
mem_stats.true_amount -= strlen(ah->comment) + 1; mem_stats.true_amount -= strlen(ah->comment) + 1;
#ifdef CONFIG_GC
ah->comment = NULL;
#else
free(ah->comment); free(ah->comment);
#endif
} }
#ifdef CONFIG_GC
ah->comment = GC_MALLOC(len + 1);
#else
ah->comment = malloc(len + 1); ah->comment = malloc(len + 1);
#endif
if (ah->comment) { if (ah->comment) {
memcpy(ah->comment, str, len); memcpy(ah->comment, str, len);
ah->comment[len] = 0; ah->comment[len] = 0;

View File

@ -55,8 +55,11 @@ mem_alloc(size_t size)
{ {
if (size) if (size)
do { do {
#ifdef CONFIG_GC
void *p = GC_MALLOC(size);
#else
void *p = malloc(size); void *p = malloc(size);
#endif
if (p) return p; if (p) return p;
} while (patience("malloc")); } while (patience("malloc"));
@ -68,8 +71,11 @@ mem_calloc(size_t count, size_t eltsize)
{ {
if (eltsize && count) if (eltsize && count)
do { do {
#ifdef CONFIG_GC
void *p = GC_MALLOC(count * eltsize);
#else
void *p = calloc(count, eltsize); void *p = calloc(count, eltsize);
#endif
if (p) return p; if (p) return p;
} while (patience("calloc")); } while (patience("calloc"));
@ -83,8 +89,11 @@ mem_free(void *p)
INTERNAL("mem_free(NULL)"); INTERNAL("mem_free(NULL)");
return; return;
} }
#ifdef CONFIG_GC
p = NULL;
#else
free(p); free(p);
#endif
} }
void * void *
@ -94,8 +103,11 @@ mem_realloc(void *p, size_t size)
if (size) if (size)
do { do {
#ifdef CONFIG_GC
void *p2 = GC_REALLOC(p, size);
#else
void *p2 = realloc(p, size); void *p2 = realloc(p, size);
#endif
if (p2) return p2; if (p2) return p2;
} while (patience("realloc")); } while (patience("realloc"));
else else

View File

@ -20,6 +20,10 @@
#include <sys/types.h> #include <sys/types.h>
#include <stddef.h> #include <stddef.h>
#ifdef CONFIG_GC
#include <gc.h>
#endif
#ifdef HAVE_MMAP #ifdef HAVE_MMAP
void *mem_mmap_alloc(size_t size); void *mem_mmap_alloc(size_t size);
void mem_mmap_free(void *p, size_t size); void mem_mmap_free(void *p, size_t size);
@ -62,12 +66,20 @@ void *mem_realloc(void *, size_t);
* For these we need some replacement functions. * For these we need some replacement functions.
* This should not be an issue on most modern systems. * This should not be an issue on most modern systems.
*/ */
#ifdef CONFIG_GC
# define mem_alloc(size) GC_MALLOC(size)
# define mem_calloc(count, size) GC_MALLOC((count) * (size))
# define mem_free(p) (p) = NULL
# define mem_realloc(p, size) GC_REALLOC(p, size)
#else
# define mem_alloc(size) malloc(size) # define mem_alloc(size) malloc(size)
# define mem_calloc(count, size) calloc(count, size) # define mem_calloc(count, size) calloc(count, size)
# define mem_free(p) free(p) # define mem_free(p) free(p)
# define mem_realloc(p, size) realloc(p, size) # define mem_realloc(p, size) realloc(p, size)
#endif
/* fmem_* functions should be use for allocation and freeing of memory /* fmem_* functions should be use for allocation and freeing of memory
* inside a function. * inside a function.