We run a webmail service and use clamdscan/clamd in mbox mode to scan
incoming messages.  Every so often certain messages will cause clamd to
hang (not crash, but just hang indefinitely), which causes all of our
incoming mail to back up.  It appears as if certain SPAM messages are
causing this behavior -- and they also cause clamscan to segfault.

I recompiled clamscan 0.60 in debug mode and ran it against one of the
messages that presumably caused clamd to hang.  As expected, clamscan
segfaulted and clamd just hung.  BTW, this same behavior was occuring
under previous versions of clamav.

Any suggestions?

The message causing the segfault is attached.  Here is the debug output:

-----
wallace:/tmp/scan2# clamscan --mbox /tmp/scan3/mboxscan-qmail.ufpwAg
LibClamAV debug: Loading databases from /var/lib/clamav/
LibClamAV debug: Loading /var/lib/clamav//viruses.db2
LibClamAV debug: Initializing trie.
LibClamAV debug: Loading /var/lib/clamav//viruses.db
LibClamAV debug: Recognized mail file.
LibClamAV debug: in mbox()
LibClamAV debug: Finished processing message
LibClamAV debug: continuationMarker(Return-Path:
<[EMAIL PROTECTED]>
)
LibClamAV debug: parseMimeHeader: cmd='Return-Path:',
arg='<[EMAIL PROTECTED]>'
LibClamAV debug: continuationMarker(Delivered-To:
[EMAIL PROTECTED]
)
LibClamAV debug: parseMimeHeader: cmd='Delivered-To:',
arg='[EMAIL PROTECTED]'
LibClamAV debug: continuationMarker(Received: (qmail 30491 invoked from
network); 22 Jun 2003 10:17:26 -0000
)
LibClamAV debug: parseMimeHeader: cmd='Received:', arg='(qmail 30491
invoked from network); 22 Jun 2003 10:17:26 -0000'
LibClamAV debug: continuationMarker(Received: from unknown (HELO
big53.bigemailoffers.com) (216.93.191.53)
)
LibClamAV debug: parseMimeHeader: cmd='Received:', arg='from unknown (HELO
big53.bigemailoffers.com) (216.93.191.53)'
LibClamAV debug: continuationMarker(  by 0 with SMTP; 22 Jun 2003 10:17:26
-0000
)
LibClamAV debug: parseMimeHeader: cmd='by', arg='0 with SMTP; 22 Jun 2003
10:17:26 -0000'
LibClamAV debug: continuationMarker(Received: by big53.bigemailoffers.com
(PowerMTA(TM) v1.5); Sun, 22 Jun 2003 03:05:07 -0700 (envelope-from
<[EMAIL PROTECTED]>)
)
LibClamAV debug: parseMimeHeader: cmd='Received:', arg='by
big53.bigemailoffers.com (PowerMTA(TM) v1.5); Sun, 22 Jun 2003 03:05:07
-0700 (envelope-from <[EMAIL PROTECTED]>)'
LibClamAV debug: continuationMarker(Subject: Take part in our software
giveaway
)
LibClamAV debug: parseMimeHeader: cmd='Subject:', arg='Take part in our
software giveaway'
LibClamAV debug: continuationMarker(From: Video
Professor<[EMAIL PROTECTED]>
)
LibClamAV debug: parseMimeHeader: cmd='From:', arg='Video
Professor<[EMAIL PROTECTED]>'
LibClamAV debug: continuationMarker(To: [EMAIL PROTECTED]
)
LibClamAV debug: parseMimeHeader: cmd='To:',
arg='[EMAIL PROTECTED]'
LibClamAV debug: continuationMarker(MIME-Version: 1.0
)
LibClamAV debug: parseMimeHeader: cmd='MIME-Version:', arg='1.0'
LibClamAV debug: continuationMarker(Content-Type: multipart/alternative;
boundary="_NextPart_6345643_boundary"
)
LibClamAV debug: parseMimeHeader: cmd='Content-Type:',
arg='multipart/alternative; boundary="_NextPart_6345643_boundary"'
LibClamAV debug: messageSetMimeType: 'multipart'
LibClamAV debug: Add argument 'boundary="_NextPart_6345643_boundary"'
LibClamAV debug: continuationMarker(Date: Sun, 22 Jun 2003 03:05:07 -0700
)
LibClamAV debug: parseMimeHeader: cmd='Date:', arg='Sun, 22 Jun 2003
03:05:07 -0700'
LibClamAV debug: End of header information
LibClamAV debug: in insert(nBlobs = 0)
LibClamAV debug: messageFindArgument: compare 8 bytes of boundary with
boundary="_NextPart_6345643_boundary"
LibClamAV debug: found _NextPart_6345643_boundary in
--_NextPart_6345643_boundary
LibClamAV debug: Now read in part 0
LibClamAV debug: continuationMarker(Content-Type: text/plain;
charset:ISO-8859-1)
LibClamAV debug: insert content-type: parse line 'Content-Type:
text/plain; charset:ISO-8859-1'
LibClamAV debug: messageSetMimeType: 'text'
LibClamAV debug: Add arguments ' charset:ISO-8859-1'
clamscan: message.c:277: messageAddArguments: Assertion `string != ((void
*)0)' failed.
Aborted (core dumped)
-----


Reply via email to