9fans archive / 1996 / 02 / 1 / next
From: G. David Butler gdb@dbS...
Subject: Kernel <-> bitmapped memory fragmentation
Date: Mon, 5 Feb 1996 02:58:04 -0500
Hello All!
Ever notice (especially on small memory machines) how after a while
you can't make those 8 1/2 window as big as you used to? Or how
you were able to display that graphic before you did a move or resize
on a window? Even after you delete all the windows and re-create them
you just can't get it back unless you reboot?
Well here is a quick fix. I changed the "first" fit xalloc into a "better"
fit xalloc. In this way the xalloc memory will not become as fragmented
so when that bit device wants his "3 screens full", he can still get it
after he let it go.
David Butler
gdb@dbS...
======================= alloc.c boddle =======================
#!/bin/rc
#
# command: /bin/boddle /sys/src/9/port/alloc.c alloc.c
# srcdir: /sys/src/9/port
# version: 823506923
# date: Mon Feb 5 01:55:23 CST 1996
#
myname=$0
doextract=no
fn usage{
echo $myname: usage: $myname '[-X] [src-directory]' >[1=2]
exit usage
}
fn sigint{
rm -rf 823506923
exit interrupt
}
while(~ $1 -*){
switch($1){
case -X
doextract=yes
case -*
usage
}
shift
}
switch($#*){
case 0
srcdir=/sys/src/9/port
case 1
srcdir=$1
case *
usage
}
if(! ~ $doextract yes){
echo This shell file contains a bundle of diffs representing changes
echo to original source files in the Plan 9 distribution. It will run
echo against the files in
echo ' ' $srcdir
echo '(unless overridden by the optional source directory argument)'
echo and create a directory 823506923 containing the updated files.
echo It will NOT automatically update the original files.
echo
echo Invoke with argument -X to perform the actual extraction.
exit 0
}
rm -rf 823506923
mkdir 823506923
target=823506923/alloc.c
echo -n '823506923/alloc.c: '
if(! test -f $srcdir/alloc.c || ! test -r $srcdir/alloc.c){
echo $srcdir/alloc.c unreadable
exit unreadable
}
sum=`{sum < $srcdir/alloc.c}
if(! ~ 8e1aa10a7934 $sum(1)^$sum(2)){
echo $srcdir/alloc.c is not the original distribution file
exit original
}
cp $srcdir/alloc.c 823506923/alloc.c
ed 823506923/alloc.c >/dev/null >[2=1] <<'//GO.SYSIN DD VADIM alloc.c'
193c
}
if (sh) {
p = (Xhdr*)sh->addr;
sh->addr += size;
sh->size -= size;
if(sh->size == 0) {
*sl = sh->link;
sh->link = xlists.flist;
xlists.flist = sh;
}
unlock(&xlists);
p = KADDR(p);
memset(p, 0, size);
p->magix = Magichole;
p->size = size;
return p->data;
.
176,191c
sh = (Hole *)nil;
SET(sl);
SET(smallest);
for(h = *l; h; l = &h->link, h = h->link) {
if (h->size >= size && (!sh || h->size < smallest)) {
smallest = h->size;
sh = h;
sl = l;
.
169c
Hole *h, **l, *sh, **sl;
ulong smallest;
.
10c
* Plan 9 has two kernel allocators, the x... routines provide a best
.
wq
//GO.SYSIN DD VADIM alloc.c
sum=`{sum < 823506923/alloc.c}
if(~ 44c9fb008090 $sum(1)^$sum(2))
echo
if not{
echo 823506923/alloc.c checksum error creating updated file
exit checksum
}