Merge branch 'for-3.16' of git://linux-nfs.org/~bfields/linux

Pull nfsd bugfix from Bruce Fields:
"Another regression from the xdr encoding rewrite"

* 'for-3.16' of git://linux-nfs.org/~bfields/linux:
NFSD: Fix crash encoding lock reply on 32-bit

+3 -1
+3 -1
fs/nfsd/nfs4xdr.c
··· 2879 * return the conflicting open: 2880 */ 2881 if (conf->len) { 2882 conf->len = 0; 2883 conf->data = NULL; 2884 goto again; ··· 2892 if (conf->len) { 2893 p = xdr_encode_opaque_fixed(p, &ld->ld_clientid, 8); 2894 p = xdr_encode_opaque(p, conf->data, conf->len); 2895 } else { /* non - nfsv4 lock in conflict, no clientid nor owner */ 2896 p = xdr_encode_hyper(p, (u64)0); /* clientid */ 2897 *p++ = cpu_to_be32(0); /* length of owner name */ ··· 2909 nfserr = nfsd4_encode_stateid(xdr, &lock->lk_resp_stateid); 2910 else if (nfserr == nfserr_denied) 2911 nfserr = nfsd4_encode_lock_denied(xdr, &lock->lk_denied); 2912 - kfree(lock->lk_denied.ld_owner.data); 2913 return nfserr; 2914 } 2915
··· 2879 * return the conflicting open: 2880 */ 2881 if (conf->len) { 2882 + kfree(conf->data); 2883 conf->len = 0; 2884 conf->data = NULL; 2885 goto again; ··· 2891 if (conf->len) { 2892 p = xdr_encode_opaque_fixed(p, &ld->ld_clientid, 8); 2893 p = xdr_encode_opaque(p, conf->data, conf->len); 2894 + kfree(conf->data); 2895 } else { /* non - nfsv4 lock in conflict, no clientid nor owner */ 2896 p = xdr_encode_hyper(p, (u64)0); /* clientid */ 2897 *p++ = cpu_to_be32(0); /* length of owner name */ ··· 2907 nfserr = nfsd4_encode_stateid(xdr, &lock->lk_resp_stateid); 2908 else if (nfserr == nfserr_denied) 2909 nfserr = nfsd4_encode_lock_denied(xdr, &lock->lk_denied); 2910 + 2911 return nfserr; 2912 } 2913