Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
wendelin.core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Joshua
wendelin.core
Commits
26bc909a
Commit
26bc909a
authored
Mar 02, 2020
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
50838492
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
10 deletions
+21
-10
wcfs/client/wcfs.cpp
wcfs/client/wcfs.cpp
+20
-9
wcfs/client/wcfs.h
wcfs/client/wcfs.h
+1
-1
No files found.
wcfs/client/wcfs.cpp
View file @
26bc909a
...
@@ -583,17 +583,21 @@ error _Conn::resync(zodb::Tid at) {
...
@@ -583,17 +583,21 @@ error _Conn::resync(zodb::Tid at) {
atMuWLocked
=
false
;
atMuWLocked
=
false
;
// send watch updates to wcfs.
// send watch updates to wcfs.
// the pinner is now running and will be able to serve pin requests triggered by out watch.
// the pinner is now running and will be able to serve pin requests triggered by our watch.
//
// update only fileh in "opened" state - for fileh in "opening" and
// "closing" states, watch setup is currently in-progress and performed by
// Conn.open and FileH.close correspondingly.
for
(
auto
fit
:
wconn
.
_filehTab
)
{
for
(
auto
fit
:
wconn
.
_filehTab
)
{
zodb
::
Oid
foid
=
fit
.
first
;
zodb
::
Oid
foid
=
fit
.
first
;
//FileH f = fit.second;
FileH
f
=
fit
.
second
;
// XXX locking ok? (protected by wconn._mu ?)
if
(
f
->
_state
!=
_FileHOpened
)
continue
;
// XXX need to lock f.mu because wconn.atMu is only R now.
// XXX need to lock f.mu because wconn.atMu is only R now. (???)
// XXX need to coordinate with e.g. FileH.close -> "if f.state != CLOSING" ?
// XXX need to coordinate with e.g. Conn.open -> "if f.state != OPENING" ?
string
ack
;
string
ack
;
// XXX f._watchMu.lock() + unlock()
// XXX + recheck status before sending the watch?
tie
(
ack
,
err
)
=
wconn
.
_wlink
->
sendReq
(
context
::
background
(),
fmt
::
sprintf
(
"watch %s @%s"
,
v
(
foid
),
v
(
at
)));
tie
(
ack
,
err
)
=
wconn
.
_wlink
->
sendReq
(
context
::
background
(),
fmt
::
sprintf
(
"watch %s @%s"
,
v
(
foid
),
v
(
at
)));
if
(
err
!=
nil
)
if
(
err
!=
nil
)
return
E
(
err
);
return
E
(
err
);
...
@@ -687,7 +691,7 @@ retry:
...
@@ -687,7 +691,7 @@ retry:
wconn
.
_filehTab
.
erase
(
foid
);
wconn
.
_filehTab
.
erase
(
foid
);
wconn
.
_mu
.
Unlock
();
wconn
.
_mu
.
Unlock
();
}
}
f
->
_state
=
_FileHOpened
;
f
->
_state
=
_FileHOpened
;
// XXX move under wconn._mu ?
f
->
_openReady
.
close
();
f
->
_openReady
.
close
();
});
});
wconn
.
_mu
.
Unlock
();
wconn
.
_mu
.
Unlock
();
...
@@ -764,7 +768,8 @@ error _FileH::close() {
...
@@ -764,7 +768,8 @@ error _FileH::close() {
});
});
// fileh.close can be called several times. just return nil for second close.
// fileh.close can be called several times. just return nil for second close.
if
(
fileh
.
_closed
)
// if (fileh._closed)
if
(
fileh
.
_state
>=
_FileHClosing
)
return
nil
;
return
nil
;
// decref open count; do real close only when last open goes away.
// decref open count; do real close only when last open goes away.
...
@@ -777,6 +782,9 @@ error _FileH::close() {
...
@@ -777,6 +782,9 @@ error _FileH::close() {
// last open went away - real close.
// last open went away - real close.
xerr
::
Contextf
E
(
"%s: close f<%s>"
,
v
(
wconn
),
v
(
fileh
.
foid
));
xerr
::
Contextf
E
(
"%s: close f<%s>"
,
v
(
wconn
),
v
(
fileh
.
foid
));
ASSERT
(
fileh
.
_state
==
_FileHOpened
);
// there can be no open-in-progress, because
fileh
.
_state
=
_FileHClosing
;
// .close() can be called only on "opened" fileh
error
err
,
eret
;
error
err
,
eret
;
auto
reterr1
=
[
&
eret
](
error
err
)
{
auto
reterr1
=
[
&
eret
](
error
err
)
{
if
(
eret
==
nil
&&
err
!=
nil
)
if
(
eret
==
nil
&&
err
!=
nil
)
...
@@ -785,6 +793,9 @@ error _FileH::close() {
...
@@ -785,6 +793,9 @@ error _FileH::close() {
// XXX change all fileh.mmaps to cause EFAULT on any access after fileh.close
// XXX change all fileh.mmaps to cause EFAULT on any access after fileh.close
// XXX unlock wconn.mu
// XXX unlock f.mu
// stop watching f XXX ok under f.mu ?
// stop watching f XXX ok under f.mu ?
string
ack
;
string
ack
;
// XXX f._watchMu.lock() + unlock
// XXX f._watchMu.lock() + unlock
...
...
wcfs/client/wcfs.h
View file @
26bc909a
...
@@ -252,7 +252,7 @@ struct _FileH : object {
...
@@ -252,7 +252,7 @@ struct _FileH : object {
bool
_closed
;
// y after .close()
bool
_closed
;
// y after .close()
// "watch <.foid> ..." requests we send to wcfs are serialized via FileH._watchMu
// "watch <.foid> ..." requests we send to wcfs are serialized via FileH._watchMu
// XXX sync::Mutex _watchMu;
// XXX sync::Mutex _watchMu;
XXX kill
// don't new - create via Conn.open
// don't new - create via Conn.open
private:
private:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment