Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/nfs Reduce stack usage on the NFS mount code path. This ...



details:   https://anonhg.NetBSD.org/src/rev/65bb44f65af5
branches:  trunk
changeset: 534423:65bb44f65af5
user:      jdolecek <jdolecek%NetBSD.org@localhost>
date:      Thu Jul 25 19:03:27 2002 +0000

description:
Reduce stack usage on the NFS mount code path. This fixes kernel stack
overflow when using IPsec on vax, as reported by Olaf Seibert on
current-users@.

diffstat:

 sys/nfs/nfs_vfsops.c |  55 ++++++++++++++++++++++++++++++++-------------------
 1 files changed, 34 insertions(+), 21 deletions(-)

diffs (110 lines):

diff -r 95b110e4f61d -r 65bb44f65af5 sys/nfs/nfs_vfsops.c
--- a/sys/nfs/nfs_vfsops.c      Thu Jul 25 15:39:41 2002 +0000
+++ b/sys/nfs/nfs_vfsops.c      Thu Jul 25 19:03:27 2002 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_vfsops.c,v 1.112 2001/12/04 18:38:08 christos Exp $        */
+/*     $NetBSD: nfs_vfsops.c,v 1.113 2002/07/25 19:03:27 jdolecek Exp $        */
 
 /*
  * Copyright (c) 1989, 1993, 1995
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_vfsops.c,v 1.112 2001/12/04 18:38:08 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_vfsops.c,v 1.113 2002/07/25 19:03:27 jdolecek Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_compat_netbsd.h"
@@ -560,9 +560,9 @@
        struct nfs_args args;
        struct mbuf *nam;
        struct vnode *vp;
-       char pth[MNAMELEN], hst[MNAMELEN];
+       char *pth=NULL, *hst=NULL;
        size_t len;
-       u_char nfh[NFSX_V3FHMAX];
+       u_char *nfh=NULL;
 
        error = copyin(data, (caddr_t)&args, sizeof (struct nfs_args));
        if (error)
@@ -591,25 +591,36 @@
                nfs_decode_args(nmp, &args);
                return (0);
        }
-       if (args.fhsize < 0 || args.fhsize > NFSX_V3FHMAX)
-               return (EINVAL);
-       error = copyin((caddr_t)args.fh, (caddr_t)nfh, args.fhsize);
-       if (error)
-               return (error);
-       error = copyinstr(path, pth, MNAMELEN-1, &len);
-       if (error)
-               return (error);
-       memset(&pth[len], 0, MNAMELEN - len);
-       error = copyinstr(args.hostname, hst, MNAMELEN-1, &len);
-       if (error)
-               return (error);
-       memset(&hst[len], 0, MNAMELEN - len);
        /* sockargs() call must be after above copyin() calls */
        error = sockargs(&nam, (caddr_t)args.addr, args.addrlen, MT_SONAME);
        if (error)
                return (error);
+       if (args.fhsize < 0 || args.fhsize > NFSX_V3FHMAX)
+               return (EINVAL);
+       MALLOC(nfh, u_char *, NFSX_V3FHMAX, M_TEMP, M_WAITOK);
+       error = copyin((caddr_t)args.fh, (caddr_t)nfh, args.fhsize);
+       if (error)
+               goto out;
+       MALLOC(pth, char *, MNAMELEN, M_TEMP, M_WAITOK);
+       error = copyinstr(path, pth, MNAMELEN-1, &len);
+       if (error)
+               goto out;
+       memset(&pth[len], 0, MNAMELEN - len);
+       MALLOC(hst, char *, MNAMELEN, M_TEMP, M_WAITOK);
+       error = copyinstr(args.hostname, hst, MNAMELEN-1, &len);
+       if (error)
+               goto out;
+       memset(&hst[len], 0, MNAMELEN - len);
        args.fh = nfh;
        error = mountnfs(&args, mp, nam, pth, hst, &vp, p);
+
+    out:
+       FREE(nfh, M_TEMP);
+       if (pth)
+               FREE(pth, M_TEMP);
+       if (hst)
+               FREE(hst, M_TEMP);
+
        return (error);
 }
 
@@ -628,7 +639,7 @@
        struct nfsmount *nmp;
        struct nfsnode *np;
        int error;
-       struct vattr attrs;
+       struct vattr *attrs;
        struct ucred *cr;
 
        /* 
@@ -727,15 +738,17 @@
        if (error)
                goto bad;
        *vpp = NFSTOV(np);
-       VOP_GETATTR(*vpp, &attrs, p->p_ucred, p);
+       MALLOC(attrs, struct vattr *, sizeof(struct vattr), M_TEMP, M_WAITOK);
+       VOP_GETATTR(*vpp, attrs, p->p_ucred, p);
        if ((nmp->nm_flag & NFSMNT_NFSV3) && ((*vpp)->v_type == VDIR)) {
                cr = crget();
-               cr->cr_uid = attrs.va_uid;
-               cr->cr_gid = attrs.va_gid;
+               cr->cr_uid = attrs->va_uid;
+               cr->cr_gid = attrs->va_gid;
                cr->cr_ngroups = 0;
                nfs_cookieheuristic(*vpp, &nmp->nm_iflag, p, cr);
                crfree(cr);
        }
+       FREE(attrs, M_TEMP);
 
        /*
         * A reference count is needed on the nfsnode representing the



Home | Main Index | Thread Index | Old Index