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:
parent
41e8570e64
commit
4aaafc4716
@ -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@
|
||||||
|
20
configure.in
20
configure.in
@ -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!
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user