diff options
-rw-r--r-- | arch/x86/mm/fault_32.c | 4 | ||||
-rw-r--r-- | arch/x86/mm/fault_64.c | 11 |
2 files changed, 14 insertions, 1 deletions
diff --git a/arch/x86/mm/fault_32.c b/arch/x86/mm/fault_32.c index 276863dc4bdd..93ede2dde958 100644 --- a/arch/x86/mm/fault_32.c +++ b/arch/x86/mm/fault_32.c | |||
@@ -475,14 +475,16 @@ good_area: | |||
475 | else | 475 | else |
476 | tsk->min_flt++; | 476 | tsk->min_flt++; |
477 | 477 | ||
478 | #ifdef CONFIG_X86_32 | ||
478 | /* | 479 | /* |
479 | * Did it hit the DOS screen memory VA from vm86 mode? | 480 | * Did it hit the DOS screen memory VA from vm86 mode? |
480 | */ | 481 | */ |
481 | if (regs->flags & VM_MASK) { | 482 | if (v8086_mode(regs)) { |
482 | unsigned long bit = (address - 0xA0000) >> PAGE_SHIFT; | 483 | unsigned long bit = (address - 0xA0000) >> PAGE_SHIFT; |
483 | if (bit < 32) | 484 | if (bit < 32) |
484 | tsk->thread.screen_bitmap |= 1 << bit; | 485 | tsk->thread.screen_bitmap |= 1 << bit; |
485 | } | 486 | } |
487 | #endif | ||
486 | up_read(&mm->mmap_sem); | 488 | up_read(&mm->mmap_sem); |
487 | return; | 489 | return; |
488 | 490 | ||
diff --git a/arch/x86/mm/fault_64.c b/arch/x86/mm/fault_64.c index 9ef0306efe9e..2d9e6da2cb30 100644 --- a/arch/x86/mm/fault_64.c +++ b/arch/x86/mm/fault_64.c | |||
@@ -514,6 +514,17 @@ good_area: | |||
514 | tsk->maj_flt++; | 514 | tsk->maj_flt++; |
515 | else | 515 | else |
516 | tsk->min_flt++; | 516 | tsk->min_flt++; |
517 | |||
518 | #ifdef CONFIG_X86_32 | ||
519 | /* | ||
520 | * Did it hit the DOS screen memory VA from vm86 mode? | ||
521 | */ | ||
522 | if (v8086_mode(regs)) { | ||
523 | unsigned long bit = (address - 0xA0000) >> PAGE_SHIFT; | ||
524 | if (bit < 32) | ||
525 | tsk->thread.screen_bitmap |= 1 << bit; | ||
526 | } | ||
527 | #endif | ||
517 | up_read(&mm->mmap_sem); | 528 | up_read(&mm->mmap_sem); |
518 | return; | 529 | return; |
519 | 530 | ||