Jianguo Wu
ae64ffcac3
mm/vmemmap: fix wrong use of virt_to_page
I enable CONFIG_DEBUG_VIRTUAL and CONFIG_SPARSEMEM_VMEMMAP, when doing
memory hotremove, there is a kernel BUG at arch/x86/mm/physaddr.c:20.
It is caused by free_section_usemap()->virt_to_page(), virt_to_page() is
only used for kernel direct mapping address, but sparse-vmemmap uses
vmemmap address, so it is going wrong here.
------------[ cut here ]------------
kernel BUG at arch/x86/mm/physaddr.c:20!
invalid opcode: 0000 [#1] SMP
Modules linked in: acpihp_drv acpihp_slot edd cpufreq_conservative cpufreq_userspace cpufreq_powersave acpi_cpufreq mperf fuse vfat fat loop dm_mod coretemp kvm crc32c_intel ipv6 ixgbe igb iTCO_wdt i7core_edac edac_core pcspkr iTCO_vendor_support ioatdma microcode joydev sr_mod i2c_i801 dca lpc_ich mfd_core mdio tpm_tis i2c_core hid_generic tpm cdrom sg tpm_bios rtc_cmos button ext3 jbd mbcache usbhid hid uhci_hcd ehci_hcd usbcore usb_common sd_mod crc_t10dif processor thermal_sys hwmon scsi_dh_alua scsi_dh_hp_sw scsi_dh_rdac scsi_dh_emc scsi_dh ata_generic ata_piix libata megaraid_sas scsi_mod
CPU 39
Pid: 6454, comm: sh Not tainted 3.7.0-rc1-acpihp-final+ #45 QCI QSSC-S4R/QSSC-S4R
RIP: 0010:[<ffffffff8103c908>] [<ffffffff8103c908>] __phys_addr+0x88/0x90
RSP: 0018:ffff8804440d7c08 EFLAGS: 00010006
RAX: 0000000000000006 RBX: ffffea0012000000 RCX: 000000000000002c
...
Signed-off-by: Jianguo Wu <wujianguo@huawei.com>
Signed-off-by: Jiang Liu <jiang.liu@huawei.com>
Reviewd-by: Wen Congyang <wency@cn.fujitsu.com>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Reviewed-by: Yasuaki Ishimatsu <isimatu.yasuaki@jp.fujitsu.com>
Reviewed-by: Michal Hocko <mhocko@suse.cz>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2012-11-30 08:51:17 -08:00
..
2012-08-25 16:58:14 +08:00
2012-11-16 14:33:04 -08:00
2012-07-18 16:40:35 -04:00
2012-05-29 23:28:33 -04:00
2012-10-19 14:07:47 -07:00
2011-12-06 09:24:07 +01:00
2011-10-31 09:20:12 -04:00
2012-09-26 22:20:08 -04:00
2012-01-03 22:54:56 -05:00
2012-10-09 16:22:58 +09:00
2012-10-09 16:22:47 +09:00
2012-10-19 13:37:57 -07:00
2012-09-21 10:38:12 -04:00
2012-11-16 14:33:04 -08:00
2012-10-15 07:59:15 -07:00
2012-07-31 18:42:41 -07:00
2012-10-09 16:23:03 +09:00
2012-07-31 18:42:43 -07:00
2011-07-26 16:49:47 -07:00
2012-10-09 16:23:03 +09:00
2012-10-09 16:22:42 +09:00
2012-10-09 16:22:53 +09:00
2012-01-10 16:30:42 -08:00
2010-03-30 22:02:32 +09:00
2011-01-27 18:31:51 +00:00
2012-10-09 16:22:39 +09:00
2012-10-09 16:22:58 +09:00
2011-10-31 09:20:12 -04:00
2012-10-09 16:22:18 +09:00
2012-10-09 16:22:39 +09:00
2012-10-24 11:52:21 -07:00
2012-11-16 14:33:04 -08:00
2012-11-16 14:33:04 -08:00
2012-10-09 16:22:41 +09:00
2012-11-16 14:33:03 -08:00
2012-10-16 18:00:50 -07:00
2012-06-25 11:53:47 +02:00
2012-07-31 18:42:48 -07:00
2012-03-21 17:54:54 -07:00
2012-10-09 16:23:03 +09:00
2011-10-31 09:20:12 -04:00
2012-11-16 14:33:03 -08:00
2012-03-21 17:54:59 -07:00
2012-10-25 14:37:53 -07:00
2012-11-16 14:33:04 -08:00
2012-03-22 09:04:48 -07:00
2012-10-09 16:22:58 +09:00
2010-05-21 18:31:21 -04:00
2012-11-16 14:33:04 -08:00
2012-10-09 16:22:39 +09:00
2012-10-09 16:22:24 +09:00
2012-11-30 08:51:17 -08:00
2012-07-31 18:42:43 -07:00
2012-07-31 18:42:47 -07:00
2012-10-09 16:22:52 +09:00
2012-09-28 20:27:49 +08:00
2012-06-20 14:39:36 -07:00
2010-10-02 10:28:42 +03:00
2012-06-20 14:39:36 -07:00
2012-10-06 03:04:44 +09:00
2012-10-09 16:22:29 +09:00
2012-05-31 17:49:32 -07:00
2011-10-31 09:20:11 -04:00
2012-09-26 22:20:08 -04:00
2012-10-25 14:37:52 -07:00
2012-11-16 14:33:04 -08:00
2012-10-10 09:25:08 +03:00
2012-10-07 07:53:13 +09:00
2012-09-05 12:07:44 +03:00
2012-10-19 15:40:18 -07:00
2012-10-03 09:56:37 +03:00
2011-10-31 09:20:11 -04:00
2012-11-30 08:51:17 -08:00
2012-07-31 18:42:47 -07:00
2012-10-09 16:22:55 +09:00
2012-11-16 14:33:04 -08:00
2012-10-09 16:22:56 +09:00
2012-09-04 10:22:58 +03:00
2012-10-09 16:23:03 +09:00
2012-11-26 17:41:24 -08:00
2012-10-09 16:22:59 +09:00