Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [RFA] dcache invalidate fix
@ 2009-11-10 21:35 Michael Snyder
  2009-11-11 23:37 ` Doug Evans
  0 siblings, 1 reply; 3+ messages in thread
From: Michael Snyder @ 2009-11-10 21:35 UTC (permalink / raw)
  To: gdb-patches, Doug Evans, jdpotter

[-- Attachment #1: Type: text/plain, Size: 363 bytes --]

Doug, I'm vague about this, but it seems right and it fixes the
bug that I'm running into.

It seems like dcache_invalidate_line needs to remove the block
from the in use list at the same time as adding it to the freed
list.

The problem that bit me was getting the two lists cross-linked,
which eventually led to an infinite loop behavior in dcache_invalidate.


[-- Attachment #2: dcache2.txt --]
[-- Type: text/plain, Size: 889 bytes --]

2009-11-10  Michael Snyder  <msnyder@vmware.com>

	* dcache.c (dcache_invalidate_line): Remove block from used list
	when adding it to freed list.

Index: dcache.c
===================================================================
RCS file: /cvs/src/src/gdb/dcache.c,v
retrieving revision 1.37
diff -u -p -r1.37 dcache.c
--- dcache.c	10 Nov 2009 18:36:50 -0000	1.37
+++ dcache.c	10 Nov 2009 21:31:03 -0000
@@ -167,10 +167,18 @@ dcache_invalidate_line (DCACHE *dcache, 
 
   if (db)
     {
+      struct dcache_block *db2;
       splay_tree_remove (dcache->tree, (splay_tree_key) db->addr);
       db->newer = dcache->freelist;
       dcache->freelist = db;
       --dcache->size;
+      /* Remove db from dcache in-use chain.  */
+      for (db2 = dcache->oldest; db2; db2 = db2->newer)
+	if (db2->newer == db)
+	  {
+	    dcache->newest = db2;
+	    db2->newer = NULL;
+	  }
     }
 }
 

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2009-11-12  0:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-11-10 21:35 [RFA] dcache invalidate fix Michael Snyder
2009-11-11 23:37 ` Doug Evans
2009-11-12  0:06   ` Michael Snyder

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox