aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2012-09-08 12:49:19 -0400
committerRuss Cox <rsc@swtch.com>2012-09-08 12:49:19 -0400
commitd905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5 (patch)
tree1a56d4d755da1ca54770cdc01d46173d0c0da529
parent1c996338485a3515b8557562f68b0455b1c5a507 (diff)
downloadplan9port-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.c24
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");