src/sys/nfs/nfsm_subs.h

180 lines
4.6 KiB
C

/* $OpenBSD: nfsm_subs.h,v 1.48 2024/04/30 17:04:23 miod Exp $ */
/* $NetBSD: nfsm_subs.h,v 1.10 1996/03/20 21:59:56 fvdl Exp $ */
/*
* Copyright (c) 1989, 1993
* The Regents of the University of California. All rights reserved.
*
* This code is derived from software contributed to Berkeley by
* Rick Macklem at The University of Guelph.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* @(#)nfsm_subs.h 8.2 (Berkeley) 3/30/95
*/
#ifndef _NFS_NFSM_SUBS_H_
#define _NFS_NFSM_SUBS_H_
struct nfsm_info {
struct mbuf *nmi_mreq;
struct mbuf *nmi_mrep;
struct proc *nmi_procp; /* XXX XXX XXX */
struct ucred *nmi_cred; /* XXX XXX XXX */
/* Setting up / Tearing down. */
struct mbuf *nmi_md;
struct mbuf *nmi_mb;
caddr_t nmi_dpos;
int nmi_v3;
int *nmi_errorp;
};
static inline void *
nfsm_dissect(struct nfsm_info *infop, int s)
{
caddr_t ret;
int avail, error;
avail = mtod(infop->nmi_md, caddr_t) + infop->nmi_md->m_len -
infop->nmi_dpos;
if (avail >= s) {
ret = infop->nmi_dpos;
infop->nmi_dpos += s;
return ret;
}
error = nfsm_disct(&infop->nmi_md, &infop->nmi_dpos, s, avail, &ret);
if (error != 0) {
m_freem(infop->nmi_mrep);
*infop->nmi_errorp = error;
return NULL;
} else {
return ret;
}
}
#define nfsm_rndup(a) (((a)+3)&(~0x3))
static inline int
nfsm_adv(struct nfsm_info *infop, int s)
{
int avail, error;
avail = mtod(infop->nmi_md, caddr_t) + infop->nmi_md->m_len -
infop->nmi_dpos;
if (avail >= s) {
infop->nmi_dpos += s;
return 0;
}
error = nfs_adv(&infop->nmi_md, &infop->nmi_dpos, s, avail);
if (error != 0) {
m_freem(infop->nmi_mrep);
*infop->nmi_errorp = error;
return error;
}
return 0;
}
static inline int
nfsm_postop_attr(struct nfsm_info *infop, struct vnode **vpp, int *attrflagp)
{
uint32_t *tl;
struct vnode *ttvp;
int attrflag, error;
if (infop->nmi_mrep == NULL)
return 0;
ttvp = *vpp;
tl = (uint32_t *)nfsm_dissect(infop, NFSX_UNSIGNED);
if (tl == NULL)
return 1; /* anything nonzero */
attrflag = fxdr_unsigned(int, *tl);
if (attrflag != 0) {
error = nfs_loadattrcache(&ttvp, &infop->nmi_md,
&infop->nmi_dpos, NULL);
if (error != 0) {
m_freem(infop->nmi_mrep);
*infop->nmi_errorp = error;
return error;
}
*vpp = ttvp;
}
*attrflagp = attrflag;
return 0;
}
static inline int
nfsm_strsiz(struct nfsm_info *infop, int *lenp, int maxlen)
{
uint32_t *tl = (uint32_t *)nfsm_dissect(infop, NFSX_UNSIGNED);
int len;
if (tl == NULL)
return 1;
len = fxdr_unsigned(int32_t, *tl);
if (len < 0 || len > maxlen) {
m_freem(infop->nmi_mrep);
*infop->nmi_errorp = EBADRPC;
return 1;
}
*lenp = len;
return 0;
}
static inline int
nfsm_mtouio(struct nfsm_info *infop, struct uio *uiop, int len)
{
int error;
if (len <= 0)
return 0;
error = nfsm_mbuftouio(&infop->nmi_md, uiop, len, &infop->nmi_dpos);
if (error != 0) {
m_freem(infop->nmi_mrep);
*infop->nmi_errorp = error;
return error;
}
return 0;
}
static inline int
nfsm_strtom(struct nfsm_info *infop, char *str, size_t len, size_t maxlen)
{
if (len > maxlen) {
m_freem(infop->nmi_mreq);
*infop->nmi_errorp = ENAMETOOLONG;
return 1;
}
nfsm_strtombuf(&infop->nmi_mb, str, len);
return 0;
}
#endif