commit d905d2f5fe89ae5b2c97d74ae9955a8e9dda87e5
parent 1c996338485a3515b8557562f68b0455b1c5a507
Author: Russ Cox <rsc@swtch.com>
Date:   Sat,  8 Sep 2012 12:49:19 -0400
9pfuse: osxfuse support
R=rsc
http://codereview.appspot.com/6503093
Diffstat:
1 file changed, 16 insertions(+), 8 deletions(-)
diff --git 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");