Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp574528pxj; Thu, 3 Jun 2021 13:55:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwhrP2kq7ur3mzNCF6Ge5rcA+nOKlU2+FaRzD6UXQ+G0nmnjhcxZUX0Ahw1oI0/Zl1q9ill X-Received: by 2002:a17:906:606:: with SMTP id s6mr1057123ejb.206.1622753699771; Thu, 03 Jun 2021 13:54:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622753699; cv=none; d=google.com; s=arc-20160816; b=tutm8e130QxW3Iwoo9fX3Zh2lXJjPj+LqCb1nrwYE4CArhIrq1OnzzzvCMzwhGElnG OGs9xhyuKFY7WMTj5JL5otQBe0Q1Yvd+DKvo3yq4fqLBtSdeD8wsaAtEMuRlnO6GlLw1 nfCwhITmv2o9wa5hj0bWQPQXOunhY/yWsoNk/PmKaaMPuC+rE3TPMMOMFcxJXDAvg7+I cslkrKB0+nH1n1tPTsTcUwg9CRl1BatUzcpYWaU/R1HUQ7ZLh8n3XLFPxsbuK4Dpd9Hu jvS6LLdIALQpO1ilW0hc/DL4IVndwX9fmnA8ae2WRPsodA+NnzrY4x4O2QrrJ0rkKunE xFvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:cc:to:from :subject; bh=B45vyxEggFdew0eXa9+OPH4PuPvlqF5LNcoWgeyRvEI=; b=cNG/EssBznxOPKDS9Bku7CAhUENgiptXq3xO3wbLNlbElkxSkU9kZuhVgdZre31vkr yq1gnxoxCP5S9ix6TqmvzvLkH13j5J5K/fTBs5HsqZNFBr0zFyBe8JC+ydH7mPlpnwlW 2Ahl7fzVHSLAQUZCu/GQ+We/lkdfw4JxEvMBWayMdrsUBbP3JOxZBToGQkyDUYl/C4CA YoI2wFyp+5VCm64ftrwfGVoEUVssqwsSRmgawQJw32nF0sgmAZlL/BiIXPAOvVGYPBmr IjutaIwHPVsQLtSFb1PfEJju4ammlfpdH1rmG2a+eyGp7tB7OOnjSukuf6dbEaV8XtiA X5fQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z5si1266234edx.70.2021.06.03.13.54.36; Thu, 03 Jun 2021 13:54:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229881AbhFCUzP (ORCPT + 99 others); Thu, 3 Jun 2021 16:55:15 -0400 Received: from mail.kernel.org ([198.145.29.99]:45306 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229617AbhFCUzP (ORCPT ); Thu, 3 Jun 2021 16:55:15 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D4A0A613E7; Thu, 3 Jun 2021 20:53:29 +0000 (UTC) Subject: [PATCH 29/29] lockd: Update the NLMv4 SHARE results encoder to use struct xdr_stream From: Chuck Lever To: bfields@fieldses.org Cc: linux-nfs@vger.kernel.org Date: Thu, 03 Jun 2021 16:53:29 -0400 Message-ID: <162275360914.32691.6053481644981091103.stgit@klimt.1015granger.net> In-Reply-To: <162275337584.32691.3943139351165347555.stgit@klimt.1015granger.net> References: <162275337584.32691.3943139351165347555.stgit@klimt.1015granger.net> User-Agent: StGit/1.1 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org Signed-off-by: Chuck Lever --- fs/lockd/xdr4.c | 22 +++++++++------------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/fs/lockd/xdr4.c b/fs/lockd/xdr4.c index efdede71b951..98e957e4566c 100644 --- a/fs/lockd/xdr4.c +++ b/fs/lockd/xdr4.c @@ -40,15 +40,6 @@ loff_t_to_s64(loff_t offset) return res; } -static __be32 * -nlm4_encode_cookie(__be32 *p, struct nlm_cookie *c) -{ - *p++ = htonl(c->len); - memcpy(p, c->data, c->len); - p+=XDR_QUADLEN(c->len); - return p; -} - /* * NLM file handles are defined by specification to be a variable-length * XDR opaque no longer than 1024 bytes. However, this implementation @@ -356,11 +347,16 @@ nlm4svc_encode_res(struct svc_rqst *rqstp, __be32 *p) int nlm4svc_encode_shareres(struct svc_rqst *rqstp, __be32 *p) { + struct xdr_stream *xdr = &rqstp->rq_res_stream; struct nlm_res *resp = rqstp->rq_resp; - if (!(p = nlm4_encode_cookie(p, &resp->cookie))) + if (!svcxdr_encode_cookie(xdr, &resp->cookie)) return 0; - *p++ = resp->status; - *p++ = xdr_zero; /* sequence argument */ - return xdr_ressize_check(rqstp, p); + if (!svcxdr_encode_stats(xdr, resp->status)) + return 0; + /* sequence */ + if (xdr_stream_encode_u32(xdr, 0) < 0) + return 0; + + return 1; }