Re: NFS problem with past 2.6.31 git tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



2009/9/28 Trond Myklebust <Trond.Myklebust@xxxxxxxxxx>:
> On Fri, 2009-09-25 at 21:46 +0200, Zdenek Kabelac wrote:
>> 2009/9/25 Trond Myklebust <Trond.Myklebust@xxxxxxxxxx>:
>> > On Fri, 2009-09-25 at 17:12 +0200, Zdenek Kabelac wrote:
>> >> Hi
>> >>
>> >> I've noticed that my qemu guest is now unable to use localy exported
>> >> nfs directory.
>> >> Directory gets mounted, plain 'ls' shows filenames - but nothing else
>> >> could be done.
>> >>
>> >> ls -la gives this output:
>> >> ls: cannot access patch: Input/output error
>> >> ...
>> >>
>> >>
>> >> Both host & guest are running same kernel:
>> >> 851b147e4411df6a1e7e90e2a609773c277eefd2
>> >>
>> >> I've checked last few commits and tried to revert them -
>> >> and this one seems to cure my problem when reverted:
>> >>
>> >> Sep 23:  8a6e5deb8a8caa810fef2c525f5dbea2cfe04a47
>> >> NFS: Get rid of the NFS_MOUNT_VER3 and NFS_MOUNT_TCP flags
>> >>
>> >> I should also probably note that I'm seeing this message in my dmesg log:
>> >> svc: failed to register lockdv1 RPC service (errno 97)
>> >>
>> >> rpcinfo -p
>> >>    program vers proto   port
>> >>     100000    2   tcp    111  portmapper
>> >>     100000    2   udp    111  portmapper
>> >>     100024    1   udp  53550  status
>> >>     100024    1   tcp  44174  status
>> >>     100021    1   udp  49878  nlockmgr
>> >>     100021    3   udp  49878  nlockmgr
>> >>     100021    4   udp  49878  nlockmgr
>> >>     100021    1   tcp  47319  nlockmgr
>> >>     100021    3   tcp  47319  nlockmgr
>> >>     100021    4   tcp  47319  nlockmgr
>> >>
>> >> automount(pid1720) /misc autofs
>> >> rw,relatime,fd=4,pgrp=1720,timeout=300,minproto=2,maxproto=4,indirect
>> >> 0 0
>> >> 192.168.122.1:/home/u/export /misc/u nfs
>> >> rw,relatime,vers=3,rsize=524288,wsize=524288,namlen=255,soft,proto=tcp,port=65535,timeo=600,retrans=2,sec=sys,mountaddr=192.168.xxx.yyy,mountvers=3,mountproto=tcp,addr=192.168.xxx.yyy
>> >> 0 0
>> >>
>> >>
>> >> Zdenek
>> > What does
>> >
>> >   cat /proc/self/mountinfo
>> >
>> > give you?
>> >
>>
>>
>> Working version: (kernel 2.6.31 or current git with reverted NFS patch)
>>
>> 22 12 0:17 / /misc rw,relatime - autofs automount(pid1720)
>> rw,fd=4,pgrp=1720,timeout=300,minproto=2,maxproto=4,indirect
>>
>> 24 22 0:19 / /misc/kabi rw,relatime - nfs IP:/home/kabi/export
>> rw,vers=3,rsize=524288,wsize=524288,namlen=255,soft,proto=tcp,port=65535,timeo=600,retrans=2,sec=sys,mountaddr=IP,mountvers=3,mountproto=tcp,addr=IP
>>
>>
>> Nonworking version:
>>
>> 22 12 0:17 / /misc rw,relatime - autofs automount(pid1704)
>> rw,fd=4,pgrp=1704,timeout=300,minproto=2,maxproto=4,indirect
>>
>> 24 22 0:19 / /misc/kabi rw,relatime - nfs IP:/home/kabi/export
>> rw,vers=2,rsize=8192,wsize=8192,namlen=255,soft,proto=tcp,port=65535,timeo=600,retrans=2,sec=sys,mountaddr=IP,mountvers=3,mountproto=tcp,addr=IP
>>
>>
>>
>> Looks like vers=2  != vers=3   and rsize/wsize - which is also set by
>> the kernel itself to those lower values.
>> (i.e. my /etc/init.d/autofs doesn't modify localoptions - of course I
>> could use this to set 8192 wsize and rsize for my working kernel)
>>
>> Zdenek
>
>
> OK. The following patch fixes the default nfs version issue for me. I
> have another one to fix the incorrectly displayed port numbers...

Hi

Thanks - this patch seems to fix my reported problem.



>
> Cheers
>  Trond
> ------------------------------------------------------------------------
> NFS: Fix a default mount regression...
> From: Trond Myklebust <Trond.Myklebust@xxxxxxxxxx>
>
> With the recent spate of changes, the nfs protocol version will now default
> to 2 instead of 3, while the mount protocol version defaults to 3.
>
> The following patch should ensure the defaults are consistent with the
> previous defaults of vers=3,proto=tcp,mountvers=3,mountproto=tcp.
>
> Signed-off-by: Trond Myklebust <Trond.Myklebust@xxxxxxxxxx>
> ---


Reported-and-tested-by: Zdenek Kabelac <zdenek.kabelac@xxxxxxxxx>


>
>  fs/nfs/super.c |   13 ++++++-------
>  1 files changed, 6 insertions(+), 7 deletions(-)
>
>
> diff --git a/fs/nfs/super.c b/fs/nfs/super.c
> index 29786d3..0343ebc 100644
> --- a/fs/nfs/super.c
> +++ b/fs/nfs/super.c
> @@ -728,22 +728,24 @@ static void nfs_umount_begin(struct super_block *sb)
>        unlock_kernel();
>  }
>
> -static struct nfs_parsed_mount_data *nfs_alloc_parsed_mount_data(int flags)
> +static struct nfs_parsed_mount_data *nfs_alloc_parsed_mount_data(unsigned int version)
>  {
>        struct nfs_parsed_mount_data *data;
>
>        data = kzalloc(sizeof(*data), GFP_KERNEL);
>        if (data) {
> -               data->flags             = flags;
>                data->rsize             = NFS_MAX_FILE_IO_SIZE;
>                data->wsize             = NFS_MAX_FILE_IO_SIZE;
>                data->acregmin          = NFS_DEF_ACREGMIN;
>                data->acregmax          = NFS_DEF_ACREGMAX;
>                data->acdirmin          = NFS_DEF_ACDIRMIN;
>                data->acdirmax          = NFS_DEF_ACDIRMAX;
> +               data->mount_server.port = NFS_UNSPEC_PORT;
>                data->nfs_server.port   = NFS_UNSPEC_PORT;
> +               data->nfs_server.protocol = XPRT_TRANSPORT_TCP;
>                data->auth_flavors[0]   = RPC_AUTH_UNIX;
>                data->auth_flavor_len   = 1;
> +               data->version           = version;
>                data->minorversion      = 0;
>        }
>        return data;
> @@ -1711,8 +1713,6 @@ static int nfs_validate_mount_data(void *options,
>
>                if (!(data->flags & NFS_MOUNT_TCP))
>                        args->nfs_server.protocol = XPRT_TRANSPORT_UDP;
> -               else
> -                       args->nfs_server.protocol = XPRT_TRANSPORT_TCP;
>                /* N.B. caller will free nfs_server.hostname in all cases */
>                args->nfs_server.hostname = kstrdup(data->hostname, GFP_KERNEL);
>                args->namlen            = data->namlen;
> @@ -2106,7 +2106,7 @@ static int nfs_get_sb(struct file_system_type *fs_type,
>        };
>        int error = -ENOMEM;
>
> -       data = nfs_alloc_parsed_mount_data(NFS_MOUNT_VER3 | NFS_MOUNT_TCP);
> +       data = nfs_alloc_parsed_mount_data(3);
>        mntfh = kzalloc(sizeof(*mntfh), GFP_KERNEL);
>        if (data == NULL || mntfh == NULL)
>                goto out_free_fh;
> @@ -2376,7 +2376,6 @@ static int nfs4_validate_mount_data(void *options,
>        if (data == NULL)
>                goto out_no_data;
>
> -       args->version           = 4;
>        switch (data->version) {
>        case 1:
>                if (data->host_addrlen > sizeof(args->nfs_server.address))
> @@ -2660,7 +2659,7 @@ static int nfs4_get_sb(struct file_system_type *fs_type,
>        struct nfs_parsed_mount_data *data;
>        int error = -ENOMEM;
>
> -       data = nfs_alloc_parsed_mount_data(0);
> +       data = nfs_alloc_parsed_mount_data(4);
>        if (data == NULL)
>                goto out_free_data;
>
>
>
>
> --
> Trond Myklebust
> Linux NFS client maintainer
>
> NetApp
> Trond.Myklebust@xxxxxxxxxx
> www.netapp.com
>
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux