2017-08-05 21:18:32 +01:00
|
|
|
(import
|
2017-08-10 15:07:20 +01:00
|
|
|
(binary-format)
|
2017-08-08 11:47:37 +01:00
|
|
|
(block-io)
|
2017-08-11 15:41:57 +01:00
|
|
|
(btree)
|
2017-08-05 21:18:32 +01:00
|
|
|
(fmt fmt)
|
2017-08-10 15:07:20 +01:00
|
|
|
(matchable)
|
2017-08-11 15:41:57 +01:00
|
|
|
(mapping-tree)
|
2017-08-10 15:07:20 +01:00
|
|
|
(rnrs))
|
2017-08-05 21:18:32 +01:00
|
|
|
|
|
|
|
;;;;---------------------------------------------------
|
|
|
|
;;;; Constants
|
|
|
|
;;;;---------------------------------------------------
|
|
|
|
|
|
|
|
;; FIXME: duplicate with main.scm
|
2017-08-10 15:07:20 +01:00
|
|
|
(define (current-metadata) "./metadata.bin")
|
2017-08-05 21:18:32 +01:00
|
|
|
|
2017-08-10 15:07:20 +01:00
|
|
|
(define $superblock-magic 27022010)
|
|
|
|
(define $superblock-salt 160774)
|
|
|
|
(define $uuid-size 16)
|
|
|
|
(define $space-map-root-size 128)
|
2017-08-05 21:18:32 +01:00
|
|
|
|
2017-08-11 15:41:57 +01:00
|
|
|
(binary-format superblock
|
2017-08-05 21:18:32 +01:00
|
|
|
(csum le32)
|
|
|
|
(flags le32)
|
|
|
|
(block-nr le64)
|
2017-08-11 15:41:57 +01:00
|
|
|
(uuid (bytes $uuid-size))
|
2017-08-05 21:18:32 +01:00
|
|
|
(magic le64)
|
|
|
|
(version le32)
|
|
|
|
(time le32)
|
|
|
|
(trans-id le64)
|
|
|
|
(metadata-snap le64)
|
2017-08-11 15:41:57 +01:00
|
|
|
(data-space-map-root (bytes $space-map-root-size))
|
|
|
|
(metadata-space-map-root (bytes $space-map-root-size))
|
2017-08-05 21:18:32 +01:00
|
|
|
(data-mapping-root le64)
|
|
|
|
(device-details-root le64)
|
|
|
|
(data-block-size le32)
|
|
|
|
(metadata-block-size le32)
|
|
|
|
(metadata-nr-blocks le64)
|
|
|
|
(compat-flags le32)
|
|
|
|
(compat-ro-flags le32)
|
|
|
|
(incompat-flags le32))
|
|
|
|
|
|
|
|
;;;;---------------------------------------------------
|
|
|
|
;;;; Top level
|
|
|
|
;;;;---------------------------------------------------
|
|
|
|
|
|
|
|
(define (check-magic sb)
|
|
|
|
((let ((m (bytevector-u32-ref sb 32 (endianness little))))
|
|
|
|
(fmt #t (dsp "on disk magic: ") (num m) nl)
|
|
|
|
)))
|
|
|
|
|
|
|
|
(define (read-superblock)
|
|
|
|
(with-metadata (md (current-metadata))
|
2017-08-11 15:41:57 +01:00
|
|
|
(superblock-unpack (read-block md 0) 0)))
|
|
|
|
|
|
|
|
(define (dump-dev-tree)
|
|
|
|
(with-metadata (md (current-metadata))
|
|
|
|
(let ((sb (superblock-unpack (read-block md 0) 0)))
|
|
|
|
(btree-each (btree-open le64-type md (superblock-data-mapping-root sb))
|
|
|
|
(lambda (k v)
|
|
|
|
(fmt #t (dsp "dev-id: ") (num k)
|
|
|
|
(dsp ", mapping root: ") (num v) nl))))))
|
|
|
|
|
|
|
|
(define (dump-mappings root)
|
|
|
|
(with-metadata (md (current-metadata))
|
|
|
|
(btree-each (btree-open le64-type md root)
|
|
|
|
(lambda (k v)
|
|
|
|
(fmt #t (dsp "vblock: ") (num k)
|
|
|
|
(dsp ", pblock: ") (num v) nl)))))
|
|
|
|
|
|
|
|
(define (dump-all-mappings)
|
|
|
|
(with-metadata (md (current-metadata))
|
|
|
|
(let ((sb (superblock-unpack (read-block md 0) 0)))
|
|
|
|
(let ((mappings (mapping-tree-open md (superblock-data-mapping-root sb))))
|
|
|
|
(mapping-tree-each mappings
|
2017-08-12 19:27:21 +01:00
|
|
|
(lambda (dev-id vblock pblock time)
|
2017-08-11 15:41:57 +01:00
|
|
|
(fmt #t
|
|
|
|
(dsp "thin dev ") (num dev-id)
|
|
|
|
(dsp ", vblock ") (num vblock)
|
|
|
|
(dsp ", pblock ") (num pblock)
|
2017-08-12 19:27:21 +01:00
|
|
|
(dsp ", time ") (num time)
|
2017-08-11 15:41:57 +01:00
|
|
|
nl)))))))
|
2017-08-05 21:18:32 +01:00
|
|
|
|
|
|
|
(define (check-superblock)
|
|
|
|
(with-metadata (md (current-metadata))
|
|
|
|
(let ((superblock (read-block md 0)))
|
|
|
|
(fmt #t (dsp "checksum on disk: ") (dsp (bytevector-u32-ref superblock 0 (endianness little))) nl)
|
2017-08-10 15:07:20 +01:00
|
|
|
;(fmt #t (dsp "calculated checksum: ") (dsp (crc32-region $superblock-salt superblock 4 4092)) nl)
|
2017-08-05 21:18:32 +01:00
|
|
|
(check-magic superblock))))
|