Andres Lagar-Cavilla
2012-Apr-13 21:18 UTC
[PATCH] x86/mm: Fix locking on hap enable failure
xen/arch/x86/mm/hap/hap.c | 3 ++-
1 files changed, 2 insertions(+), 1 deletions(-)
If enabling hap fails due to out of memory, the locking on the clean up path is
broken.
Signed-off-by: Andres Lagar-Cavilla <andres@lagarcavilla.org>
diff -r 8ec52231c03d -r 15a3c740419f xen/arch/x86/mm/hap/hap.c
--- a/xen/arch/x86/mm/hap/hap.c
+++ b/xen/arch/x86/mm/hap/hap.c
@@ -585,13 +585,14 @@ int hap_enable(struct domain *d, u32 mod
unsigned int r;
paging_lock(d);
r = hap_set_allocation(d, 256, NULL);
- paging_unlock(d);
if ( r != 0 )
{
hap_set_allocation(d, 0, NULL);
+ paging_unlock(d);
rv = -ENOMEM;
goto out;
}
+ paging_unlock(d);
}
/* Allow p2m and log-dirty code to borrow our memory */
At 17:18 -0400 on 13 Apr (1334337486), Andres Lagar-Cavilla wrote:> xen/arch/x86/mm/hap/hap.c | 3 ++- > 1 files changed, 2 insertions(+), 1 deletions(-) > > > If enabling hap fails due to out of memory, the locking on the clean up path is > broken. > > Signed-off-by: Andres Lagar-Cavilla <andres@lagarcavilla.org>Applied, thanks. Tim.