On Wed, 28 Nov 2012, M Joonas Pihlaja wrote:

> Package: unzip
> Version: 6.0-7
> Severity: grave
> Tags: upstream
> Justification: causes non-serious data loss
> 
> Dear Maintainer,
> 
> Unzipping an archive gives me CRC errors and corrupt files.  Please consider
> adding -DNOMEMCPY to the compile line.  I was merrily unzipping an
> archive when I came across CRC errors for some of the extracted files:
> 
> $ unzip ../walk_network_20120628.zip
> Archive:  ../walk_network_20120628.zip
>   inflating: walk_network.shx
>   inflating: walk_network.dbf     bad CRC b3242663  (should be 7d1b61e0)
>   inflating: walk_network.prj
>   inflating: walk_network.sbn
>   inflating: walk_network.sbx
>   inflating: walk_network.shp     bad CRC 13443cc8  (should be 0adaa078)
>   inflating: walk_network.shp.xml
> 
> The extracted files are corrupted.  I suspected a memory failure
> so ran memtester with a large percentage of ram under test.  Nothing
> showed up and grumpyness ensued.
> 
> So I downloaded the source using apt-get source unzip, built
> the unzip executable with flags -O0 -g and removed the -s
> flag from the link line to not strip the resulting binaries, like so:
> 
> $ make -B -f unix/Makefile LF2="" CFLAGS="-O0 -g" unzip
> [...]
> 
> Running the unzip command above under valgrind and tells me this:
> 
> $ valgrind ../unzip-6.0/unzip ../lvm_walk_network_20120628.zip 
> ==19732== Memcheck, a memory error detector
> ==19732== Copyright (C) 2002-2011, and GNU GPL'd, by Julian Seward et al.
> ==19732== Using Valgrind-3.7.0 and LibVEX; rerun with -h for copyright info
> ==19732== Command: ../unzip-6.0/unzip ../walk_network_20120628.zip
> ==19732== 
> Archive:  ../walk_network_20120628.zip
>   inflating: walk_network.shx    
>   inflating: walk_network.dbf    ==19732== Source and destination overlap in 
> memcpy(0x70dd44, 0x70dd72, 74)
> ==19732==    at 0x4C2A690: memcpy (mc_replace_strmem.c:838)
> ==19732==    by 0x40D377: inflate_codes (inflate.c:1021)
> ==19732==    by 0x40E151: inflate_dynamic (inflate.c:1373)
> ==19732==    by 0x40E2D0: inflate_block (inflate.c:1421)
> ==19732==    by 0x40E3E7: inflate (inflate.c:1494)
> ==19732==    by 0x408B38: extract_or_test_member (extract.c:1855)
> ==19732==    by 0x408091: extract_or_test_entrylist (extract.c:1576)
> ==19732==    by 0x406060: extract_or_test_files (extract.c:584)
> ==19732==    by 0x4116D8: do_seekable (process.c:987)
> ==19732==    by 0x410719: process_zipfiles (process.c:401)
> ==19732==    by 0x402195: unzip (unzip.c:1253)
> ==19732==    by 0x401B10: main (unzip.c:720)
> ==19732== 
> 
> Looking at the source I see it choosing between memcpy() and
> a hand-rolled forward copy like this:
> 
> #ifndef NOMEMCPY
>           if ((unsigned)w - d >= e)
>           /* (this test assumes unsigned comparison) */
>           {
>             memcpy(redirSlide + (unsigned)w, redirSlide + d, e);
>             w += e;
>             d += e;
>           }
>           else                  /* do it slowly to avoid memcpy() overlap */
> #endif /* !NOMEMCPY */
>             do {
>               redirSlide[w++] = redirSlide[d++];
>             } while (--e);
> 
> The same style of test occurs in explode.c twice.  So I added -DNOMEMCPY to
> the compile line, rebuilt, and ran the unzip command again. All files were
> intact without any corruption.

Thanks a lot for such a detailed bug report.
This is certainly something to be fixed in wheezy.
Working on it now.


-- 
To UNSUBSCRIBE, email to debian-bugs-rc-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org

Reply via email to