usr/src/uts/common/rpc/xdr_rdma.c
author Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
Fri, 10 Apr 2009 22:57:35 -0700
changeset 9348 7155ecb17858
parent 7387 0b3a92e31fd8
child 9803 35261329983d
permissions -rw-r--r--
6760947 NFS/RDMA port should be changed to IANA assigned 20049 6762173 rdma panic on writes from linux client 6790590 readdir fails from Linux client against Solaris server 6790588 linux client fails to decode READ replies from Solaris server 6790586 Solaris server should better handle chunked RPC/RDMA messages 6826476 rpcib leaks memory registrations while handling multiple chunks
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
 * CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
 * The contents of this file are subject to the terms of the
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
     5
 * Common Development and Distribution License (the "License").
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
     6
 * You may not use this file except in compliance with the License.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
 * or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
 * See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
 * and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
 * When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
 * If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
 * fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
 * information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
 * CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    21
/*
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
    22
 * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    23
 * Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    26
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    27
 * Copyright (c) 2007, The Ohio State University. All rights reserved.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    28
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    29
 * Portions of this source code is developed by the team members of
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    30
 * The Ohio State University's Network-Based Computing Laboratory (NBCL),
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    31
 * headed by Professor Dhabaleswar K. (DK) Panda.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    32
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    33
 * Acknowledgements to contributions from developors:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    34
 *   Ranjit Noronha: [email protected]
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    35
 *   Lei Chai      : [email protected]
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    36
 *   Weikuan Yu    : [email protected]
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    37
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    38
 */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
 * xdr_rdma.c, XDR implementation using RDMA to move large chunks
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
#include <sys/param.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
#include <sys/types.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
#include <sys/systm.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
#include <sys/kmem.h>
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    48
#include <sys/sdt.h>
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    49
#include <sys/debug.h>
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
#include <rpc/types.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
#include <rpc/xdr.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
#include <sys/cmn_err.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
#include <rpc/rpc_sztypes.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
#include <rpc/rpc_rdma.h>
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    56
#include <sys/sysmacros.h>
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    58
static bool_t   xdrrdma_getint32(XDR *, int32_t *);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    59
static bool_t   xdrrdma_putint32(XDR *, int32_t *);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    60
static bool_t   xdrrdma_getbytes(XDR *, caddr_t, int);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    61
static bool_t   xdrrdma_putbytes(XDR *, caddr_t, int);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    62
uint_t		xdrrdma_getpos(XDR *);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    63
bool_t		xdrrdma_setpos(XDR *, uint_t);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    64
static rpc_inline_t *xdrrdma_inline(XDR *, int);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    65
void		xdrrdma_destroy(XDR *);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    66
static bool_t   xdrrdma_control(XDR *, int, void *);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
    67
static bool_t  xdrrdma_read_a_chunk(XDR *, CONN **);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
    68
static void xdrrdma_free_xdr_chunks(CONN *, struct clist *);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    69
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    70
struct xdr_ops  xdrrdmablk_ops = {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    71
	xdrrdma_getbytes,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    72
	xdrrdma_putbytes,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    73
	xdrrdma_getpos,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    74
	xdrrdma_setpos,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    75
	xdrrdma_inline,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    76
	xdrrdma_destroy,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    77
	xdrrdma_control,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    78
	xdrrdma_getint32,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    79
	xdrrdma_putint32
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    80
};
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    81
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    82
struct xdr_ops  xdrrdma_ops = {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    83
	xdrrdma_getbytes,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    84
	xdrrdma_putbytes,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    85
	xdrrdma_getpos,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    86
	xdrrdma_setpos,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    87
	xdrrdma_inline,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    88
	xdrrdma_destroy,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    89
	xdrrdma_control,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    90
	xdrrdma_getint32,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    91
	xdrrdma_putint32
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    92
};
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    95
 * A chunk list entry identifies a chunk of opaque data to be moved
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    96
 * separately from the rest of the RPC message. xp_min_chunk = 0, is a
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    97
 * special case for ENCODING, which means do not chunk the incoming stream of
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
    98
 * data.
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
    99
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   100
 * A read chunk can contain part of the RPC message in addition to the
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   101
 * inline message. In such a case, (xp_offp - x_base) will not provide
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   102
 * the correct xdr offset of the entire message. xp_off is used in such
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   103
 * a case to denote the offset or current position in the overall message
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   104
 * covering both the inline and the chunk. This is used only in the case
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   105
 * of decoding and useful to compare read chunk 'c_xdroff' offsets.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   106
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   107
 * An example for a read chunk containing an XDR message:
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   108
 * An NFSv4 compound as following:
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   109
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   110
 * PUTFH
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   111
 * WRITE [4109 bytes]
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   112
 * GETATTR
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   113
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   114
 * Solaris Encoding is:
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   115
 * -------------------
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   116
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   117
 * <Inline message>: [PUTFH WRITE4args GETATTR]
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   118
 *                                   |
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   119
 *                                   v
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   120
 * [RDMA_READ chunks]:               [write data]
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   121
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   122
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   123
 * Linux encoding is:
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   124
 * -----------------
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   125
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   126
 * <Inline message>: [PUTFH WRITE4args]
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   127
 *                                    |
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   128
 *                                    v
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   129
 * [RDMA_READ chunks]:                [Write data] [Write data2] [Getattr chunk]
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   130
 *                                     chunk1       chunk2         chunk3
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   131
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   132
 * where the READ chunks are as:
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   133
 *
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   134
 *             - chunk1 - 4k
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   135
 * write data |
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   136
 *             - chunk2 - 13 bytes(4109 - 4k)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   137
 * getattr op  - chunk3 - 19 bytes
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   138
 * (getattr op starts at byte 4 after 3 bytes of roundup)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   139
 *
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   142
typedef struct {
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
	caddr_t		xp_offp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   144
	int		xp_min_chunk;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   145
	uint_t		xp_flags;	/* Controls setting for rdma xdr */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   146
	int		xp_buf_size;	/* size of xdr buffer */
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   147
	int		xp_off;		/* overall offset */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   148
	struct clist	*xp_rcl;	/* head of chunk list */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   149
	struct clist	**xp_rcl_next;	/* location to place/find next chunk */
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   150
	struct clist	*xp_rcl_xdr;	/* copy of rcl containing RPC message */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   151
	struct clist	*xp_wcl;	/* head of write chunk list */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   152
	CONN		*xp_conn;	/* connection for chunk data xfer */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   153
	uint_t		xp_reply_chunk_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   154
	/* used to track length for security modes: integrity/privacy */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   155
	uint_t		xp_reply_chunk_len_alt;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   156
} xrdma_private_t;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   157
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   158
extern kmem_cache_t *clist_cache;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   159
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   160
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   161
xdrrdma_getrdmablk(XDR *xdrs, struct clist **rlist, uint_t *sizep,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   162
    CONN **conn, const uint_t maxsize)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   163
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   164
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   165
	struct clist	*cle = *(xdrp->xp_rcl_next);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   166
	struct clist	*rdclist = NULL, *prev = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   167
	bool_t		retval = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   168
	uint32_t	cur_offset = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   169
	uint32_t	total_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   170
	uint32_t	actual_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   171
	uint32_t	alen;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   172
	uint_t		total_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   173
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   174
	ASSERT(xdrs->x_op != XDR_FREE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   175
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   176
	/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   177
	 * first deal with the length since xdr bytes are counted
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   178
	 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   179
	if (!xdr_u_int(xdrs, sizep)) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   180
		DTRACE_PROBE(xdr__e__getrdmablk_sizep_fail);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   181
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   182
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   183
	total_len = *sizep;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   184
	if (total_len > maxsize) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   185
		DTRACE_PROBE2(xdr__e__getrdmablk_bad_size,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   186
		    int, total_len, int, maxsize);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   187
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   188
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   189
	(*conn) = xdrp->xp_conn;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   190
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   191
	/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   192
	 * if no data we are done
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   193
	 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   194
	if (total_len == 0)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   195
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   196
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   197
	while (cle) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   198
		total_segments++;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   199
		cle = cle->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   200
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   201
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   202
	cle = *(xdrp->xp_rcl_next);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   203
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   204
	/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   205
	 * If there was a chunk at the current offset, then setup a read
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   206
	 * chunk list which records the destination address and length
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   207
	 * and will RDMA READ the data in later.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   208
	 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   209
	if (cle == NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   210
		return (FALSE);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   211
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   212
	if (cle->c_xdroff != (xdrp->xp_offp - xdrs->x_base))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   213
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   214
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   215
	/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   216
	 * Setup the chunk list with appropriate
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   217
	 * address (offset) and length
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   218
	 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   219
	for (actual_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   220
	    actual_segments < total_segments; actual_segments++) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   221
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   222
		DTRACE_PROBE3(krpc__i__xdrrdma_getrdmablk, uint32_t, cle->c_len,
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   223
		    uint32_t, total_len, uint32_t, cle->c_xdroff);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   224
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   225
		if (total_len <= 0)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   226
			break;
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   227
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   228
		/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   229
		 * not the first time in the loop
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   230
		 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   231
		if (actual_segments > 0)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   232
			cle = cle->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   233
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   234
		cle->u.c_daddr = (uint64) cur_offset;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   235
		alen = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   236
		if (cle->c_len > total_len) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   237
			alen = cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   238
			cle->c_len = total_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   239
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   240
		if (!alen)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   241
			xdrp->xp_rcl_next = &cle->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   242
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   243
		cur_offset += cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   244
		total_len -= cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   245
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   246
		if ((total_segments - actual_segments - 1) == 0 &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   247
		    total_len > 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   248
			DTRACE_PROBE(krpc__e__xdrrdma_getblk_chunktooshort);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   249
			retval = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   250
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   251
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   252
		if ((total_segments - actual_segments - 1) > 0 &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   253
		    total_len == 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   254
			DTRACE_PROBE2(krpc__e__xdrrdma_getblk_toobig,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   255
			    int, total_segments, int, actual_segments);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   256
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   257
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   258
		rdclist = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   259
		(*rdclist) = (*cle);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   260
		if ((*rlist) == NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   261
			(*rlist) = rdclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   262
		if (prev == NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   263
			prev = rdclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   264
		else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   265
			prev->c_next = rdclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   266
			prev = rdclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   267
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   268
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   269
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   270
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   271
out:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   272
	if (prev != NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   273
		prev->c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   274
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   275
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   276
	 * Adjust the chunk length, if we read only a part of
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   277
	 * a chunk.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   278
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   279
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   280
	if (alen) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   281
		cle->w.c_saddr =
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   282
		    (uint64)(uintptr_t)cle->w.c_saddr + cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   283
		cle->c_len = alen - cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   284
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   285
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   286
	return (retval);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   287
}
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   288
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   289
/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   290
 * The procedure xdrrdma_create initializes a stream descriptor for a memory
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   291
 * buffer.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   292
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   293
void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   294
xdrrdma_create(XDR *xdrs, caddr_t addr, uint_t size,
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   295
    int min_chunk, struct clist *cl, enum xdr_op op, CONN *conn)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   296
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   297
	xrdma_private_t *xdrp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   298
	struct clist   *cle;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   299
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   300
	xdrs->x_op = op;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   301
	xdrs->x_ops = &xdrrdma_ops;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   302
	xdrs->x_base = addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   303
	xdrs->x_handy = size;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   304
	xdrs->x_public = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   305
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   306
	xdrp = (xrdma_private_t *)kmem_zalloc(sizeof (xrdma_private_t),
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   307
	    KM_SLEEP);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   308
	xdrs->x_private = (caddr_t)xdrp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   309
	xdrp->xp_offp = addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   310
	xdrp->xp_min_chunk = min_chunk;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   311
	xdrp->xp_flags = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   312
	xdrp->xp_buf_size = size;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   313
	xdrp->xp_rcl = cl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   314
	xdrp->xp_reply_chunk_len = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   315
	xdrp->xp_reply_chunk_len_alt = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   316
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   317
	if (op == XDR_ENCODE && cl != NULL) {
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   318
		/* Find last element in chunk list and set xp_rcl_next */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   319
		for (cle = cl; cle->c_next != NULL; cle = cle->c_next)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   320
			continue;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   321
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   322
		xdrp->xp_rcl_next = &(cle->c_next);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   323
	} else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   324
		xdrp->xp_rcl_next = &(xdrp->xp_rcl);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   325
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   326
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   327
	xdrp->xp_wcl = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   328
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   329
	xdrp->xp_conn = conn;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   330
	if (xdrp->xp_min_chunk != 0)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   331
		xdrp->xp_flags |= XDR_RDMA_CHUNK;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   332
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   333
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   334
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   335
void
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   336
xdrrdma_destroy(XDR * xdrs)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   337
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   338
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   339
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   340
	if (xdrp == NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   341
		return;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   342
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   343
	if (xdrp->xp_wcl) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   344
		if (xdrp->xp_flags & XDR_RDMA_WLIST_REG) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   345
			(void) clist_deregister(xdrp->xp_conn, xdrp->xp_wcl);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   346
			rdma_buf_free(xdrp->xp_conn,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   347
			    &xdrp->xp_wcl->rb_longbuf);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   348
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   349
		clist_free(xdrp->xp_wcl);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   350
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   351
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   352
	if (xdrp->xp_rcl) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   353
		if (xdrp->xp_flags & XDR_RDMA_RLIST_REG) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   354
			(void) clist_deregister(xdrp->xp_conn, xdrp->xp_rcl);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   355
			rdma_buf_free(xdrp->xp_conn,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   356
			    &xdrp->xp_rcl->rb_longbuf);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   357
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   358
		clist_free(xdrp->xp_rcl);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   359
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   360
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   361
	if (xdrp->xp_rcl_xdr)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   362
		xdrrdma_free_xdr_chunks(xdrp->xp_conn, xdrp->xp_rcl_xdr);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   363
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   364
	(void) kmem_free(xdrs->x_private, sizeof (xrdma_private_t));
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   365
	xdrs->x_private = NULL;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   366
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   367
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   368
static	bool_t
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   369
xdrrdma_getint32(XDR *xdrs, int32_t *int32p)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   370
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   371
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   372
	int chunked = 0;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   373
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   374
	if ((xdrs->x_handy -= (int)sizeof (int32_t)) < 0) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   375
		/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   376
		 * check if rest of the rpc message is in a chunk
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   377
		 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   378
		if (!xdrrdma_read_a_chunk(xdrs, &xdrp->xp_conn)) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   379
			return (FALSE);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   380
		}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   381
		chunked = 1;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   382
	}
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   383
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   384
	/* LINTED pointer alignment */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   385
	*int32p = (int32_t)ntohl((uint32_t)(*((int32_t *)(xdrp->xp_offp))));
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   386
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   387
	DTRACE_PROBE1(krpc__i__xdrrdma_getint32, int32_t, *int32p);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   388
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   389
	xdrp->xp_offp += sizeof (int32_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   390
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   391
	if (chunked)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   392
		xdrs->x_handy -= (int)sizeof (int32_t);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   393
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   394
	if (xdrp->xp_off != 0) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   395
		xdrp->xp_off += sizeof (int32_t);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   396
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   397
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   398
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   399
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   400
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   401
static	bool_t
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   402
xdrrdma_putint32(XDR *xdrs, int32_t *int32p)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   403
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   404
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   405
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   406
	if ((xdrs->x_handy -= (int)sizeof (int32_t)) < 0)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   407
		return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   408
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   409
	/* LINTED pointer alignment */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   410
	*(int32_t *)xdrp->xp_offp = (int32_t)htonl((uint32_t)(*int32p));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   411
	xdrp->xp_offp += sizeof (int32_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   412
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   413
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   414
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   415
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   416
/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   417
 * DECODE bytes from XDR stream for rdma.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   418
 * If the XDR stream contains a read chunk list,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   419
 * it will go through xdrrdma_getrdmablk instead.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   420
 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   421
static	bool_t
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   422
xdrrdma_getbytes(XDR *xdrs, caddr_t addr, int len)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   423
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   424
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   425
	struct clist	*cle = *(xdrp->xp_rcl_next);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   426
	struct clist	*cls = *(xdrp->xp_rcl_next);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   427
	struct clist	cl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   428
	bool_t		retval = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   429
	uint32_t	total_len = len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   430
	uint32_t	cur_offset = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   431
	uint32_t	total_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   432
	uint32_t	actual_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   433
	uint32_t	status;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   434
	uint32_t	alen;
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   435
	uint32_t	xpoff;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   436
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   437
	while (cle) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   438
		total_segments++;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   439
		cle = cle->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   440
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   441
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   442
	cle = *(xdrp->xp_rcl_next);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   443
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   444
	if (xdrp->xp_off) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   445
		xpoff = xdrp->xp_off;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   446
	} else {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   447
		xpoff = (xdrp->xp_offp - xdrs->x_base);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   448
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   449
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   450
	/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   451
	 * If there was a chunk at the current offset, then setup a read
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   452
	 * chunk list which records the destination address and length
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   453
	 * and will RDMA READ the data in later.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   454
	 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   455
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   456
	if (cle != NULL && cle->c_xdroff == xpoff) {
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   457
		for (actual_segments = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   458
		    actual_segments < total_segments; actual_segments++) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   459
			if (total_len <= 0)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   460
				break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   461
			cle->u.c_daddr = (uint64)(uintptr_t)addr + cur_offset;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   462
			alen = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   463
			if (cle->c_len > total_len) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   464
				alen = cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   465
				cle->c_len = total_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   466
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   467
			if (!alen)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   468
				xdrp->xp_rcl_next = &cle->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   469
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   470
			cur_offset += cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   471
			total_len -= cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   472
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   473
			if ((total_segments - actual_segments - 1) == 0 &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   474
			    total_len > 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   475
				DTRACE_PROBE(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   476
				    krpc__e__xdrrdma_getbytes_chunktooshort);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   477
				retval = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   478
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   479
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   480
			if ((total_segments - actual_segments - 1) > 0 &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   481
			    total_len == 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   482
				DTRACE_PROBE2(krpc__e__xdrrdma_getbytes_toobig,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   483
				    int, total_segments, int, actual_segments);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   484
			}
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   485
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   486
			/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   487
			 * RDMA READ the chunk data from the remote end.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   488
			 * First prep the destination buffer by registering
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   489
			 * it, then RDMA READ the chunk data. Since we are
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   490
			 * doing streaming memory, sync the destination
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   491
			 * buffer to CPU and deregister the buffer.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   492
			 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   493
			if (xdrp->xp_conn == NULL) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   494
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   495
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   496
			cl = *cle;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   497
			cl.c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   498
			if (clist_register(xdrp->xp_conn, &cl, CLIST_REG_DST)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   499
			    != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   500
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   501
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   502
			cle->c_dmemhandle = cl.c_dmemhandle;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   503
			cle->c_dsynchandle = cl.c_dsynchandle;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   504
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   505
			/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   506
			 * Now read the chunk in
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   507
			 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   508
			if ((total_segments - actual_segments - 1) == 0 ||
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   509
			    total_len == 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   510
				status = RDMA_READ(xdrp->xp_conn, &cl, WAIT);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   511
			} else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   512
				status = RDMA_READ(xdrp->xp_conn, &cl, NOWAIT);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   513
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   514
			if (status != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   515
				DTRACE_PROBE1(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   516
				    krpc__i__xdrrdma_getblk_readfailed,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   517
				    int, status);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   518
				retval = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   519
				goto out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   520
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   521
			cle = cle->c_next;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   522
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   523
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   524
		/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   525
		 * sync the memory for cpu
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   526
		 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   527
		cl = *cls;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   528
		cl.c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   529
		cl.c_len = cur_offset;
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   530
		if (clist_syncmem(
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   531
		    xdrp->xp_conn, &cl, CLIST_REG_DST) != RDMA_SUCCESS) {
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   532
			retval = FALSE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   533
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   534
out:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   535
		/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   536
		 * Deregister the chunks
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   537
		 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   538
		cle = cls;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   539
		cl = *cle;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   540
		cl.c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   541
		cl.c_len = cur_offset;
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   542
		(void) clist_deregister(xdrp->xp_conn, &cl);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   543
		if (alen) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   544
			cle->w.c_saddr =
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   545
			    (uint64)(uintptr_t)cle->w.c_saddr + cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   546
			cle->c_len = alen - cle->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   547
		}
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   548
		return (retval);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   549
	}
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   550
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   551
	if ((xdrs->x_handy -= len) < 0)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   552
		return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   553
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   554
	bcopy(xdrp->xp_offp, addr, len);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   555
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   556
	xdrp->xp_offp += len;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   557
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   558
	if (xdrp->xp_off != 0)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   559
		xdrp->xp_off += len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   560
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   561
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   562
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   563
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   564
/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   565
 * ENCODE some bytes into an XDR stream xp_min_chunk = 0, means the stream of
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   566
 * bytes contain no chunks to seperate out, and if the bytes do not fit in
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   567
 * the supplied buffer, grow the buffer and free the old buffer.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   568
 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   569
static	bool_t
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   570
xdrrdma_putbytes(XDR *xdrs, caddr_t addr, int len)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   571
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   572
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   573
	/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   574
	 * Is this stream accepting chunks?
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   575
	 * If so, does the either of the two following conditions exist?
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   576
	 * - length of bytes to encode is greater than the min chunk size?
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   577
	 * - remaining space in this stream is shorter than length of
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   578
	 *   bytes to encode?
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   579
	 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   580
	 * If the above exists, then create a chunk for this encoding
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   581
	 * and save the addresses, etc.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   582
	 */
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   583
	if (xdrp->xp_flags & XDR_RDMA_CHUNK &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   584
	    ((xdrp->xp_min_chunk != 0 &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   585
	    len >= xdrp->xp_min_chunk) ||
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   586
	    (xdrs->x_handy - len  < 0))) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   587
		struct clist	*cle;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   588
		int		offset = xdrp->xp_offp - xdrs->x_base;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   589
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   590
		cle = clist_alloc();
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   591
		cle->c_xdroff = offset;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   592
		cle->c_len = len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   593
		cle->w.c_saddr = (uint64)(uintptr_t)addr;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   594
		cle->c_next = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   595
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   596
		*(xdrp->xp_rcl_next) = cle;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   597
		xdrp->xp_rcl_next = &(cle->c_next);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   598
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   599
		return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   600
	}
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   601
	/* Is there enough space to encode what is left? */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   602
	if ((xdrs->x_handy -= len) < 0) {
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   603
		return (FALSE);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   604
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   605
	bcopy(addr, xdrp->xp_offp, len);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   606
	xdrp->xp_offp += len;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   607
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   608
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   609
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   610
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   611
uint_t
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   612
xdrrdma_getpos(XDR *xdrs)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   613
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   614
	xrdma_private_t *xdrp = (xrdma_private_t *)(xdrs->x_private);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   615
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   616
	return ((uint_t)((uintptr_t)xdrp->xp_offp - (uintptr_t)xdrs->x_base));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   617
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   618
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   619
bool_t
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   620
xdrrdma_setpos(XDR *xdrs, uint_t pos)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   621
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   622
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   623
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   624
	caddr_t		newaddr = xdrs->x_base + pos;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   625
	caddr_t		lastaddr = xdrp->xp_offp + xdrs->x_handy;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   626
	ptrdiff_t	diff;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   627
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   628
	if (newaddr > lastaddr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   629
		return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   630
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   631
	xdrp->xp_offp = newaddr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   632
	diff = lastaddr - newaddr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   633
	xdrs->x_handy = (int)diff;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   634
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   635
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   636
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   637
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   638
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   639
static rpc_inline_t *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   640
xdrrdma_inline(XDR *xdrs, int len)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   641
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   642
	rpc_inline_t	*buf = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   643
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   644
	struct clist	*cle = *(xdrp->xp_rcl_next);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   645
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   646
	if (xdrs->x_op == XDR_DECODE) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   647
		/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   648
		 * Since chunks aren't in-line, check to see whether there is
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   649
		 * a chunk in the inline range.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   650
		 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   651
		if (cle != NULL &&
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   652
		    cle->c_xdroff <= (xdrp->xp_offp - xdrs->x_base + len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   653
			return (NULL);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   654
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   655
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   656
	/* LINTED pointer alignment */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   657
	buf = (rpc_inline_t *)xdrp->xp_offp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   658
	if (!IS_P2ALIGNED(buf, sizeof (int32_t)))
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   659
		return (NULL);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   660
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   661
	if ((xdrs->x_handy < len) || (xdrp->xp_min_chunk != 0 &&
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   662
	    len >= xdrp->xp_min_chunk)) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   663
		return (NULL);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   664
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   665
		xdrs->x_handy -= len;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   666
		xdrp->xp_offp += len;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   667
		return (buf);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   668
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   669
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   670
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   671
static	bool_t
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   672
xdrrdma_control(XDR *xdrs, int request, void *info)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   673
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   674
	int32_t		*int32p;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   675
	int		len, i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   676
	uint_t		in_flags;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   677
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   678
	rdma_chunkinfo_t *rcip = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   679
	rdma_wlist_conn_info_t *rwcip = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   680
	rdma_chunkinfo_lengths_t *rcilp = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   681
	struct uio *uiop;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   682
	struct clist	*rwl = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   683
	struct clist	*prev = NULL;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   684
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   685
	switch (request) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   686
	case XDR_PEEK:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   687
		/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   688
		 * Return the next 4 byte unit in the XDR stream.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   689
		 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   690
		if (xdrs->x_handy < sizeof (int32_t))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   691
			return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   692
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   693
		int32p = (int32_t *)info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   694
		*int32p = (int32_t)ntohl((uint32_t)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   695
		    (*((int32_t *)(xdrp->xp_offp))));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   696
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   697
		return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   698
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   699
	case XDR_SKIPBYTES:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   700
		/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   701
		 * Skip the next N bytes in the XDR stream.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   702
		 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   703
		int32p = (int32_t *)info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   704
		len = RNDUP((int)(*int32p));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   705
		if ((xdrs->x_handy -= len) < 0)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   706
			return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   707
		xdrp->xp_offp += len;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   708
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   709
		return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   710
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   711
	case XDR_RDMA_SET_FLAGS:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   712
		/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   713
		 * Set the flags provided in the *info in xp_flags for rdma
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   714
		 * xdr stream control.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   715
		 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   716
		int32p = (int32_t *)info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   717
		in_flags = (uint_t)(*int32p);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   718
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   719
		xdrp->xp_flags |= in_flags;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   720
		return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   721
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   722
	case XDR_RDMA_GET_FLAGS:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   723
		/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   724
		 * Get the flags provided in xp_flags return through *info
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   725
		 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   726
		int32p = (int32_t *)info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   727
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   728
		*int32p = (int32_t)xdrp->xp_flags;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   729
		return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   730
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   731
	case XDR_RDMA_GET_CHUNK_LEN:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   732
		rcilp = (rdma_chunkinfo_lengths_t *)info;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   733
		rcilp->rcil_len = xdrp->xp_reply_chunk_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   734
		rcilp->rcil_len_alt = xdrp->xp_reply_chunk_len_alt;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   735
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   736
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   737
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   738
	case XDR_RDMA_ADD_CHUNK:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   739
		/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   740
		 * Store wlist information
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   741
		 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   742
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   743
		rcip = (rdma_chunkinfo_t *)info;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   744
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   745
		switch (rcip->rci_type) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   746
		case RCI_WRITE_UIO_CHUNK:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   747
			xdrp->xp_reply_chunk_len_alt += rcip->rci_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   748
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   749
			if (rcip->rci_len < xdrp->xp_min_chunk) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   750
				xdrp->xp_wcl = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   751
				*(rcip->rci_clpp) = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   752
				return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   753
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   754
			uiop = rcip->rci_a.rci_uiop;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   755
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   756
			for (i = 0; i < uiop->uio_iovcnt; i++) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   757
				rwl = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   758
				rwl->c_len = uiop->uio_iov[i].iov_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   759
				rwl->u.c_daddr =
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   760
				    (uint64)(uintptr_t)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   761
				    (uiop->uio_iov[i].iov_base);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   762
				/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   763
				 * if userspace address, put adspace ptr in
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   764
				 * clist. If not, then do nothing since it's
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   765
				 * already set to NULL (from kmem_zalloc)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   766
				 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   767
				if (uiop->uio_segflg == UIO_USERSPACE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   768
					rwl->c_adspc = ttoproc(curthread)->p_as;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   769
				}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   770
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   771
				if (prev == NULL)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   772
					prev = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   773
				else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   774
					prev->c_next = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   775
					prev = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   776
				}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   777
			}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   778
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   779
			rwl->c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   780
			xdrp->xp_wcl = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   781
			*(rcip->rci_clpp) = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   782
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   783
			break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   784
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   785
		case RCI_WRITE_ADDR_CHUNK:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   786
			rwl = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   787
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   788
			rwl->c_len = rcip->rci_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   789
			rwl->u.c_daddr3 = rcip->rci_a.rci_addr;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   790
			rwl->c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   791
			xdrp->xp_reply_chunk_len_alt += rcip->rci_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   792
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   793
			xdrp->xp_wcl = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   794
			*(rcip->rci_clpp) = rwl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   795
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   796
			break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   797
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   798
		case RCI_REPLY_CHUNK:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   799
			xdrp->xp_reply_chunk_len += rcip->rci_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   800
			break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   801
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   802
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   803
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   804
	case XDR_RDMA_GET_WLIST:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   805
		*((struct clist **)info) = xdrp->xp_wcl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   806
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   807
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   808
	case XDR_RDMA_SET_WLIST:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   809
		xdrp->xp_wcl = (struct clist *)info;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   810
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   811
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   812
	case XDR_RDMA_GET_RLIST:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   813
		*((struct clist **)info) = xdrp->xp_rcl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   814
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   815
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   816
	case XDR_RDMA_GET_WCINFO:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   817
		rwcip = (rdma_wlist_conn_info_t *)info;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   818
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   819
		rwcip->rwci_wlist = xdrp->xp_wcl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   820
		rwcip->rwci_conn = xdrp->xp_conn;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   821
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   822
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   823
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   824
	default:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   825
		return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   826
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   827
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   828
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   829
bool_t xdr_do_clist(XDR *, clist **);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   830
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   831
/*
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   832
 * Not all fields in struct clist are interesting to the RPC over RDMA
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   833
 * protocol. Only XDR the interesting fields.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   834
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   835
bool_t
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   836
xdr_clist(XDR *xdrs, clist *objp)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   837
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   838
	if (!xdr_uint32(xdrs, &objp->c_xdroff))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   839
		return (FALSE);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   840
	if (!xdr_uint32(xdrs, &objp->c_smemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   841
		return (FALSE);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   842
	if (!xdr_uint32(xdrs, &objp->c_len))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   843
		return (FALSE);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   844
	if (!xdr_uint64(xdrs, &objp->w.c_saddr))
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   845
		return (FALSE);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   846
	if (!xdr_do_clist(xdrs, &objp->c_next))
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   847
		return (FALSE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   848
	return (TRUE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   849
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   850
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   851
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   852
 * The following two functions are forms of xdr_pointer()
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   853
 * and xdr_reference(). Since the generic versions just
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   854
 * kmem_alloc() a new clist, we actually want to use the
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   855
 * rdma_clist kmem_cache.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   856
 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   857
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   858
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   859
 * Generate or free a clist structure from the
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   860
 * kmem_cache "rdma_clist"
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   861
 */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   862
bool_t
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   863
xdr_ref_clist(XDR *xdrs, caddr_t *pp)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   864
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   865
	caddr_t loc = *pp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   866
	bool_t stat;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   867
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   868
	if (loc == NULL) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   869
		switch (xdrs->x_op) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   870
		case XDR_FREE:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   871
			return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   872
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   873
		case XDR_DECODE:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   874
			*pp = loc = (caddr_t)clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   875
			break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   876
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   877
		case XDR_ENCODE:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   878
			ASSERT(loc);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   879
			break;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   880
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   881
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   882
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   883
	stat = xdr_clist(xdrs, (struct clist *)loc);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   884
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   885
	if (xdrs->x_op == XDR_FREE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   886
		kmem_cache_free(clist_cache, loc);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   887
		*pp = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   888
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   889
	return (stat);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   890
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   891
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   892
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   893
 * XDR a pointer to a possibly recursive clist. This differs
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   894
 * with xdr_reference in that it can serialize/deserialiaze
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   895
 * trees correctly.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   896
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   897
 *  What is sent is actually a union:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   898
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   899
 *  union object_pointer switch (boolean b) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   900
 *  case TRUE: object_data data;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   901
 *  case FALSE: void nothing;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   902
 *  }
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   903
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   904
 * > objpp: Pointer to the pointer to the object.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   905
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   906
 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   907
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   908
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   909
xdr_do_clist(XDR *xdrs, clist **objpp)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   910
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   911
	bool_t more_data;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   912
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   913
	more_data = (*objpp != NULL);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   914
	if (!xdr_bool(xdrs, &more_data))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   915
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   916
	if (!more_data) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   917
		*objpp = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   918
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   919
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   920
	return (xdr_ref_clist(xdrs, (caddr_t *)objpp));
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   921
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   922
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   923
uint_t
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   924
xdr_getbufsize(XDR *xdrs)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   925
{
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   926
	xrdma_private_t *xdrp = (xrdma_private_t *)(xdrs->x_private);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   927
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   928
	return ((uint_t)xdrp->xp_buf_size);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   929
}
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   930
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   931
/* ARGSUSED */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   932
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   933
xdr_encode_rlist_svc(XDR *xdrs, clist *rlist)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   934
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   935
	bool_t	vfalse = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   936
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   937
	ASSERT(rlist == NULL);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   938
	return (xdr_bool(xdrs, &vfalse));
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   939
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   940
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   941
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   942
xdr_encode_wlist(XDR *xdrs, clist *w)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   943
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   944
	bool_t		vfalse = FALSE, vtrue = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   945
	int		i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   946
	uint_t		num_segment = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   947
	struct clist	*cl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   948
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   949
	/* does a wlist exist? */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   950
	if (w == NULL) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   951
		return (xdr_bool(xdrs, &vfalse));
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   952
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   953
	/* Encode N consecutive segments, 1, N, HLOO, ..., HLOO, 0 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   954
	if (!xdr_bool(xdrs, &vtrue))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   955
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   956
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   957
	for (cl = w; cl != NULL; cl = cl->c_next) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   958
		num_segment++;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   959
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   960
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   961
	if (!xdr_uint32(xdrs, &num_segment))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   962
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   963
	for (i = 0; i < num_segment; i++) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   964
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   965
		DTRACE_PROBE1(krpc__i__xdr_encode_wlist_len, uint_t, w->c_len);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
   966
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   967
		if (!xdr_uint32(xdrs, &w->c_dmemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   968
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   969
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   970
		if (!xdr_uint32(xdrs, &w->c_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   971
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   972
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   973
		if (!xdr_uint64(xdrs, &w->u.c_daddr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   974
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   975
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   976
		w = w->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   977
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   978
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   979
	if (!xdr_bool(xdrs, &vfalse))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   980
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   981
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   982
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   983
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   984
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   985
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   986
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   987
 * Conditionally decode a RDMA WRITE chunk list from XDR stream.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   988
 *
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   989
 * If the next boolean in the XDR stream is false there is no
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   990
 * RDMA WRITE chunk list present. Otherwise iterate over the
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   991
 * array and for each entry: allocate a struct clist and decode.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   992
 * Pass back an indication via wlist_exists if we have seen a
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   993
 * RDMA WRITE chunk list.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   994
 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   995
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   996
xdr_decode_wlist(XDR *xdrs, struct clist **w, bool_t *wlist_exists)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   997
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   998
	struct clist	*tmp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
   999
	bool_t		more = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1000
	uint32_t	seg_array_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1001
	uint32_t	i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1002
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1003
	if (!xdr_bool(xdrs, &more))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1004
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1005
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1006
	/* is there a wlist? */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1007
	if (more == FALSE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1008
		*wlist_exists = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1009
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1010
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1011
	*wlist_exists = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1012
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1013
	if (!xdr_uint32(xdrs, &seg_array_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1014
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1015
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1016
	tmp = *w = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1017
	for (i = 0; i < seg_array_len; i++) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1018
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1019
		if (!xdr_uint32(xdrs, &tmp->c_dmemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1020
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1021
		if (!xdr_uint32(xdrs, &tmp->c_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1022
			return (FALSE);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1023
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1024
		DTRACE_PROBE1(krpc__i__xdr_decode_wlist_len,
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1025
		    uint_t, tmp->c_len);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1026
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1027
		if (!xdr_uint64(xdrs, &tmp->u.c_daddr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1028
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1029
		if (i < seg_array_len - 1) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1030
			tmp->c_next = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1031
			tmp = tmp->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1032
		} else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1033
			tmp->c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1034
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1035
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1036
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1037
	more = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1038
	if (!xdr_bool(xdrs, &more))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1039
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1040
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1041
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1042
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1043
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1044
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1045
 * Server side RDMA WRITE list decode.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1046
 * XDR context is memory ops
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1047
 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1048
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1049
xdr_decode_wlist_svc(XDR *xdrs, struct clist **wclp, bool_t *wwl,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1050
    uint32_t *total_length, CONN *conn)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1051
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1052
	struct clist	*first, *ncl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1053
	char		*memp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1054
	uint32_t	num_wclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1055
	uint32_t	wcl_length = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1056
	uint32_t	i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1057
	bool_t		more = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1058
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1059
	*wclp = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1060
	*wwl = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1061
	*total_length = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1062
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1063
	if (!xdr_bool(xdrs, &more)) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1064
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1065
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1066
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1067
	if (more == FALSE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1068
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1069
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1070
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1071
	*wwl = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1072
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1073
	if (!xdr_uint32(xdrs, &num_wclist)) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1074
		DTRACE_PROBE(krpc__e__xdrrdma__wlistsvc__listlength);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1075
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1076
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1077
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1078
	first = ncl = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1079
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1080
	for (i = 0; i < num_wclist; i++) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1081
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1082
		if (!xdr_uint32(xdrs, &ncl->c_dmemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1083
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1084
		if (!xdr_uint32(xdrs, &ncl->c_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1085
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1086
		if (!xdr_uint64(xdrs, &ncl->u.c_daddr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1087
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1088
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1089
		if (ncl->c_len > MAX_SVC_XFER_SIZE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1090
			DTRACE_PROBE(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1091
			    krpc__e__xdrrdma__wlistsvc__chunklist_toobig);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1092
			ncl->c_len = MAX_SVC_XFER_SIZE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1093
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1094
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1095
		DTRACE_PROBE1(krpc__i__xdr_decode_wlist_svc_len,
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1096
		    uint_t, ncl->c_len);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1097
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1098
		wcl_length += ncl->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1099
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1100
		if (i < num_wclist - 1) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1101
			ncl->c_next = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1102
			ncl = ncl->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1103
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1104
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1105
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1106
	if (!xdr_bool(xdrs, &more))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1107
		goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1108
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1109
	first->rb_longbuf.type = RDMA_LONG_BUFFER;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1110
	first->rb_longbuf.len =
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1111
	    wcl_length > WCL_BUF_LEN ? wcl_length : WCL_BUF_LEN;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1112
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1113
	if (rdma_buf_alloc(conn, &first->rb_longbuf)) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1114
		clist_free(first);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1115
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1116
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1117
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1118
	memp = first->rb_longbuf.addr;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1119
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1120
	ncl = first;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1121
	for (i = 0; i < num_wclist; i++) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1122
		ncl->w.c_saddr3 = (caddr_t)memp;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1123
		memp += ncl->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1124
		ncl = ncl->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1125
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1126
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1127
	*wclp = first;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1128
	*total_length = wcl_length;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1129
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1130
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1131
err_out:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1132
	clist_free(first);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1133
	return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1134
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1135
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1136
/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1137
 * XDR decode the long reply write chunk.
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1138
 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1139
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1140
xdr_decode_reply_wchunk(XDR *xdrs, struct clist **clist)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1141
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1142
	bool_t		have_rchunk = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1143
	struct clist	*first = NULL, *ncl = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1144
	uint32_t	num_wclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1145
	uint32_t	i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1146
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1147
	if (!xdr_bool(xdrs, &have_rchunk))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1148
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1149
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1150
	if (have_rchunk == FALSE)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1151
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1152
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1153
	if (!xdr_uint32(xdrs, &num_wclist)) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1154
		DTRACE_PROBE(krpc__e__xdrrdma__replywchunk__listlength);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1155
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1156
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1157
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1158
	if (num_wclist == 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1159
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1160
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1161
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1162
	first = ncl = clist_alloc();
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1163
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1164
	for (i = 0; i < num_wclist; i++) {
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1165
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1166
		if (i > 0) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1167
			ncl->c_next = clist_alloc();
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1168
			ncl = ncl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1169
		}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1170
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1171
		if (!xdr_uint32(xdrs, &ncl->c_dmemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1172
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1173
		if (!xdr_uint32(xdrs, &ncl->c_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1174
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1175
		if (!xdr_uint64(xdrs, &ncl->u.c_daddr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1176
			goto err_out;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1177
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1178
		if (ncl->c_len > MAX_SVC_XFER_SIZE) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1179
			DTRACE_PROBE(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1180
			    krpc__e__xdrrdma__replywchunk__chunklist_toobig);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1181
			ncl->c_len = MAX_SVC_XFER_SIZE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1182
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1183
		if (!(ncl->c_dmemhandle.mrc_rmr &&
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1184
		    (ncl->c_len > 0) && ncl->u.c_daddr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1185
			DTRACE_PROBE(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1186
			    krpc__e__xdrrdma__replywchunk__invalid_segaddr);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1187
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1188
		DTRACE_PROBE1(krpc__i__xdr_decode_reply_wchunk_c_len,
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1189
		    uint32_t, ncl->c_len);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1190
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1191
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1192
	*clist = first;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1193
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1194
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1195
err_out:
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1196
	clist_free(first);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1197
	return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1198
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1199
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1200
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1201
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1202
xdr_encode_reply_wchunk(XDR *xdrs,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1203
    struct clist *cl_longreply, uint32_t seg_array_len)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1204
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1205
	int		i;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1206
	bool_t		long_reply_exists = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1207
	uint32_t	length;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1208
	uint64		offset;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1209
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1210
	if (seg_array_len > 0) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1211
		if (!xdr_bool(xdrs, &long_reply_exists))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1212
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1213
		if (!xdr_uint32(xdrs, &seg_array_len))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1214
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1215
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1216
		for (i = 0; i < seg_array_len; i++) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1217
			if (!cl_longreply)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1218
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1219
			length = cl_longreply->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1220
			offset = (uint64) cl_longreply->u.c_daddr;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1221
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1222
			DTRACE_PROBE1(
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1223
			    krpc__i__xdr_encode_reply_wchunk_c_len,
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1224
			    uint32_t, length);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1225
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1226
			if (!xdr_uint32(xdrs,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1227
			    &cl_longreply->c_dmemhandle.mrc_rmr))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1228
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1229
			if (!xdr_uint32(xdrs, &length))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1230
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1231
			if (!xdr_uint64(xdrs, &offset))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1232
				return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1233
			cl_longreply = cl_longreply->c_next;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1234
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1235
	} else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1236
		long_reply_exists = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1237
		if (!xdr_bool(xdrs, &long_reply_exists))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1238
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1239
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1240
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1241
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1242
bool_t
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1243
xdrrdma_read_from_client(struct clist *rlist, CONN **conn, uint_t count)
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1244
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1245
	struct clist	*rdclist;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1246
	struct clist	cl;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1247
	uint_t		total_len = 0;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1248
	uint32_t	status;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1249
	bool_t		retval = TRUE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1250
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1251
	rlist->rb_longbuf.type = RDMA_LONG_BUFFER;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1252
	rlist->rb_longbuf.len =
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1253
	    count > RCL_BUF_LEN ? count : RCL_BUF_LEN;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1254
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1255
	if (rdma_buf_alloc(*conn, &rlist->rb_longbuf)) {
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1256
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1257
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1258
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1259
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1260
	 * The entire buffer is registered with the first chunk.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1261
	 * Later chunks will use the same registered memory handle.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1262
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1263
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1264
	cl = *rlist;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1265
	cl.c_next = NULL;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1266
	if (clist_register(*conn, &cl, CLIST_REG_DST) != RDMA_SUCCESS) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1267
		rdma_buf_free(*conn, &rlist->rb_longbuf);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1268
		DTRACE_PROBE(
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1269
		    krpc__e__xdrrdma__readfromclient__clist__reg);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1270
		return (FALSE);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1271
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1272
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1273
	rlist->c_regtype = CLIST_REG_DST;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1274
	rlist->c_dmemhandle = cl.c_dmemhandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1275
	rlist->c_dsynchandle = cl.c_dsynchandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1276
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1277
	for (rdclist = rlist;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1278
	    rdclist != NULL; rdclist = rdclist->c_next) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1279
		total_len += rdclist->c_len;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1280
#if (defined(OBJ32)||defined(DEBUG32))
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1281
		rdclist->u.c_daddr3 =
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1282
		    (caddr_t)((char *)rlist->rb_longbuf.addr +
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1283
		    (uint32) rdclist->u.c_daddr3);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1284
#else
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1285
		rdclist->u.c_daddr3 =
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1286
		    (caddr_t)((char *)rlist->rb_longbuf.addr +
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1287
		    (uint64) rdclist->u.c_daddr);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1288
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1289
#endif
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1290
		cl = (*rdclist);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1291
		cl.c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1292
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1293
		/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1294
		 * Use the same memory handle for all the chunks
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1295
		 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1296
		cl.c_dmemhandle = rlist->c_dmemhandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1297
		cl.c_dsynchandle = rlist->c_dsynchandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1298
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1299
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1300
		DTRACE_PROBE1(krpc__i__xdrrdma__readfromclient__buflen,
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1301
		    int, rdclist->c_len);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1302
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1303
		/*
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1304
		 * Now read the chunk in
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1305
		 */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1306
		if (rdclist->c_next == NULL) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1307
			status = RDMA_READ(*conn, &cl, WAIT);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1308
		} else {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1309
			status = RDMA_READ(*conn, &cl, NOWAIT);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1310
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1311
		if (status != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1312
			DTRACE_PROBE(
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1313
			    krpc__e__xdrrdma__readfromclient__readfailed);
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1314
			rdma_buf_free(*conn, &rlist->rb_longbuf);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1315
			return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1316
		}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1317
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1318
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1319
	cl = (*rlist);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1320
	cl.c_next = NULL;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1321
	cl.c_len = total_len;
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1322
	if (clist_syncmem(*conn, &cl, CLIST_REG_DST) != RDMA_SUCCESS) {
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1323
		retval = FALSE;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1324
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1325
	return (retval);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1326
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1327
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1328
bool_t
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1329
xdrrdma_free_clist(CONN *conn, struct clist *clp)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1330
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1331
	rdma_buf_free(conn, &clp->rb_longbuf);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1332
	clist_free(clp);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1333
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1334
}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1335
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1336
bool_t
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1337
xdrrdma_send_read_data(XDR *xdrs, uint_t data_len, struct clist *wcl)
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1338
{
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1339
	int status;
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1340
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1341
	struct xdr_ops *xops = xdrrdma_xops();
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1342
	struct clist *tcl, *wrcl, *cl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1343
	struct clist fcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1344
	int rndup_present, rnduplen;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1345
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1346
	rndup_present = 0;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1347
	wrcl = NULL;
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1348
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1349
	/* caller is doing a sizeof */
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1350
	if (xdrs->x_ops != &xdrrdma_ops || xdrs->x_ops == xops)
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1351
		return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1352
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1353
	/* copy of the first chunk */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1354
	fcl = *wcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1355
	fcl.c_next = NULL;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1356
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1357
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1358
	 * The entire buffer is registered with the first chunk.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1359
	 * Later chunks will use the same registered memory handle.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1360
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1361
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1362
	status = clist_register(xdrp->xp_conn, &fcl, CLIST_REG_SOURCE);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1363
	if (status != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1364
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1365
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1366
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1367
	wcl->c_regtype = CLIST_REG_SOURCE;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1368
	wcl->c_smemhandle = fcl.c_smemhandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1369
	wcl->c_ssynchandle = fcl.c_ssynchandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1370
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1371
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1372
	 * Only transfer the read data ignoring any trailing
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1373
	 * roundup chunks. A bit of work, but it saves an
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1374
	 * unnecessary extra RDMA_WRITE containing only
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1375
	 * roundup bytes.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1376
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1377
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1378
	rnduplen = clist_len(wcl) - data_len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1379
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1380
	if (rnduplen) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1381
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1382
		tcl = wcl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1383
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1384
		/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1385
		 * Check if there is a trailing roundup chunk
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1386
		 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1387
		while (tcl) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1388
			if ((tcl->c_next == NULL) && (tcl->c_len == rnduplen)) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1389
				rndup_present = 1;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1390
				break;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1391
			}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1392
			tcl = tcl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1393
		}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1394
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1395
		/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1396
		 * Make a copy chunk list skipping the last chunk
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1397
		 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1398
		if (rndup_present) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1399
			cl = wcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1400
			tcl = NULL;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1401
			while (cl) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1402
				if (tcl == NULL) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1403
					tcl = clist_alloc();
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1404
					wrcl = tcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1405
				} else {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1406
					tcl->c_next = clist_alloc();
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1407
					tcl = tcl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1408
				}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1409
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1410
				*tcl = *cl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1411
				cl = cl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1412
				/* last chunk */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1413
				if (cl->c_next == NULL)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1414
					break;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1415
			}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1416
			tcl->c_next = NULL;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1417
		}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1418
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1419
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1420
	if (wrcl == NULL) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1421
		/* No roundup chunks */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1422
		wrcl = wcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1423
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1424
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1425
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1426
	 * Set the registered memory handles for the
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1427
	 * rest of the chunks same as the first chunk.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1428
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1429
	tcl = wrcl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1430
	while (tcl) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1431
		tcl->c_smemhandle = fcl.c_smemhandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1432
		tcl->c_ssynchandle = fcl.c_ssynchandle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1433
		tcl = tcl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1434
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1435
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1436
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1437
	 * Sync the total len beginning from the first chunk.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1438
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1439
	fcl.c_len = clist_len(wrcl);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1440
	status = clist_syncmem(xdrp->xp_conn, &fcl, CLIST_REG_SOURCE);
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1441
	if (status != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1442
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1443
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1444
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1445
	status = RDMA_WRITE(xdrp->xp_conn, wrcl, WAIT);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1446
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1447
	if (rndup_present)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1448
		clist_free(wrcl);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1449
7387
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1450
	if (status != RDMA_SUCCESS) {
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1451
		return (FALSE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1452
	}
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1453
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1454
	return (TRUE);
0b3a92e31fd8 PSARC 2007/347 NFS/RDMA - Transport Version Update
Robert Gordon <Robert.Gordon@Sun.COM>
parents: 0
diff changeset
  1455
}
9348
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1456
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1457
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1458
/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1459
 * Reads one chunk at a time
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1460
 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1461
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1462
static bool_t
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1463
xdrrdma_read_a_chunk(XDR *xdrs, CONN **conn)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1464
{
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1465
	int status;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1466
	int32_t len = 0;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1467
	xrdma_private_t	*xdrp = (xrdma_private_t *)(xdrs->x_private);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1468
	struct clist *cle = *(xdrp->xp_rcl_next);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1469
	struct clist *rclp = xdrp->xp_rcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1470
	struct clist *clp;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1471
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1472
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1473
	 * len is used later to decide xdr offset in
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1474
	 * the chunk factoring any 4-byte XDR alignment
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1475
	 * (See read chunk example top of this file)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1476
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1477
	while (rclp != cle) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1478
		len += rclp->c_len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1479
		rclp = rclp->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1480
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1481
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1482
	len = RNDUP(len) - len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1483
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1484
	ASSERT(xdrs->x_handy <= 0);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1485
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1486
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1487
	 * If this is the first chunk to contain the RPC
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1488
	 * message set xp_off to the xdr offset of the
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1489
	 * inline message.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1490
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1491
	if (xdrp->xp_off == 0)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1492
		xdrp->xp_off = (xdrp->xp_offp - xdrs->x_base);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1493
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1494
	if (cle == NULL || (cle->c_xdroff != xdrp->xp_off))
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1495
		return (FALSE);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1496
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1497
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1498
	 * Make a copy of the chunk to read from client.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1499
	 * Chunks are read on demand, so read only one
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1500
	 * for now.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1501
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1502
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1503
	rclp = clist_alloc();
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1504
	*rclp = *cle;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1505
	rclp->c_next = NULL;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1506
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1507
	xdrp->xp_rcl_next = &cle->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1508
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1509
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1510
	 * If there is a roundup present, then skip those
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1511
	 * bytes when reading.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1512
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1513
	if (len) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1514
		rclp->w.c_saddr =
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1515
		    (uint64)(uintptr_t)rclp->w.c_saddr + len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1516
			rclp->c_len = rclp->c_len - len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1517
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1518
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1519
	status = xdrrdma_read_from_client(rclp, conn, rclp->c_len);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1520
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1521
	if (status == FALSE) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1522
		clist_free(rclp);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1523
		return (status);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1524
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1525
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1526
	xdrp->xp_offp = rclp->rb_longbuf.addr;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1527
	xdrs->x_base = xdrp->xp_offp;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1528
	xdrs->x_handy = rclp->c_len;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1529
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1530
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1531
	 * This copy of read chunks containing the XDR
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1532
	 * message is freed later in xdrrdma_destroy()
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1533
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1534
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1535
	if (xdrp->xp_rcl_xdr) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1536
		/* Add the chunk to end of the list */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1537
		clp = xdrp->xp_rcl_xdr;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1538
		while (clp->c_next != NULL)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1539
			clp = clp->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1540
		clp->c_next = rclp;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1541
	} else {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1542
		xdrp->xp_rcl_xdr = rclp;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1543
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1544
	return (TRUE);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1545
}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1546
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1547
static void
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1548
xdrrdma_free_xdr_chunks(CONN *conn, struct clist *xdr_rcl)
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1549
{
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1550
	struct clist *cl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1551
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1552
	(void) clist_deregister(conn, xdr_rcl);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1553
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1554
	/*
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1555
	 * Read chunks containing parts XDR message are
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1556
	 * special: in case of multiple chunks each has
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1557
	 * its own buffer.
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1558
	 */
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1559
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1560
	cl = xdr_rcl;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1561
	while (cl) {
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1562
		rdma_buf_free(conn, &cl->rb_longbuf);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1563
		cl = cl->c_next;
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1564
	}
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1565
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1566
	clist_free(xdr_rcl);
7155ecb17858 6760947 NFS/RDMA port should be changed to IANA assigned 20049
Siddheshwar Mahesh <Siddheshwar.Mahesh@Sun.COM>
parents: 7387
diff changeset
  1567
}