diff options
author | Yehuda Sadeh <yehuda@newdream.net> | 2009-11-20 21:59:13 (GMT) |
---|---|---|
committer | Sage Weil <sage@newdream.net> | 2009-11-20 22:24:46 (GMT) |
commit | dc14657c9c946f25b84a98e9ffa41b812a70699e (patch) | |
tree | 3ac124fd88bf85244114a3e7646b87b84ef6ae9d /fs/ceph/super.c | |
parent | 94045e115ee72aee3b17295791da07078f2f778c (diff) | |
download | linux-dc14657c9c946f25b84a98e9ffa41b812a70699e.tar.xz |
ceph: mount fails immediately on error
Signed-off-by: Yehuda Sadeh <yehuda@newdream.net>
Diffstat (limited to 'fs/ceph/super.c')
-rw-r--r-- | fs/ceph/super.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/fs/ceph/super.c b/fs/ceph/super.c index 3df6d4a..a828943 100644 --- a/fs/ceph/super.c +++ b/fs/ceph/super.c @@ -712,10 +712,14 @@ static int ceph_mount(struct ceph_client *client, struct vfsmount *mnt, /* wait */ dout("mount waiting for mon_map\n"); err = wait_event_interruptible_timeout(client->mount_wq, /* FIXME */ - have_mon_map(client), + have_mon_map(client) || (client->mount_err < 0), timeout); if (err == -EINTR || err == -ERESTARTSYS) goto out; + if (client->mount_err < 0) { + err = client->mount_err; + goto out; + } } dout("mount opening root\n"); |