From patchwork Wed Jan 19 23:01:11 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mike Travis X-Patchwork-Id: 490731 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by demeter1.kernel.org (8.14.4/8.14.3) with ESMTP id p0JN2YTG031085 for ; Wed, 19 Jan 2011 23:02:34 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755110Ab1ASXBO (ORCPT ); Wed, 19 Jan 2011 18:01:14 -0500 Received: from relay3.sgi.com ([192.48.152.1]:40743 "EHLO relay.sgi.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755090Ab1ASXBM (ORCPT ); Wed, 19 Jan 2011 18:01:12 -0500 Received: from gulag1.americas.sgi.com (gulag1.americas.sgi.com [128.162.236.41]) by relay3.corp.sgi.com (Postfix) with ESMTP id AB654AC007; Wed, 19 Jan 2011 15:01:09 -0800 (PST) Received: by gulag1.americas.sgi.com (Postfix, from userid 5508) id 4208E103768B0; Wed, 19 Jan 2011 17:01:07 -0600 (CST) Message-Id: <20110119230107.134657025@gulag1.americas.sgi.com> References: <20110119230106.341785959@gulag1.americas.sgi.com> User-Agent: quilt/0.46-1 Date: Wed, 19 Jan 2011 17:01:11 -0600 From: Mike Travis To: Ingo Molnar , Len Brown , "H. Peter Anvin" Cc: Thomas Gleixner , Jack Steiner , Robin Holt , Lori Gilbertson , x86@kernel.org, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org Subject: [PATCH 5/6] x86: Minimize SRAT messages Content-Disposition: inline; filename=minimize-srat-msgs Sender: linux-acpi-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-acpi@vger.kernel.org X-Greylist: IP, sender and recipient auto-whitelisted, not delayed by milter-greylist-4.2.6 (demeter1.kernel.org [140.211.167.41]); Wed, 19 Jan 2011 23:02:35 +0000 (UTC) --- linux-2.6.32.orig/arch/x86/mm/srat_64.c +++ linux-2.6.32/arch/x86/mm/srat_64.c @@ -115,6 +115,7 @@ acpi_numa_x2apic_affinity_init(struct ac { int pxm, node; int apic_id; + static int last_node = -1, last_pxm = -1; if (srat_disabled()) return; @@ -136,8 +137,16 @@ acpi_numa_x2apic_affinity_init(struct ac apicid_to_node[apic_id] = node; node_set(node, cpu_nodes_parsed); acpi_numa = 1; - printk(KERN_INFO "SRAT: PXM %u -> APIC %u -> Node %u\n", - pxm, apic_id, node); + if (node != last_node) { + pr_info("SRAT: Node %u: PXM:APIC %u:%u", + node, pxm, apic_id); + last_node = node; + last_pxm = pxm; + } else if (pxm != last_pxm) { + pr_cont(" %u:%u", pxm, apic_id); + last_pxm = pxm; + } else + pr_cont(" :%u", apic_id); } /* Callback for Proximity Domain -> LAPIC mapping */ @@ -294,8 +303,7 @@ acpi_numa_memory_affinity_init(struct ac nd->end = end; } - printk(KERN_INFO "SRAT: Node %u PXM %u %lx-%lx\n", node, pxm, - start, end); + pr_info("SRAT: Node %u PXM %u %lx+%lx\n", node, pxm, start, end-start); e820_register_active_regions(node, start >> PAGE_SHIFT, end >> PAGE_SHIFT); --- linux-2.6.32.orig/drivers/acpi/numa.c +++ linux-2.6.32/drivers/acpi/numa.c @@ -290,6 +290,9 @@ int __init acpi_numa_init(void) if (!acpi_table_parse(ACPI_SIG_SRAT, acpi_parse_srat)) { acpi_table_parse_srat(ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY, acpi_parse_x2apic_affinity, NR_CPUS); + /* insure trailing newline is output */ + pr_cont("\n"); + acpi_table_parse_srat(ACPI_SRAT_TYPE_CPU_AFFINITY, acpi_parse_processor_affinity, NR_CPUS); acpi_table_parse_srat(ACPI_SRAT_TYPE_MEMORY_AFFINITY,