Subject: Re: IPSEC still fails on BETA2/vax (not anymore!)
To: Anders Magnusson <ragge@ludd.luth.se>
From: Olaf Seibert <rhialto@polderland.nl>
List: port-vax
Date: 07/15/2002 01:03:15
On Sun 14 Jul 2002 at 22:40:45 +0200, Anders Magnusson wrote:
> >  
> > -#define ISTACK_SIZE NBPG
> > +#define ISTACK_SIZE (NBPG * 2)
> >  vaddr_t istack;
> >  /* 
> >   * This code uses bitfield operators for most page table entries.  
> > 
> > This seems to fix the problem for me. So unless there are hidden
> > assumptions in the code that ISTACK_SIZE is just NBPG, I would propose
> > this change to go into -current and pulled up to the 1.6 branch.
> > 
> > The larger size could possibly be made dependent on IPSEC, but since the
> > interrupt stack is allocated only once anyway, this seems a bit
> > over-frugal to me.
> > 
> Yes, thanks for finding this. Even though I donīt like that people write
> in-kernel code that eats up the stack (and especially not on interrupt
> level, there may be nested interrupts) it would be OK to do in this case.
> There are no dependencies on the interrupt stack size elsewhere, just 
> enlarge it.

I agree with you about using up stack. That's why I don't really like
the following patch, which I needed to get the nfs mount command to work
(which overflowed the kernel stack). Even more so because there is a
kernel stack for each process so the price to be paid is much higher,
even when IPsec is not used. I wonder if there would be some other
clever solution. Why is the kernel stack in the U area anyway? Can't it
just grow on the normal process stack? Perhaps the answer is in the
Lions book, or The Design and Implementation Of 4.xBSD, but I don't
recall it exactly. Maybe it has something to do with pageability of the
user stack ISTR (after some thinking).

--- sys/arch/vax/include/param.h.orig	Sun Apr 21 23:00:29 2002
+++ sys/arch/vax/include/param.h	Sat Jul 13 13:50:09 2002
@@ -84,7 +84,7 @@
 #define	MAXPHYS		(64 * 1024)	/* max raw I/O transfer size */
 #define	MAXBSIZE	0x4000		/* max FS block size - XXX */
 
-#define	UPAGES		2		/* pages of u-area */
+#define	UPAGES		3		/* pages of u-area */
 #define USPACE		(NBPG*UPAGES)
 #define	REDZONEADDR	(VAX_NBPG*3)	/* Must be > sizeof(struct user) */
 
(patch performed via an IPsec telnet connection and redirected to an
IPsec NFS mount).

> -- Ragge
-Olaf.
-- 
___ Olaf 'Rhialto' Seibert - rhialto@       -- Woe betide the one who feels
\X/ polderland.nl  -- remorse without sin - Tom Poes, "Het boze oog", 4444.