mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
file-systems: Add support for FAT16.
* gnu/build/file-systems.scm (check-fat32-file-system): Rename to... (check-fat-file-system): ... this. (check-file-system): Adjust accordingly. (fat16-superblock?, read-fat16-superblock) (fat16-superblock-uuid, fat16-superblock-volume-name): New procedures. (%partition-label-readers, %partition-uuid-readers): Add FAT16.
This commit is contained in:
parent
9976c76aab
commit
88235675fc
1 changed files with 35 additions and 4 deletions
|
@ -194,7 +194,7 @@ (define (fat32-superblock-volume-name sblock)
|
||||||
Trailing spaces are trimmed."
|
Trailing spaces are trimmed."
|
||||||
(string-trim-right (latin1->string (sub-bytevector sblock 71 11) (lambda (c) #f)) #\space))
|
(string-trim-right (latin1->string (sub-bytevector sblock 71 11) (lambda (c) #f)) #\space))
|
||||||
|
|
||||||
(define (check-fat32-file-system device)
|
(define (check-fat-file-system device)
|
||||||
"Return the health of a fat file system on DEVICE."
|
"Return the health of a fat file system on DEVICE."
|
||||||
(match (status:exit-val
|
(match (status:exit-val
|
||||||
(system* "fsck.vfat" "-v" "-a" device))
|
(system* "fsck.vfat" "-v" "-a" device))
|
||||||
|
@ -202,6 +202,33 @@ (define (check-fat32-file-system device)
|
||||||
(1 'errors-corrected)
|
(1 'errors-corrected)
|
||||||
(_ 'fatal-error)))
|
(_ 'fatal-error)))
|
||||||
|
|
||||||
|
|
||||||
|
;;;
|
||||||
|
;;; FAT16 file systems.
|
||||||
|
;;;
|
||||||
|
|
||||||
|
(define (fat16-superblock? sblock)
|
||||||
|
"Return #t when SBLOCK is a fat16 boot record."
|
||||||
|
(bytevector=? (sub-bytevector sblock 54 8)
|
||||||
|
(string->utf8 "FAT16 ")))
|
||||||
|
|
||||||
|
(define (read-fat16-superblock device)
|
||||||
|
"Return the raw contents of DEVICE's fat16 superblock as a bytevector, or
|
||||||
|
#f if DEVICE does not contain a fat16 file system."
|
||||||
|
(read-superblock device 0 62 fat16-superblock?))
|
||||||
|
|
||||||
|
(define (fat16-superblock-uuid sblock)
|
||||||
|
"Return the Volume ID of a fat superblock SBLOCK as a 4-byte bytevector."
|
||||||
|
(sub-bytevector sblock 39 4))
|
||||||
|
|
||||||
|
(define (fat16-superblock-volume-name sblock)
|
||||||
|
"Return the volume name of SBLOCK as a string of at most 11 characters, or
|
||||||
|
#f if SBLOCK has no volume name. The volume name is a latin1 string.
|
||||||
|
Trailing spaces are trimmed."
|
||||||
|
(string-trim-right (latin1->string (sub-bytevector sblock 43 11)
|
||||||
|
(lambda (c) #f))
|
||||||
|
#\space))
|
||||||
|
|
||||||
|
|
||||||
;;;
|
;;;
|
||||||
;;; ISO9660 file systems.
|
;;; ISO9660 file systems.
|
||||||
|
@ -386,7 +413,9 @@ (define %partition-label-readers
|
||||||
(partition-field-reader read-btrfs-superblock
|
(partition-field-reader read-btrfs-superblock
|
||||||
btrfs-superblock-volume-name)
|
btrfs-superblock-volume-name)
|
||||||
(partition-field-reader read-fat32-superblock
|
(partition-field-reader read-fat32-superblock
|
||||||
fat32-superblock-volume-name)))
|
fat32-superblock-volume-name)
|
||||||
|
(partition-field-reader read-fat16-superblock
|
||||||
|
fat16-superblock-volume-name)))
|
||||||
|
|
||||||
(define %partition-uuid-readers
|
(define %partition-uuid-readers
|
||||||
(list (partition-field-reader read-iso9660-superblock
|
(list (partition-field-reader read-iso9660-superblock
|
||||||
|
@ -396,7 +425,9 @@ (define %partition-uuid-readers
|
||||||
(partition-field-reader read-btrfs-superblock
|
(partition-field-reader read-btrfs-superblock
|
||||||
btrfs-superblock-uuid)
|
btrfs-superblock-uuid)
|
||||||
(partition-field-reader read-fat32-superblock
|
(partition-field-reader read-fat32-superblock
|
||||||
fat32-superblock-uuid)))
|
fat32-superblock-uuid)
|
||||||
|
(partition-field-reader read-fat16-superblock
|
||||||
|
fat16-superblock-uuid)))
|
||||||
|
|
||||||
(define read-partition-label
|
(define read-partition-label
|
||||||
(cut read-partition-field <> %partition-label-readers))
|
(cut read-partition-field <> %partition-label-readers))
|
||||||
|
@ -511,7 +542,7 @@ (define check-procedure
|
||||||
(cond
|
(cond
|
||||||
((string-prefix? "ext" type) check-ext2-file-system)
|
((string-prefix? "ext" type) check-ext2-file-system)
|
||||||
((string-prefix? "btrfs" type) check-btrfs-file-system)
|
((string-prefix? "btrfs" type) check-btrfs-file-system)
|
||||||
((string-suffix? "fat" type) check-fat32-file-system)
|
((string-suffix? "fat" type) check-fat-file-system)
|
||||||
(else #f)))
|
(else #f)))
|
||||||
|
|
||||||
(if check-procedure
|
(if check-procedure
|
||||||
|
|
Loading…
Reference in a new issue