]> git.baikalelectronics.ru Git - kernel.git/commit
mm: Fix PageHead when !CONFIG_PAGEFLAGS_EXTENDED
authorChristoffer Dall <cdall@cs.columbia.edu>
Fri, 21 Dec 2012 18:03:50 +0000 (13:03 -0500)
committerLinus Torvalds <torvalds@linux-foundation.org>
Wed, 26 Dec 2012 22:57:34 +0000 (14:57 -0800)
commit75e837ef5a73962d89953b707c6a97b61020fe24
treeaa9d7bc0e606df0104b47716c90a38c6689fc713
parent4f322f5ad6b5f32d8d7ce66f2a6b689b51c56073
mm: Fix PageHead when !CONFIG_PAGEFLAGS_EXTENDED

Unfortunately with !CONFIG_PAGEFLAGS_EXTENDED, (!PageHead) is false, and
(PageHead) is true, for tail pages.  If this is indeed the intended
behavior, which I doubt because it breaks cache cleaning on some ARM
systems, then the nomenclature is highly problematic.

This patch makes sure PageHead is only true for head pages and PageTail
is only true for tail pages, and neither is true for non-compound pages.

[ This buglet seems ancient - seems to have been introduced back in Apr
  2008 in commit 223451b3b556: "pageflags: convert to the use of new
  macros".  And the reason nobody noticed is because the PageHead()
  tests are almost all about just sanity-checking, and only used on
  pages that are actual page heads.  The fact that the old code returned
  true for tail pages too was thus not really noticeable.   - Linus ]

Signed-off-by: Christoffer Dall <cdall@cs.columbia.edu>
Acked-by: Andrea Arcangeli <aarcange@redhat.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Will Deacon <Will.Deacon@arm.com>
Cc: Steve Capper <Steve.Capper@arm.com>
Cc: Christoph Lameter <cl@linux.com>
Cc: stable@kernel.org # 2.6.26+
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
include/linux/page-flags.h