From 1f74c2fedafe46eec33c6cab76a3fd3159fcd548 Mon Sep 17 00:00:00 2001 From: Shuoran Liu Date: Mon, 21 Oct 2019 11:52:16 +0800 Subject: [PATCH] fix: directIO read size can exceed buffer size Since the package uses a fixed-size memory pool for out messages, it is important to tell fuse kernel module what the maximum read size is. Otherwise, a large read will cause a panic. Right now, max readahead size can only affect buffered read. The kernel might still send a large directIO read in spite of the max readahead size. We need to specify "max_read" option during mount. Signed-off-by: Shuoran Liu --- mount_linux.go | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/mount_linux.go b/mount_linux.go index ce83d9fa..5b38e5c2 100644 --- a/mount_linux.go +++ b/mount_linux.go @@ -7,9 +7,12 @@ import ( "net" "os" "os/exec" + "strconv" "syscall" "golang.org/x/sys/unix" + + "github.com/jacobsa/fuse/internal/buffer" ) func fusermount(dir string, cfg *MountConfig) (*os.File, error) { @@ -29,6 +32,11 @@ func fusermount(dir string, cfg *MountConfig) (*os.File, error) { // Start fusermount, passing it a buffer in which to write stderr. var stderr bytes.Buffer + if cfg.Options == nil { + cfg.Options = make(map[string]string) + } + cfg.Options["max_read"] = strconv.Itoa(buffer.MaxReadSize) + cmd := exec.Command( "fusermount", "-o", cfg.toOptionsString(),