diff options
author | Russ Cox <rsc@swtch.com> | 2012-09-08 12:49:19 -0400 |
---|---|---|
committer | Russ Cox <rsc@swtch.com> | 2012-09-08 12:49:19 -0400 |
commit | d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5 (patch) | |
tree | 1a56d4d755da1ca54770cdc01d46173d0c0da529 | |
parent | 1c996338485a3515b8557562f68b0455b1c5a507 (diff) | |
download | plan9port-d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5.tar.gz plan9port-d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5.tar.bz2 plan9port-d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5.zip |
9pfuse: osxfuse support
R=rsc
http://codereview.appspot.com/6503093
-rw-r--r-- | src/cmd/9pfuse/fuse.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/src/cmd/9pfuse/fuse.c b/src/cmd/9pfuse/fuse.c index 1ac77469..4d4b8954 100644 --- a/src/cmd/9pfuse/fuse.c +++ b/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"); |