2 * Copyright (c) 2010 Your Filesystem Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR `AS IS'' AND ANY EXPRESS OR
14 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
15 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
16 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
17 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
18 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
22 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 #include <afsconfig.h>
26 #include <afs/param.h>
29 # include "afs/sysincludes.h"
37 xdrlen_destroy(XDR
*xdrs
)
42 xdrlen_getint32(XDR
*xdrs
, afs_int32
* lp
)
48 xdrlen_putint32(XDR
*xdrs
, afs_int32
* lp
)
50 xdrs
->x_handy
+= sizeof(afs_int32
);
55 xdrlen_getbytes(XDR
*xdrs
, caddr_t addr
, u_int len
)
61 xdrlen_putbytes(XDR
*xdrs
, caddr_t addr
, u_int len
)
68 xdrlen_getpos(XDR
*xdrs
)
74 xdrlen_setpos(XDR
*xdrs
, u_int pos
)
81 xdrlen_inline(XDR
*xdrs
, u_int len
)
86 static struct xdr_ops xdrlen_ops
= {
87 #ifndef HAVE_STRUCT_LABEL_SUPPORT
88 /* Windows does not support labeled assigments */
89 xdrlen_getint32
, /* not supported */
90 xdrlen_putint32
, /* serialize an afs_int32 */
91 xdrlen_getbytes
, /* not supported */
92 xdrlen_putbytes
, /* serialize counted bytes */
93 xdrlen_getpos
, /* get offset in the stream */
94 xdrlen_setpos
, /* set offset in the stream */
95 xdrlen_inline
, /* not supported */
96 xdrlen_destroy
, /* destroy stream */
98 .x_getint32
= xdrlen_getint32
,
99 .x_putint32
= xdrlen_putint32
,
100 .x_getbytes
= xdrlen_getbytes
,
101 .x_putbytes
= xdrlen_putbytes
,
102 .x_getpostn
= xdrlen_getpos
,
103 .x_setpostn
= xdrlen_setpos
,
104 .x_inline
= xdrlen_inline
,
105 .x_destroy
= xdrlen_destroy
110 * Initialise an XDR stream to calculate the space required to encode
112 * This initialises an XDR stream object which can be used to calculate
113 * the space required to encode a particular structure into memory. No
114 * encoding is actually performed, a later call using xdrmem is necessary
118 * A pointer to a preallocated XDR sized block of memory.
121 xdrlen_create(XDR
* xdrs
)
123 xdrs
->x_op
= XDR_ENCODE
;
124 xdrs
->x_ops
= &xdrlen_ops
;