Re: memory leak in DBI XS bootstrap code
- From: Tim.Bunce@xxxxxxxxx (Tim Bunce)
- Date: Thu, 29 Jun 2006 23:00:19 +0100
On Thu, Jun 29, 2006 at 06:52:56AM -0700, Ephraim Dan wrote:
I don't see what you mean in the "INSTALL" that comes with perl 5.8.0 (that's what we're using).
The file called INSTALL in the perl source code directory.
Note that perl 5.8.0 is very old now and many significant bugs have been
fixed in later 5.8.x versions.
Can you be more specific? Would I need to build perl in a special way, or DBI, or both?
Both. Configure the new perl with a new install directory, install it,
add that dir to your PATH then build a new DBI and 'make install' it
into that new perl directory.
I was sort of hoping someone more familiar with the code might be able to pinpoint it (of course, this is always preferable to doing it myself).
I've no time, sorry. You'll have to scratch this itch yourself
(or hope that someone else has the same itch.)
Tim.
Any further pointers are appreciated....
-edan
-----Original Message-----
From: Tim Bunce [mailto:Tim.Bunce@xxxxxxxxx]
Sent: Thursday, June 29, 2006 14:47
To: Ephraim Dan
Cc: dbi-users@xxxxxxxx
Subject: Re: memory leak in DBI XS bootstrap code
Try building perl with options to make valgrind leak tracing more
effective (see perl's INSTALL file). That may help you pinpoint
the problem.
Tim.
On Thu, Jun 29, 2006 at 04:33:40AM -0700, Ephraim Dan wrote:
I am experiencing what I believe to be a memory leak in the DBIbootstrap code. This is a problem for me because I am embedding perl in a
long-running program, and DBI is being loaded over and over, so my program
grows and grows.
multi/auto/DBI/DBI.so)
The problem appears to be in the following routines:
boot_DBI (in /usr/lib/perl5/vendor_perl/5.8.0/i386-linux-thread-
XS_DBI__install_method (in /usr/lib/perl5/vendor_perl/5.8.0/i386-linux-thread-multi/auto/DBI/DBI.so)
leak using the following code:
I am using DBI 1.51
The tool "valgrind" (http://valgrind.org) can be used to reproduce the
patch to DBI 1.51 as soon as someone has one.
---
File: embed_test.c
---
#include <EXTERN.h> /* from the Perl distribution */
#include <perl.h> /* from the Perl distribution */
static PerlInterpreter *my_perl; /*** The Perl interpreter ***/
EXTERN_C void xs_init (pTHX); /*** init dyn. loading ***/
int main(int argc, char **argv, char **env)
{
char *embedding[] = { "", "-e", "0" };
my_perl = perl_alloc();
perl_construct(my_perl);
perl_parse(my_perl, xs_init, 3, embedding, (char **)NULL);
PL_exit_flags |= PERL_EXIT_DESTRUCT_END;
perl_run(my_perl);
eval_pv("use DBI", TRUE);
perl_destruct(my_perl);
perl_free(my_perl);
}
---
File: Makefile
---
CC_OPTS = $(shell perl -MExtUtils::Embed -e ccopts)
LD_OPTS = $(shell perl -MExtUtils::Embed -e ldopts)
EXE = embed_test
$(EXE): xsinit.o embed_test.o
gcc -o $(EXE) embed_test.o xsinit.o $(LD_OPTS)
embed_test.o: embed_test.c
gcc -c embed_test.c $(CC_OPTS)
xsinit.o: xsinit.c
gcc -c xsinit.c $(CC_OPTS)
xsinit.c:
perl -MExtUtils::Embed -e xsinit -- -o xsinit.c
clean:
rm -f *.o xsinit.c $(EXE)
---
EOF
---
Can anyone suggest a fix for this? I'd be more than willing to take a
Thanks,
Ephraim Dan
- Follow-Ups:
- RE: memory leak in DBI XS bootstrap code
- From: Ephraim Dan
- RE: memory leak in DBI XS bootstrap code
- References:
- RE: memory leak in DBI XS bootstrap code
- From: Ephraim Dan
- RE: memory leak in DBI XS bootstrap code
- Prev by Date: RE: Errors, Connecting to Oracle
- Next by Date: DBD::Sybase with MS SQL insert problem
- Previous by thread: RE: memory leak in DBI XS bootstrap code
- Next by thread: RE: memory leak in DBI XS bootstrap code
- Index(es):
Relevant Pages
|
|