[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.3] x86/mm: PV superpage handling lacks sanity checks
commit 4a47fbb72ed42b6e2d5b0afa1e8265e9b16b4b38 Author: Jan Beulich <jbeulich@xxxxxxxx> AuthorDate: Wed Jan 20 14:11:52 2016 +0100 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Wed Jan 20 14:11:52 2016 +0100 x86/mm: PV superpage handling lacks sanity checks MMUEXT_{,UN}MARK_SUPER fail to check the input MFN for validity before dereferencing pointers into the superpage frame table. Reported-by: Qinghao Tang <luodalongde@xxxxxxxxx> get_superpage() has a similar issue. This is CVE-2016-1570 / XSA-167. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> Acked-by: Ian Campbell <ian.campbell@xxxxxxxxxx> master commit: 47abf29a9255b2e7b94e56d66b455d0a584b68b8 master date: 2016-01-20 13:49:23 +0100 --- xen/arch/x86/mm.c | 29 +++++++---------------------- 1 files changed, 7 insertions(+), 22 deletions(-) diff --git a/xen/arch/x86/mm.c b/xen/arch/x86/mm.c index 1caa555..222fe5f 100644 --- a/xen/arch/x86/mm.c +++ b/xen/arch/x86/mm.c @@ -2566,6 +2566,9 @@ int get_superpage(unsigned long mfn, struct domain *d) ASSERT(opt_allow_superpage); + if ( !mfn_valid(mfn | (L1_PAGETABLE_ENTRIES - 1)) ) + return -EINVAL; + spage = mfn_to_spage(mfn); y = spage->type_info; do { @@ -3320,14 +3323,6 @@ long do_mmuext_op( unsigned long mfn; struct spage_info *spage; - mfn = op.arg1.mfn; - if ( mfn & (L1_PAGETABLE_ENTRIES-1) ) - { - MEM_LOG("Unaligned superpage reference mfn %lx", mfn); - okay = 0; - break; - } - if ( !opt_allow_superpage ) { MEM_LOG("Superpages disallowed"); @@ -3336,16 +3331,6 @@ long do_mmuext_op( break; } - spage = mfn_to_spage(mfn); - okay = (mark_superpage(spage, d) >= 0); - break; - } - - case MMUEXT_UNMARK_SUPER: - { - unsigned long mfn; - struct spage_info *spage; - mfn = op.arg1.mfn; if ( mfn & (L1_PAGETABLE_ENTRIES-1) ) { @@ -3354,16 +3339,16 @@ long do_mmuext_op( break; } - if ( !opt_allow_superpage ) + if ( !mfn_valid(mfn | (L1_PAGETABLE_ENTRIES - 1)) ) { - MEM_LOG("Superpages disallowed"); okay = 0; - rc = -ENOSYS; break; } spage = mfn_to_spage(mfn); - okay = (unmark_superpage(spage) >= 0); + okay = ((op.cmd == MMUEXT_MARK_SUPER + ? mark_superpage(spage, d) + : unmark_superpage(spage)) >= 0); break; } -- generated by git-patchbot for /home/xen/git/xen.git#stable-4.3 _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |