]> xenbits.xensource.com Git - qemu-xen-4.1-testing.git/commitdiff
mapcache: Fix invalidate if memory requested was not bucket aligned xen-4.1.4 xen-4.1.4-rc1 xen-4.1.4-rc2
authorIan Jackson <ian.jackson@eu.citrix.com>
Tue, 13 Nov 2012 18:25:17 +0000 (18:25 +0000)
committerIan Jackson <Ian.Jackson@eu.citrix.com>
Tue, 13 Nov 2012 18:25:17 +0000 (18:25 +0000)
When memory is mapped in qemu_map_cache with lock != 0 a reverse mapping
is created pointing to the virtual address of location requested.
The cached mapped entry is saved in last_address_vaddr with the memory
location of the base virtual address (without bucket offset).
However when this entry is invalidated the virtual address saved in the
reverse mapping is used. This cause that the mapping is freed but the
last_address_vaddr is not reset.

Signed-off-by: Frediano Ziglio <frediano.ziglio@citrix.com>
Acked-by: Ian Jackson <ian.jackson@eu.citrix.com>
Committed-by: Ian Jackson <ian.jackson@eu.citrix.com>
(cherry picked from commit d94efd9aa814f17f3243dae91476dc42b5ad052e)

Conflicts:
hw/xen_machine_fv.c

Signed-off-by: Ian Jackson <ian.jackson@eu.citrix.com>
hw/xen_machine_fv.c

index a353ee6cafc0a5dab99d40f5bc2ce25a977667ff..786a8fb1ff97b5ef13bf5b8cbca0ce6882a23fea 100644 (file)
@@ -181,9 +181,6 @@ void qemu_invalidate_entry(uint8_t *buffer)
     unsigned long paddr_index;
     int found = 0;
     
-    if (last_address_vaddr == buffer)
-        last_address_index =  ~0UL;
-
     TAILQ_FOREACH(reventry, &locked_entries, next) {
         if (reventry->vaddr_req == buffer) {
             paddr_index = reventry->paddr_index;
@@ -201,6 +198,10 @@ void qemu_invalidate_entry(uint8_t *buffer)
     TAILQ_REMOVE(&locked_entries, reventry, next);
     qemu_free(reventry);
 
+    if (last_address_index == paddr_index) {
+        last_address_index =  ~0UL;
+    }
+
     entry = &mapcache_entry[paddr_index % nr_buckets];
     while (entry && entry->paddr_index != paddr_index) {
         pentry = entry;