Subject: Re: pkg/35092 (proftpd-1.3.0nb1 causes segfaults)
To: None <adrianp@NetBSD.org, gnats-admin@netbsd.org,>
From: Adrian Portelli <adrianp@NetBSD.org>
List: pkgsrc-bugs
Date: 11/22/2006 20:10:03
The following reply was made to PR pkg/35092; it has been noted by GNATS.

From: Adrian Portelli <adrianp@NetBSD.org>
To: gnats-bugs@NetBSD.org
Cc: naoto@morishima.net
Subject: Re: pkg/35092 (proftpd-1.3.0nb1 causes segfaults)
Date: Wed, 22 Nov 2006 20:07:53 +0000

 This is a multi-part message in MIME format.
 --------------000607070206020203070607
 Content-Type: text/plain; charset=ISO-8859-1
 Content-Transfer-Encoding: 7bit
 
 Hi,
 
 Could you please try the attached patch and let me know how you get on.
 
 thanks,
 
 adrian.
 
 
 --------------000607070206020203070607
 Content-Type: text/plain;
  name="proftpd.diff"
 Content-Transfer-Encoding: 7bit
 Content-Disposition: inline;
  filename="proftpd.diff"
 
 Index: Makefile
 ===================================================================
 RCS file: /cvsroot/pkgsrc/net/proftpd/Makefile,v
 retrieving revision 1.36
 diff -u -r1.36 Makefile
 --- Makefile	18 Nov 2006 14:32:58 -0000	1.36
 +++ Makefile	22 Nov 2006 20:04:03 -0000
 @@ -1,7 +1,7 @@
  # $NetBSD: Makefile,v 1.36 2006/11/18 14:32:58 adrianp Exp $
  
  DISTNAME=	proftpd-1.3.0
 -PKGREVISION=	1
 +PKGREVISION=	2
  CATEGORIES=	net
  MASTER_SITES=	ftp://ftp.proftpd.org/distrib/source/ \
  		ftp://ftp.servus.at/ProFTPD/distrib/source/ \
 Index: distinfo
 ===================================================================
 RCS file: /cvsroot/pkgsrc/net/proftpd/distinfo,v
 retrieving revision 1.19
 diff -u -r1.19 distinfo
 --- distinfo	18 Nov 2006 14:32:58 -0000	1.19
 +++ distinfo	22 Nov 2006 20:04:03 -0000
 @@ -5,4 +5,4 @@
  Size (proftpd-1.3.0.tar.bz2) = 1386086 bytes
  SHA1 (patch-aa) = 5ebfe97a0edb8ecee7495fd5d487eff3cf32d1fe
  SHA1 (patch-ab) = 8886177b90089c8a2fa580aceb7a0514fe0ea6a7
 -SHA1 (patch-ac) = 25a0b27773e5e025096cf08ad33243aaf143fbb8
 +SHA1 (patch-ac) = 4cdfd0cff027524c38785a5a45bae747e3b151f7
 Index: patches/patch-ac
 ===================================================================
 RCS file: /cvsroot/pkgsrc/net/proftpd/patches/patch-ac,v
 retrieving revision 1.5
 diff -u -r1.5 patch-ac
 --- patches/patch-ac	18 Nov 2006 14:32:58 -0000	1.5
 +++ patches/patch-ac	22 Nov 2006 20:04:03 -0000
 @@ -1,47 +1,49 @@
 -$NetBSD: patch-ac,v 1.5 2006/11/18 14:32:58 adrianp Exp $
 +$NetBSD$
  
 ---- src/main.c.orig	2006-11-18 14:24:35.000000000 +0000
 +--- src/main.c.orig	2006-03-15 19:41:01.000000000 +0000
  +++ src/main.c
  @@ -116,6 +116,8 @@ static unsigned char have_dead_child = F
   
   static char sbuf[PR_TUNABLE_BUFFER_SIZE] = {'\0'};
   
 -+#define PR_DEFAULT_CMD_BUFSZ   512
 ++#define PR_DEFAULT_CMD_BUFSZ    512
  +
   static char **Argv = NULL;
   static char *LastArgv = NULL;
   static const char *PidPath = PR_PID_FILE_PATH;
 -@@ -820,16 +822,25 @@ static void cmd_loop(server_rec *server,
 +@@ -820,17 +822,24 @@ static void cmd_loop(server_rec *server,
         pr_timer_reset(TIMER_IDLE, NULL);
   
       if (cmd_buf_size == -1) {
  -      long *buf_size = get_param_ptr(main_server->conf,
  -        "CommandBufferSize", FALSE);
 -+      int *bufsz = get_param_ptr(main_server->conf, "CommandBufferSize",
 -+        FALSE);
 - 
 +-
  -      if (buf_size == NULL || *buf_size <= 0)
  -        cmd_buf_size = 512;
 -+      if (bufsz == NULL ||
 -+          *bufsz <= 0) {
 -+	pr_log_pri(PR_LOG_WARNING, "invalid CommandBufferSize size (%d) "
 -+          "given, resetting to default buffer size (%u)",
 -+          *bufsz, (unsigned int) PR_DEFAULT_CMD_BUFSZ);
 -+        cmd_buf_size = PR_DEFAULT_CMD_BUFSZ;
 -+
 -+      } else if (*bufsz + 1 > sizeof(buf)) {
 -+	pr_log_pri(PR_LOG_WARNING, "invalid CommandBufferSize size (%d) "
 -+          "given, resetting to default buffer size (%u)",
 -+          *bufsz, (unsigned int) PR_DEFAULT_CMD_BUFSZ);
 -+	cmd_buf_size = PR_DEFAULT_CMD_BUFSZ;
 - 
 +-
  -      else if (*buf_size + 1 > sizeof(buf)) {
  -	pr_log_pri(PR_LOG_WARNING, "Invalid CommandBufferSize size given. "
  -          "Resetting to 512.");
  -	cmd_buf_size = 512;
 -+      } else {
 -+        pr_log_debug(DEBUG1, "setting CommandBufferSize to %d", *bufsz);
 -+        cmd_buf_size = (long) *bufsz;
 -       }
 +-      }
 ++      int *bufsz = get_param_ptr(main_server->conf, "CommandBufferSize", FALSE);
 ++    if (bufsz == NULL) {
 ++      cmd_buf_size = PR_DEFAULT_CMD_BUFSZ;
 ++    }
 ++    else if ( bufsz <= 0 ) {
 ++      pr_log_pri(PR_LOG_WARNING, "invalid CommandBufferSize size (%d) "
 ++                 "given, resetting to default buffer size (%u)",
 ++		 *bufsz, (unsigned int) PR_DEFAULT_CMD_BUFSZ);
 ++      cmd_buf_size = PR_DEFAULT_CMD_BUFSZ;
 ++    } else if (*bufsz + 1 > sizeof(buf)) {
 ++	     pr_log_pri(PR_LOG_WARNING, "invalid CommandBufferSize size (%d) "
 ++			"given, using default buffer size (%u) instead",
 ++			*bufsz, (unsigned int) PR_DEFAULT_CMD_BUFSZ);
 ++	     cmd_buf_size = PR_DEFAULT_CMD_BUFSZ;
 ++	   } else {
 ++	     pr_log_debug(DEBUG1, "setting CommandBufferSize to %d", *bufsz);
 ++	     cmd_buf_size = (long) *bufsz;
 ++	   }
       }
   
 +     buf[cmd_buf_size - 1] = '\0';
 
 --------------000607070206020203070607--