| /* | 
 |  * Copyright (c) 2003-2007 Network Appliance, Inc. All rights reserved. | 
 |  * | 
 |  * This software is available to you under a choice of one of two | 
 |  * licenses.  You may choose to be licensed under the terms of the GNU | 
 |  * General Public License (GPL) Version 2, available from the file | 
 |  * COPYING in the main directory of this source tree, or the BSD-type | 
 |  * license below: | 
 |  * | 
 |  * Redistribution and use in source and binary forms, with or without | 
 |  * modification, are permitted provided that the following conditions | 
 |  * are met: | 
 |  * | 
 |  *      Redistributions of source code must retain the above copyright | 
 |  *      notice, this list of conditions and the following disclaimer. | 
 |  * | 
 |  *      Redistributions in binary form must reproduce the above | 
 |  *      copyright notice, this list of conditions and the following | 
 |  *      disclaimer in the documentation and/or other materials provided | 
 |  *      with the distribution. | 
 |  * | 
 |  *      Neither the name of the Network Appliance, Inc. nor the names of | 
 |  *      its contributors may be used to endorse or promote products | 
 |  *      derived from this software without specific prior written | 
 |  *      permission. | 
 |  * | 
 |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
 |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
 |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
 |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
 |  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
 |  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
 |  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
 |  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
 |  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
 |  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
 |  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
 |  */ | 
 |  | 
 | #ifndef _LINUX_SUNRPC_XPRTRDMA_H | 
 | #define _LINUX_SUNRPC_XPRTRDMA_H | 
 |  | 
 | /* | 
 |  * RPC transport identifier for RDMA | 
 |  */ | 
 | #define XPRT_TRANSPORT_RDMA	256 | 
 |  | 
 | /* | 
 |  * rpcbind (v3+) RDMA netid. | 
 |  */ | 
 | #define RPCBIND_NETID_RDMA	"rdma" | 
 |  | 
 | /* | 
 |  * Constants. Max RPC/NFS header is big enough to account for | 
 |  * additional marshaling buffers passed down by Linux client. | 
 |  * | 
 |  * RDMA header is currently fixed max size, and is big enough for a | 
 |  * fully-chunked NFS message (read chunks are the largest). Note only | 
 |  * a single chunk type per message is supported currently. | 
 |  */ | 
 | #define RPCRDMA_MIN_SLOT_TABLE	(2U) | 
 | #define RPCRDMA_DEF_SLOT_TABLE	(32U) | 
 | #define RPCRDMA_MAX_SLOT_TABLE	(256U) | 
 |  | 
 | #define RPCRDMA_DEF_INLINE  (1024)	/* default inline max */ | 
 |  | 
 | #define RPCRDMA_INLINE_PAD_THRESH  (512)/* payload threshold to pad (bytes) */ | 
 |  | 
 | #define RDMA_RESOLVE_TIMEOUT	(5*HZ)	/* TBD 5 seconds */ | 
 | #define RDMA_CONNECT_RETRY_MAX	(2)	/* retries if no listener backlog */ | 
 |  | 
 | /* memory registration strategies */ | 
 | #define RPCRDMA_PERSISTENT_REGISTRATION (1) | 
 |  | 
 | enum rpcrdma_memreg { | 
 | 	RPCRDMA_BOUNCEBUFFERS = 0, | 
 | 	RPCRDMA_REGISTER, | 
 | 	RPCRDMA_MEMWINDOWS, | 
 | 	RPCRDMA_MEMWINDOWS_ASYNC, | 
 | 	RPCRDMA_MTHCAFMR, | 
 | 	RPCRDMA_ALLPHYSICAL, | 
 | 	RPCRDMA_LAST | 
 | }; | 
 |  | 
 | #endif /* _LINUX_SUNRPC_XPRTRDMA_H */ |