summaryrefslogtreecommitdiff
path: root/trans
diff options
context:
space:
mode:
authorJustus Winter <4winter@informatik.uni-hamburg.de>2013-12-04 10:43:04 +0100
committerJustus Winter <4winter@informatik.uni-hamburg.de>2013-12-04 12:10:03 +0100
commit93976a816e6d690a6c7d77801e31ce6ee5bc4899 (patch)
tree6876384dd11d78bb9816ec8cdc8ecc81e804b805 /trans
parentdf66588b0f6daf99573153cb384a676ced27f0b1 (diff)
trans: fix transparent reauthentication in fakeroot
When looking up files, fakeroot intercepts reauthentication requests and executes io_reauthenticate and auth_user_authenticate transparently for the client. This, however, makes the client incorrectly assume that the lookup is finished (assuming /media/scratch is a translator): % cd /media/scratch && fakeroot-hurd pwd pwd: reading directory `..': Bad file descriptor Make the reauthentication completely transparent to the client by re-doing the lookup ourselves. * trans/fakeroot.c (netfs_S_dir_lookup): Fix transparent reauthentication.
Diffstat (limited to 'trans')
-rw-r--r--trans/fakeroot.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/trans/fakeroot.c b/trans/fakeroot.c
index b6938dce..24d3a4f9 100644
--- a/trans/fakeroot.c
+++ b/trans/fakeroot.c
@@ -235,7 +235,10 @@ netfs_S_dir_lookup (struct protid *diruser,
return EOPNOTSUPP;
dnp = diruser->po->np;
- err = dir_lookup (dnp->nn->file, filename,
+
+ mach_port_t dir = dnp->nn->file;
+ redo_lookup:
+ err = dir_lookup (dir, filename,
flags & (O_NOLINK|O_RDWR|O_EXEC|O_CREAT|O_EXCL|O_NONBLOCK),
mode, do_retry, retry_name, &file);
if (err)
@@ -252,14 +255,14 @@ netfs_S_dir_lookup (struct protid *diruser,
mach_port_deallocate (mach_task_self (), file);
err = auth_user_authenticate (fakeroot_auth_port, ref,
MACH_MSG_TYPE_MAKE_SEND,
- retry_port);
+ &dir);
}
mach_port_destroy (mach_task_self (), ref);
if (err)
return err;
}
- *do_retry = FS_RETRY_NORMAL;
- /*FALLTHROUGH*/
+ filename = retry_name;
+ goto redo_lookup;
case FS_RETRY_NORMAL:
case FS_RETRY_MAGICAL: