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
eac823f2
Commit
eac823f2
authored
Jan 15, 2020
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
95bbdf2a
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
22 additions
and
12 deletions
+22
-12
wcfs/internal/wcfs.cpp
wcfs/internal/wcfs.cpp
+20
-12
wcfs/internal/wcfs.h
wcfs/internal/wcfs.h
+1
-0
wcfs/wcfs_test.py
wcfs/wcfs_test.py
+1
-0
No files found.
wcfs/internal/wcfs.cpp
View file @
eac823f2
...
@@ -108,8 +108,7 @@ static global<error> errConnClosed = errors::New("connection closed");
...
@@ -108,8 +108,7 @@ static global<error> errConnClosed = errors::New("connection closed");
// close releases resources associated with wconn.
// close releases resources associated with wconn.
//
//
// opened fileh and mappings becomes invalid to use.
// opened fileh and mappings becomes invalid to use except close and unmap.
// XXX what happens to file mmappings?
error
_Conn
::
close
()
{
error
_Conn
::
close
()
{
_Conn
&
wconn
=
*
this
;
_Conn
&
wconn
=
*
this
;
//xerr::Contextf E("close conn @%s", v(wconn.at));
//xerr::Contextf E("close conn @%s", v(wconn.at));
...
@@ -135,9 +134,10 @@ error _Conn::close() {
...
@@ -135,9 +134,10 @@ error _Conn::close() {
reterr1
(
err
);
reterr1
(
err
);
// close all files - both that have no mappings and that still have opened mappings.
// close all files - both that have no mappings and that still have opened mappings.
// XXX after file is closed mappings continue to survive, but we can no
//
// longer maintain consistent view.
// NOTE after file is closed mappings could continue to survive, but we can no
// XXX change mapping to something that gives EFAULT on access?
// longer maintain consistent view. For this reason we change mappings to
// something that gives EFAULT on access. XXX implement
wconn
.
_filehmu
.
lock
();
wconn
.
_filehmu
.
lock
();
defer
([
&
]()
{
defer
([
&
]()
{
wconn
.
_filehmu
.
unlock
();
wconn
.
_filehmu
.
unlock
();
...
@@ -145,7 +145,7 @@ error _Conn::close() {
...
@@ -145,7 +145,7 @@ error _Conn::close() {
for
(
auto
_
:
wconn
.
_filehtab
)
{
for
(
auto
_
:
wconn
.
_filehtab
)
{
auto
f
=
_
.
second
;
auto
f
=
_
.
second
;
err
=
f
->
_headf
->
close
();
// XXX
better -> fileh.close()? or deadlock on ._filehmu ?
err
=
f
->
_headf
->
close
();
// XXX
mark fileh as down so that fileh.close does not say "bad fd"
if
(
err
!=
nil
)
if
(
err
!=
nil
)
reterr1
(
err
);
reterr1
(
err
);
f
->
_headf
=
nil
;
f
->
_headf
=
nil
;
...
@@ -302,13 +302,13 @@ pair<FileH, error> _Conn::open(zodb::Oid foid) {
...
@@ -302,13 +302,13 @@ pair<FileH, error> _Conn::open(zodb::Oid foid) {
wconn
.
_filehmu
.
unlock
();
wconn
.
_filehmu
.
unlock
();
});
});
if
(
wconn
.
_downErr
!=
nil
)
if
(
wconn
.
_downErr
!=
nil
)
// XXX under filehmu or downMu ?
return
make_pair
(
nil
,
E
(
wconn
.
_downErr
));
return
make_pair
(
nil
,
E
(
wconn
.
_downErr
));
FileH
f
;
bool
ok
;
FileH
f
;
bool
ok
;
tie
(
f
,
ok
)
=
wconn
.
_filehtab
.
get
(
foid
);
tie
(
f
,
ok
)
=
wconn
.
_filehtab
.
get
(
foid
);
if
(
f
!=
nil
)
{
if
(
f
!=
nil
)
{
// XXX incref open count
?
// XXX incref open count
return
make_pair
(
f
,
nil
);
return
make_pair
(
f
,
nil
);
}
}
...
@@ -349,12 +349,20 @@ pair<FileH, error> _Conn::open(zodb::Oid foid) {
...
@@ -349,12 +349,20 @@ pair<FileH, error> _Conn::open(zodb::Oid foid) {
// close releases resources associated with FileH.
// close releases resources associated with FileH.
//
//
// Left fileh mappings become invalid to use.
// Left fileh mappings become invalid to use
except unmap
.
error
_FileH
::
close
()
{
error
_FileH
::
close
()
{
_FileH
&
fileh
=
*
this
;
_FileH
&
fileh
=
*
this
;
xerr
::
Contextf
E
(
"conn @%s: close f<%s>"
,
v
(
fileh
.
wconn
->
at
),
v
(
fileh
.
foid
));
// XXX + wcfs path?
Conn
wconn
=
fileh
.
wconn
;
xerr
::
Contextf
E
(
"conn @%s: close f<%s>"
,
v
(
wconn
->
at
),
v
(
fileh
.
foid
));
// XXX + wcfs path?
// XXX remove fileh from .wconn._filehtab ?
// remove fileh from wconn._filehtab
// fileh.close can be called several times and after first call another
// fileh could be opened for the same foid. Be careful not to erase it.
wconn
->
_filehmu
.
lock
();
// XXX decref open count
if
(
wconn
->
_filehtab
.
get
(
fileh
.
foid
)
==
fileh
)
wconn
->
_filehtab
.
erase
(
fileh
.
foid
);
wconn
->
_filehmu
.
unlock
();
return
E
(
fileh
.
_headf
->
close
());
return
E
(
fileh
.
_headf
->
close
());
}
}
...
...
wcfs/internal/wcfs.h
View file @
eac823f2
...
@@ -104,6 +104,7 @@ struct _Conn : object {
...
@@ -104,6 +104,7 @@ struct _Conn : object {
zodb
::
Tid
at
;
zodb
::
Tid
at
;
WatchLink
_wlink
;
// watch/receive pins for mappings created under this conn
WatchLink
_wlink
;
// watch/receive pins for mappings created under this conn
// XXX kill downMu? (move under filehmu so that e.g. .open() can check downErr without race)
sync
::
Mutex
_downMu
;
sync
::
Mutex
_downMu
;
error
_downErr
;
// !nil if connection is closed or no longer operational
error
_downErr
;
// !nil if connection is closed or no longer operational
...
...
wcfs/wcfs_test.py
View file @
eac823f2
...
@@ -1820,6 +1820,7 @@ def test_wcfs_virtmem():
...
@@ -1820,6 +1820,7 @@ def test_wcfs_virtmem():
# XXX w mapping with RW - in sync
# XXX w mapping with RW - in sync
# XXX fh close then open again and use
# XXX fh close then open again and use
# XXX open same fh twice, close once - fh2 continue to work ok
# XXX wconn.open() after wconn.close() -> error
# XXX wconn.open() after wconn.close() -> error
# XXX wconn.resync() after wconn.close() -> error
# XXX wconn.resync() after wconn.close() -> error
...
...
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