Subject: Pool problems/fixes?
To: port-mac68k <port-mac68k@netbsd.org>
From: Bob Nestor <rnestor@metronet.com>
List: port-mac68k
Date: 04/01/1999 19:49:46
I noticed this source changed posted the other day and wonder if this 
relates to the mac68k kernel panics some of us have been struggling with. 
 The comments that look like they are related to our problem I've marked 
with (*).

Has anyone built a new kernel with these patches yet?  If so, does it 
help the kernel panic problem/multi-disk bug for the mac68k users?

Thanks,
-bob

Modified Files:
	src/sys/sys: pool.h
	src/sys/kern: subr_pool.c
Log Message:
Yet more fixes to the pool allocator:

(*)- Protect userspace from unnecessary header inclusions (as noted on
current-users).

- Some const poisioning.

- GREATLY simplify the locking protocol, and fix potential deadlock
scenarios.  In particular, assume that the back-end page allocator
provides its own locking mechanism (this is currently true for all
such allocators in the NetBSD kernel).  Doing so allows us to simply
use one spin lock for serialized access to all r/w members of the pool
descriptor.  The spin lock is released before calling the back-end
allocator, and re-acquired upon return from it.

(*)- Fix a problem in pr_rmpage() where a data structure was referenced
after it was freed.

- Minor tweak to page manaement.  Migrate both idle and empty pages
to the end of the page list.  As soon as a page becomes un-empty
(by a pool_put()), place it at the head of the page list, and set
curpage to point to it.  This reduces fragmentation as well as the
time required to find a non-empty page as soon as curpage becomes
empty again.

(*)- Use mono_time throughout, and protect access to it w/ splclock().

- In pool_reclaim(), if freeing an idle page would reduce the number
of allocatable items to below the low water mark, don't.