Commit 1b4a34cc authored by Srdjan Rilak's avatar Srdjan Rilak

Add CreateLink implementation

parent 88e3bc5f
...@@ -420,6 +420,32 @@ func convertInMessage( ...@@ -420,6 +420,32 @@ func convertInMessage(
Flags: fusekernel.InitFlags(in.Flags), Flags: fusekernel.InitFlags(in.Flags),
} }
case fusekernel.OpLink:
type input fusekernel.LinkIn
in := (*input)(inMsg.Consume(unsafe.Sizeof(input{})))
if in == nil {
err = errors.New("Corrupt OpLink")
return
}
name := inMsg.ConsumeBytes(inMsg.Len())
i := bytes.IndexByte(name, '\x00')
if i < 0 {
err = errors.New("Corrupt OpLink")
return
}
name = name[:i]
if len(name) == 0 {
err = errors.New("Corrupt OpLink (Name not read)")
return
}
o = &fuseops.CreateLinkOp{
Parent: fuseops.InodeID(inMsg.Header().Nodeid),
Name: string(name),
Target: fuseops.InodeID(in.Oldnodeid),
}
case fusekernel.OpRemovexattr: case fusekernel.OpRemovexattr:
buf := inMsg.ConsumeBytes(inMsg.Len()) buf := inMsg.ConsumeBytes(inMsg.Len())
n := len(buf) n := len(buf)
...@@ -647,6 +673,11 @@ func (c *Connection) kernelResponseForOp( ...@@ -647,6 +673,11 @@ func (c *Connection) kernelResponseForOp(
out := (*fusekernel.EntryOut)(m.Grow(size)) out := (*fusekernel.EntryOut)(m.Grow(size))
convertChildInodeEntry(&o.Entry, out) convertChildInodeEntry(&o.Entry, out)
case *fuseops.CreateLinkOp:
size := int(fusekernel.EntryOutSize(c.protocol))
out := (*fusekernel.EntryOut)(m.Grow(size))
convertChildInodeEntry(&o.Entry, out)
case *fuseops.RenameOp: case *fuseops.RenameOp:
// Empty response // Empty response
......
...@@ -317,6 +317,26 @@ type CreateSymlinkOp struct { ...@@ -317,6 +317,26 @@ type CreateSymlinkOp struct {
Entry ChildInodeEntry Entry ChildInodeEntry
} }
// Create a hard link to an inode. If the name already exists, the file system
// should return EEXIST (cf. the notes on CreateFileOp and MkDirOp).
type CreateLinkOp struct {
// The ID of parent directory inode within which to create the child hard
// link.
Parent InodeID
// The name of the new inode.
Name string
// The ID of the target inode.
Target InodeID
// Set by the file system: information about the inode that was created.
//
// The lookup count for the inode is implicitly incremented. See notes on
// ForgetInodeOp for more information.
Entry ChildInodeEntry
}
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
// Unlinking // Unlinking
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
......
...@@ -43,6 +43,7 @@ type FileSystem interface { ...@@ -43,6 +43,7 @@ type FileSystem interface {
MkDir(context.Context, *fuseops.MkDirOp) error MkDir(context.Context, *fuseops.MkDirOp) error
MkNode(context.Context, *fuseops.MkNodeOp) error MkNode(context.Context, *fuseops.MkNodeOp) error
CreateFile(context.Context, *fuseops.CreateFileOp) error CreateFile(context.Context, *fuseops.CreateFileOp) error
CreateLink(context.Context, *fuseops.CreateLinkOp) error
CreateSymlink(context.Context, *fuseops.CreateSymlinkOp) error CreateSymlink(context.Context, *fuseops.CreateSymlinkOp) error
Rename(context.Context, *fuseops.RenameOp) error Rename(context.Context, *fuseops.RenameOp) error
RmDir(context.Context, *fuseops.RmDirOp) error RmDir(context.Context, *fuseops.RmDirOp) error
...@@ -159,6 +160,9 @@ func (s *fileSystemServer) handleOp( ...@@ -159,6 +160,9 @@ func (s *fileSystemServer) handleOp(
case *fuseops.CreateFileOp: case *fuseops.CreateFileOp:
err = s.fs.CreateFile(ctx, typed) err = s.fs.CreateFile(ctx, typed)
case *fuseops.CreateLinkOp:
err = s.fs.CreateLink(ctx, typed)
case *fuseops.CreateSymlinkOp: case *fuseops.CreateSymlinkOp:
err = s.fs.CreateSymlink(ctx, typed) err = s.fs.CreateSymlink(ctx, typed)
......
...@@ -92,6 +92,13 @@ func (fs *NotImplementedFileSystem) CreateSymlink( ...@@ -92,6 +92,13 @@ func (fs *NotImplementedFileSystem) CreateSymlink(
return return
} }
func (fs *NotImplementedFileSystem) CreateLink(
ctx context.Context,
op *fuseops.CreateLinkOp) (err error) {
err = fuse.ENOSYS
return
}
func (fs *NotImplementedFileSystem) Rename( func (fs *NotImplementedFileSystem) Rename(
ctx context.Context, ctx context.Context,
op *fuseops.RenameOp) (err error) { op *fuseops.RenameOp) (err error) {
......
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