Commit bbab9e89 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 8fd39879
...@@ -606,10 +606,10 @@ type BigFile struct { ...@@ -606,10 +606,10 @@ type BigFile struct {
// i.e. changed under zhead.W // i.e. changed under zhead.W
blksize int64 // zfile.blksize blksize int64 // zfile.blksize
size int64 // zfile.Size() size int64 // zfile.Size()
rev zodb.Tid // last revision that modified zfile data revApprox zodb.Tid // approx last revision that modified zfile data
// XXX we can't know rev fully as some later blocks could be learnt only // ( we can't know rev fully as some later blocks could be learnt only
// while populating δFtail lazily // while populating δFtail lazily. For simplicity we don't delve into
// XXX or then it is not "constant during lifetime of current txn" // updating revApprox during lifetime of current transaction )
// inflight loadings of ZBigFile from ZODB. // inflight loadings of ZBigFile from ZODB.
// successful load results are kept here until blkdata is put into OS pagecache. // successful load results are kept here until blkdata is put into OS pagecache.
...@@ -946,9 +946,9 @@ retry: ...@@ -946,9 +946,9 @@ retry:
bfdir.δFtail.Track(zfile, -1, sizePath, blkCov, nil) bfdir.δFtail.Track(zfile, -1, sizePath, blkCov, nil)
} }
// XXX we can miss a change to file if δblk is not yet tracked // NOTE we can miss a change to file if δblk is not yet tracked
// -> need to update file.rev at read time -> locking=XXX // that's why revision is only approximated
file.rev = zhead.At() file.revApprox = zhead.At()
} }
// notify .wcfs/zhead // notify .wcfs/zhead
...@@ -2194,12 +2194,10 @@ func (head *Head) bigfopen(ctx context.Context, oid zodb.Oid) (_ *BigFile, err e ...@@ -2194,12 +2194,10 @@ func (head *Head) bigfopen(ctx context.Context, oid zodb.Oid) (_ *BigFile, err e
return nil, err return nil, err
} }
blksize := zfile.BlkSize() blksize := zfile.BlkSize()
// XXX it should be revision of both ZBigFile and its data. But we // NOTE file revision should be revision of both ZBigFile and its data. But we
// cannot get data revision without expensive scan of all ZBigFile's objects. // cannot get data revision without expensive scan of all ZBigFile's objects.
// -> approximate mtime initially with ZBigFile object mtime. // -> approximate mtime initially with ZBigFile object mtime.
// revApprox := zfile.PSerial()
// XXX for @rev/... we can know initial mtime more exactly?
rev := zfile.PSerial()
zfile.PDeactivate() zfile.PDeactivate()
size, sizePath, blkCov, err := zfile.Size(ctx) size, sizePath, blkCov, err := zfile.Size(ctx)
...@@ -2213,7 +2211,7 @@ func (head *Head) bigfopen(ctx context.Context, oid zodb.Oid) (_ *BigFile, err e ...@@ -2213,7 +2211,7 @@ func (head *Head) bigfopen(ctx context.Context, oid zodb.Oid) (_ *BigFile, err e
zfile: zfile, zfile: zfile,
blksize: blksize, blksize: blksize,
size: size, size: size,
rev: rev, revApprox: revApprox,
loading: make(map[int64]*blkLoadState), loading: make(map[int64]*blkLoadState),
} }
...@@ -2280,7 +2278,7 @@ func (f *BigFile) getattr(out *fuse.Attr) { ...@@ -2280,7 +2278,7 @@ func (f *BigFile) getattr(out *fuse.Attr) {
out.Blksize = uint32(f.blksize) // NOTE truncating 64 -> 32 out.Blksize = uint32(f.blksize) // NOTE truncating 64 -> 32
// .Blocks // .Blocks
mtime := f.rev.Time().Time mtime := f.revApprox.Time().Time
out.SetTimes(/*atime=*/nil, /*mtime=*/&mtime, /*ctime=*/&mtime) out.SetTimes(/*atime=*/nil, /*mtime=*/&mtime, /*ctime=*/&mtime)
} }
...@@ -2537,7 +2535,7 @@ func _main() (err error) { ...@@ -2537,7 +2535,7 @@ func _main() (err error) {
if errors.Cause(err) != context.Canceled { if errors.Cause(err) != context.Canceled {
log.Error(err) log.Error(err)
log.Errorf("zwatcher failed -> switching filesystem to EIO mode (TODO)") log.Errorf("zwatcher failed -> switching filesystem to EIO mode (TODO)")
//panic("TODO: switch fs to EIO mode") // XXX // TODO: switch fs to EIO mode
} }
// wait for unmount // wait for unmount
......
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