Received: by 10.223.185.116 with SMTP id b49csp6919504wrg; Wed, 28 Feb 2018 18:53:57 -0800 (PST) X-Google-Smtp-Source: AG47ELvzv7JfIGIJ74uyrZvunvs6flyOkThXeOM86LmJOhUq3K7hJz3Y3BjySRhQ6nZQjFtckq8y X-Received: by 10.98.68.154 with SMTP id m26mr313266pfi.171.1519872837221; Wed, 28 Feb 2018 18:53:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519872837; cv=none; d=google.com; s=arc-20160816; b=zY6EB+yobstoa4rt0i8o24bZ9vlXx2exzHDuIsDNfbsCBvViHliUB2v/C3x7LYaW7R ubbLFgEzz8SiJ+h1AIImJuvUUIy+uZpOfdSlIBQjjoi15EaZ2IH8jt/ZoctGV7K32i0g TwUEn6ovQKx9ZbzcFGLWq8OnYqWRmJovI2XVSRQ7VAQ2+6AVcz6WJ6GuLJIsO0V+Q3SR SklEansvcW5fky2UkjHkMUy4exqp8HxAzsWvRCzQwYo09d11Pxq06+m/XZ1UalJfbL0K qCP/9MAJQhl1JH1ePjYxG+k0oh72pwOBQ7JHB3eMDD55xIlIIAjOzdXGtROB8qeN1YlY RaJA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:date:cc:to:from:subject:message-id :arc-authentication-results; bh=cnHraT3Mtrmxr2wQ1E2VFmRGAT189tzcdAEI0E1eFK0=; b=KqHvthCYm5/iF9DWKuHVNV0x3iLQKzqlel9FrJCKoE0yjgtG4iPU8y3D17DTYjIwHf oFE0syU97sDPoOqs1YJSz0s/EgA/gMA1hDoa7KKe//fyviGivtIyNxdj+StDBHcUSpuW GFkVlBzJ0t7FbHShp8oX4CE5qo9MVKsDnr2mShtdkGE0ERxAtj9EJK11gfc3kpawNhtC BXbZm3D9pMHWw6vyZBk3gVWXBNLnv0+3zDAHMaQT8LjMqmJSe7+VJ6NX5/VX6NlRRUJd 6jp0KIz6oOsTWmfMBxozlV1pMpnGSTj4BvXlpB00b3kZiYZ2ObQQr8NA4BLpRL66o0qr FCVw== 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 q5-v6si2255547pll.88.2018.02.28.18.53.42; Wed, 28 Feb 2018 18:53:57 -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 S965612AbeCACwz (ORCPT + 99 others); Wed, 28 Feb 2018 21:52:55 -0500 Received: from mga14.intel.com ([192.55.52.115]:53180 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965522AbeCACwx (ORCPT ); Wed, 28 Feb 2018 21:52:53 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Feb 2018 18:52:53 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,407,1515484800"; d="scan'208";a="24136183" Received: from dph9ls1.fm.intel.com ([10.80.209.182]) by fmsmga002.fm.intel.com with ESMTP; 28 Feb 2018 18:52:53 -0800 Message-ID: <1519872334.58658.188.camel@intel.com> Subject: [PATCH v2 2/3] x86: devicetree: enable multiprocessing in DT From: Ivan Gorinov To: Thomas Gleixner Cc: Linux Kernel Mailing List , Ingo Molnar Date: Wed, 28 Feb 2018 18:45:34 -0800 Organization: Intel Corporation Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.18.5.2-0ubuntu3.2 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Adding code to register 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(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