The following commit has been merged in the master branch:
commit d61fbafbbe3858150ddcd349df8e10557b0fe0cf
Author: Guillem Jover <[email protected]>
Date:   Mon Apr 15 04:33:39 2013 +0200

    libdpkg: Move verification out of tar_header_checksum()
    
    This will allow to use the same function to produce the checksum when
    creating a tar archive.

diff --git a/lib/dpkg/tarfn.c b/lib/dpkg/tarfn.c
index 90d5071..93643bd 100644
--- a/lib/dpkg/tarfn.c
+++ b/lib/dpkg/tarfn.c
@@ -3,7 +3,7 @@
  * tarfn.c - tar archive extraction functions
  *
  * Copyright © 1995 Bruce Perens
- * Copyright © 2007-2011 Guillem Jover <[email protected]>
+ * Copyright © 2007-2011,2013 Guillem Jover <[email protected]>
  *
  * This is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -129,17 +129,14 @@ get_unix_mode(struct tar_header *h)
        return mode;
 }
 
-static bool
+static long
 tar_header_checksum(struct tar_header *h)
 {
        unsigned char *s = (unsigned char *)h;
        unsigned int i;
        const size_t checksum_offset = offsetof(struct tar_header, checksum);
-       long checksum;
        long sum;
 
-       checksum = OtoM(h->checksum, sizeof(h->checksum));
-
        /* Treat checksum field as all blank. */
        sum = ' ' * sizeof(h->checksum);
 
@@ -152,7 +149,7 @@ tar_header_checksum(struct tar_header *h)
        for (i = TARBLKSZ - checksum_offset - sizeof(h->checksum); i > 0; i--)
                sum += *s++;
 
-       return (sum == checksum);
+       return sum;
 }
 
 static int
@@ -160,6 +157,7 @@ tar_header_decode(struct tar_header *h, struct tar_entry *d)
 {
        struct passwd *passwd = NULL;
        struct group *group = NULL;
+       long checksum;
 
        if (memcmp(h->magic, TAR_MAGIC_GNU, 6) == 0)
                d->format = tar_format_gnu;
@@ -198,7 +196,9 @@ tar_header_decode(struct tar_header *h, struct tar_entry *d)
        else
                d->stat.gid = (gid_t)OtoM(h->gid, sizeof(h->gid));
 
-       return tar_header_checksum(h);
+       checksum = OtoM(h->checksum, sizeof(h->checksum));
+
+       return tar_header_checksum(h) == checksum;
 }
 
 /**

-- 
dpkg's main repository


-- 
To UNSUBSCRIBE, email to [email protected]
with a subject of "unsubscribe". Trouble? Contact [email protected]

Reply via email to