Received: by 10.223.185.116 with SMTP id b49csp8003879wrg; Thu, 1 Mar 2018 15:15:40 -0800 (PST) X-Google-Smtp-Source: AG47ELseDDuPkHQfUWeR5rqcvaVYsUeRVj99u7y/Wl6D6vtDm4p+QJTq0ODm6E7rHeXg3n9EW9lx X-Received: by 10.99.115.5 with SMTP id o5mr2913897pgc.226.1519946140244; Thu, 01 Mar 2018 15:15:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519946140; cv=none; d=google.com; s=arc-20160816; b=FGH8m1DMpjxAv8Rs1u1k6APvrfFKok2nn2kK6lBq53djmduoD90HtztLArlhP53+Qf iVnfk4l+DQ9HzJGKUCUkxFGos+zg0GXf93OhcCxTDPVmwNhHkc+QfB4dwbP6DV3jSogu zpjevsvlTE8VfzhADfX6Q4NPxSTIFj3F8ebVSGCyYUoEg4H2uRIOErMsw8hghUWL4kZr r2WeqzLPeGOEtzcaMML+onrv8XmLpGFZXZisbAI+PPp22B2DG25J1FJTzqg24BMKuqe2 QiD5+0smUK/d8NX9hSv2EICNUAOjdYBJ2Fw6YSKYwrfEExNhEVjVzdyIeLgM9sVDPuZB M4Rg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-disposition :mime-version:message-id:subject:cc:to:from:date :arc-authentication-results; bh=byHyEFb+YvTzYKJRQRRUl9w7+YjQ+uJ1uaTqCLhoi08=; b=lMPnTlbgveGsK8fJCezi4ogHFEpiMS9SYZuDRJOuKXdOBeMBgAcSvD4dJAlAPbuPr8 VIH+6BgLSP7I8cVFal9ail0vK+hFkAEu/MYJJdheAYQgHkNno29RTy7aYY0gXMFY5vHb BfnDZnVQDGJjKUBNp6J/duFwrrUR8AG+WZtysuBu1j4W3Btsqavf0pQOo0/AmjWhH3es KS1n1rBcsESYAinxneG05ynPYDwyWF1Af48v6Jk5351mtgIQ8PixmJcoX1vDl4r7tbPU VXkB4aTi33Fy2fgUheYR7C84sYx/I2gSpbQQ/MEzJxb7nwOrLmfXB3TWZ2/6rtCSjq5L 5OWQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h10-v6si3807226plk.706.2018.03.01.15.15.26; Thu, 01 Mar 2018 15:15:40 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1163041AbeCAXOJ (ORCPT + 99 others); Thu, 1 Mar 2018 18:14:09 -0500 Received: from mga04.intel.com ([192.55.52.120]:30415 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1162811AbeCAXOG (ORCPT ); Thu, 1 Mar 2018 18:14:06 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga002.jf.intel.com ([10.7.209.21]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 Mar 2018 15:14:01 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,409,1515484800"; d="scan'208";a="38605567" Received: from dph9ls1.fm.intel.com (HELO intel.com) ([10.80.209.182]) by orsmga002.jf.intel.com with ESMTP; 01 Mar 2018 15:14:01 -0800 Date: Thu, 1 Mar 2018 15:06:40 -0800 From: Ivan Gorinov To: Thomas Gleixner Cc: Linux Kernel Mailing List , Ingo Molnar Subject: [PATCH v3 2/3] x86: devicetree: enable multiprocessing in DT Message-ID: <20180301230640.GA48521@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Adding code to register the processors described in Device Tree. APIC ID is specified in 'intel-apic_id' propery as used in U-Boot. First address specified in 'reg' is used as default APIC ID. Signed-off-by: Ivan Gorinov --- arch/x86/kernel/devicetree.c | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/arch/x86/kernel/devicetree.c b/arch/x86/kernel/devicetree.c index 44189ee..ef1cd85 100644 --- a/arch/x86/kernel/devicetree.c +++ b/arch/x86/kernel/devicetree.c @@ -130,6 +130,29 @@ static void __init dtb_setup_hpet(void) #endif } +static void __init dtb_cpu_setup(void) +{ + struct device_node *dn; + struct resource r; + const void *prop; + int apic_id, version; + int ret; + + version = GET_APIC_VERSION(apic_read(APIC_LVR)); + for_each_node_by_type(dn, "cpu") { + prop = of_get_property(dn, "intel,apic-id", NULL); + if (prop) { + apic_id = be32_to_cpup(prop); + } else { + ret = of_address_to_resource(dn, 0, &r); + if (WARN_ON_ONCE(ret)) + continue; + apic_id = r.start; + } + generic_processor_info(apic_id, version); + } +} + static void __init dtb_lapic_setup(void) { #ifdef CONFIG_X86_LOCAL_APIC @@ -153,8 +176,6 @@ static void __init dtb_lapic_setup(void) smp_found_config = 1; pic_mode = 1; register_lapic_address(r.start); - generic_processor_info(boot_cpu_physical_apicid, - GET_APIC_VERSION(apic_read(APIC_LVR))); #endif } @@ -256,6 +277,7 @@ static void __init dtb_ioapic_setup(void) {} static void __init dtb_apic_setup(void) { dtb_lapic_setup(); + dtb_cpu_setup(); dtb_ioapic_setup(); } -- 2.7.4