From: Jeremy Harris Date: Mon, 26 May 2014 15:07:33 +0000 (+0100) Subject: Ensure output buffer big enough for DSN additions to MAIL FROM. Bug 1482 X-Git-Tag: exim-4_83_RC2~3 X-Git-Url: https://git.exim.org/exim.git/commitdiff_plain/984702029ad4e6a1686dd801811a68f6034e6b38 Ensure output buffer big enough for DSN additions to MAIL FROM. Bug 1482 --- diff --git a/src/src/smtp_out.c b/src/src/smtp_out.c index 0fa4ccd48..b6ff51108 100644 --- a/src/src/smtp_out.c +++ b/src/src/smtp_out.c @@ -352,6 +352,10 @@ if (!string_vformat(big_buffer, big_buffer_size, CS format, ap)) va_end(ap); count = Ustrlen(big_buffer); +if (count > outblock->buffersize) + log_write(0, LOG_MAIN|LOG_PANIC_DIE, "overlong write_command in outgoing " + "SMTP"); + if (count > outblock->buffersize - (outblock->ptr - outblock->buffer)) { rc = outblock->cmd_count; /* flush resets */ diff --git a/src/src/transports/smtp.c b/src/src/transports/smtp.c index 33c91a67a..40eebe8b6 100644 --- a/src/src/transports/smtp.c +++ b/src/src/transports/smtp.c @@ -1228,7 +1228,7 @@ uschar new_message_id[MESSAGE_ID_LENGTH + 1]; uschar *p; uschar buffer[4096]; uschar inbuffer[4096]; -uschar outbuffer[1024]; +uschar outbuffer[4096]; suppress_tls = suppress_tls; /* stop compiler warning when no TLS support */