Hi,

Tried your patch on 2.2.4-test9-pre4
with the included debug patch applied.

Rebooted, started mmap002

After a while it starts outputting (magic did not work
this time - usually does):

- - -
"VM: try_to_free_pages (result: 1) try_again # 12345"
"VM: try_to_free_pages (result: 1) try_again # 12346"
- - -

My interpretation:
1) try_to_free_pages succeeds (or returns ok when it did not work)
2) __alloc_pages still can't alloc

Maybe it is different limits,
  try_to_free_pages requires less to succeed than
  __alloc_pages_limit requires.
or a bug in
  __alloc_pages_limit(zonelist, order, PAGES_MIN, direct_reclaim)

Note:
  12345  is an example, it loops to over 30000...

/RogerL

Rik van Riel wrote:
> 
> Hi,
> 
> I've found and fixed the deadlocks in the new VM. They turned out
> to be single-cpu only bugs, which explains why they didn't crash my
> SMP tesnt box ;)
> 
> They have to do with the fact that processes schedule away while
> holding IO locks after waking up kswapd. At that point kswapd
> spends its time spinning on the IO locks and single-cpu systems
> will die...
> 
> Due to bad connectivity I'm not attaching this patch but have only
> put it online on my home page:
> 
> http://www.surriel.com/patches/2.4.0-t9p2-vmpatch
> 
> (yes, I'm at a conference now ... the worst beating this patch
> has had is a full night in 'make bzImage' with mem=8m)
> 
> regards,
> 
> Rik
> --
> "What you're running that piece of shit Gnome?!?!"
>        -- Miguel de Icaza, UKUUG 2000
> 
> http://www.conectiva.com/               http://www.surriel.com/
> 
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to [EMAIL PROTECTED]
> Please read the FAQ at http://www.tux.org/lkml/

--
Home page:
  http://www.norran.net/nra02596/
--- mm/page_alloc.c.orig        Thu Sep 21 20:02:54 2000
+++ mm/page_alloc.c     Thu Sep 21 20:49:35 2000
@@ -295,6 +295,7 @@
        int direct_reclaim = 0;
        unsigned int gfp_mask = zonelist->gfp_mask;
        struct page * page = NULL;
+       int try_again_loops = 0;
 
        /*
         * Allocations put pressure on the VM subsystem.
@@ -320,8 +321,10 @@
        /*
         * Are we low on inactive pages?
         */
-       if (inactive_shortage() > inactive_target / 2 && free_shortage())
+       if (inactive_shortage() > inactive_target / 2 && free_shortage()) {
+         printk("VM: inactive shortage wake kswapd\n");
                wakeup_kswapd(0);
+       }
 
 try_again:
        /*
@@ -410,6 +413,7 @@
                 * piece of free memory.
                 */
                if (order > 0 && (gfp_mask & __GFP_WAIT)) {
+                 printk("VM: higher order");
                        zone = zonelist->zones;
                        /* First, clean some dirty pages. */
                        page_launder(gfp_mask, 1);
@@ -444,7 +448,9 @@
                 * processes, etc).
                 */
                if (gfp_mask & __GFP_WAIT) {
-                       try_to_free_pages(gfp_mask);
+                       int success = try_to_free_pages(gfp_mask);
+         printk("VM: try_to_free_pages (result: %d) try_again # %d\n",
+                success, ++try_again_loops);   
                        memory_pressure++;
                        goto try_again;
                }

Reply via email to