linux-initrd: Produce cpio archives with zeroed timestamps, etc.
authorLudovic Courtès <ludo@gnu.org>
Wed, 24 Jun 2015 16:02:15 +0000 (18:02 +0200)
committerLudovic Courtès <ludo@gnu.org>
Wed, 24 Jun 2015 16:05:03 +0000 (18:05 +0200)
* guix/cpio.scm (file->cpio-header*): New procedure.
* gnu/build/linux-initrd.scm (write-cpio-archive): Add #:file->header argument
  to 'cpio:write-cpio-archive'.

gnu/build/linux-initrd.scm
guix/cpio.scm

index 815c7a0..e26c067 100644 (file)
@@ -68,7 +68,8 @@ COMPRESS? is true, compress it using GZIP.  On success, return OUTPUT."
 
   (call-with-output-file output
     (lambda (port)
-      (cpio:write-cpio-archive files port)))
+      (cpio:write-cpio-archive files port
+                               #:file->header cpio:file->cpio-header*)))
 
   (or (not compress?)
       (and (zero? (system* gzip "--best" output))
index f1c2130..e4692e2 100644 (file)
@@ -26,6 +26,7 @@
   #:export (cpio-header?
             make-cpio-header
             file->cpio-header
+            file->cpio-header*
             write-cpio-header
             read-cpio-header
 
@@ -174,6 +175,18 @@ using FILE-NAME as its file name."
                       #:rdev (stat:rdev st)
                       #:name-size (string-length file-name))))
 
+(define* (file->cpio-header* file
+                             #:optional (file-name file)
+                             #:key (stat lstat))
+  "Similar to 'file->cpio-header', but return a header with a zeroed
+modification time, inode number, UID/GID, etc.  This allows archives to be
+produced in a deterministic fashion."
+  (let ((st (stat file)))
+    (make-cpio-header #:mode (stat:mode st)
+                      #:nlink (stat:nlink st)
+                      #:size (stat:size st)
+                      #:name-size (string-length file-name))))
+
 (define %trailer
   "TRAILER!!!")