aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/super.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/nfs/super.c')
-rw-r--r--fs/nfs/super.c29
1 files changed, 15 insertions, 14 deletions
diff --git a/fs/nfs/super.c b/fs/nfs/super.c
index f48db679a1c6..2b0c8e132b54 100644
--- a/fs/nfs/super.c
+++ b/fs/nfs/super.c
@@ -1329,8 +1329,13 @@ out_security_failure:
1329static int nfs_try_mount(struct nfs_parsed_mount_data *args, 1329static int nfs_try_mount(struct nfs_parsed_mount_data *args,
1330 struct nfs_fh *root_fh) 1330 struct nfs_fh *root_fh)
1331{ 1331{
1332 struct sockaddr *sap = (struct sockaddr *)&args->mount_server.address; 1332 struct nfs_mount_request request = {
1333 char *hostname; 1333 .sap = (struct sockaddr *)
1334 &args->mount_server.address,
1335 .dirpath = args->nfs_server.export_path,
1336 .protocol = args->mount_server.protocol,
1337 .fh = root_fh,
1338 };
1334 int status; 1339 int status;
1335 1340
1336 if (args->mount_server.version == 0) { 1341 if (args->mount_server.version == 0) {
@@ -1339,42 +1344,38 @@ static int nfs_try_mount(struct nfs_parsed_mount_data *args,
1339 else 1344 else
1340 args->mount_server.version = NFS_MNT_VERSION; 1345 args->mount_server.version = NFS_MNT_VERSION;
1341 } 1346 }
1347 request.version = args->mount_server.version;
1342 1348
1343 if (args->mount_server.hostname) 1349 if (args->mount_server.hostname)
1344 hostname = args->mount_server.hostname; 1350 request.hostname = args->mount_server.hostname;
1345 else 1351 else
1346 hostname = args->nfs_server.hostname; 1352 request.hostname = args->nfs_server.hostname;
1347 1353
1348 /* 1354 /*
1349 * Construct the mount server's address. 1355 * Construct the mount server's address.
1350 */ 1356 */
1351 if (args->mount_server.address.ss_family == AF_UNSPEC) { 1357 if (args->mount_server.address.ss_family == AF_UNSPEC) {
1352 memcpy(sap, &args->nfs_server.address, 1358 memcpy(request.sap, &args->nfs_server.address,
1353 args->nfs_server.addrlen); 1359 args->nfs_server.addrlen);
1354 args->mount_server.addrlen = args->nfs_server.addrlen; 1360 args->mount_server.addrlen = args->nfs_server.addrlen;
1355 } 1361 }
1362 request.salen = args->mount_server.addrlen;
1356 1363
1357 /* 1364 /*
1358 * autobind will be used if mount_server.port == 0 1365 * autobind will be used if mount_server.port == 0
1359 */ 1366 */
1360 nfs_set_port(sap, args->mount_server.port); 1367 nfs_set_port(request.sap, args->mount_server.port);
1361 1368
1362 /* 1369 /*
1363 * Now ask the mount server to map our export path 1370 * Now ask the mount server to map our export path
1364 * to a file handle. 1371 * to a file handle.
1365 */ 1372 */
1366 status = nfs_mount(sap, 1373 status = nfs_mount(&request);
1367 args->mount_server.addrlen,
1368 hostname,
1369 args->nfs_server.export_path,
1370 args->mount_server.version,
1371 args->mount_server.protocol,
1372 root_fh);
1373 if (status == 0) 1374 if (status == 0)
1374 return 0; 1375 return 0;
1375 1376
1376 dfprintk(MOUNT, "NFS: unable to mount server %s, error %d\n", 1377 dfprintk(MOUNT, "NFS: unable to mount server %s, error %d\n",
1377 hostname, status); 1378 request.hostname, status);
1378 return status; 1379 return status;
1379} 1380}
1380 1381