Subject: pkg/35677: librsync patch for no progress error large files
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: Andreas Wrede <andreas@planix.com>
List: pkgsrc-bugs
Date: 02/17/2007 20:40:01
>Number:         35677
>Category:       pkg
>Synopsis:       librsync patch for no progress error large files
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    pkg-manager
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Sat Feb 17 20:40:01 +0000 2007
>Originator:     Andreas Wrede
>Release:        NetBSD 4.0_BETA2
>Organization:
Andreas Wrede              Planix, Inc.
andreas@planix.com         Networking, System Administration, Consulting
http://www.planix.com      Toronto, Ontario, Canada

"The steady state of disks is full."
                               -- Ken Thompson
>Environment:
	
	
System: NetBSD whome.planix.com 4.0_BETA2 NetBSD 4.0_BETA2 (PLANIX.MPACPI) #56: Thu Jan 25 23:30:23 EST 2007 root@whome.planix.com:/u2/netbsd-4.0/obj.i386/sys/arch/i386/compile/PLANIX.MPACPI i386

Architecture: i386
Machine: i386
>Description:
	librsync will stall on transfers of files over 4 Gb, esp. between 32 <-> 64 bit hosts. See
https://sourceforge.net/tracker/index.php?func=detail&aid=1439412&group_id=56125&atid=479441

>How-To-Repeat:
	
  run rdiff-backup between a NetBSD/amd64 and NetBSD/i386 machine. Observe stalled process.
>Fix:
	
Two patch files for pkgsrc/devel/librsync/patches:

[--patch-aa--]
--- mdfour.h.orig    2004-02-08 10:17:57.000000000 +1100
+++ mdfour.h  2006-02-27 14:35:26.086597250 +1100
@@ -24,7 +24,7 @@
 #include "types.h"

 struct rs_mdfour {
-    int                 A, B, C, D;
+    unsigned int        A, B, C, D;
 #if HAVE_UINT64
     uint64_t            totalN;
 #else
[EOP]

[--patch-ab--]
--- patch.c.orig	2007-01-27 19:06:40.000000000 -0500
+++ patch.c	2007-01-27 19:08:09.000000000 -0500
@@ -214,12 +214,12 @@
     void            *buf, *ptr;
     rs_buffers_t    *buffs = job->stream;
 
-    len = job->basis_len;
-    
     /* copy only as much as will fit in the output buffer, so that we
      * don't have to block or store the input. */
-    if (len > buffs->avail_out)
+    if (job->basis_len > buffs->avail_out)
         len = buffs->avail_out;
+    else
+        len = job->basis_len;
 
     if (!len)
         return RS_BLOCKED;
[EOP]

>Unformatted: