Commit 6293a019 authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

nodefs: fix double syscall.Close

syscall.Close is not safe to run twice. Reused fds cause random things
to break.
parent f4f9e240
...@@ -147,22 +147,39 @@ func TestCopyFileRange(t *testing.T) { ...@@ -147,22 +147,39 @@ func TestCopyFileRange(t *testing.T) {
if err != nil { if err != nil {
t.Fatalf("Open src: %v", err) t.Fatalf("Open src: %v", err)
} }
defer syscall.Close(f1) defer func() {
// syscall.Close() is treacherous; because fds are
// reused, a double close can cause serious havoc
if f1 > 0 {
syscall.Close(f1)
}
}()
f2, err := syscall.Open(tc.mntDir+"/dst", syscall.O_RDWR, 0) f2, err := syscall.Open(tc.mntDir+"/dst", syscall.O_RDWR, 0)
if err != nil { if err != nil {
t.Fatalf("Open dst: %v", err) t.Fatalf("Open dst: %v", err)
} }
defer func() {
if f2 > 0 {
defer syscall.Close(f2) defer syscall.Close(f2)
}
}()
srcOff := int64(5) srcOff := int64(5)
dstOff := int64(7) dstOff := int64(7)
if sz, err := unix.CopyFileRange(f1, &srcOff, f2, &dstOff, 3, 0); err != nil || sz != 3 { if sz, err := unix.CopyFileRange(f1, &srcOff, f2, &dstOff, 3, 0); err != nil || sz != 3 {
t.Fatalf("CopyFileRange: %d,%v", sz, err) t.Fatalf("CopyFileRange: %d,%v", sz, err)
} }
if err := syscall.Close(f1); err != nil {
err = syscall.Close(f1)
f1 = 0
if err != nil {
t.Fatalf("Close src: %v", err) t.Fatalf("Close src: %v", err)
} }
if err := syscall.Close(f2); err != nil {
err = syscall.Close(f2)
f2 = 0
if err != nil {
t.Fatalf("Close dst: %v", err) t.Fatalf("Close dst: %v", err)
} }
c, err := ioutil.ReadFile(tc.mntDir + "/dst") c, err := ioutil.ReadFile(tc.mntDir + "/dst")
......
...@@ -128,7 +128,7 @@ func TestBasic(t *testing.T) { ...@@ -128,7 +128,7 @@ func TestBasic(t *testing.T) {
} }
} }
func TestFile(t *testing.T) { func TestFileBasic(t *testing.T) {
tc := newTestCase(t, true, true) tc := newTestCase(t, true, true)
defer tc.Clean() defer tc.Clean()
......
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