diff options
| author | 2014-11-19 21:32:12 +1100 | |
|---|---|---|
| committer | 2014-11-19 21:32:12 +1100 | |
| commit | b10778a00d40b3d9fdaaf5891e802794781ff71c (patch) | |
| tree | 6ba4cbac86eecedc3f30650e7f764ecf00c83898 /fs/nfsd/nfsproc.c | |
| parent | integrity: do zero padding of the key id (diff) | |
| parent | Linux 3.17 (diff) | |
| download | linux-dev-b10778a00d40b3d9fdaaf5891e802794781ff71c.tar.xz linux-dev-b10778a00d40b3d9fdaaf5891e802794781ff71c.zip | |
Merge commit 'v3.17' into next
Diffstat (limited to 'fs/nfsd/nfsproc.c')
| -rw-r--r-- | fs/nfsd/nfsproc.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/fs/nfsd/nfsproc.c b/fs/nfsd/nfsproc.c index 54c6b3d3cc79..b8680738f588 100644 --- a/fs/nfsd/nfsproc.c +++ b/fs/nfsd/nfsproc.c @@ -403,12 +403,13 @@ nfsd_proc_symlink(struct svc_rqst *rqstp, struct nfsd_symlinkargs *argp,  	fh_init(&newfh, NFS_FHSIZE);  	/* -	 * Create the link, look up new file and set attrs. +	 * Crazy hack: the request fits in a page, and already-decoded +	 * attributes follow argp->tname, so it's safe to just write a +	 * null to ensure it's null-terminated:  	 */ +	argp->tname[argp->tlen] = '\0';  	nfserr = nfsd_symlink(rqstp, &argp->ffh, argp->fname, argp->flen, -						 argp->tname, argp->tlen, -				 		 &newfh, &argp->attrs); - +						 argp->tname, &newfh);  	fh_put(&argp->ffh);  	fh_put(&newfh); @@ -716,6 +717,7 @@ nfserrno (int errno)  		{ nfserr_noent, -ENOENT },  		{ nfserr_io, -EIO },  		{ nfserr_nxio, -ENXIO }, +		{ nfserr_fbig, -E2BIG },  		{ nfserr_acces, -EACCES },  		{ nfserr_exist, -EEXIST },  		{ nfserr_xdev, -EXDEV }, @@ -743,6 +745,7 @@ nfserrno (int errno)  		{ nfserr_notsupp, -EOPNOTSUPP },  		{ nfserr_toosmall, -ETOOSMALL },  		{ nfserr_serverfault, -ESERVERFAULT }, +		{ nfserr_serverfault, -ENFILE },  	};  	int	i; @@ -750,7 +753,7 @@ nfserrno (int errno)  		if (nfs_errtbl[i].syserr == errno)  			return nfs_errtbl[i].nfserr;  	} -	printk (KERN_INFO "nfsd: non-standard errno: %d\n", errno); +	WARN(1, "nfsd: non-standard errno: %d\n", errno);  	return nfserr_io;  } | 
