2017-09-14 11:47:23 +01:00
|
|
|
(library
|
|
|
|
(thin check)
|
|
|
|
|
|
|
|
(export thin-check
|
|
|
|
thin-check-flags)
|
|
|
|
|
|
|
|
(import
|
|
|
|
(bcache block-manager)
|
|
|
|
(persistent-data btree)
|
|
|
|
(fmt fmt)
|
|
|
|
(list-utils)
|
|
|
|
(matchable)
|
|
|
|
(parser-combinators)
|
|
|
|
(srfi s8 receive)
|
|
|
|
(thin metadata)
|
|
|
|
(thin mapping-tree)
|
|
|
|
(chezscheme))
|
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-09-14 11:47:23 +01:00
|
|
|
(define-compound-value-type device-details-vt ThinDeviceDetails)
|
2017-08-05 21:18:32 +01:00
|
|
|
|
2017-09-14 11:47:23 +01:00
|
|
|
(define (block->superblock b)
|
|
|
|
(make-ftype-pointer ThinSuperblock (block-data b)))
|
|
|
|
|
|
|
|
;;;------------------------------------------------
|
|
|
|
;;; Fluid vars for the switches
|
|
|
|
|
|
|
|
(define quiet #f)
|
|
|
|
(define clear-needs-check-flag #f)
|
|
|
|
(define ignore-non-fatal-errors #f)
|
|
|
|
(define skip-mappings #f)
|
|
|
|
(define super-block-only #f)
|
|
|
|
|
|
|
|
(define (dump-dev-tree cache root)
|
2017-09-14 16:09:43 +01:00
|
|
|
(with-spine (sp cache 1)
|
|
|
|
(btree-each (btree-open device-details-vt root) sp
|
|
|
|
(lambda (k v)
|
|
|
|
(fmt #t
|
|
|
|
"dev-id: " k "\n"
|
|
|
|
" mapped blocks: " (ftype-ref ThinDeviceDetails (mapped-blocks) v) "\n"
|
|
|
|
" transaction id: " (ftype-ref ThinDeviceDetails (transaction-id) v) "\n"
|
|
|
|
" creation time: " (ftype-ref ThinDeviceDetails (creation-time) v) "\n"
|
|
|
|
" snapshotted time: " (ftype-ref ThinDeviceDetails (snapshotted-time) v) "\n")))))
|
2017-09-14 11:47:23 +01:00
|
|
|
|
|
|
|
(define-enumeration thin-check-element
|
|
|
|
(quiet
|
|
|
|
clear-needs-check-flag
|
|
|
|
ignore-non-fatal-errors
|
|
|
|
skip-mappings
|
|
|
|
super-block-only)
|
|
|
|
thin-check-flags)
|
|
|
|
|
|
|
|
(define (thin-check metadata-path flags)
|
|
|
|
(define (member? s)
|
|
|
|
(enum-set-member? s flags))
|
|
|
|
|
|
|
|
(fluid-let ((quiet (member? 'quiet))
|
|
|
|
(clear-needs-check-flag (member? 'clear-needs-check-flag))
|
|
|
|
(ignore-non-fatal-errors (member? 'ignore-non-fatal-errors))
|
|
|
|
(skip-mappings (member? 'skip-mappings))
|
|
|
|
(super-block-only (member? 'super-block-only)))
|
|
|
|
|
|
|
|
(fmt (current-output-port)
|
|
|
|
"quiet: " quiet "\n"
|
|
|
|
"clear-needs-check-flag: " clear-needs-check-flag "\n"
|
|
|
|
"ignore-non-fatal-errors: " ignore-non-fatal-errors "\n"
|
|
|
|
"skip-mappings: " skip-mappings "\n"
|
|
|
|
"super-block-only: " super-block-only "\n"
|
|
|
|
"input-file: " metadata-path "\n")
|
|
|
|
|
|
|
|
(with-bcache (cache metadata-path 1024)
|
|
|
|
(with-block (b cache 0 (get-flags))
|
|
|
|
(let ((sb (block->superblock b)))
|
|
|
|
(fmt (current-output-port)
|
|
|
|
"block-nr: " (ftype-ref ThinSuperblock (block-nr) sb) "\n"
|
|
|
|
"magic: " (ftype-ref ThinSuperblock (magic) sb) "\n"
|
|
|
|
"data-mapping-root: " (ftype-ref ThinSuperblock (data-mapping-root) sb) "\n"
|
|
|
|
"device-details-root: " (ftype-ref ThinSuperblock (device-details-root) sb) "\n")
|
|
|
|
(dump-dev-tree cache (ftype-ref ThinSuperblock (device-details-root) sb)))))))
|
2017-08-05 21:18:32 +01:00
|
|
|
|
2017-09-14 11:47:23 +01:00
|
|
|
)
|