mm: add pmd_t initializer __pmd() to work around a GCC bug.
authorZi Yan <zi.yan@cs.rutgers.edu>
Thu, 3 Aug 2017 13:17:21 +0000 (09:17 -0400)
committerDavid S. Miller <davem@davemloft.net>
Thu, 10 Aug 2017 22:03:57 +0000 (15:03 -0700)
commit9157259d16a8ee8116a98d32f29b797689327e8d
tree9e6be0a3afafd94057c375dc241ccee9179313c4
parent26273939ace935dd7553b31d279eab30b40f7b9a
mm: add pmd_t initializer __pmd() to work around a GCC bug.

THP migration is added but only supports x86_64 at the moment. For all
other architectures, swp_entry_to_pmd() only returns a zero pmd_t.

Due to a GCC zero initializer bug #53119, the standard (pmd_t){0}
initializer is not accepted by all GCC versions. __pmd() is a feasible
workaround. In addition, sparc32's pmd_t is an array instead of a single
value, so we need (pmd_t){ {0}, } instead of (pmd_t){0}. Thus,
a different __pmd() definition is needed in sparc32.

Signed-off-by: Zi Yan <zi.yan@cs.rutgers.edu>
Signed-off-by: David S. Miller <davem@davemloft.net>
arch/sparc/include/asm/page_32.h