summaryrefslogtreecommitdiff
path: root/sys/src/9/port/page.c
diff options
context:
space:
mode:
authorcinap_lenrek <cinap_lenrek@gmx.de>2013-10-25 02:42:35 +0200
committercinap_lenrek <cinap_lenrek@gmx.de>2013-10-25 02:42:35 +0200
commitc7c7e7ee2afcb21f5523d6b66e539befe2b93b01 (patch)
tree95b780eab4082c83e163ffdaac56cc4bd0b5b1e0 /sys/src/9/port/page.c
parentb66c4a6232489ede3bfe29b813d5fee0a66dc11f (diff)
kernel: disable freelist page caching for executables run from uncached mount
the image cache has the property of keeping a channel for the executable binary arround which prevents the mountpoint from going away. this can easily be reproduced by running: @{rfork n; ramfs; cp /bin/echo /tmp; /tmp/echo} observe how ramfs stays arround until the image is reclaimed. the echo binary is also cached but is unreachable from any namespace. we now restrict the caching to mounts that use the client cache (-C flag) only. this should always be the case for /bin. places where this isnt the case might observe a performance regression.
Diffstat (limited to 'sys/src/9/port/page.c')
-rw-r--r--sys/src/9/port/page.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/sys/src/9/port/page.c b/sys/src/9/port/page.c
index e8c5b6ce0..50cb4efca 100644
--- a/sys/src/9/port/page.c
+++ b/sys/src/9/port/page.c
@@ -228,6 +228,9 @@ putpage(Page *p)
return;
}
+ if(p->image && p->image->nocache)
+ uncachepage(p);
+
if(p->image && p->image != &swapimage)
pagechaintail(p);
else
@@ -291,8 +294,8 @@ duppage(Page *p) /* Always call with p locked */
return;
}
- /* No freelist cache when memory is very low */
- if(palloc.freecount < swapalloc.highwater) {
+ /* No freelist cache with uncached image or when memory is very low */
+ if(p->image->nocache || palloc.freecount < swapalloc.highwater) {
unlock(&palloc);
uncachepage(p);
return;