Commit 4e5298c2 authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

Really flush fd in LoopbackFile.Flush.

This will catch potential data loss when the underlying storage is
full or faulty.
parent 0c3881b5
...@@ -122,7 +122,6 @@ func (f *LoopbackFile) Write(data []byte, off int64) (uint32, Status) { ...@@ -122,7 +122,6 @@ func (f *LoopbackFile) Write(data []byte, off int64) (uint32, Status) {
return uint32(n), ToStatus(err) return uint32(n), ToStatus(err)
} }
// TODO - should bring back close error back to user space.
func (f *LoopbackFile) Release() { func (f *LoopbackFile) Release() {
f.lock.Lock() f.lock.Lock()
f.File.Close() f.File.Close()
...@@ -130,7 +129,19 @@ func (f *LoopbackFile) Release() { ...@@ -130,7 +129,19 @@ func (f *LoopbackFile) Release() {
} }
func (f *LoopbackFile) Flush() Status { func (f *LoopbackFile) Flush() Status {
return OK f.lock.Lock()
// Since Flush() may be called for each dup'd fd, we don't
// want to really close the file, we just want to flush. This
// is achieved by closing a dup'd fd.
newFd, err := syscall.Dup(int(f.File.Fd()))
f.lock.Unlock()
if err != nil {
return ToStatus(err)
}
err = syscall.Close(newFd)
return ToStatus(err)
} }
func (f *LoopbackFile) Fsync(flags int) (code Status) { func (f *LoopbackFile) Fsync(flags int) (code Status) {
......
...@@ -43,6 +43,7 @@ func (fs *LoopbackFileSystem) GetAttr(name string, context *Context) (a *Attr, c ...@@ -43,6 +43,7 @@ func (fs *LoopbackFileSystem) GetAttr(name string, context *Context) (a *Attr, c
} else { } else {
err = syscall.Lstat(fullPath, &st) err = syscall.Lstat(fullPath, &st)
} }
if err != nil { if err != nil {
return nil, ToStatus(err) return nil, ToStatus(err)
} }
......
...@@ -5,6 +5,7 @@ import ( ...@@ -5,6 +5,7 @@ import (
"log" "log"
"os" "os"
"sync" "sync"
"syscall"
"time" "time"
) )
...@@ -147,11 +148,16 @@ func (n *memNodeFile) InnerFile() File { ...@@ -147,11 +148,16 @@ func (n *memNodeFile) InnerFile() File {
func (n *memNodeFile) Flush() Status { func (n *memNodeFile) Flush() Status {
code := n.LoopbackFile.Flush() code := n.LoopbackFile.Flush()
var a Attr
n.LoopbackFile.GetAttr(&a) if !code.Ok() {
n.node.info.Size = a.Size return code
n.node.info.Blocks = a.Blocks }
return code
st := syscall.Stat_t{}
err := syscall.Stat(n.node.filename(), &st)
n.node.info.Size = uint64(st.Size)
n.node.info.Blocks = uint64(st.Blocks)
return ToStatus(err)
} }
func (n *memNode) newFile(f *os.File) File { func (n *memNode) newFile(f *os.File) File {
......
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