2017-08-11 15:41:57 +01:00
|
|
|
(library
|
2017-09-14 11:47:23 +01:00
|
|
|
(thin mapping-tree)
|
2017-08-11 15:41:57 +01:00
|
|
|
|
2017-09-14 16:09:43 +01:00
|
|
|
(export mapping-tree-lookup
|
2017-08-11 15:41:57 +01:00
|
|
|
mapping-tree-each)
|
|
|
|
|
2017-09-14 11:47:23 +01:00
|
|
|
(import (persistent-data btree)
|
2017-09-14 16:09:43 +01:00
|
|
|
(bcache block-manager)
|
2017-08-11 15:41:57 +01:00
|
|
|
(chezscheme)
|
2017-08-12 19:27:21 +01:00
|
|
|
(srfi s8 receive))
|
2017-08-11 15:41:57 +01:00
|
|
|
|
2017-08-14 10:05:38 +01:00
|
|
|
;; (values <block> <time>)
|
|
|
|
(define time-mask (- (fxsll 1 24) 1))
|
|
|
|
|
|
|
|
(define (unpack-block-time bt)
|
|
|
|
(values (fxsrl bt 24) (fxlogand bt time-mask)))
|
|
|
|
|
|
|
|
;; FIXME: unpack the block time
|
2017-09-14 16:09:43 +01:00
|
|
|
(define (mapping-tree-lookup cache root dev-id vblock default)
|
|
|
|
(with-spine (sp cache 1)
|
|
|
|
(let* ((unique (gensym))
|
|
|
|
(dev-tree (btree-open le64-vt root))
|
|
|
|
(root2 (btree-lookup dev-tree sp dev-id unique)))
|
|
|
|
(if (eq? unique root2)
|
|
|
|
default
|
|
|
|
(btree-lookup (btree-open le64-vt root2) sp vblock default)))))
|
2017-08-11 15:41:57 +01:00
|
|
|
|
2017-08-12 19:27:21 +01:00
|
|
|
;;; Visits every entry in the mapping tree calling (fn dev-id vblock pblock time).
|
2017-09-14 16:09:43 +01:00
|
|
|
(define (mapping-tree-each cache root fn)
|
|
|
|
(with-spine (sp cache 1)
|
|
|
|
(let ((dev-tree (btree-open le64-vt root)))
|
|
|
|
|
|
|
|
(define (visit-dev dev-id mapping-root)
|
|
|
|
(btree-each (btree-open le64-vt mapping-root)
|
|
|
|
(lambda (vblock mapping)
|
|
|
|
(receive (block time) (unpack-block-time mapping)
|
|
|
|
(fn dev-id vblock block time)))))
|
|
|
|
|
|
|
|
(btree-each dev-tree sp visit-dev))))
|
|
|
|
)
|