Subject: Re: Virtual memory (I think)
To: Reuben Thomas <rrt1001@cam.ac.uk>
From: Ale Terlevich <A.I.Terlevich@durham.ac.uk>
List: port-arm32
Date: 03/14/1997 09:55:13
> When using X the computer freezes every thirty seconds or so for a second
> or two. It seems to access the disk. Is this paging of some sort going on?
> Why the freeze? Is there any way I can stop it?

 This is because the fs cache is cleaning itself.
This was brought up on the list about a month ago, 

Here's Mark's reply....


>From amb@physig.ph.kcl.ac.ukFri Mar 14 09:53:10 1997
Date: Tue, 25 Feb 1997 20:56:47 +0000 (GMT)
From: Mark Brinicombe <amb@physig.ph.kcl.ac.uk>
To: Ale Terlevich <A.I.Terlevich@durham.ac.uk>
Cc: RiscBSD <port-arm32@NetBSD.ORG>
Subject: Recent sync() fix (was update)


A recent change added a call to vnode_page_sync() in the sync() system
call.

>revision 1.76
>date: 1997/02/13 02:54:06;  author: tls;  state: Exp;  lines: +2 -1
>sync needs to clean VM objects backed by vnode pagers

This call has the effect of using a large amount of CPU time. and since it
update (8) calls sync every 30 secs you will see a system pause every
30 seconds when update is running.

Closer inspectition reveals that a large number of pmap_enter() and
pmap_remove() calls are being made. Due to the virtual writeback cache on
the SA110 these calls trigger a lot of cache cleaning (which has to be
done in software) and it is this cleaning that is accumulating the system
CPU time.
 
>   Are there any ramifications to running without update? (I'm using the 
> machine mainly as an xterminal at the mo, i.e. not writing much to disk)

I would not recommend this.

being HACK HACK HACK

You would probably be better off commenting out the vnode_pager_sync()
call on line 453 (v1.78) of kern/vfs_syscalls.c
This will give you the sync behaviour we had before.

end HACK HACK HACK


The real solution is being worked on. A complete pmap rewrite is in the
pipeline that will be more aware of the writeback cache and the problems
that introduces (the orig pmap was written when there was only the ARm6
writethough cache). The rewrite will result in much more optimised and
efficient pmap code and this should reduce the ammount of cache cleaning
that will need to be done and thus will reduce the ammount of time spent
in the pmap_enter() and pmap_remove() routines.


Cheers,
				Mark