Pascal Volk
2013-Apr-15  14:37 UTC
[Dovecot] imap Panic: file index-attachment.c: line 231 (index_attachment_save_finish): assertion failed: (attach->input->eof)
Hi Timo,
some imap processes seems to have some problems.
Regards,
Pascal
-------------- next part --------------
Core was generated by `dovecot/imap'.
Program terminated with signal 6, Aborted.
#0  0x00007fbf87b25475 in raise () from /lib/x86_64-linux-gnu/libc.so.6
(gdb) bt full
#0  0x00007fbf87b25475 in raise () from /lib/x86_64-linux-gnu/libc.so.6
No symbol table info available.
#1  0x00007fbf87b286f0 in abort () from /lib/x86_64-linux-gnu/libc.so.6
No symbol table info available.
#2  0x00007fbf87ef71c9 in default_fatal_finish (type=LOG_TYPE_PANIC, status=0)
at failures.c:191
        backtrace = 0x194bf58
"/usr/local/lib/dovecot/libdovecot.so.0(+0x7a1a2) [0x7fbf87ef71a2] ->
/usr/local/lib/dovecot/libdovecot.so.0(+0x7b4cd) [0x7fbf87ef84cd] ->
/usr/local/lib/dovecot/libdovecot.so.0(i_fatal+0) [0x7fbf87ef7"...
#3  0x00007fbf87ef84cd in i_internal_fatal_handler (ctx=0x7fffb895a7b0,
format=0x7fbf8828f4c0 "file %s: line %d (%s): assertion failed: (%s)",
args=0x7fffb895a798) at failures.c:652
        status = 0
#4  0x00007fbf87ef74a5 in i_panic (format=0x7fbf8828f4c0 "file %s: line %d
(%s): assertion failed: (%s)") at failures.c:263
        ctx = {type = LOG_TYPE_PANIC, exit_status = 0, timestamp = 0x0}
        args = {{gp_offset = 40, fp_offset = 48, overflow_arg_area =
0x7fffb895a880, reg_save_area = 0x7fffb895a7c0}}
#5  0x00007fbf8822776e in index_attachment_save_finish (ctx=0x19ed140) at
index-attachment.c:231
        attach = 0x1a0d870
        __FUNCTION__ = "index_attachment_save_finish"
#6  0x00007fbf881b3ab0 in dbox_save_end (ctx=0x19ed140) at dbox-save.c:106
        mdata = 0x19ed150
        dbox_output = 0x1a07008
        __FUNCTION__ = "dbox_save_end"
#7  0x00007fbf881aadf7 in mdbox_save_finish_write (_ctx=0x19ed140) at
mdbox-save.c:198
        ctx = 0x19ed140
        mail = 0x636c08
#8  0x00007fbf881aaf5d in mdbox_save_finish (ctx=0x19ed140) at mdbox-save.c:228
        ret = 0
#9  0x00007fbf872c505b in quota_save_finish (ctx=0x19ed140) at
quota-storage.c:281
        qbox = 0x19e0a50
#10 0x00007fbf882041f7 in mailbox_save_finish (_ctx=0x1971498) at
mail-storage.c:2022
        ctx = 0x19ed140
        t = 0x19ebdc0
        keywords = 0x0
        pvt_flags = 0
        copying_via_save = false
        ret = 0
        __FUNCTION__ = "mailbox_save_finish"
#11 0x000000000040d165 in cmd_append_continue_message (cmd=0x1971340) at
cmd-append.c:802
        all_written = true
        client = 0x1970760
        ctx = 0x1971438
        ret = 0
#12 0x000000000041a04e in command_exec (cmd=0x1971340) at imap-commands.c:156
        hook = 0x1954da0
        ret = false
#13 0x000000000040b9be in client_input_append (cmd=0x1971340) at
cmd-append.c:112
        ctx = 0x1971438
        client = 0x1970760
        reason = 0x7fbf87ef5033 "H\213\005.3'"
        finished = false
        __FUNCTION__ = "client_input_append"
#14 0x00007fbf87f0e58d in io_loop_call_io (io=0x19de2a0) at ioloop.c:387
        ioloop = 0x1953720
        t_id = 2
#15 0x00007fbf87f101ed in io_loop_handler_run (ioloop=0x1953720) at
ioloop-epoll.c:215
        ctx = 0x1953aa0
        events = 0x1953b10
        event = 0x1953b10
        list = 0x1971290
        io = 0x19de2a0
        tv = {tv_sec = 59, tv_usec = 999033}
        events_count = 6
        msecs = 60000
        ret = 1
        i = 0
        j = 0
        call = true
        __FUNCTION__ = "io_loop_handler_run"
#16 0x00007fbf87f0e630 in io_loop_run (ioloop=0x1953720) at ioloop.c:406
No locals.
#17 0x00007fbf87ea609e in master_service_run (service=0x19535b0,
callback=0x426143 <client_connected>) at master-service.c:560
No locals.
#18 0x000000000042645c in main (argc=1, argv=0x1953390) at main.c:400
        set_roots = {0x42f500, 0x0}
        login_set = {auth_socket_path = 0x194b050  <incomplete sequence
\335>, postlogin_socket_path = 0x0, postlogin_timeout_secs = 60, callback =
0x425f07 <login_client_connected>, failure_callback = 0x4260cf
<login_client_failed>, request_auth_token = 1}
        service_flags = MASTER_SERVICE_FLAG_KEEP_CONFIG_OPEN
        storage_service_flags = MAIL_STORAGE_SERVICE_FLAG_DISALLOW_ROOT
        username = 0x0
        c = -1
-------------- next part --------------
# 2.2.0: /usr/local/etc/dovecot/dovecot.conf
# OS: Linux 3.2.0-4-amd64 x86_64 Debian 7.0 
auth_mechanisms = plain login
debug_log_path = /var/log/dovecot_dbg.log
dict {
  quota = pgsql:/usr/local/etc/dovecot/dovecot-dict-sql.conf.ext
}
first_valid_gid = 70000
first_valid_uid = 70000
lmtp_save_to_detail_mailbox = yes
login_access_sockets = tcpwrap
mail_access_groups = dovemail
mail_attachment_dir = /srv/mail/.SiS/%X{gid}
mail_attachment_fs = sis posix:mode=0660
mail_attachment_hash = %{sha256}
mail_location = mdbox:~/mdbox
mail_plugins = quota stats zlib
managesieve_notify_capability = mailto
managesieve_sieve_capability = fileinto reject envelope encoded-character
vacation subaddress comparator-i;ascii-numeric relational regex imap4flags copy
include variables body enotify environment mailbox date ihave
namespace Public {
  location =
maildir:/srv/mail/.public/%X{gid}/Maildir:LAYOUT=fs:INDEX=~/Maildir/public
  prefix = "#Public/"
  separator = /
  subscriptions = no
  type = public
}
namespace inbox {
  inbox = yes
  location = 
  mailbox Drafts {
    special_use = \Drafts
  }
  mailbox Junk {
    special_use = \Junk
  }
  mailbox Sent {
    special_use = \Sent
  }
  mailbox Trash {
    special_use = \Trash
  }
  prefix = 
  separator = /
}
passdb {
  args = /usr/local/etc/dovecot/dovecot-sql.conf.ext
  driver = sql
}
plugin {
  quota = dict:user:%{uid}:noenforcing:proxy::quota
  quota_rule = *:storage=2G:messages=0
  quota_rule2 = Trash:storage=+100M
  recipient_delimiter = +
  sieve = ~/.dovecot.sieve
  sieve_dir = ~/sieve
  stats_refresh = 1min
  zlib_save = bz2
  zlib_save_level = 6
}
postmaster_address = postmaster at example.com
protocols = imap lmtp sieve
service auth-worker {
  unix_listener auth-worker {
    group = $default_internal_user
    mode = 0660
    user = doveauth
  }
  user = doveauth
}
service auth {
  client_limit = 1425
  unix_listener /var/spool/postfix-orange/private/dovecot-auth {
    group = postfix
    mode = 0600
    user = postfix
  }
  user = doveauth
}
service dict {
  idle_kill = 150 secs
  unix_listener dict {
    group = dovemail
    mode = 0660
  }
}
service imap-login {
  process_limit = 256
}
service imap {
  process_limit = 256
}
service lmtp {
  executable = lmtp -D
  unix_listener /var/spool/postfix-blau/private/dovecot-lmtp {
    group = postfix
    mode = 0600
    user = postfix
  }
  unix_listener /var/spool/postfix-orange/private/dovecot-lmtp {
    group = postfix
    mode = 0600
    user = postfix
  }
}
service stats {
  fifo_listener stats-mail {
    mode = 0666
  }
}
service tcpwrap {
  unix_listener login/tcpwrap {
    group = $default_login_user
    mode = 0600
    user = $default_login_user
  }
}
ssl = required
ssl_cert = </etc/ssl/certs/cert.crt
ssl_key = </etc/ssl/private/key.key
userdb {
  args = /usr/local/etc/dovecot/dovecot-sql.conf.ext
  driver = sql
}
verbose_proctitle = yes
protocol lda {
  mail_plugins = quota stats zlib sieve
}
protocol imap {
  imap_client_workarounds = delay-newmail tb-extra-mailbox-sep tb-lsub-flags
  imap_id_log = *
  imap_id_send = name
  imap_logout_format = in=%i out=%o, session=<%{session}>
  mail_plugins = quota stats zlib imap_quota imap_stats imap_zlib
}
protocol lmtp {
  mail_plugins = quota stats zlib sieve
}
Timo Sirainen
2013-Apr-15  14:51 UTC
[Dovecot] imap Panic: file index-attachment.c: line 231 (index_attachment_save_finish): assertion failed: (attach->input->eof)
On Mon, 2013-04-15 at 16:37 +0200, Pascal Volk wrote:> some imap processes seems to have some problems.Can you reproduce it? What client was that with? I wonder if it was using CATENATE extension.
Timo Sirainen
2013-Apr-15  16:50 UTC
[Dovecot] imap Panic: file index-attachment.c: line 231 (index_attachment_save_finish): assertion failed: (attach->input->eof)
On Mon, 2013-04-15 at 16:37 +0200, Pascal Volk wrote:> some imap processes seems to have some problems.I still can't reproduce .. but I wonder if the attached patch makes a difference. Also in the gdb these would be useful to know: p *attach.input.real_stream.parent.real_stream p *attach.input.real_stream.parent.real_stream.parent.real_stream p *attach.input.real_stream.parent.real_stream.parent.real_stream.parent.real_stream (not sure how many parents it has) -------------- next part -------------- A non-text attachment was scrubbed... Name: diff Type: text/x-patch Size: 1439 bytes Desc: not available URL: <http://dovecot.org/pipermail/dovecot/attachments/20130415/319f9b6c/attachment.bin>
Pascal Volk
2013-Apr-16  17:28 UTC
[Dovecot] imap Panic: file index-attachment.c: line 231 (index_attachment_save_finish): assertion failed: (attach->input->eof)
On 04/15/2013 11:33 PM Pascal Volk wrote:> OK, applied that patch. Lets see what will happen. >Looks good. No crash in the last 20 hours. Regards, Pascal -- The trapper recommends today: cafefeed.1310619 at localdomain.org
Timo Sirainen
2013-Apr-17  13:21 UTC
[Dovecot] imap Panic: file index-attachment.c: line 231 (index_attachment_save_finish): assertion failed: (attach->input->eof)
On Tue, 2013-04-16 at 19:28 +0200, Pascal Volk wrote:> On 04/15/2013 11:33 PM Pascal Volk wrote: > > OK, applied that patch. Lets see what will happen. > > > > Looks good. No crash in the last 20 hours.OK. Committed the patch a little bit differently: http://hg.dovecot.org/dovecot-2.2/rev/8a07a5f6fd54
Apparently Analagous Threads
- failed assertion in 1.1.8: istream.c: line 81
- mail_filter plugin: failed: EOF without input (Gedalya)
- dovecot 1.1.4 maildir imap segfault in message_parse_header_next
- assertion failure in current hg, file istream.c: line 303 (i_stream_read_data): assertion failed: (stream->stream_errno != 0) (1.1.3 was working fine)
- stacking istreams and ostreams