|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH V2] x86/p2m: fixed p2m_change_type_range() start / end check
p2m_change_type_range() handles end > max_mapped_pfn, but not
start > max_mapped_pfn. Check the latter just after grabbing the
lock and bail if true.
Signed-off-by: Razvan Cojocaru <rcojocaru@xxxxxxxxxxxxxxx>
Suggested-by: George Dunlap <george.dunlap@xxxxxxxxxx>
---
Changes since V1:
- Added ASSERT()s.
- Wrapped the new condition in an unlikely().
---
xen/arch/x86/mm/p2m.c | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/xen/arch/x86/mm/p2m.c b/xen/arch/x86/mm/p2m.c
index c53cab4..e09b256 100644
--- a/xen/arch/x86/mm/p2m.c
+++ b/xen/arch/x86/mm/p2m.c
@@ -978,8 +978,19 @@ void p2m_change_type_range(struct domain *d,
p2m_lock(p2m);
p2m->defer_nested_flush = 1;
+ ASSERT(start < end);
+
+ if ( unlikely(start > p2m->max_mapped_pfn) )
+ {
+ ASSERT(!p2m_is_hostp2m(p2m));
+ p2m_unlock(p2m);
+ return;
+ }
+
if ( unlikely(end > p2m->max_mapped_pfn) )
{
+ ASSERT(end == ~0UL || !p2m_is_hostp2m(p2m));
+
if ( !gfn )
{
p2m->change_entry_type_global(p2m, ot, nt);
--
2.7.4
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/mailman/listinfo/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |