commit d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5 from: Russ Cox date: Sat Sep 08 16:49:19 2012 UTC 9pfuse: osxfuse support R=rsc http://codereview.appspot.com/6503093 commit - 1c996338485a3515b8557562f68b0455b1c5a507 commit + d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5 blob - 1ac774691f2537e0ff3f33614dfe33703e424030 blob + 4d4b8954a941cb490a4d7ea4036ac2c22cc2bc3d --- src/cmd/9pfuse/fuse.c +++ src/cmd/9pfuse/fuse.c @@ -675,7 +675,7 @@ fusefmt(Fmt *fmt) break; } case FUSE_SETXATTR: { - fmtprint(fmt, "(Serxattr)"); + fmtprint(fmt, "(Setxattr)"); break; } case FUSE_GETXATTR: { @@ -798,11 +798,13 @@ mountfuse(char *mtpt) int i, pid, fd, r; char buf[20]; struct vfsconf vfs; - char *f; + char *f, *v; - if(getvfsbyname("fusefs", &vfs) < 0){ - if(access(f="/System/Library/Extensions/fusefs.kext" - "/Contents/Resources/load_fusefs", 0) < 0 && + if(getvfsbyname(v="osxfusefs", &vfs) < 0 && getvfsbyname(v="fusefs", &vfs) < 0){ + if(access((v="osxfusefs", f="/Library/Filesystems/osxfusefs.fs" + "/Support/load_osxfusefs"), 0) < 0 && + access((v="fusefs", f="/System/Library/Extensions/fusefs.kext" + "/Contents/Resources/load_fusefs"), 0) < 0 && access(f="/Library/Extensions/fusefs.kext" "/Contents/Resources/load_fusefs", 0) < 0 && access(f="/Library/Filesystems" @@ -820,15 +822,15 @@ mountfuse(char *mtpt) werrstr("load_fusefs failed: exit %d", r); return -1; } - if(getvfsbyname("fusefs", &vfs) < 0){ - werrstr("getvfsbyname fusefs: %r"); + if(getvfsbyname(v, &vfs) < 0){ + werrstr("getvfsbyname %s: %r", v); return -1; } } /* Look for available FUSE device. */ for(i=0;; i++){ - snprint(buf, sizeof buf, "/dev/fuse%d", i); + snprint(buf, sizeof buf, "/dev/%.*s%d", strlen(v)-2, v, i); if(access(buf, 0) < 0){ werrstr("no available fuse devices"); return -1; @@ -848,6 +850,12 @@ mountfuse(char *mtpt) * mount_fusefs binary in different places. * Try all. */ + /* Lion OSXFUSE location */ + putenv("MOUNT_FUSEFS_DAEMON_PATH", + "/Library/Filesystems/osxfusefs.fs/Support/mount_osxfusefs"); + execl("/Library/Filesystems/osxfusefs.fs/Support/mount_osxfusefs", + "mount_osxfusefs", buf, mtpt, nil); + /* Leopard location */ putenv("MOUNT_FUSEFS_DAEMON_PATH", "/Library/Filesystems/fusefs.fs/Support/mount_fusefs");