Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go-fuse
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
Kirill Smelkov
go-fuse
Commits
98c05019
Commit
98c05019
authored
Mar 27, 2016
by
Jakob Unterwurzacher
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
misc: add comments, small logging improvements
Change-Id: I5612016b2bccf9e28186a83f2f420cefe1c30120
parent
5f1423b7
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
38 additions
and
12 deletions
+38
-12
example/loopback/main.go
example/loopback/main.go
+1
-1
fuse/nodefs/fsconnector.go
fuse/nodefs/fsconnector.go
+1
-0
fuse/nodefs/fsops.go
fuse/nodefs/fsops.go
+6
-0
fuse/nodefs/handle.go
fuse/nodefs/handle.go
+17
-5
fuse/nodefs/inode.go
fuse/nodefs/inode.go
+2
-0
fuse/opcode.go
fuse/opcode.go
+2
-0
fuse/print.go
fuse/print.go
+3
-2
unionfs/unionfs_test.go
unionfs/unionfs_test.go
+6
-4
No files found.
example/loopback/main.go
View file @
98c05019
...
@@ -4,9 +4,9 @@
...
@@ -4,9 +4,9 @@
package
main
package
main
import
(
import
(
"log"
"flag"
"flag"
"fmt"
"fmt"
"log"
"os"
"os"
"path"
"path"
"path/filepath"
"path/filepath"
...
...
fuse/nodefs/fsconnector.go
View file @
98c05019
...
@@ -114,6 +114,7 @@ func (c *FileSystemConnector) lookupUpdate(node *Inode) (id, generation uint64)
...
@@ -114,6 +114,7 @@ func (c *FileSystemConnector) lookupUpdate(node *Inode) (id, generation uint64)
return
return
}
}
// forgetUpdate decrements the reference counter for "nodeID" by "forgetCount".
// Must run outside treeLock.
// Must run outside treeLock.
func
(
c
*
FileSystemConnector
)
forgetUpdate
(
nodeID
uint64
,
forgetCount
int
)
{
func
(
c
*
FileSystemConnector
)
forgetUpdate
(
nodeID
uint64
,
forgetCount
int
)
{
if
nodeID
==
fuse
.
FUSE_ROOT_ID
{
if
nodeID
==
fuse
.
FUSE_ROOT_ID
{
...
...
fuse/nodefs/fsops.go
View file @
98c05019
...
@@ -68,8 +68,14 @@ func (c *FileSystemConnector) lookupMountUpdate(out *fuse.Attr, mount *fileSyste
...
@@ -68,8 +68,14 @@ func (c *FileSystemConnector) lookupMountUpdate(out *fuse.Attr, mount *fileSyste
return
mount
.
mountInode
,
fuse
.
OK
return
mount
.
mountInode
,
fuse
.
OK
}
}
// internalLookup executes a lookup without affecting NodeId reference counts.
func
(
c
*
FileSystemConnector
)
internalLookup
(
out
*
fuse
.
Attr
,
parent
*
Inode
,
name
string
,
header
*
fuse
.
InHeader
)
(
node
*
Inode
,
code
fuse
.
Status
)
{
func
(
c
*
FileSystemConnector
)
internalLookup
(
out
*
fuse
.
Attr
,
parent
*
Inode
,
name
string
,
header
*
fuse
.
InHeader
)
(
node
*
Inode
,
code
fuse
.
Status
)
{
// We may already know the child because it was created using Create or Mkdir,
// from an earlier lookup, or because the nodes were created in advance
// (in-memory filesystems).
child
:=
parent
.
GetChild
(
name
)
child
:=
parent
.
GetChild
(
name
)
if
child
!=
nil
&&
child
.
mountPoint
!=
nil
{
if
child
!=
nil
&&
child
.
mountPoint
!=
nil
{
return
c
.
lookupMountUpdate
(
out
,
child
.
mountPoint
)
return
c
.
lookupMountUpdate
(
out
,
child
.
mountPoint
)
}
}
...
...
fuse/nodefs/handle.go
View file @
98c05019
...
@@ -6,20 +6,27 @@ import (
...
@@ -6,20 +6,27 @@ import (
)
)
// HandleMap translates objects in Go space to 64-bit handles that can
// HandleMap translates objects in Go space to 64-bit handles that can
// be given out to -say- the linux kernel.
// be given out to -say- the linux kernel
as NodeIds
.
//
//
// The 32 bits version of this is a threadsafe wrapper around a map.
// The 32 bits version of this is a threadsafe wrapper around a map.
//
//
// To use it, include
Handled
as first member of the structure
// To use it, include
"handled"
as first member of the structure
// you wish to export.
// you wish to export.
//
//
// This structure is thread-safe.
// This structure is thread-safe.
type
handleMap
interface
{
type
handleMap
interface
{
// Register stores "obj" and returns a unique (NodeId, generation) tuple.
Register
(
obj
*
handled
)
(
handle
,
generation
uint64
)
Register
(
obj
*
handled
)
(
handle
,
generation
uint64
)
Count
()
int
Count
()
int
// Decode retrieves a stored object from its 64-bit handle.
Decode
(
uint64
)
*
handled
Decode
(
uint64
)
*
handled
// Forget decrements the reference counter for "handle" by "count" and drops
// the object if the refcount reaches zero.
// Returns a boolean whether the object was dropped and the object itself.
Forget
(
handle
uint64
,
count
int
)
(
bool
,
*
handled
)
Forget
(
handle
uint64
,
count
int
)
(
bool
,
*
handled
)
// Handle gets the object's NodeId.
Handle
(
obj
*
handled
)
uint64
Handle
(
obj
*
handled
)
uint64
// Has checks if NodeId is stored.
Has
(
uint64
)
bool
Has
(
uint64
)
bool
}
}
...
@@ -45,9 +52,14 @@ const _ALREADY_MSG = "Object already has a handle"
...
@@ -45,9 +52,14 @@ const _ALREADY_MSG = "Object already has a handle"
type
portableHandleMap
struct
{
type
portableHandleMap
struct
{
sync
.
RWMutex
sync
.
RWMutex
// The generation counter is incremented each time a NodeId is reused,
// hence the (NodeId, Generation) tuple is always unique.
generation
uint64
generation
uint64
// Number of currently used handles
used
int
used
int
// Array of Go objects indexed by NodeId
handles
[]
*
handled
handles
[]
*
handled
// Free slots in the "handles" array
freeIds
[]
uint64
freeIds
[]
uint64
}
}
...
...
fuse/nodefs/inode.go
View file @
98c05019
...
@@ -163,6 +163,7 @@ func (n *Inode) RmChild(name string) (ch *Inode) {
...
@@ -163,6 +163,7 @@ func (n *Inode) RmChild(name string) (ch *Inode) {
//////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////
// private
// private
// addChild adds "child" to our children under name "name".
// Must be called with treeLock for the mount held.
// Must be called with treeLock for the mount held.
func
(
n
*
Inode
)
addChild
(
name
string
,
child
*
Inode
)
{
func
(
n
*
Inode
)
addChild
(
name
string
,
child
*
Inode
)
{
if
paranoia
{
if
paranoia
{
...
@@ -177,6 +178,7 @@ func (n *Inode) addChild(name string, child *Inode) {
...
@@ -177,6 +178,7 @@ func (n *Inode) addChild(name string, child *Inode) {
}
}
}
}
// rmChild drops "name" from our children.
// Must be called with treeLock for the mount held.
// Must be called with treeLock for the mount held.
func
(
n
*
Inode
)
rmChild
(
name
string
)
*
Inode
{
func
(
n
*
Inode
)
rmChild
(
name
string
)
*
Inode
{
ch
:=
n
.
children
[
name
]
ch
:=
n
.
children
[
name
]
...
...
fuse/opcode.go
View file @
98c05019
...
@@ -229,12 +229,14 @@ func doGetAttr(server *Server, req *request) {
...
@@ -229,12 +229,14 @@ func doGetAttr(server *Server, req *request) {
req
.
status
=
s
req
.
status
=
s
}
}
// doForget - forget one NodeId
func
doForget
(
server
*
Server
,
req
*
request
)
{
func
doForget
(
server
*
Server
,
req
*
request
)
{
if
!
server
.
opts
.
RememberInodes
{
if
!
server
.
opts
.
RememberInodes
{
server
.
fileSystem
.
Forget
(
req
.
inHeader
.
NodeId
,
(
*
ForgetIn
)(
req
.
inData
)
.
Nlookup
)
server
.
fileSystem
.
Forget
(
req
.
inHeader
.
NodeId
,
(
*
ForgetIn
)(
req
.
inData
)
.
Nlookup
)
}
}
}
}
// doBatchForget - forget a list of NodeIds
func
doBatchForget
(
server
*
Server
,
req
*
request
)
{
func
doBatchForget
(
server
*
Server
,
req
*
request
)
{
in
:=
(
*
_BatchForgetIn
)(
req
.
inData
)
in
:=
(
*
_BatchForgetIn
)(
req
.
inData
)
wantBytes
:=
uintptr
(
in
.
Count
)
*
unsafe
.
Sizeof
(
_ForgetOne
{})
wantBytes
:=
uintptr
(
in
.
Count
)
*
unsafe
.
Sizeof
(
_ForgetOne
{})
...
...
fuse/print.go
View file @
98c05019
...
@@ -93,11 +93,11 @@ func FlagString(names map[int64]string, fl int64, def string) string {
...
@@ -93,11 +93,11 @@ func FlagString(names map[int64]string, fl int64, def string) string {
}
}
func
(
me
*
ForgetIn
)
string
()
string
{
func
(
me
*
ForgetIn
)
string
()
string
{
return
fmt
.
Sprintf
(
"{%d}"
,
me
.
Nlookup
)
return
fmt
.
Sprintf
(
"{
Nlookup=
%d}"
,
me
.
Nlookup
)
}
}
func
(
me
*
_BatchForgetIn
)
string
()
string
{
func
(
me
*
_BatchForgetIn
)
string
()
string
{
return
fmt
.
Sprintf
(
"{%d}"
,
me
.
Count
)
return
fmt
.
Sprintf
(
"{
Count=
%d}"
,
me
.
Count
)
}
}
func
(
me
*
MkdirIn
)
string
()
string
{
func
(
me
*
MkdirIn
)
string
()
string
{
...
@@ -195,6 +195,7 @@ func (me *AttrOut) string() string {
...
@@ -195,6 +195,7 @@ func (me *AttrOut) string() string {
me
.
AttrValid
,
me
.
AttrValidNsec
,
&
me
.
Attr
)
me
.
AttrValid
,
me
.
AttrValidNsec
,
&
me
.
Attr
)
}
}
// Returned by LOOKUP
func
(
me
*
EntryOut
)
string
()
string
{
func
(
me
*
EntryOut
)
string
()
string
{
return
fmt
.
Sprintf
(
"{NodeId: %d Generation=%d EntryValid=%d.%03d AttrValid=%d.%03d Attr=%v}"
,
return
fmt
.
Sprintf
(
"{NodeId: %d Generation=%d EntryValid=%d.%03d AttrValid=%d.%03d Attr=%v}"
,
me
.
NodeId
,
me
.
Generation
,
me
.
EntryValid
,
me
.
EntryValidNsec
/
1000000
,
me
.
NodeId
,
me
.
Generation
,
me
.
EntryValid
,
me
.
EntryValidNsec
/
1000000
,
...
...
unionfs/unionfs_test.go
View file @
98c05019
...
@@ -51,13 +51,15 @@ func setRecursiveWritable(t *testing.T, dir string, writable bool) {
...
@@ -51,13 +51,15 @@ func setRecursiveWritable(t *testing.T, dir string, writable bool) {
}
}
}
}
// Creates 3 directories on a temporary dir: /mnt with the overlayed
// Creates a temporary dir "wd" with 3 directories:
// (unionfs) mount, rw with modifiable data, and ro on the bottom.
// mnt ... overlayed (unionfs) mount
func
setupUfs
(
t
*
testing
.
T
)
(
workdir
string
,
cleanup
func
())
{
// rw .... modifiable data
// ro .... read-only data
func
setupUfs
(
t
*
testing
.
T
)
(
wd
string
,
cleanup
func
())
{
// Make sure system setting does not affect test.
// Make sure system setting does not affect test.
syscall
.
Umask
(
0
)
syscall
.
Umask
(
0
)
wd
,
_
:
=
ioutil
.
TempDir
(
""
,
"unionfs"
)
wd
,
_
=
ioutil
.
TempDir
(
""
,
"unionfs"
)
err
:=
os
.
Mkdir
(
wd
+
"/mnt"
,
0700
)
err
:=
os
.
Mkdir
(
wd
+
"/mnt"
,
0700
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Fatalf
(
"Mkdir failed: %v"
,
err
)
t
.
Fatalf
(
"Mkdir failed: %v"
,
err
)
...
...
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