Commit 5f82a882 authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

Fix unmount notify on root node mounts.

parent 978e8f18
...@@ -315,19 +315,29 @@ func (c *FileSystemConnector) Unmount(node *Inode) Status { ...@@ -315,19 +315,29 @@ func (c *FileSystemConnector) Unmount(node *Inode) Status {
node.treeLock.Lock() node.treeLock.Lock()
defer node.treeLock.Unlock() defer node.treeLock.Unlock()
mountInode := mount.mountInode if mount.mountInode != node {
if !mountInode.canUnmount() { log.Panicf("got two different mount inodes %v vs %v",
mount.mountInode.nodeId, node.nodeId)
}
if !node.canUnmount() {
return EBUSY return EBUSY
} }
mount.mountInode = nil mount.mountInode = nil
// TODO - racy. // TODO - racy.
mountInode.mountPoint = nil node.mountPoint = nil
delete(parentNode.children, name) delete(parentNode.children, name)
mount.fs.OnUnmount() mount.fs.OnUnmount()
c.fsInit.DeleteNotify(parentNode.nodeId, mountInode.nodeId, name) parentId := parentNode.nodeId
if parentNode == c.rootNode {
// TODO - test coverage. Currently covered by zipfs/multizip_test.go
parentId = raw.FUSE_ROOT_ID
}
c.fsInit.DeleteNotify(parentId, node.nodeId, name)
return OK return OK
} }
...@@ -363,22 +373,27 @@ func (c *FileSystemConnector) EntryNotify(dir *Inode, name string) Status { ...@@ -363,22 +373,27 @@ func (c *FileSystemConnector) EntryNotify(dir *Inode, name string) Status {
} }
func (c *FileSystemConnector) DeleteNotify(dir *Inode, child *Inode, name string) Status { func (c *FileSystemConnector) DeleteNotify(dir *Inode, child *Inode, name string) Status {
dir.treeLock.RLock() var nId uint64
n := dir.nodeId
var chId uint64 var chId uint64
dir.treeLock.RLock()
if dir == c.rootNode {
nId = raw.FUSE_ROOT_ID
} else {
nId = dir.nodeId
}
if child.treeLock != dir.treeLock { if child.treeLock != dir.treeLock {
child.treeLock.RLock() child.treeLock.RLock()
chId = child.nodeId chId = child.nodeId
child.treeLock.RUnlock() child.treeLock.RUnlock()
} else {
chId = child.nodeId
} }
dir.treeLock.RUnlock() dir.treeLock.RUnlock()
if dir == c.rootNode { if nId == 0 {
n = raw.FUSE_ROOT_ID
}
if n == 0 {
return OK return OK
} }
return c.fsInit.DeleteNotify(n, chId, name) return c.fsInit.DeleteNotify(nId, chId, name)
} }
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