1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause 3 * 4 * Copyright (c) 2009 Rick Macklem, University of Guelph 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28 29 #ifndef _NFS_NFSCL_H 30 #define _NFS_NFSCL_H 31 32 /* 33 * Extra stuff for a NFSv4 nfsnode. 34 * MALLOC'd to the correct length for the name and file handle. 35 * n4_data has the file handle, followed by the file name. 36 * The macro NFS4NODENAME() returns a pointer to the start of the 37 * name. 38 */ 39 struct nfsv4node { 40 u_int16_t n4_fhlen; 41 u_int16_t n4_namelen; 42 u_int8_t n4_data[1]; 43 }; 44 45 #define NFS4NODENAME(n) (&((n)->n4_data[(n)->n4_fhlen])) 46 47 /* 48 * Just a macro to convert the nfscl_reqstart arguments. 49 */ 50 #define NFSCL_REQSTART(n, p, v, c) \ 51 nfscl_reqstart((n), (p), VFSTONFS((v)->v_mount), \ 52 VTONFS(v)->n_fhp->nfh_fh, VTONFS(v)->n_fhp->nfh_len, NULL, \ 53 NULL, 0, 0, (c)) 54 55 /* 56 * These two macros convert between a lease duration and renew interval. 57 * For now, just make the renew interval 1/2 the lease duration. 58 * (They should be inverse operators.) 59 */ 60 #define NFSCL_RENEW(l) (((l) < 2) ? 1 : ((l) / 2)) 61 #define NFSCL_LEASE(r) ((r) * 2) 62 63 /* This macro checks to see if a forced dismount is about to occur. */ 64 #define NFSCL_FORCEDISM(m) (((m)->mnt_kern_flag & MNTK_UNMOUNTF) != 0 || \ 65 (VFSTONFS(m)->nm_privflag & NFSMNTP_FORCEDISM) != 0) 66 67 /* 68 * These flag bits are used for the argument to nfscl_fillsattr() to 69 * indicate special handling of the attributes. 70 */ 71 #define NFSSATTR_FULL 0x01 72 #define NFSSATTR_SIZE0 0x02 73 #define NFSSATTR_SIZENEG1 0x04 74 #define NFSSATTR_SIZERDEV 0x08 75 #define NFSSATTR_NEWFILE 0x10 76 77 /* Use this macro for debug printfs. */ 78 #define NFSCL_DEBUG(level, ...) do { \ 79 if (nfscl_debuglevel >= (level)) \ 80 printf(__VA_ARGS__); \ 81 } while (0) 82 83 struct nfscl_reconarg { 84 int minorvers; 85 uint8_t sessionid[NFSX_V4SESSIONID]; 86 }; 87 88 #endif /* _NFS_NFSCL_H */ 89