Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp573746pxj; Thu, 3 Jun 2021 13:53:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJww5ccXY9nw9tfgSo2V7wqrYv3XVmXJ9oaXL9A3D0QzFbH1n6gdlOQXrcTA1PrudKOipQMC X-Received: by 2002:aa7:d755:: with SMTP id a21mr1304992eds.146.1622753624250; Thu, 03 Jun 2021 13:53:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622753624; cv=none; d=google.com; s=arc-20160816; b=EuTaB1zFwm0exXHtMe2ijm0NntLT81Zk0HOQwvVAaLuu9rdS7TO22za4s6FsUc2Vsn 5ttxvjN3WOpPdSZ1nBUbECaY3hi6hGzbxdy5MEBFSvFZAp4CwoTgegZCb/6m9FyOA2cL TuXQ17E2HZy5n0NyAcA5Js/dHT04Z9hc8PxBQwYlhje04R5o8fW1Haw8k5OgLtPzRLW9 xTfOq3qLipUaicvjFhC4eEETw795cvsJjQDh+mjHBu/AU4+xgdUlQN0wIiDY+OCIRfW4 kv/GqRFMot37RCGw9Gtr0fk4o4WoMpTDxsx4trSl1u5ezB85PVnUyvou1cyXF83Vw2XC LTkg== 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=Gxr2TOdMhICzpLFGKOnk7MOXtbrpkRsiotWWlqYOhhA=; b=CG/Gz7jDvnkFjHxOrykEv7kdVvMJOYvQaALC7uib+LUilFTMIxr2Sf/U9HcoEXI8w9 Iqme87HiHA9CmLZPrO+DxONwlAPX6LXZOFJjfM10wJKIcLiIkGQQ5RIy8JzIs1+67htz X6EGlgrvbcPrNY1Xz+EkvCbjczhPOpSQwf2lO9EaaWj4bwSK3kvuS+tYC/a8GjfbUVLZ FUJxdIiJJfVIk0C5dpL+w6a9lO2ouatMOPcU43NRvb+AJe3tU4GUT1HgjcB0ig39/z6L oOfd9f1ANbFucBRhXM/EmF1lKc8hywLiy2j1jKq0c4EidJ0qbuOv1cfsh6tw+Va4A8Lk XDYw== 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 be8si150738edb.223.2021.06.03.13.53.21; Thu, 03 Jun 2021 13:53:44 -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 S230044AbhFCUx4 (ORCPT + 99 others); Thu, 3 Jun 2021 16:53:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:44920 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229719AbhFCUx4 (ORCPT ); Thu, 3 Jun 2021 16:53:56 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 54DCE61263; Thu, 3 Jun 2021 20:52:11 +0000 (UTC) Subject: [PATCH 16/29] lockd: Update the NLMv1 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:52:10 -0400 Message-ID: <162275353062.32691.6997690954350199852.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/xdr.c | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/fs/lockd/xdr.c b/fs/lockd/xdr.c index 4fb6090bc915..9235e60b1769 100644 --- a/fs/lockd/xdr.c +++ b/fs/lockd/xdr.c @@ -41,18 +41,6 @@ loff_t_to_s32(loff_t offset) return res; } -/* - * XDR functions for basic NLM types - */ -static inline __be32 * -nlm_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 @@ -361,11 +349,16 @@ nlmsvc_encode_res(struct svc_rqst *rqstp, __be32 *p) int nlmsvc_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 = nlm_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; }