Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964979Ab3HHJnx (ORCPT ); Thu, 8 Aug 2013 05:43:53 -0400 Received: from cn.fujitsu.com ([222.73.24.84]:16337 "EHLO song.cn.fujitsu.com" rhost-flags-OK-FAIL-OK-OK) by vger.kernel.org with ESMTP id S934203Ab3HHJm6 (ORCPT ); Thu, 8 Aug 2013 05:42:58 -0400 X-IronPort-AV: E=Sophos;i="4.89,838,1367942400"; d="scan'208";a="8153672" From: Tang Chen To: robert.moore@intel.com, lv.zheng@intel.com, rjw@sisk.pl, lenb@kernel.org, tglx@linutronix.de, mingo@elte.hu, hpa@zytor.com, akpm@linux-foundation.org, tj@kernel.org, trenn@suse.de, yinghai@kernel.org, jiang.liu@huawei.com, wency@cn.fujitsu.com, laijs@cn.fujitsu.com, isimatu.yasuaki@jp.fujitsu.com, izumi.taku@jp.fujitsu.com, mgorman@suse.de, minchan@kernel.org, mina86@mina86.com, gong.chen@linux.intel.com, vasilis.liaskovitis@profitbricks.com, lwoodman@redhat.com, riel@redhat.com, jweiner@redhat.com, prarit@redhat.com, zhangyanfei@cn.fujitsu.com, yanghy@cn.fujitsu.com Cc: x86@kernel.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-acpi@vger.kernel.org Subject: [PATCH part4 3/4] x86, acpica, acpi: Try to find SRAT in firmware earlier. Date: Thu, 8 Aug 2013 17:41:22 +0800 Message-Id: <1375954883-30225-4-git-send-email-tangchen@cn.fujitsu.com> X-Mailer: git-send-email 1.7.11.7 In-Reply-To: <1375954883-30225-1-git-send-email-tangchen@cn.fujitsu.com> References: <1375954883-30225-1-git-send-email-tangchen@cn.fujitsu.com> X-MIMETrack: Itemize by SMTP Server on mailserver/fnst(Release 8.5.3|September 15, 2011) at 2013/08/08 17:41:22, Serialize by Router on mailserver/fnst(Release 8.5.3|September 15, 2011) at 2013/08/08 17:41:27, Serialize complete at 2013/08/08 17:41:27 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5047 Lines: 158 This patch introduce early_acpi_firmware_srat() to find the phys addr of SRAT provided by firmware. And call it in find_hotpluggable_memory(). Since we have initialized acpi_gbl_root_table_list earlier, and store all the tables' phys addrs and signatures in it, it is easy to find the SRAT. Signed-off-by: Tang Chen Reviewed-by: Zhang Yanfei --- drivers/acpi/acpica/tbxface.c | 32 ++++++++++++++++++++++++++++++++ drivers/acpi/osl.c | 22 ++++++++++++++++++++++ include/acpi/acpixf.h | 4 ++++ include/linux/acpi.h | 4 ++++ mm/memory_hotplug.c | 8 ++++++-- 5 files changed, 68 insertions(+), 2 deletions(-) diff --git a/drivers/acpi/acpica/tbxface.c b/drivers/acpi/acpica/tbxface.c index ecaa5e1..a025dcc 100644 --- a/drivers/acpi/acpica/tbxface.c +++ b/drivers/acpi/acpica/tbxface.c @@ -236,6 +236,38 @@ acpi_status acpi_reallocate_root_table(void) return_ACPI_STATUS(status); } +/** + * acpi_get_table_desc - Get the acpi table descriptor of a specific table. + * @signature: The signature of the table to be found. + * @out_desc: The out returned descriptor. + * + * Iterate over acpi_gbl_root_table_list to find a specific table and then + * return its phys addr. + * + * NOTE: The caller has the responsibility to allocate memory for @out_desc. + * + * Return AE_OK on success, AE_NOT_FOUND if the table is not found. + */ +acpi_status acpi_get_table_desc(char *signature, + struct acpi_table_desc *out_desc) +{ + struct acpi_table_desc *desc; + int pos, count = acpi_gbl_root_table_list.current_table_count; + + for (pos = 0; pos < count; pos++) { + desc = &acpi_gbl_root_table_list.tables[pos]; + + if (!ACPI_COMPARE_NAME(&desc->signature, signature)) + continue; + + memcpy(out_desc, desc, sizeof(struct acpi_table_desc)); + + return_ACPI_STATUS(AE_OK); + } + + return_ACPI_STATUS(AE_NOT_FOUND); +} + /******************************************************************************* * * FUNCTION: acpi_get_table_header diff --git a/drivers/acpi/osl.c b/drivers/acpi/osl.c index dcbca3e..ec490fe 100644 --- a/drivers/acpi/osl.c +++ b/drivers/acpi/osl.c @@ -53,6 +53,7 @@ #include #include #include +#include #define _COMPONENT ACPI_OS_SERVICES ACPI_MODULE_NAME("osl"); @@ -760,6 +761,27 @@ void __init acpi_initrd_override(void *data, size_t size) } #endif /* CONFIG_ACPI_INITRD_TABLE_OVERRIDE */ +#ifdef CONFIG_ACPI_NUMA +/******************************************************************************* + * + * FUNCTION: early_acpi_firmware_srat + * + * RETURN: Phys addr of SRAT on success, 0 on error. + * + * DESCRIPTION: Get the phys addr of SRAT provided by firmware. + * + ******************************************************************************/ +phys_addr_t __init early_acpi_firmware_srat(void) +{ + struct acpi_table_desc table_desc; + + if (acpi_get_table_desc(ACPI_SIG_SRAT, &table_desc)) + return 0; + + return table_desc.address; +} +#endif /* CONFIG_ACPI_NUMA */ + static void acpi_table_taint(struct acpi_table_header *table) { pr_warn(PREFIX diff --git a/include/acpi/acpixf.h b/include/acpi/acpixf.h index 99c9d7b..daa7c10 100644 --- a/include/acpi/acpixf.h +++ b/include/acpi/acpixf.h @@ -188,6 +188,10 @@ acpi_status acpi_find_root_pointer(acpi_size *rsdp_address); acpi_status acpi_unload_table_id(acpi_owner_id id); acpi_status +acpi_get_table_desc(char *signature, + struct acpi_table_desc *out_desc); + +acpi_status acpi_get_table_header(acpi_string signature, u32 instance, struct acpi_table_header *out_table_header); diff --git a/include/linux/acpi.h b/include/linux/acpi.h index bdcb9dd..280078c 100644 --- a/include/linux/acpi.h +++ b/include/linux/acpi.h @@ -97,6 +97,10 @@ static inline phys_addr_t early_acpi_override_srat(void) } #endif /* CONFIG_ACPI_INITRD_TABLE_OVERRIDE */ +#ifdef CONFIG_ACPI_NUMA +phys_addr_t early_acpi_firmware_srat(void); +#endif /* CONFIG_ACPI_NUMA */ + char * __acpi_map_table (unsigned long phys_addr, unsigned long size); void __acpi_unmap_table(char *map, unsigned long size); int early_acpi_boot_init(void); diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c index 2a57888..2dfb06f 100644 --- a/mm/memory_hotplug.c +++ b/mm/memory_hotplug.c @@ -107,8 +107,12 @@ void __init find_hotpluggable_memory(void) /* Try to find if SRAT is overridden */ srat_paddr = early_acpi_override_srat(); - if (!srat_paddr) - return; + if (!srat_paddr) { + /* Try to find SRAT from firmware if it wasn't overridden */ + srat_paddr = early_acpi_firmware_srat(); + if (!srat_paddr) + return; + } /* Will parse SRAT and find out hotpluggable memory here */ } -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/