Commit 0e8a1ecb authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 51eed733
...@@ -53,16 +53,15 @@ from six import reraise ...@@ -53,16 +53,15 @@ from six import reraise
# WCFS represents filesystem-level connection to wcfs server. # WCFS represents filesystem-level connection to wcfs server.
# #
# It has to be created with join. # Use join to create it.
# Only 1 connection is maintained for one file server.
# #
# The primary way to access wcfs is to open logical connection viewing on-wcfs # The primary way to access wcfs is to open logical connection viewing on-wcfs
# data as of particular database state, and use that logical connection to # data as of particular database state, and use that logical connection to
# create base-layer mappings. See .open and Conn for details. # create base-layer mappings. See .connect and Conn for details.
# #
# Raw files on wcfs can be accessed with ._path/._read/._stat/._open . # Raw files on wcfs can be accessed with ._path/._read/._stat/._open .
# #
# XXX WCFS parallels ZODB.DB . # WCFS logically mirrors ZODB.DB .
class WCFS(object): class WCFS(object):
# .mountpoint path to wcfs mountpoint # .mountpoint path to wcfs mountpoint
# ._fwcfs /.wcfs/zurl opened to keep the server from going away (at least cleanly) # ._fwcfs /.wcfs/zurl opened to keep the server from going away (at least cleanly)
...@@ -79,8 +78,9 @@ class WCFS(object): ...@@ -79,8 +78,9 @@ class WCFS(object):
# maintain isolated database view while at the same time sharing most of data # maintain isolated database view while at the same time sharing most of data
# cache in OS pagecache of /head/bigfile/*. # cache in OS pagecache of /head/bigfile/*.
# #
# XXX wc conn <-> zconn # Use .mmap to create new Mappings.
# XXX Conn parallels ZODB.Connection . #
# Conn logically mirrors ZODB.Connection .
class Conn(object): class Conn(object):
# ._wc WCFS # ._wc WCFS
# .at Tid # .at Tid
...@@ -146,7 +146,7 @@ def _pinner(wconn, ctx): ...@@ -146,7 +146,7 @@ def _pinner(wconn, ctx):
continue continue
# FIXME check if virtmem did not mapped RW page into this block already # FIXME check if virtmem did not mapped RW page into this block already
mmap.mmapblk(req.blk, req.at) mmap._mmapblk(req.blk, req.at)
# update f.pinned # update f.pinned
if req.at is None: if req.at is None:
...@@ -155,12 +155,12 @@ def _pinner(wconn, ctx): ...@@ -155,12 +155,12 @@ def _pinner(wconn, ctx):
f.pinned[req.blk] = req.at f.pinned[req.blk] = req.at
# pin remmaps mapping memory for [blk] to be viewing database as of @at state. # _mmapblk remmaps mapping memory for file[blk] to be viewing database as of @at state.
# #
# at=None means unpin to head/ . # at=None means unpin to head/ .
# NOTE this does not check wrt virtmem already mapped blk as RW XXX ok? # NOTE this does not check wrt virtmem already mapped blk as RW XXX ok?
@func(_Mapping) @func(_Mapping)
def pin(mmap, blk, at): def _mmapblk(mmap, blk, at):
assert mmap.blk_start <= blk < mmap.blk_stop assert mmap.blk_start <= blk < mmap.blk_stop
f = mmap.file f = mmap.file
if at is None: if at is None:
...@@ -188,10 +188,10 @@ def mmap(wconn, foid, offset, size): # -> Mapping XXX offset, size -> blko ...@@ -188,10 +188,10 @@ def mmap(wconn, foid, offset, size): # -> Mapping XXX offset, size -> blko
# create memory with head/f mapping and applied pins # create memory with head/f mapping and applied pins
mem = mm.mmap_ro(f.headf.fileno(), offset, size) mem = mm.mmap_ro(f.headf.fileno(), offset, size)
mmap = _Mapping(f, blk_start, mem) mmap = _Mapping(f, blk_start, mem)
for blk, rev in f.pin.items(): # XXX keep f.pin ↑blk and use binary search? for blk, rev in f.pinned.items(): # XXX keep f.pinned ↑blk and use binary search?
if not (blk_start <= blk && blk < blk_stop): if not (blk_start <= blk && blk < blk_stop):
continue # blk out of this mapping continue # blk out of this mapping
mmap.mmapblk(blk, rev) mmap._mmapblk(blk, rev)
f.mmaps.append(mmap) # XXX keep f.mmaps ↑blk_start f.mmaps.append(mmap) # XXX keep f.mmaps ↑blk_start
...@@ -204,7 +204,7 @@ def remmap_blk(mmap, blk): ...@@ -204,7 +204,7 @@ def remmap_blk(mmap, blk):
# XXX locking # XXX locking
assert (mmap.blk_start <= blk < mmap.blk_stop) assert (mmap.blk_start <= blk < mmap.blk_stop)
blkrev = mmap.pinned.get(blk, None) # rev | @head blkrev = mmap.pinned.get(blk, None) # rev | @head
mmap.mmapblk(blk, blkrev) mmap._mmapblk(blk, blkrev)
# unmap is removes mapping memory from address space. # unmap is removes mapping memory from address space.
...@@ -580,6 +580,8 @@ def _default_autostart(): ...@@ -580,6 +580,8 @@ def _default_autostart():
# #
# If wcfs for that zurl was already started, join connects to it. # If wcfs for that zurl was already started, join connects to it.
# Otherwise it starts wcfs for zurl if autostart is True. # Otherwise it starts wcfs for zurl if autostart is True.
#
# For the same zurl join returns the WCFS object.
def join(zurl, autostart=_default_autostart()): # -> WCFS def join(zurl, autostart=_default_autostart()): # -> WCFS
mntpt = _mntpt_4zurl(zurl) mntpt = _mntpt_4zurl(zurl)
with _wcmu: with _wcmu:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment