diff options
author | Hugh Dickins <hughd@google.com> | 2012-08-21 19:15:45 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-08-21 19:45:02 -0400 |
commit | f9aed62a2b12a8e04077737c9942111e14ed738e (patch) | |
tree | c6e4702415f153c615c961a7d6d5f35a718c34ef /mm/mmap.c | |
parent | 61e01be22e954f53a4bbac8066015d9f4ab9e42d (diff) |
mm: change nr_ptes BUG_ON to WARN_ON
Occasionally an isolated BUG_ON(mm->nr_ptes) gets reported, indicating
that not all the page tables allocated could be found and freed when
exit_mmap() tore down the user address space.
There's usually nothing we can say about it, beyond that it's probably a
sign of some bad memory or memory corruption; though it might still
indicate a bug in vma or page table management (and did recently reveal a
race in THP, fixed a few months ago).
But one overdue change we can make is from BUG_ON to WARN_ON.
It's fairly likely that the system will crash shortly afterwards in some
other way (for example, the BUG_ON(page_mapped(page)) in
__delete_from_page_cache(), once an inode mapped into the lost page tables
gets evicted); but might tell us more before that.
Change the BUG_ON(page_mapped) to WARN_ON too? Later perhaps: I'm less
eager, since that one has several times led to fixes.
Signed-off-by: Hugh Dickins <hughd@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/mmap.c')
-rw-r--r-- | mm/mmap.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -2309,7 +2309,7 @@ void exit_mmap(struct mm_struct *mm) | |||
2309 | } | 2309 | } |
2310 | vm_unacct_memory(nr_accounted); | 2310 | vm_unacct_memory(nr_accounted); |
2311 | 2311 | ||
2312 | BUG_ON(mm->nr_ptes > (FIRST_USER_ADDRESS+PMD_SIZE-1)>>PMD_SHIFT); | 2312 | WARN_ON(mm->nr_ptes > (FIRST_USER_ADDRESS+PMD_SIZE-1)>>PMD_SHIFT); |
2313 | } | 2313 | } |
2314 | 2314 | ||
2315 | /* Insert vm structure into process list sorted by address | 2315 | /* Insert vm structure into process list sorted by address |