Summary: | libpbl-1.03 (databases/libpbl) is broken, spamprobe-1.4d_1 (mail/spamprobe) does not work at all with a pbl file | ||||||||
---|---|---|---|---|---|---|---|---|---|
Product: | Ports & Packages | Reporter: | kenji.rikitake | ||||||
Component: | Individual Port(s) | Assignee: | Stefan Walter <stefan> | ||||||
Status: | Closed FIXED | ||||||||
Severity: | Affects Only Me | ||||||||
Priority: | Normal | ||||||||
Version: | Latest | ||||||||
Hardware: | Any | ||||||||
OS: | Any | ||||||||
Attachments: |
|
Description
kenji.rikitake
2009-01-06 15:40:01 UTC
Maintainer of databases/libpbl, Please note that PR ports/130236 has just been submitted. If it contains a patch for an upgrade, an enhancement or a bug fix you agree on, reply to this email stating that you approve the patch and a committer will take care of it. The full text of the PR can be found at: http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/130236 -- Edwin Groothuis via the GNATS Auto Assign Tool edwin@FreeBSD.org State Changed From-To: open->feedback Awaiting maintainers feedback (via the GNATS Auto Assign Tool) Responsible Changed From-To: freebsd-ports-bugs->stefan Take. Hi Kenji, I maintain mail/spamprobe. On my 7.1-RELEASE i386 system, I get the same warnings when compiling libpbl. However, I use spamprobe with a libpbl database all the time and still cannot reproduce any problem with it. (I just rebuilt libpbl and spamprobe and created a new database to be sure - no problem here.) Can you please explain in detail what you are doing and what problems you are facing so I can try to reproduce that? Regards, Stefan Hello Stefan: I was trying to open a very large pbl database (approx. 200Mbytes) and I could no longer open it anymore, after I upgraded the system from 6.4-RELEASE to 7.1-RELEASE on i386. I'll try to retrieve the database I was using from my past backup. Give me a little time. Regards, Kenji Rikitake Hello Stefan: I got the database back from the past archive. The error is reproduced as follows. reseaux[1]% pwd /var/tmp/kenji/.spamprobe reseaux[2]% ls -l total 216656 -rw------- 1 kenji k2r 0 Jan 9 18:01 lock -rw------- 1 kenji k2r 221712384 Dec 31 18:55 sp_words.pkey reseaux[3]% spamprobe-withpbl -d /var/tmp/kenji/.spamprobe/ export caught runtime exception: pblKfGetAbs: Cannot allocate memory (12) reseaux[4]% The tcsh limit command says: reseaux[13]% limit cputime unlimited filesize unlimited datasize 524288 kbytes stacksize 65536 kbytes coredumpsize 0 kbytes memoryuse unlimited vmemoryuse unlimited descriptors 14781 memorylocked unlimited maxproc 7390 sbsize unlimited The error was same as I compiled the libpbl-1.03 and spamprobe-1.4d_1 by 7.1-RELEASE-stock gcc-4.2.1 and gcc42 (gcc 4.2.5 20081126). I will try what happens when the two ports are compiled with gcc34, but I need to build the gcc34 by myself first, so please give me a time again. Regards, Kenji Rikitake PS: I was a bit shocked when I found out the 220Mbyte database content was no longer useful. That was the reason I classified the PR "critical." Kenji Rikitake, 09.01.09, 09:46h CET: > Hello Stefan: > > I was trying to open a very large pbl database (approx. 200Mbytes) and I > could no longer open it anymore, after I upgraded the system from > 6.4-RELEASE to 7.1-RELEASE on i386. I'll try to retrieve the database I > was using from my past backup. Give me a little time. Sure, thanks for your feedback! Since you mentioned a large pbl db, it might be you're hitting a limit there - see [1]. If you find out anything, let me know. Regards, Stefan [1]: http://sourceforge.net/mailarchive/forum.php?thread_name=495E45E8.5060800%40schuerger.com&forum_name=spamprobe-users Stefan: thanks for the info. I'll try rebuilding the libpbl-1.03 with the -DPBLFILEBLOCKS=0x3ffff option. Retrieving the past spam database is worth trying. Regards, Kenji Rikitake Hello again Stefan: -DPBLFILEBLOCKS=0x3ffff for libpbl didn't work with stock gcc 4.2.1. I built the gcc34 from the port. I tried building the libpbl-1.03 and spamprobe-1.4d with gcc34 by specifying USE_GCC=3.4 in the port Makefiles. The result was as follows (to extract the 220Mbyte database with "spamprobe export"): (libpbl in stock gcc 4.2.1) and (spamprobe in stock gcc 4.2.1): didn't work (libpbl in gcc34) and (spamprobe in stock gcc 4.2.1): didn't work (libpbl in gcc34) and (spamprobe in gcc34): worked! I suspect there's something different on the memory allocation between gcc34 and stock gcc 4.2.1. All the above cases are tested on 7.1-RELEASE i386. FYI. Kenji Rikitake Kenji Rikitake, 09.01.09, 11:07h CET:
> Hello again Stefan:
>
> -DPBLFILEBLOCKS=0x3ffff for libpbl didn't work with stock gcc 4.2.1.
>
> I built the gcc34 from the port.
>
> I tried building the libpbl-1.03 and spamprobe-1.4d with gcc34
> by specifying USE_GCC=3.4 in the port Makefiles.
> The result was as follows
> (to extract the 220Mbyte database with "spamprobe export"):
>
> (libpbl in stock gcc 4.2.1) and (spamprobe in stock gcc 4.2.1): didn't work
> (libpbl in gcc34) and (spamprobe in stock gcc 4.2.1): didn't work
> (libpbl in gcc34) and (spamprobe in gcc34): worked!
>
> I suspect there's something different on the memory allocation
> between gcc34 and stock gcc 4.2.1.
>
> All the above cases are tested on 7.1-RELEASE i386.
Thanks for the info! I'll look at this a bit closer soon (hopefully...).
Regards,
Stefan
Hi Kenji, hi Zach, I suspect the real problem are the "differ in signedness" errors that you see when compiling libpbl with gcc 4.2.1. I guess that the declaration of some variables in the libpbl source code as 'signed' or 'unsigned' (explicitly or implicitly) is incorrect, so the solution would be to fix those declarations. At the moment, it doesn't look like I'll have the time to work on this soon, but if anyone of you is willing to work on this, I'd be willing to check patches and commit them. Best regards, Stefan Stefan Walter (Tue 01/27/09 08:30):
> Hi Kenji, hi Zach,
>
> I suspect the real problem are the "differ in signedness" errors that you
> see when compiling libpbl with gcc 4.2.1. I guess that the declaration of
> some variables in the libpbl source code as 'signed' or 'unsigned'
> (explicitly or implicitly) is incorrect, so the solution would be to fix
> those declarations.
>
> At the moment, it doesn't look like I'll have the time to work on this
> soon, but if anyone of you is willing to work on this, I'd be willing to
> check patches and commit them.
>
> Best regards,
> Stefan
Though I can "fix" signedness warnings I don't have time to verify
that the hundreds of casts necessary won't break something else. I can
see if the author is interested in updating it for gcc 4+ but for the
time being perhaps it's best if we mark it broken. Shall I submit a
patch for this?
Zach
Hi Zach,
Zach Thompson, 28.01.09, 04:55h CET:
> Though I can "fix" signedness warnings I don't have time to verify
> that the hundreds of casts necessary won't break something else. I can
> see if the author is interested in updating it for gcc 4+ but for the
> time being perhaps it's best if we mark it broken. Shall I submit a
> patch for this?
hm...it's only broken with gcc 4.x as it seems, so adding USE_GCC=3.4
would help libpbl - I don't see any signedness warnings there, and Kenji
reported spamprobe works in that case (when compiled with gcc 3.4, too).
On the other hand, I'm a bit reluctant to add the necessary dependency on
gcc 3.4 to the spamprobe port since it's pretty heavy-weight. Furthermore,
the problem seems to exist with databases >200 megabytes only; mine
doesn't grow beyond ~35 megabytes.
My suggestion would be the following:
- I mark databases/libpbl as broken for now.
- You contact libpbl's author and see if we can get a fix for the problem
soon. (There aren't that many signedness warnings, so maybe we're lucky
and it's not too much work.)
- If we get a fix, we apply it; if not, we'll add a dependency on gcc 3.4
to libpbl and spamprobe (when compiled with support for libpbl).
Can we agree on this for now?
Best regards,
Stefan
Stefan and all: I think this decision is rational and acceptable. One clarification: spamprobe without libppl works OK with gcc 4.x. Regards, Kenji Rikitake In the message <20090128073528.GA2300@kyuzo.dunkelkammer.void> dated Wed, Jan 28, 2009 at 08:35:04AM +0100, Stefan Walter <stefan@FreeBSD.org> writes: > My suggestion would be the following: > > - I mark databases/libpbl as broken for now. > - You contact libpbl's author and see if we can get a fix for the problem > soon. (There aren't that many signedness warnings, so maybe we're lucky > and it's not too much work.) > - If we get a fix, we apply it; if not, we'll add a dependency on gcc 3.4 > to libpbl and spamprobe (when compiled with support for libpbl). > > Can we agree on this for now? > > Best regards, > Stefan Stefan Walter (Wed 01/28/09 08:35):
> Hi Zach,
>
> Zach Thompson, 28.01.09, 04:55h CET:
>
> > Though I can "fix" signedness warnings I don't have time to verify
> > that the hundreds of casts necessary won't break something else. I can
> > see if the author is interested in updating it for gcc 4+ but for the
> > time being perhaps it's best if we mark it broken. Shall I submit a
> > patch for this?
>
> hm...it's only broken with gcc 4.x as it seems, so adding USE_GCC=3.4
> would help libpbl - I don't see any signedness warnings there, and Kenji
> reported spamprobe works in that case (when compiled with gcc 3.4, too).
> On the other hand, I'm a bit reluctant to add the necessary dependency on
> gcc 3.4 to the spamprobe port since it's pretty heavy-weight. Furthermore,
> the problem seems to exist with databases >200 megabytes only; mine
> doesn't grow beyond ~35 megabytes.
>
> My suggestion would be the following:
>
> - I mark databases/libpbl as broken for now.
> - You contact libpbl's author and see if we can get a fix for the problem
> soon. (There aren't that many signedness warnings, so maybe we're lucky
> and it's not too much work.)
> - If we get a fix, we apply it; if not, we'll add a dependency on gcc 3.4
> to libpbl and spamprobe (when compiled with support for libpbl).
>
> Can we agree on this for now?
>
> Best regards,
> Stefan
Stefan,
Sounds good to me.
Zach
stefan 2009-02-02 14:23:18 UTC FreeBSD ports repository Modified files: databases/libpbl Makefile Log: Mark as BROKEN on OSVERSION >= 700000 for now: does not work with databases bigger than ~200 MB. PR: 130236 Submitted by: Kenji Rikitake <kenji.rikitake@acm.org> Approved by: maintainer Revision Changes Path 1.8 +7 -1 ports/databases/libpbl/Makefile _______________________________________________ cvs-all@freebsd.org mailing list http://lists.freebsd.org/mailman/listinfo/cvs-all To unsubscribe, send any mail to "cvs-all-unsubscribe@freebsd.org" Hi Zach, any news on this issue? Have you heard anything from libpbl's author, yet? Regards, Stefan Stefan Walter (Thu 02/05/09 09:07):
> Hi Zach,
>
> any news on this issue? Have you heard anything from libpbl's author, yet?
>
> Regards,
> Stefan
Hi Stefan,
Unfortunately I haven't heard from Peter yet. Didn't have any luck
fixing the problem myself yet either, though I have gotten it to
compile without warnings.
Zach
Zach Thompson (Thu 02/05/09 06:32):
> Stefan Walter (Thu 02/05/09 09:07):
> > Hi Zach,
> >
> > any news on this issue? Have you heard anything from libpbl's author, yet?
> >
> > Regards,
> > Stefan
>
> Hi Stefan,
>
> Unfortunately I haven't heard from Peter yet. Didn't have any luck
> fixing the problem myself yet either, though I have gotten it to
> compile without warnings.
>
> Zach
Just thought I'd pass along that I heard from the author (Peter Graf)
of libpbl today. He will look at getting it to work with gcc 4.2 but
probably won't be able to get back to me until the end of March.
Zach
Hi Zach,
Zach Thompson, 02.03.09, 23:47h CET:
> Just thought I'd pass along that I heard from the author (Peter Graf)
> of libpbl today. He will look at getting it to work with gcc 4.2 but
> probably won't be able to get back to me until the end of March.
have you heard anything, yet?
Regards,
Stefan
Hi Zach, sorry for the very late reply. I somehow managed to defer this PR repeatedly... Zach Thompson, 12.08.09, 21:52h CEST: > Yes, Peter updated libpbl to 1.04 and sent me an email back on March > 15th. I updated the port locally and tested. However, I still got > the same signedness errors and ultimately the same error when used via > Spamprobe. Though I sent him a follow-up I still haven't heard anything. I guess this hasn't changed in the meantime? Was he able to reproduce the problem? > I guess I've done about as much as I can do on this port. Perhaps > someone with more C experience than me can figure out how to patch it. Unfortunately, I haven't had much time for FreeBSD related work, and probably won't be having any soon, so I still can't help here. Maybe someone on the ports mailing list can help. The best choice for those who have large databases would be to use one of the other backends in spamprobe for the moment, I guess. Regards, Stefan Hello Peter, at [1], there's a problem report concerning the FreeBSD port of PBL. It looks like the problem described there is related to signedness issues that somehow were not a problem with older gcc versions, but do result in problems with more recent ones. I don't think it's FreeBSD-specific - it should be reproducable on Linux systems, for instance, as well. Could you have a look at the problem description in the report and maybe provide some feedback regarding its solution? Best regards, Stefan [1]: http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/130236 Hello Stefan I will look into the matter, although last time I did, I could compile on all current gcc compilers on Ubuntu, Suse and Mac OS without any warnings, and somebody from your group still reported problems on FreeBSD. Maybe this time I install FreeBSD myself. but I know from my schedule for the next couple of weeks that I will probably not have time in October, the week starting November 9th is the most likely the first with any spare time. Hope that helps nevertheless Greetings Peter Am 25.09.2009 um 19:08 schrieb Stefan Walter: > Hello Peter, > > at [1], there's a problem report concerning the FreeBSD port of PBL. > It > looks like the problem described there is related to signedness issues > that somehow were not a problem with older gcc versions, but do > result in > problems with more recent ones. I don't think it's FreeBSD-specific > - it > should be reproducable on Linux systems, for instance, as well. > > Could you have a look at the problem description in the report and > maybe > provide some feedback regarding its solution? > > Best regards, > Stefan > > [1]: http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/130236 ---------------------------------------------------------- Peter Graf, Peter.Graf@mission-base.com Tel: +49 (89) 2023 2149 Cell: +49 (170) 832 9632 https://www.xing.com/hp/Peter_Graf2/ http://www.mission-base.com/ skype: peter_graf http://www.freebsd.org/cgi/query-pr.cgi?pr=130236 Please, try the attached update for the port. It: 1. Updates the software to version 1.04 (the latest from author at the time of this writing). 2. Ensures warning-free build. 3. Declares the software as safe for parallel building. 4. Runs the author's bundled self-tests after building. I think, once the current urgent problem is resolved, the port should be modified to build both static and shared version of the pbl-library (using bsd.lib.mk), but that can wait. I also dislike, how the databases/libpbl port edits the author's code on the fly instead of static patches, which could've been sent to Peter (CC-ed) to spare him some work -- such as port to MacOS, for which he had to ifdef-out malloc.h, incorrectly assuming, that the include is needed somewhere else... Changing this can also wait, though. To build spamprobe against this new version of libpbl on my amd64-system, I had to add the second attachment to mail/spamprobe/files (it may not be needed on a 32-bit platform). My system is now busy importing my giant (never purged) database into PBL-format from the BDB. Things seem to work, but I'm yet to test thoroughly. Yours, -mi Hi all, I tried Mikhail's patch for the the PBL and Spamprobe ports. I can confirm that the compile time warnings with PBL are gone, and Spamprobe seems to work with a freshly created and trained PBL database, too. Zach: If you agree, I would commit it. Best regards, Stefan stefan 2009-10-06 14:52:01 UTC FreeBSD ports repository Modified files: databases/libpbl Makefile distinfo mail/spamprobe Makefile Added files: mail/spamprobe/files patch-src_database_FrequencyCBImpl_pbl.cc Log: - Update databases/libpbl to 1.04, fix compile-time warnings, declare as safe for parallel building and run bundled self-tests after building. - Patch mail/spamprobe to make it work with libpbl on amd64. PR: 130236 Submitted by: Kenji Rikitake <kenji.rikitake@acm.org> Patch by: mi Approved by: Zach Thompson <hideo@lastamericanempire.com> (maintainer) Revision Changes Path 1.9 +10 -13 ports/databases/libpbl/Makefile 1.2 +3 -3 ports/databases/libpbl/distinfo 1.26 +1 -1 ports/mail/spamprobe/Makefile 1.1 +21 -0 ports/mail/spamprobe/files/patch-src_database_FrequencyCBImpl_pbl.cc (new) _______________________________________________ cvs-all@freebsd.org mailing list http://lists.freebsd.org/mailman/listinfo/cvs-all To unsubscribe, send any mail to "cvs-all-unsubscribe@freebsd.org" State Changed From-To: feedback->closed Fixed in most recent update of libpbl/spamprobe. |