Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751602AbdH2WpE (ORCPT ); Tue, 29 Aug 2017 18:45:04 -0400 Received: from mail-lf0-f67.google.com ([209.85.215.67]:38786 "EHLO mail-lf0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751270AbdH2WpC (ORCPT ); Tue, 29 Aug 2017 18:45:02 -0400 X-Google-Smtp-Source: ADKCNb5FRSJYDmvr+Du6zdT8U5hqDJIlAL7IWCCEb6BITwNvIjcP1pEzJxyYJnN4MkfxHWG+MrSJft8qcplhTkWEI04= MIME-Version: 1.0 In-Reply-To: <20170829192915.26251-3-longli@exchange.microsoft.com> References: <20170829192915.26251-1-longli@exchange.microsoft.com> <20170829192915.26251-3-longli@exchange.microsoft.com> From: Pavel Shilovsky Date: Tue, 29 Aug 2017 15:44:59 -0700 Message-ID: Subject: Re: [Patch v3 02/19] CIFS: SMBD: Add SMBDirect protocol and transport constants To: Long Li Cc: Steve French , linux-cifs , samba-technical , Kernel Mailing List , linux-rdma@vger.kernel.org, Christoph Hellwig , Tom Talpey , Matthew Wilcox , Long Li Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5191 Lines: 142 2017-08-29 12:28 GMT-07:00 Long Li : > From: Long Li > > To prepare for protocol implementation, add constants and user-configurable > values in the SMBDirect protocol. > > Signed-off-by: Long Li > --- > fs/cifs/smbdirect.c | 78 +++++++++++++++++++++++++++++++++++++++++++++++++++++ > fs/cifs/smbdirect.h | 20 ++++++++++++++ > 2 files changed, 98 insertions(+) > create mode 100644 fs/cifs/smbdirect.c > create mode 100644 fs/cifs/smbdirect.h > > diff --git a/fs/cifs/smbdirect.c b/fs/cifs/smbdirect.c > new file mode 100644 > index 0000000..d785bc1 > --- /dev/null > +++ b/fs/cifs/smbdirect.c > @@ -0,0 +1,78 @@ > +/* > + * Copyright (C) 2017, Microsoft Corporation. > + * > + * Author(s): Long Li > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License as published by > + * the Free Software Foundation; either version 2 of the License, or > + * (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See > + * the GNU General Public License for more details. > + */ > +#include > +#include "smbdirect.h" > +#include "cifs_debug.h" > + > +/* SMBD version number */ > +#define SMBD_V1 0x0100 > + > +/* Port numbers for SMBD transport */ > +#define SMB_PORT 445 > +#define SMBD_PORT 5445 > + > +/* Address lookup and resolve timeout in ms */ > +#define RDMA_RESOLVE_TIMEOUT 5000 > + > +/* SMBD negotiation timeout in seconds */ > +#define SMBD_NEGOTIATE_TIMEOUT 120 > + > +/* SMBD minimum receive size and fragmented sized defined in [MS-SMBD] */ > +#define SMBD_MIN_RECEIVE_SIZE 128 > +#define SMBD_MIN_FRAGMENTED_SIZE 131072 > + > +/* > + * Default maximum number of RDMA read/write outstanding on this connection > + * This value is possibly decreased during QP creation on hardware limit > + */ > +#define SMBD_CM_RESPONDER_RESOURCES 32 > + > +/* Maximum number of retries on data transfer operations */ > +#define SMBD_CM_RETRY 6 > +/* No need to retry on Receiver Not Ready since SMBD manages credits */ > +#define SMBD_CM_RNR_RETRY 0 > + > +/* > + * User configurable initial values per SMBD transport connection > + * as defined in [MS-SMBD] 3.1.1.1 > + * Those may change after a SMBD negotiation > + */ Since these value are per transport connection, why they are global? Shouldn't they be inside a some structure that is created for a particular connection? Also the constants below should be defines. > +/* The local peer's maximum number of credits to grant to the peer */ > +static int receive_credit_max = 255; > +/* The remote peer's credit request of local peer */ > +static int send_credit_target = 255; > +/* The maximum single message size can be sent to remote peer */ > +static int max_send_size = 1364; > +/* The maximum fragmented upper-layer payload receive size supported */ > +static int max_fragmented_recv_size = 1024 * 1024; > +/* The maximum single-message size which can be received */ > +static int max_receive_size = 8192; > + > +/* The timeout to initiate send of a keepalive message on idle */ > +static int keep_alive_interval = 120; > + > +/* > + * User configurable initial values for RDMA transport > + * The actual values used may be lower and are limited to hardware capabilities > + */ > +/* Default maximum number of SGEs in a RDMA send/recv */ > +static int max_send_sge = SMBDIRECT_MAX_SGE; > +static int max_recv_sge = SMBDIRECT_MAX_SGE; > +/* Default maximum number of SGEs in a RDMA write/read */ > +static int max_frmr_depth = 2048; > + > +/* If payload is less than this byte, use RDMA send/recv not read/write */ > +static int rdma_readwrite_threshold = 4096; > diff --git a/fs/cifs/smbdirect.h b/fs/cifs/smbdirect.h > new file mode 100644 > index 0000000..06eeb0b > --- /dev/null > +++ b/fs/cifs/smbdirect.h > @@ -0,0 +1,20 @@ > +/* > + * Copyright (C) 2017, Microsoft Corporation. > + * > + * Author(s): Long Li > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License as published by > + * the Free Software Foundation; either version 2 of the License, or > + * (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See > + * the GNU General Public License for more details. > + */ > +#ifndef _SMBDIRECT_H > +#define _SMBDIRECT_H > + > +#define SMBDIRECT_MAX_SGE 16 > +#endif > -- > 2.7.4 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-cifs" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- Best regards, Pavel Shilovsky