• Wu Fengguang's avatar
    resource: Fix generic page_is_ram() for partial RAM pages · 37b99dd5
    Wu Fengguang authored
    The System RAM walk shall skip partial RAM pages and avoid calling
    func() on them. So that page_is_ram() return 0 for a partial RAM page.
    
    In particular, it shall not call func() with len=0.
    This fixes a boot time bug reported by Sachin and root caused by Thomas:
    
    > >>> WARNING: at arch/x86/mm/ioremap.c:111 __ioremap_caller+0x169/0x2f1()
    > >>> Hardware name: BladeCenter LS21 -[79716AA]-
    > >>> Modules linked in:
    > >>> Pid: 0, comm: swapper Not tainted 2.6.33-git6-autotest #1
    > >>> Call Trace:
    > >>> [<ffffffff81047cff>] ? __ioremap_caller+0x169/0x2f1
    > >>> [<ffffffff81063b7d>] warn_slowpath_common+0x77/0xa4
    > >>> [<ffffffff81063bb9>] warn_slowpath_null+0xf/0x11
    > >>> [<ffffffff81047cff>] __ioremap_caller+0x169/0x2f1
    > >>> [<ffffffff813747a3>] ? acpi_os_map_memory+0x12/0x1b
    > >>> [<ffffffff81047f10>] ioremap_nocache+0x12/0x14
    > >>> [<ffffffff813747a3>] acpi_os_map_memory+0x12/0x1b
    > >>> [<ffffffff81282fa0>] acpi_tb_verify_table+0x29/0x5b
    > >>> [<ffffffff812827f0>] acpi_load_tables+0x39/0x15a
    > >>> [<ffffffff8191c8f8>] acpi_early_init+0x60/0xf5
    > >>> [<ffffffff818f2cad>] start_kernel+0x397/0x3a7
    > >>> [<ffffffff818f2295>] x86_64_start_reservations+0xa5/0xa9
    > >>> [<ffffffff818f237a>] x86_64_start_kernel+0xe1/0xe8
    > >>> ---[ end trace 4eaa2a86a8e2da22 ]---
    > >>> ioremap reserve_memtype failed -22
    
    The return code is -EINVAL, so it failed in the is_ram check, which is
    not too surprising
    
    > BIOS-provided physical RAM map:
    >  BIOS-e820: 0000000000000000 - 000000000009c000 (usable)
    >  BIOS-e820: 000000000009c000 - 00000000000a0000 (reserved)
    >  BIOS-e820: 00000000000e0000 - 0000000000100000 (reserved)
    >  BIOS-e820: 0000000000100000 - 00000000cffa3900 (usable)
    >  BIOS-e820: 00000000cffa3900 - 00000000cffa7400 (ACPI data)
    
    The ACPI data is not starting on a page boundary and neither does the
    usable RAM area end on a page boundary. Very useful !
    
    > ACPI: DSDT 00000000cffa3900 036CE (v01 IBM    SERLEWIS 00001000 INTL 20060912)
    
    ACPI is trying to map DSDT at cffa3900, which results in a check
    vs. cffa3000 which is the relevant page boundary. The generic is_ram
    check correctly identifies that as RAM because it's in the usable
    resource area. The old e820 based is_ram check does not take
    overlapping resource areas into account. That's why it works.
    
    CC: Sachin Sant <sachinp@in.ibm.com>
    CC: Thomas Gleixner <tglx@linutronix.de>
    CC: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
    Signed-off-by: default avatarWu Fengguang <fengguang.wu@intel.com>
    LKML-Reference: <20100301135551.GA9998@localhost>
    Signed-off-by: default avatarH. Peter Anvin <hpa@zytor.com>
    37b99dd5
resource.c 21.5 KB